deemix-gui-pyweb/server.py

158 lines
4.7 KiB
Python
Raw Normal View History

2020-04-07 22:19:27 +00:00
import json
import os
import webbrowser
from functools import wraps
from flask import Flask, render_template, request, session
from flask_socketio import SocketIO, emit
import logging
from deemix.api.deezer import Deezer
import app
2020-04-11 19:55:12 +00:00
import time
import sys
2020-04-07 22:19:27 +00:00
2020-04-08 16:43:35 +00:00
class CustomFlask(Flask):
jinja_options = Flask.jinja_options.copy()
jinja_options.update(dict(
block_start_string='$$',
block_end_string='$$',
variable_start_string='$',
variable_end_string='$',
comment_start_string='$#',
comment_end_string='#$',
))
2020-04-07 22:19:27 +00:00
gui_dir = os.path.join(os.path.dirname(__file__), 'public') # development path
if not os.path.exists(gui_dir): # frozen executable path
gui_dir = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'public')
2020-04-08 16:43:35 +00:00
server = CustomFlask(__name__, static_folder=gui_dir, template_folder=gui_dir)
2020-04-07 22:19:27 +00:00
server.config['SEND_FILE_MAX_AGE_DEFAULT'] = 1 # disable caching
socketio = SocketIO(server)
serverLog = logging.getLogger('werkzeug')
serverLog.disabled = True
server.logger.disabled = True
2020-04-07 22:19:27 +00:00
2020-04-13 17:22:34 +00:00
app.initialize()
2020-04-07 22:19:27 +00:00
@server.route('/')
def landing():
2020-04-15 12:03:10 +00:00
return render_template('index.html')
2020-04-07 22:19:27 +00:00
@server.route('/shutdown')
def closing():
app.shutdown(socket=socketio)
func = request.environ.get('werkzeug.server.shutdown')
func()
return 'server closed'
@socketio.on('connect')
def on_connect():
session['dz'] = Deezer()
2020-04-13 17:22:34 +00:00
emit('init_settings', app.getSettings_link())
2020-04-14 14:48:13 +00:00
queue, queueComplete, queueList, currentItem = app.getQueue_link()
emit('init_downloadQueue', {'queue': queue, 'queueComplete': queueComplete, 'queueList': queueList, 'currentItem': currentItem})
2020-04-11 19:55:12 +00:00
@socketio.on('login')
2020-04-12 22:14:34 +00:00
def login(arl, force=False):
emit('toast', {'msg': "Logging in...", 'icon': 'loading', 'dismiss': False, 'id': "login-toast"})
if not session['dz'].logged_in:
result = session['dz'].login_via_arl(arl)
else:
if force:
session['dz'] = Deezer()
result = session['dz'].login_via_arl(arl)
if result == 1:
result = 3
else:
result = 2
emit('logged_in', {'status': result, 'arl': arl, 'user': app.getUser(session['dz'])})
2020-04-11 19:55:12 +00:00
2020-04-12 22:14:34 +00:00
@socketio.on('logout')
def logout():
status = 0
if session['dz'].logged_in:
session['dz'] = Deezer()
status = 0
else:
status = 1
emit('logged_out', status)
2020-04-11 19:55:12 +00:00
@socketio.on('loginpage')
def login_app():
2020-04-12 22:14:34 +00:00
emit('toast', {'msg': "Logging in...", 'icon': 'loading', 'dismiss': False, 'id': "login-toast"})
2020-04-11 19:55:12 +00:00
loginWindow = webview.create_window('Login into deezer.com', 'https://www.deezer.com/login', user_agent="Mozilla/5.0 (Linux; U; Android 4.0.3; ko-kr; LG-L160L Build/IML74K) AppleWebkit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30")
while (loginWindow and loginWindow.get_current_url().startswith("https://www.deezer.com")):
time.sleep(1)
if loginWindow:
url = loginWindow.get_current_url()
loginWindow.destroy()
arl = url[url.find("arl%3D")+6:]
arl = arl[:arl.find("&")]
2020-04-12 22:14:34 +00:00
# Login function
if not session['dz'].logged_in:
result = session['dz'].login_via_arl(arl)
else:
result = 2
emit('logged_in', {'status': result, 'arl': arl, 'user': app.getUser(session['dz'])})
2020-04-11 19:55:12 +00:00
else:
emit('logged_in', {'status': 0})
2020-04-07 22:19:27 +00:00
@socketio.on('mainSearch')
def mainSearch(data):
emit('mainSearch', app.mainSearch(session['dz'], data['term']))
2020-04-09 14:06:33 +00:00
@socketio.on('search')
def search(data):
result = app.search(session['dz'], data['term'], data['type'], data['start'], data['nb'])
2020-04-09 14:06:33 +00:00
result['type'] = data['type']
emit('search', result)
2020-04-08 21:52:08 +00:00
@socketio.on('addToQueue')
def addToQueue(data):
result = app.addToQueue_link(session['dz'], data['url'], socket=socketio)
if result == "Not logged in":
emit('toast', {'msg': "You need to log in to download tracks!", 'icon': 'report'})
2020-04-08 21:52:08 +00:00
2020-04-11 13:43:59 +00:00
@socketio.on('removeFromQueue')
def removeFromQueue(uuid):
app.removeFromQueue_link(uuid, socket=socketio)
2020-04-14 14:48:13 +00:00
@socketio.on('removeFinishedDownloads')
def removeFinishedDownloads():
app.removeFinishedDownloads_link(socket=socketio)
@socketio.on('cancelAllDownloads')
def cancelAllDownloads():
app.cancelAllDownloads_link(socket=socketio)
2020-04-14 17:58:54 +00:00
@socketio.on('saveSettings')
def saveSettings(settings):
app.saveSettings_link(settings)
socketio.emit('updateSettings', settings)
2020-04-08 21:52:08 +00:00
# Example code leftover, could be usefull later on
2020-04-07 22:19:27 +00:00
@server.route('/choose/path', methods=['POST'])
def choose_path():
dirs = webview.windows[0].create_file_dialog(webview.FOLDER_DIALOG)
if dirs and len(dirs) > 0:
directory = dirs[0]
if isinstance(directory, bytes):
directory = directory.decode('utf-8')
response = {'status': 'ok', 'directory': directory}
else:
response = {'status': 'cancel'}
return jsonify(response)
def run_server(port):
print("Starting server at http://127.0.0.1:"+str(port))
2020-04-13 22:09:19 +00:00
socketio.run(server, host='0.0.0.0', port=port)
2020-04-07 22:19:27 +00:00
if __name__ == '__main__':
if len(sys.argv) >= 2:
port = int(sys.argv[1])
else:
port = 33333
run_server(port)