mirror of
https://github.com/spl0k/supysonic.git
synced 2024-12-23 01:16:18 +00:00
Implemented getCoverArt.view
This commit is contained in:
parent
584f1cf90c
commit
6198660765
@ -17,7 +17,7 @@ def set_formatter():
|
|||||||
(f, callback) = map(request.args.get, ['f', 'callback'])
|
(f, callback) = map(request.args.get, ['f', 'callback'])
|
||||||
if f == 'jsonp':
|
if f == 'jsonp':
|
||||||
# Some clients (MiniSub, Perisonic) set f to jsonp without callback for streamed data
|
# Some clients (MiniSub, Perisonic) set f to jsonp without callback for streamed data
|
||||||
if not callback and request.endpoint not in [ 'stream_media' ]:
|
if not callback and request.endpoint not in [ 'stream_media', 'cover_art' ]:
|
||||||
return ResponseHelper.responsize_json({
|
return ResponseHelper.responsize_json({
|
||||||
'error': {
|
'error': {
|
||||||
'code': 0,
|
'code': 0,
|
||||||
|
@ -36,7 +36,7 @@ def list_indexes():
|
|||||||
|
|
||||||
folder = Folder.query.get(mfid)
|
folder = Folder.query.get(mfid)
|
||||||
|
|
||||||
if not folder and not folder.root:
|
if not folder or (type(folder) is not list and not folder.root):
|
||||||
return request.error_formatter(70, 'Folder not found')
|
return request.error_formatter(70, 'Folder not found')
|
||||||
|
|
||||||
last_modif = max(map(lambda f: f.last_scan, folder)) if type(folder) is list else folder.last_scan
|
last_modif = max(map(lambda f: f.last_scan, folder)) if type(folder) is list else folder.last_scan
|
||||||
|
41
api/media.py
41
api/media.py
@ -1,8 +1,10 @@
|
|||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
|
|
||||||
from flask import request, send_file
|
from flask import request, send_file
|
||||||
|
import Image
|
||||||
from web import app
|
from web import app
|
||||||
from db import Track
|
from db import Track, Folder
|
||||||
|
import config
|
||||||
import os.path, uuid
|
import os.path, uuid
|
||||||
|
|
||||||
@app.route('/rest/stream.view')
|
@app.route('/rest/stream.view')
|
||||||
@ -39,3 +41,40 @@ def stream_media():
|
|||||||
|
|
||||||
return send_file(track.path)
|
return send_file(track.path)
|
||||||
|
|
||||||
|
@app.route('/rest/getCoverArt.view')
|
||||||
|
def cover_art():
|
||||||
|
id = request.args.get('id')
|
||||||
|
if not id:
|
||||||
|
return request.error_formatter(10, 'Missing cover art id')
|
||||||
|
try:
|
||||||
|
fid = uuid.UUID(id)
|
||||||
|
except:
|
||||||
|
return request.error_formatter(0, 'Invalid cover art id')
|
||||||
|
folder = Folder.query.get(fid)
|
||||||
|
if not folder or not folder.has_cover_art or not os.path.isfile(os.path.join(folder.path, 'cover.jpg')):
|
||||||
|
return request.error_formatter(70, 'Cover art not found')
|
||||||
|
|
||||||
|
size = request.args.get('size')
|
||||||
|
if size:
|
||||||
|
try:
|
||||||
|
size = int(size)
|
||||||
|
except:
|
||||||
|
return request.error_formatter(0, 'Invalid size value')
|
||||||
|
else:
|
||||||
|
return send_file(os.path.join(folder.path, 'cover.jpg'))
|
||||||
|
|
||||||
|
im = Image.open(os.path.join(folder.path, 'cover.jpg'))
|
||||||
|
if size > im.size[0] and size > im.size[1]:
|
||||||
|
return send_file(os.path.join(folder.path, 'cover.jpg'))
|
||||||
|
|
||||||
|
size_path = os.path.join(config.get('CACHE_DIR'), str(size))
|
||||||
|
path = os.path.join(size_path, id)
|
||||||
|
if os.path.exists(path):
|
||||||
|
return send_file(path)
|
||||||
|
if not os.path.exists(size_path):
|
||||||
|
os.makedirs(size_path)
|
||||||
|
|
||||||
|
im.thumbnail([size, size], Image.ANTIALIAS)
|
||||||
|
im.save(path, 'JPEG')
|
||||||
|
return send_file(path)
|
||||||
|
|
||||||
|
@ -2,12 +2,6 @@
|
|||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
def try_load_config(path):
|
|
||||||
if os.path.exists(path):
|
|
||||||
app.config.from_pyfile(path)
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
def check():
|
def check():
|
||||||
path = os.path.join(os.path.expanduser('~'), '.supysonic')
|
path = os.path.join(os.path.expanduser('~'), '.supysonic')
|
||||||
if os.path.exists(path):
|
if os.path.exists(path):
|
||||||
|
6
db.py
6
db.py
@ -62,6 +62,7 @@ class Folder(Base):
|
|||||||
root = Column(Boolean, default = False)
|
root = Column(Boolean, default = False)
|
||||||
name = Column(String)
|
name = Column(String)
|
||||||
path = Column(String, unique = True)
|
path = Column(String, unique = True)
|
||||||
|
has_cover_art = Column(Boolean, default = False)
|
||||||
last_scan = Column(DateTime, default = datetime.datetime.min)
|
last_scan = Column(DateTime, default = datetime.datetime.min)
|
||||||
|
|
||||||
parent_id = Column(UUID, ForeignKey('folder.id'), nullable = True)
|
parent_id = Column(UUID, ForeignKey('folder.id'), nullable = True)
|
||||||
@ -76,6 +77,8 @@ class Folder(Base):
|
|||||||
if not self.root:
|
if not self.root:
|
||||||
info['parent'] = str(self.parent_id)
|
info['parent'] = str(self.parent_id)
|
||||||
info['artist'] = self.parent.name
|
info['artist'] = self.parent.name
|
||||||
|
if self.has_cover_art:
|
||||||
|
info['coverArt'] = str(self.id)
|
||||||
|
|
||||||
return info
|
return info
|
||||||
|
|
||||||
@ -139,8 +142,9 @@ class Track(Base):
|
|||||||
info['year'] = self.year
|
info['year'] = self.year
|
||||||
if self.genre:
|
if self.genre:
|
||||||
info['genre'] = self.genre
|
info['genre'] = self.genre
|
||||||
|
if self.folder.has_cover_art:
|
||||||
|
info['coverArt'] = str(self.folder_id)
|
||||||
|
|
||||||
# coverArt
|
|
||||||
# transcodedContentType
|
# transcodedContentType
|
||||||
# transcodedSuffix
|
# transcodedSuffix
|
||||||
# userRating
|
# userRating
|
||||||
|
4
main.py
4
main.py
@ -2,12 +2,16 @@
|
|||||||
|
|
||||||
from web import app
|
from web import app
|
||||||
import db, config
|
import db, config
|
||||||
|
import os.path
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
if not config.check():
|
if not config.check():
|
||||||
print >>sys.stderr, "Couldn't find configuration file"
|
print >>sys.stderr, "Couldn't find configuration file"
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
if not os.path.exists(config.get('CACHE_DIR')):
|
||||||
|
os.makedirs(config.get('CACHE_DIR'))
|
||||||
|
|
||||||
db.init_db()
|
db.init_db()
|
||||||
app.run(debug = True)
|
app.run(debug = True)
|
||||||
|
|
||||||
|
@ -45,6 +45,11 @@ class Scanner:
|
|||||||
|
|
||||||
self.__cleanup_folder(folder)
|
self.__cleanup_folder(folder)
|
||||||
|
|
||||||
|
def check_cover_art(self, folder):
|
||||||
|
folder.has_cover_art = os.path.isfile(os.path.join(folder.path, 'cover.jpg'))
|
||||||
|
for f in folder.children:
|
||||||
|
self.check_cover_art(f)
|
||||||
|
|
||||||
def __scan_file(self, path, folder):
|
def __scan_file(self, path, folder):
|
||||||
tag = eyeD3.Tag()
|
tag = eyeD3.Tag()
|
||||||
tag.link(path)
|
tag.link(path)
|
||||||
|
2
web.py
2
web.py
@ -162,6 +162,7 @@ def scan_folder(id = None):
|
|||||||
for folder in db.Folder.query.filter(db.Folder.root == True).all():
|
for folder in db.Folder.query.filter(db.Folder.root == True).all():
|
||||||
s.scan(folder)
|
s.scan(folder)
|
||||||
s.prune(folder)
|
s.prune(folder)
|
||||||
|
s.check_cover_art(folder)
|
||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
idid = uuid.UUID(id)
|
idid = uuid.UUID(id)
|
||||||
@ -176,6 +177,7 @@ def scan_folder(id = None):
|
|||||||
|
|
||||||
s.scan(folder)
|
s.scan(folder)
|
||||||
s.prune(folder)
|
s.prune(folder)
|
||||||
|
s.check_cover_art(folder)
|
||||||
|
|
||||||
added, deleted = s.stats()
|
added, deleted = s.stats()
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
Loading…
Reference in New Issue
Block a user