mirror of
https://github.com/spl0k/supysonic.git
synced 2024-12-22 08:56:17 +00:00
Reworked imports
This commit is contained in:
parent
6ed86f544f
commit
4ce3958cbb
@ -190,3 +190,13 @@ def get_entity(req, ent, param = 'id'):
|
||||
|
||||
return True, entity
|
||||
|
||||
from .system import *
|
||||
from .browse import *
|
||||
from .user import *
|
||||
from .albums_songs import *
|
||||
from .media import *
|
||||
from .annotation import *
|
||||
from .chat import *
|
||||
from .search import *
|
||||
from .playlists import *
|
||||
|
||||
|
@ -22,7 +22,7 @@ import time
|
||||
import uuid
|
||||
from flask import request
|
||||
from web import app
|
||||
from api import get_entity
|
||||
from . import get_entity
|
||||
from lastfm import LastFm
|
||||
from db import *
|
||||
|
||||
|
@ -21,7 +21,7 @@
|
||||
from flask import request
|
||||
from web import app
|
||||
from db import Folder, Artist, Album, Track
|
||||
from api import get_entity
|
||||
from . import get_entity
|
||||
import uuid, time, string
|
||||
|
||||
@app.route('/rest/getMusicFolders.view', methods = [ 'GET', 'POST' ])
|
||||
|
@ -29,7 +29,7 @@ from xml.etree import ElementTree
|
||||
import config, scanner
|
||||
from web import app
|
||||
from db import Track, Album, Artist, Folder, User, ClientPrefs, now, session
|
||||
from api import get_entity
|
||||
from . import get_entity
|
||||
|
||||
from sqlalchemy import func
|
||||
|
||||
|
55
frontend/__init__.py
Normal file
55
frontend/__init__.py
Normal file
@ -0,0 +1,55 @@
|
||||
# coding: utf-8
|
||||
|
||||
# This file is part of Supysonic.
|
||||
#
|
||||
# Supysonic is a Python implementation of the Subsonic server API.
|
||||
# Copyright (C) 2014 Alban 'spl0k' Féron
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Affero General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Affero General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Affero General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
from web import app
|
||||
from managers.user import UserManager
|
||||
|
||||
app.add_template_filter(str)
|
||||
|
||||
@app.before_request
|
||||
def login_check():
|
||||
if request.path.startswith('/rest/'):
|
||||
return
|
||||
|
||||
if request.endpoint != 'login':
|
||||
should_login = False
|
||||
if not session.get('userid'):
|
||||
should_login = True
|
||||
elif UserManager.get(session.get('userid'))[0] != UserManager.SUCCESS:
|
||||
session.clear()
|
||||
should_login = True
|
||||
|
||||
if should_login:
|
||||
flash('Please login')
|
||||
return redirect(url_for('login', returnUrl = request.script_root + request.url[len(request.url_root)-1:]))
|
||||
|
||||
@app.route('/')
|
||||
def index():
|
||||
stats = {
|
||||
'artists': db.Artist.query.count(),
|
||||
'albums': db.Album.query.count(),
|
||||
'tracks': db.Track.query.count()
|
||||
}
|
||||
return render_template('home.html', stats = stats, admin = UserManager.get(session.get('userid'))[1].admin)
|
||||
|
||||
from .user import *
|
||||
from .folder import *
|
||||
from .playlist import *
|
||||
|
44
web.py
44
web.py
@ -23,33 +23,9 @@ from flask import Flask, request, session, flash, render_template, redirect, url
|
||||
|
||||
import config
|
||||
|
||||
def login_check():
|
||||
if request.path.startswith('/rest/'):
|
||||
return
|
||||
|
||||
if request.endpoint != 'login':
|
||||
should_login = False
|
||||
if not session.get('userid'):
|
||||
should_login = True
|
||||
elif UserManager.get(session.get('userid'))[0] != UserManager.SUCCESS:
|
||||
session.clear()
|
||||
should_login = True
|
||||
|
||||
if should_login:
|
||||
flash('Please login')
|
||||
return redirect(url_for('login', returnUrl = request.script_root + request.url[len(request.url_root)-1:]))
|
||||
|
||||
def teardown(exception):
|
||||
db.session.remove()
|
||||
|
||||
def index():
|
||||
stats = {
|
||||
'artists': db.Artist.query.count(),
|
||||
'albums': db.Album.query.count(),
|
||||
'tracks': db.Track.query.count()
|
||||
}
|
||||
return render_template('home.html', stats = stats, admin = UserManager.get(session.get('userid'))[1].admin)
|
||||
|
||||
def create_application():
|
||||
global app, db, UserManager
|
||||
|
||||
@ -72,26 +48,10 @@ def create_application():
|
||||
handler.setLevel(logging.WARNING)
|
||||
app.logger.addHandler(handler)
|
||||
|
||||
from managers.user import UserManager
|
||||
|
||||
app.before_request(login_check)
|
||||
app.teardown_request(teardown)
|
||||
app.add_template_filter(str)
|
||||
app.add_url_rule('/', view_func = index)
|
||||
|
||||
import user
|
||||
import folder
|
||||
import playlist
|
||||
|
||||
import api.system
|
||||
import api.browse
|
||||
import api.user
|
||||
import api.albums_songs
|
||||
import api.media
|
||||
import api.annotation
|
||||
import api.chat
|
||||
import api.search
|
||||
import api.playlists
|
||||
import frontend
|
||||
import api
|
||||
|
||||
return app
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user