Sto cercando di accedere alla configurazione dell'applicazione di accesso all'interno di un progetto authorisation.pyche in un pacchetto api. Sto inizializzando il progetto in __init__.pycui viene utilizzato in authorisation.py.
__init__.py
from flask import Blueprint
api_blueprint = Blueprint("xxx.api", __name__, None)
from api import authorisation
authorisation.py
from flask import request, jsonify, current_app
from ..oauth_adapter import OauthAdapter
from api import api_blueprint as api
client_id = current_app.config.get('CLIENT_ID')
client_secret = current_app.config.get('CLIENT_SECRET')
scope = current_app.config.get('SCOPE')
callback = current_app.config.get('CALLBACK')
auth = OauthAdapter(client_id, client_secret, scope, callback)
@api.route('/authorisation_url')
def authorisation_url():
url = auth.get_authorisation_url()
return str(url)
Ricevo RuntimeError: lavoro al di fuori del contesto dell'applicazione
Capisco il motivo, ma qual è il modo corretto di accedere a tali impostazioni di configurazione?
---- Aggiorna ---- Temporaneamente, l'ho fatto.
@api.route('/authorisation_url')
def authorisation_url():
client_id, client_secret, scope, callback = config_helper.get_config()
auth = OauthAdapter(client_id, client_secret, scope, callback)
url = auth.get_authorisation_url()
return str(url)
current_appproxy è disponibile solo nel contesto di una richiesta.