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:
parent
8fe9f9b715
commit
1271a35c20
@ -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
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user