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


Python flask_principal.RoleNeed方法代碼示例

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


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

示例1: test_record_patron_create

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def test_record_patron_create(client, db, users, with_role_creator):
    """Test patron create."""

    tests = [
        ({"foo": "bar"}, "create", True),
        ({"foo": "bar"}, "update", False),
        ({"foo": "bar"}, "delete", False),
    ]

    @identity_loaded.connect
    def add_roles_to_identity(sender, identity):
        """Provide additional role to the user."""
        roles = [RoleNeed("records-creators")]
        identity.provides |= set(roles)

    for access, action, is_allowed in tests:
        # create role to be able to create records
        user_login(client, "patron1", users)

        id = uuid.uuid4()
        record = Record.create(access, id_=id)
        factory = RecordPermission(record, action)

        assert factory.can() if is_allowed else not factory.can() 
開發者ID:inveniosoftware,項目名稱:invenio-app-ils,代碼行數:26,代碼來源:test_record_permissions.py

示例2: on_identity_loaded

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def on_identity_loaded(sender, identity):
    # Set the identity user object
    identity.user = current_user

    # Add the UserNeed to the identity
    if hasattr(current_user, 'username'):
        identity.provides.add(UserNeed(current_user.username))

    # Assuming the User model has a list of roles, update the
    # identity with the roles that the user provides
    if hasattr(current_user, 'role'):
        # for role in current_user.roles:
        identity.provides.add(RoleNeed(current_user.role))
    
    # if current_user.is_superuser:
    if hasattr(current_user, 'is_superuser') and current_user.is_superuser:
        identity.provides.add(su_need)
        # return current_user.role

    identity.allow_su = su_permission.allows(identity)
    identity.allow_admin = admin_permission.allows(identity)
    identity.allow_edit = editor_permission.allows(identity)
    identity.allow_general = general_permission.allows(identity) 
開發者ID:GitMarkTeam,項目名稱:gitmark,代碼行數:25,代碼來源:permissions.py

示例3: record_needs

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def record_needs(self):
        """Create needs of the record."""
        needs = []
        for access_entity in self.record_explicit_restrictions():
            try:
                if isinstance(access_entity, string_types):
                    needs.append(UserNeed(int(access_entity)))
                elif isinstance(access_entity, int):
                    needs.append(UserNeed(access_entity))
            except ValueError:
                needs.append(RoleNeed(access_entity.lower()))
        return needs 
開發者ID:inveniosoftware,項目名稱:invenio-app-ils,代碼行數:14,代碼來源:permissions.py

示例4: roles_required

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def roles_required(*roles):
    """Decorator which specifies that a user must have all the specified roles.
    Example::

        @app.route('/dashboard')
        @roles_required('admin', 'editor')
        def dashboard():
            return 'Dashboard'

    The current user must have both the `admin` role and `editor` role in order
    to view the page.

    :param roles: The required roles.
    """

    def wrapper(fn):
        @wraps(fn)
        def decorated_view(*args, **kwargs):
            perms = [Permission(RoleNeed(role)) for role in roles]
            for perm in perms:
                if not perm.can():
                    if _security._unauthorized_callback:
                        # Backwards compat - deprecated
                        return _security._unauthorized_callback()
                    return _security._unauthz_handler(roles_required, list(roles))
            return fn(*args, **kwargs)

        return decorated_view

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

示例5: roles_accepted

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def roles_accepted(*roles):
    """Decorator which specifies that a user must have at least one of the
    specified roles. Example::

        @app.route('/create_post')
        @roles_accepted('editor', 'author')
        def create_post():
            return 'Create Post'

    The current user must have either the `editor` role or `author` role in
    order to view the page.

    :param roles: The possible roles.
    """

    def wrapper(fn):
        @wraps(fn)
        def decorated_view(*args, **kwargs):
            perm = Permission(*[RoleNeed(role) for role in roles])
            if perm.can():
                return fn(*args, **kwargs)
            if _security._unauthorized_callback:
                # Backwards compat - deprecated
                return _security._unauthorized_callback()
            return _security._unauthz_handler(roles_accepted, list(roles))

        return decorated_view

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

示例6: _on_identity_loaded

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def _on_identity_loaded(sender, identity):
    if hasattr(current_user, "fs_uniquifier"):
        identity.provides.add(UserNeed(current_user.fs_uniquifier))

    for role in getattr(current_user, "roles", []):
        identity.provides.add(RoleNeed(role.name))
        for fsperm in role.get_permissions():
            identity.provides.add(FsPermNeed(fsperm))

    identity.user = current_user 
開發者ID:Flask-Middleware,項目名稱:flask-security,代碼行數:12,代碼來源:core.py

示例7: __init__

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def __init__(self, *needs):
        '''Let administrator bypass all permissions'''
        super(Permission, self).__init__(RoleNeed('admin'), *needs) 
開發者ID:opendatateam,項目名稱:udata,代碼行數:5,代碼來源:__init__.py

示例8: blogger_permission

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def blogger_permission(self):
        if self._blogger_permission is None:
            if self.config.get("BLOGGING_PERMISSIONS", False):
                self._blogger_permission = Permission(RoleNeed(
                    self.config.get("BLOGGING_PERMISSIONNAME", "blogger")))
            else:
                self._blogger_permission = Permission()
        return self._blogger_permission 
開發者ID:gouthambs,項目名稱:Flask-Blogging,代碼行數:10,代碼來源:engine.py

示例9: __init__

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def __init__(self):
        needs = [RoleNeed("admin")]
        sensitive_domain_roles = current_app.config.get("SENSITIVE_DOMAIN_ROLES", [])

        if sensitive_domain_roles:
            for role in sensitive_domain_roles:
                needs.append(RoleNeed(role))

        super(SensitiveDomainPermission, self).__init__(*needs) 
開發者ID:Netflix,項目名稱:lemur,代碼行數:11,代碼來源:permissions.py

示例10: on_identity_loaded

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def on_identity_loaded(sender, identity):
	user = load_user(identity.id)
	if user is None:
		return

	identity.provides.add(UserNeed(user.get_name()))
	if user.is_user():
		identity.provides.add(RoleNeed("user"))
	if user.is_admin():
		identity.provides.add(RoleNeed("admin")) 
開發者ID:AstroPrint,項目名稱:AstroBox,代碼行數:12,代碼來源:__init__.py

示例11: roles_accepted

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def roles_accepted(*roles):
    """
    Decorator which specifies that a user must have at least one of the
    specified roles.

    Aborts with HTTP: 403 if the user doesn't have at least one of the roles.

    Example::

        @app.route('/create_post')
        @roles_accepted('ROLE_ADMIN', 'ROLE_EDITOR')
        def create_post():
            return 'Create Post'

    The current user must have either the `ROLE_ADMIN` role or `ROLE_EDITOR`
    role in order to view the page.

    :param roles: The possible roles.
    """
    def wrapper(fn):
        @wraps(fn)
        def decorated_view(*args, **kwargs):
            perm = Permission(*[RoleNeed(role) for role in roles])
            if not perm.can():
                abort(HTTPStatus.FORBIDDEN)
            return fn(*args, **kwargs)
        return decorated_view
    return wrapper 
開發者ID:briancappello,項目名稱:flask-unchained,代碼行數:30,代碼來源:roles_accepted.py

示例12: roles_required

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def roles_required(*roles):
    """
    Decorator which specifies that a user must have all the specified roles.

    Aborts with HTTP 403: Forbidden if the user doesn't have the required roles.

    Example::

        @app.route('/dashboard')
        @roles_required('ROLE_ADMIN', 'ROLE_EDITOR')
        def dashboard():
            return 'Dashboard'

    The current user must have both the `ROLE_ADMIN` and `ROLE_EDITOR` roles
    in order to view the page.

    :param roles: The required roles.
    """
    def wrapper(fn):
        @wraps(fn)
        def decorated_view(*args, **kwargs):
            perms = [Permission(RoleNeed(role)) for role in roles]
            for perm in perms:
                if not perm.can():
                    abort(HTTPStatus.FORBIDDEN)
            return fn(*args, **kwargs)
        return decorated_view
    return wrapper 
開發者ID:briancappello,項目名稱:flask-unchained,代碼行數:30,代碼來源:roles_required.py

示例13: _on_identity_loaded

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def _on_identity_loaded(self, sender, identity: Identity) -> None:
        """
        Callback that runs whenever a new identity has been loaded.
        """
        if hasattr(current_user, 'id'):
            identity.provides.add(UserNeed(current_user.id))

        for role in getattr(current_user, 'roles', []):
            identity.provides.add(RoleNeed(role.name))

        identity.user = current_user 
開發者ID:briancappello,項目名稱:flask-unchained,代碼行數:13,代碼來源:security.py

示例14: init_app

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def init_app(app):
    @identity_loaded.connect_via(app)
    def on_identity_loaded(sender, identity):
        '''基礎權限'''
        identity.user = current_user

        if hasattr(current_user, 'id'):
            identity.provides.add(UserNeed(current_user.id))

        if hasattr(current_user, 'is_superuser'):
            if current_user.is_superuser:
                identity.provides.add(RoleNeed('super'))

        if hasattr(current_user, 'is_confirmed'):
            if current_user.is_confirmed:
                identity.provides.add(RoleNeed('confirmed'))

        if hasattr(current_user, 'is_authenticated'):
            if current_user.is_authenticated:
                identity.provides.add(RoleNeed('auth'))
            else:
                identity.provides.add(RoleNeed('guest'))

        if hasattr(current_user, 'topics'):
            for topic in current_user.topics:
                identity.provides.add(TopicNeed(topic.id))

        if hasattr(current_user, 'replies'):
            for reply in current_user.replies:
                identity.provides.add(ReplyNeed(reply.id))

        if hasattr(current_user, 'collects'):
            for collect in current_user.collects:
                identity.provides.add(CollectNeed(collect.id)) 
開發者ID:honmaple,項目名稱:maple-bbs,代碼行數:36,代碼來源:app.py

示例15: on_identity_loaded

# 需要導入模塊: import flask_principal [as 別名]
# 或者: from flask_principal import RoleNeed [as 別名]
def on_identity_loaded(sender, identity):
    """Helper for flask-principal."""
    # Set the identity user object
    identity.user = current_user

    # Add the UserNeed to the identity
    if hasattr(current_user, "id"):
        identity.provides.add(UserNeed(current_user.id))

    try:
        if current_user.is_admin:
            identity.provides.add(RoleNeed("admin"))
    except AttributeError:
        pass  # Definitely not an admin 
開發者ID:Flowminder,項目名稱:FlowKit,代碼行數:16,代碼來源:main.py


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