1
0
mirror of https://github.com/spl0k/supysonic.git synced 2024-12-23 01:16:18 +00:00

WIP rewrite config.py: simply retab web.py

This commit is contained in:
Óscar García Amor 2017-08-07 09:37:37 +02:00
parent 8fe9f9b715
commit 1271a35c20

View File

@ -1,22 +1,14 @@
# coding: utf-8 #! /usr/bin/env python
# -*- coding: utf-8 -*-
# vim:fenc=utf-8
#
# This file is part of Supysonic. # This file is part of Supysonic.
#
# Supysonic is a Python implementation of the Subsonic server API. # Supysonic is a Python implementation of the Subsonic server API.
# Copyright (C) 2013 Alban 'spl0k' Féron
# #
# This program is free software: you can redistribute it and/or modify # Copyright © 2013-2017 Alban 'spl0k' Féron
# it under the terms of the GNU Affero General Public License as published by # 2017 Óscar García Amor
# 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, # Distributed under terms of the GNU AGPLv3 license.
# 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/>.
import os.path import os.path
from flask import Flask, g from flask import Flask, g
@ -26,50 +18,50 @@ from supysonic import config
from supysonic.db import get_store from supysonic.db import get_store
def get_db_store(): def get_db_store():
store = getattr(g, 'store', None) store = getattr(g, 'store', None)
if store: if store:
return store return store
g.store = get_store(config.get('base', 'database_uri')) g.store = get_store(config.get('base', 'database_uri'))
return g.store return g.store
store = LocalProxy(get_db_store) store = LocalProxy(get_db_store)
def teardown_db(exception): def teardown_db(exception):
store = getattr(g, 'store', None) store = getattr(g, 'store', None)
if store: if store:
store.close() store.close()
def create_application(): def create_application():
global app global app
if not config.check(): if not config.check():
return None return None
if not os.path.exists(config.get('webapp', 'cache_dir')): if not os.path.exists(config.get('webapp', 'cache_dir')):
os.makedirs(config.get('webapp', 'cache_dir')) os.makedirs(config.get('webapp', 'cache_dir'))
app = Flask(__name__) app = Flask(__name__)
app.secret_key = '?9huDM\\H' app.secret_key = '?9huDM\\H'
app.teardown_appcontext(teardown_db) app.teardown_appcontext(teardown_db)
if config.get('webapp', 'log_file'): if config.get('webapp', 'log_file'):
import logging import logging
from logging.handlers import TimedRotatingFileHandler from logging.handlers import TimedRotatingFileHandler
handler = TimedRotatingFileHandler(config.get('webapp', 'log_file'), when = 'midnight') handler = TimedRotatingFileHandler(config.get('webapp', 'log_file'), when = 'midnight')
if config.get('webapp', 'log_level'): if config.get('webapp', 'log_level'):
mapping = { mapping = {
'DEBUG': logging.DEBUG, 'DEBUG': logging.DEBUG,
'INFO': logging.INFO, 'INFO': logging.INFO,
'WARNING': logging.WARNING, 'WARNING': logging.WARNING,
'ERROR': logging.ERROR, 'ERROR': logging.ERROR,
'CRTICAL': logging.CRITICAL 'CRTICAL': logging.CRITICAL
} }
handler.setLevel(mapping.get(config.get('webapp', 'log_level').upper(), logging.NOTSET)) handler.setLevel(mapping.get(config.get('webapp', 'log_level').upper(), logging.NOTSET))
app.logger.addHandler(handler) app.logger.addHandler(handler)
from supysonic import frontend from supysonic import frontend
from supysonic import api from supysonic import api
return app return app