當前位置: 首頁>>代碼示例>>Python>>正文


Python flask_principal.Identity方法代碼示例

本文整理匯總了Python中flask_principal.Identity方法的典型用法代碼示例。如果您正苦於以下問題:Python flask_principal.Identity方法的具體用法?Python flask_principal.Identity怎麽用?Python flask_principal.Identity使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在flask_principal的用法示例。


在下文中一共展示了flask_principal.Identity方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _check_token

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _check_token():
    # N.B. this isn't great Flask-Login 0.5.0 made this protected
    # Issue https://github.com/maxcountryman/flask-login/issues/471
    # was filed to restore public access. We want to call this via
    # login_manager in case someone has overridden the login_manager which we
    # allow.
    if hasattr(_security.login_manager, "request_callback"):
        # Pre 0.5.0
        user = _security.login_manager.request_callback(request)
    else:
        user = _security.login_manager._request_callback(request)

    if user and user.is_authenticated:
        app = current_app._get_current_object()
        _request_ctx_stack.top.user = user
        identity_changed.send(app, identity=Identity(user.fs_uniquifier))
        return True

    return False 
開發者ID:Flask-Middleware,項目名稱:flask-security,代碼行數:21,代碼來源:decorators.py

示例2: configure_auth

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def configure_auth():
    from zou.app.services import persons_service

    @jwt.token_in_blacklist_loader
    def check_if_token_is_revoked(decrypted_token):
        return auth_tokens_store.is_revoked(decrypted_token)

    @jwt.user_loader_callback_loader
    def add_permissions(callback):
        try:
            user = persons_service.get_current_user()
            if user is not None:
                identity_changed.send(
                    current_app._get_current_object(),
                    identity=Identity(user["id"]),
                )
            return user
        except PersonNotFoundException:
            return None 
開發者ID:cgwire,項目名稱:zou,代碼行數:21,代碼來源:__init__.py

示例3: login

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def login():
    """GET|POST /login: login form handler
    """
    form = LoginForm()
    if form.validate_on_submit():
        # login user
        u = User.query.filter(User.email == form.email.data).first()
        login_user(u, remember=form.remember_me.data)

        # tell flask-principal the identity changed
        identity_changed.send(current_app._get_current_object(),
                              identity=Identity(u.id))

        return redirect(request.args.get('next') or url_for('content.home'))

    return render_template('/auth/login.html', form=form) 
開發者ID:muicss,項目名稱:flaskapp,代碼行數:18,代碼來源:auth.py

示例4: create_account

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def create_account():
    """GET|POST /create-account: create account form handler
    """
    form = CreateAccountForm()
    if form.validate_on_submit():
        # add user to database
        u = User(email=form.email.data,
                 password=generate_password_hash(form.password.data))
        db.session.add(u)
        db.session.flush()

        # send verification email
        send_verification_email(u)

        # login user
        login_user(u, remember=True)
        identity_changed.send(current_app._get_current_object(),
                              identity=Identity(u.id))

        return redirect(request.args.get('next') or url_for('content.home'))

    return render_template('/auth/create-account.html', form=form) 
開發者ID:muicss,項目名稱:flaskapp,代碼行數:24,代碼來源:auth.py

示例5: identity

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def identity(self):
        """
        Returns the identity for the auth context.
        """
        if self.oauthtoken:
            scope_set = scopes_from_scope_string(self.oauthtoken.scope)
            return QuayDeferredPermissionUser.for_user(self.oauthtoken.authorized_user, scope_set)

        if self.authed_user:
            return QuayDeferredPermissionUser.for_user(self.authed_user)

        if self.token:
            return Identity(self.token.get_code(), "token")

        if self.signed_data:
            identity = Identity(None, "signed_grant")
            identity.provides.update(self.signed_data["grants"])
            return identity

        return None 
開發者ID:quay,項目名稱:quay,代碼行數:22,代碼來源:auth_context_type.py

示例6: post

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def post(self):
        if request.form.get('login_github'):
            session['oauth_callback_type'] = 'login'
            return github_auth.github_auth()
            # return 'login_github'

        form = forms.LoginForm(obj=request.form)
        if form.validate():
            try:
                user = models.User.objects.get(username=form.username.data)
            except models.User.DoesNotExist:
                user = None

            if user and user.verify_password(form.password.data):
                login_user(user, form.remember_me.data)
                user.last_login = datetime.datetime.now
                user.save()
                identity_changed.send(current_app._get_current_object(), identity=Identity(user.username))
                return redirect(request.args.get('next') or url_for('main.index'))
            flash('Invalid username or password', 'danger')
        return self.get(form=form) 
開發者ID:GitMarkTeam,項目名稱:gitmark,代碼行數:23,代碼來源:views.py

示例7: api_auth_required

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def api_auth_required(f):
    @wraps(f)
    def wrapper(*args, **kwargs):
        if request.authorization and request.authorization.type == "basic":
            user = user_datastore.find_user(api_key=request.authorization.username)
            if user and user.has_role("developer"):
                _request_ctx_stack.top.user = user
                identity_changed.send(
                    current_app._get_current_object(), identity=Identity(user.id)
                )
                return f(*args, **kwargs)
        abort(401)

    return wrapper 
開發者ID:SynoCommunity,項目名稱:spkrepo,代碼行數:16,代碼來源:api.py

示例8: _check_http_auth

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _check_http_auth():
    auth = request.authorization or BasicAuth(username=None, password=None)
    if not auth.username:
        return False
    user = find_user(auth.username)

    if user and user.verify_and_update_password(auth.password):
        _security.datastore.commit()
        app = current_app._get_current_object()
        _request_ctx_stack.top.user = user
        identity_changed.send(app, identity=Identity(user.fs_uniquifier))
        return True

    return False 
開發者ID:Flask-Middleware,項目名稱:flask-security,代碼行數:16,代碼來源:decorators.py

示例9: _

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _(translate):
    """Identity function to mark strings for translation."""
    return translate 
開發者ID:Flask-Middleware,項目名稱:flask-security,代碼行數:5,代碼來源:utils.py

示例10: _identity_loader

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _identity_loader():
    if not isinstance(current_user._get_current_object(), AnonymousUserMixin):
        identity = Identity(current_user.fs_uniquifier)
        return identity 
開發者ID:Flask-Middleware,項目名稱:flask-security,代碼行數:6,代碼來源:core.py

示例11: reset_password

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def reset_password():
    """GET /reset-password: choose new password
    """
    # get password-reset entry
    f = (PasswordResetRequest.key == request.args.get('key'),
         User.email == request.args.get('email'))
    r = PasswordResetRequest.query.filter(*f).first()

    # return error response if link doesn't exist or wrong email
    if r == None or r.user.email != request.args['email']:
        return render_template('/auth/reset-password-error.html'), 400

    # expired if older than 1 day
    delta = datetime.datetime.utcnow() - r.create_ts
    if delta.days > 0:
        db.session.delete(r)
        db.session.flush()
        return render_template('/auth/reset-password-error.html'), 400

    # handle form
    form = ResetPasswordForm()
    if form.validate_on_submit():
        # save new password
        u = r.user
        u.password = generate_password_hash(form.password.data)
        db.session.add(u)

        # login user
        login_user(u, remember=True)
        identity_changed.send(current_app._get_current_object(),
                              identity=Identity(u.id))

        # delete password reset
        db.session.delete(r)
        db.session.flush()

        return render_template('/auth/reset-password-followup.html')

    return render_template('/auth/reset-password.html', form=form) 
開發者ID:muicss,項目名稱:flaskapp,代碼行數:41,代碼來源:auth.py

示例12: request_reissue

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def request_reissue(certificate, commit):
    """
    Reissuing certificate and handles any exceptions.
    :param certificate:
    :param commit:
    :return:
    """
    status = FAILURE_METRIC_STATUS
    try:
        print("[+] {0} is eligible for re-issuance".format(certificate.name))

        # set the lemur identity for all cli commands
        identity_changed.send(current_app._get_current_object(), identity=Identity(1))

        details = get_certificate_primitives(certificate)
        print_certificate_details(details)

        if commit:
            new_cert = reissue_certificate(certificate, replace=True)
            print("[+] New certificate named: {0}".format(new_cert.name))

        status = SUCCESS_METRIC_STATUS

    except Exception as e:
        sentry.captureException(extra={"certificate_name": str(certificate.name)})
        current_app.logger.exception(
            f"Error reissuing certificate: {certificate.name}", exc_info=True
        )
        print(f"[!] Failed to reissue certificate: {certificate.name}. Reason: {e}")

    metrics.send(
        "certificate_reissue",
        "counter",
        1,
        metric_tags={"status": status, "certificate": certificate.name},
    ) 
開發者ID:Netflix,項目名稱:lemur,代碼行數:38,代碼來源:cli.py

示例13: logged_in_user

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def logged_in_user(session, app):
    with app.test_request_context():
        identity_changed.send(current_app._get_current_object(), identity=Identity(1))
        yield 
開發者ID:Netflix,項目名稱:lemur,代碼行數:6,代碼來源:conftest.py

示例14: _check_token

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _check_token():
    user = security.login_manager._request_callback(request)

    if user and user.is_authenticated:
        _request_ctx_stack.top.user = user
        identity_changed.send(current_app._get_current_object(),
                              identity=Identity(user.id))
        return True

    return False 
開發者ID:briancappello,項目名稱:flask-unchained,代碼行數:12,代碼來源:auth_required.py

示例15: _identity_loader

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import Identity [as 別名]
def _identity_loader(self) -> Union[Identity, None]:
        """
        Identity loading function to be passed to be assigned to the Principal
        instance returned by :meth:`_get_principal`.
        """
        if not isinstance(current_user._get_current_object(), AnonymousUser):
            return Identity(current_user.id) 
開發者ID:briancappello,項目名稱:flask-unchained,代碼行數:9,代碼來源:security.py


注:本文中的flask_principal.Identity方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。