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

68 lines
1.8 KiB
Python
Raw Normal View History

2012-10-13 09:29:48 +00:00
# coding: utf-8
2014-03-02 17:31:32 +00:00
# This file is part of Supysonic.
#
# 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
# 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/>.
2014-03-03 20:43:06 +00:00
import os.path
2014-03-16 17:51:19 +00:00
from flask import Flask, g
from werkzeug.local import LocalProxy
2012-10-13 09:29:48 +00:00
2012-11-21 12:09:31 +00:00
import config
2014-03-16 17:51:19 +00:00
from db import get_store
2012-10-13 09:29:48 +00:00
2014-03-16 17:51:19 +00:00
def get_db_store():
store = getattr(g, 'store', None)
if store:
return store
g.store = get_store(config.get('base', 'database_uri'))
return g.store
store = LocalProxy(get_db_store)
def teardown_db(exception):
store = getattr(g, 'store', None)
if store:
store.close()
2012-10-13 09:29:48 +00:00
2014-03-03 20:43:06 +00:00
def create_application():
2014-03-16 17:51:19 +00:00
global app
2014-03-03 20:43:06 +00:00
if not config.check():
return None
if not os.path.exists(config.get('base', 'cache_dir')):
os.makedirs(config.get('base', 'cache_dir'))
app = Flask(__name__)
app.secret_key = '?9huDM\\H'
2014-03-16 17:51:19 +00:00
app.teardown_appcontext(teardown_db)
2014-03-03 20:43:06 +00:00
if config.get('base', 'log_file'):
import logging
from logging.handlers import TimedRotatingFileHandler
handler = TimedRotatingFileHandler(config.get('base', 'log_file'), when = 'midnight')
handler.setLevel(logging.WARNING)
app.logger.addHandler(handler)
2014-03-04 21:56:53 +00:00
import frontend
import api
2014-03-03 20:43:06 +00:00
return app
2012-10-13 09:29:48 +00:00