установить время жизни для каждого сеанса отдельно колбу KVsession - PullRequest
0 голосов
/ 05 ноября 2018

KBsession хранит TTL сеанса на основе PERMANENT_SESSION_LIFETIME, есть ли способ переопределить это для определенных сеансов

EDIT: поэтому у меня есть два разных API для входа, мне нужно дать любому пользователю логин от одного из них бесконечный TTL сеанса, другой примет значение PERMANENT_SESSION_LIFETIME примечание: серверная часть KBsession - redis

1 Ответ

0 голосов
/ 06 ноября 2018

Я думаю, что лучший способ - использовать Session Interface для создания определенной обработки. Это всего лишь пример, но я надеюсь, что вы понимаете подход.

from flask import Flask, session as flask_session, jsonify

flask_app = Flask(__name__)
# just a few user types
UNIQUE_USER_TYPE = 'unique'
DEFAULT_USER_TYPE = 'default'

@flask_app.route('/login-default')
def login_default():
    flask_session['user_type'] = DEFAULT_USER_TYPE
    return 'login default done'

@flask_app.route('/login-unique')
def login_unique():
    flask_session['user_type'] = UNIQUE_USER_TYPE
    return 'login unique done'

@flask_app.route('/session-state')
def get_session_state():
    return jsonify(dict(flask_session))


class UserTypeSessionInterface(SecureCookieSessionInterface):

    def get_expiration_time(self, app, session):
        """
        I just override method. Just demonstration.
        It's called from save_session() and open_session()
        """
        if session.get('user_type') == UNIQUE_USER_TYPE:
            # set 1 hour for unique users
            delta = datetime.utcnow() + timedelta(hours=1)
        else:
            # set 3 hour for default users
            delta = datetime.utcnow() + timedelta(hours=3)
        # add datetime data into session
        session['lifetime'] = delta.strftime('%Y-%m-%dT%H:%M:%S')
        return delta
# use our custom session implementation
flask_app.session_interface = UserTypeSessionInterface()

Запустите сервер, откройте новое личное окно, /login-default и /session-state:

# default behaviour
{
  "lifetime": "2018-11-06T16:22:21", 
  "user_type": "default"
}

Открыть еще одно личное окно, /login-unique и /session-state:

# unique behaviour
{
   "lifetime": "2018-11-06T14:25:17", 
   "user_type": "unique"
}

Итак, инструмент хранения сеанса не имеет значения (redis, cassandra или что-то еще). Все, что вам нужно, это просто реализовать open_session() и save_session():

class YourSessionProcessor(SessionInterface):

    def open_session(self, app, request):
        # just do here all what you need
        pass

    def save_session(self, app, session, response):
        # just do here all what you need
        pass

flask_app.session_interface = YourSessionProcessor()

Также вы можете использовать пользовательский класс сеанса (просто пример):

from flask.sessions import SessionMixin
from werkzeug.datastructures import CallbackDict

class CustomSession(CallbackDict, SessionMixin):

    def __init__(self, initial=None, sid=None):
        def on_update(self):
            self.modified = True

        CallbackDict.__init__(self, initial, on_update=on_update)
        self.sid = sid
        self.modified = False

# YourSessionProcessor
def open_session(self, app, request):
    # you can find any useful data in request
    # you can find all settings in app.config
    sid = request.cookies.get(app.session_cookie_name)
    # ... do here everything what you need
    return CustomSession(sid=sid)

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...