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


Python status.HTTP_403_FORBIDDEN屬性代碼示例

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


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

示例1: __call__

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def __call__(
        self, request: Request
    ) -> Optional[HTTPAuthorizationCredentials]:
        authorization: str = request.headers.get("Authorization")
        scheme, credentials = get_authorization_scheme_param(authorization)
        if not (authorization and scheme and credentials):
            if self.auto_error:
                raise HTTPException(
                    status_code=HTTP_403_FORBIDDEN, detail="Not authenticated"
                )
            else:
                return None
        if scheme.lower() != "bearer":
            if self.auto_error:
                raise HTTPException(
                    status_code=HTTP_403_FORBIDDEN,
                    detail="Invalid authentication credentials",
                )
            else:
                return None
        return HTTPAuthorizationCredentials(scheme=scheme, credentials=credentials) 
開發者ID:tiangolo,項目名稱:fastapi,代碼行數:23,代碼來源:http.py

示例2: _get_authorization_header

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def _get_authorization_header(
    api_key: str = Security(RWAPIKeyHeader(name=HEADER_KEY)),
) -> str:
    try:
        token_prefix, token = api_key.split(" ")
    except ValueError:
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN, detail=strings.WRONG_TOKEN_PREFIX,
        )

    if token_prefix != JWT_TOKEN_PREFIX:
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN, detail=strings.WRONG_TOKEN_PREFIX,
        )

    return token 
開發者ID:nsidnev,項目名稱:fastapi-realworld-example-app,代碼行數:18,代碼來源:authentication.py

示例3: _get_current_user

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def _get_current_user(
    users_repo: UsersRepository = Depends(get_repository(UsersRepository)),
    token: str = Depends(_get_authorization_header_retriever()),
) -> User:
    try:
        username = jwt.get_username_from_token(token, str(SECRET_KEY))
    except ValueError:
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN, detail=strings.MALFORMED_PAYLOAD,
        )

    try:
        return await users_repo.get_user_by_username(username=username)
    except EntityDoesNotExist:
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN, detail=strings.MALFORMED_PAYLOAD,
        ) 
開發者ID:nsidnev,項目名稱:fastapi-realworld-example-app,代碼行數:19,代碼來源:authentication.py

示例4: test_forbidden_exception

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def test_forbidden_exception():
    detail = "You have no rights, peasant."
    with pytest.raises(ForbiddenError) as excinfo:
        raise ForbiddenError(
            detail=detail
        )

    exc = excinfo.value
    assert exc.error_code == status.HTTP_403_FORBIDDEN
    assert exc.status_code == status.HTTP_403_FORBIDDEN
    assert exc.detail == detail

    error_code = 444
    with pytest.raises(ForbiddenError) as excinfo:
        raise ForbiddenError(
            detail=detail,
            error_code=error_code
        )

    exc = excinfo.value
    assert exc.error_code == error_code
    assert exc.status_code == status.HTTP_403_FORBIDDEN
    assert exc.detail == detail 
開發者ID:identixone,項目名稱:fastapi_contrib,代碼行數:25,代碼來源:test_exceptions.py

示例5: test_permissions_dependency_as_class

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def test_permissions_dependency_as_class(dumb_request):
    class FailPermission(BasePermission):

        def has_required_permisions(self, request: Request) -> bool:
            return False

    class AllowPermission(BasePermission):

        def has_required_permisions(self, request: Request) -> bool:
            return True

    dependency = PermissionsDependency(permissions_classes=[AllowPermission])
    dependency(request=dumb_request)

    dependency = PermissionsDependency(
        permissions_classes=[AllowPermission, FailPermission])

    with pytest.raises(HTTPException) as excinfo:
        dependency(request=dumb_request)

    assert excinfo.value.status_code == status.HTTP_403_FORBIDDEN
    assert excinfo.value.detail == "Forbidden." 
開發者ID:identixone,項目名稱:fastapi_contrib,代碼行數:24,代碼來源:test_permissions.py

示例6: get_current_user

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def get_current_user(token: str = Security(reusable_oauth2)):
    try:
        payload = jwt.decode(token, config.SECRET_KEY, algorithms=[ALGORITHM])
        token_data = TokenPayload(**payload)
    except PyJWTError:
        raise HTTPException(
            status_code=HTTP_403_FORBIDDEN, detail="Could not validate credentials"
        )
    bucket = get_default_bucket()
    user = crud.user.get(bucket, username=token_data.username)
    if not user:
        raise HTTPException(status_code=404, detail="User not found")
    return user 
開發者ID:tiangolo,項目名稱:full-stack-fastapi-couchbase,代碼行數:15,代碼來源:security.py

示例7: __call__

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def __call__(self, request: Request) -> Optional[str]:
        authorization: str = request.headers.get("Authorization")
        if not authorization:
            if self.auto_error:
                raise HTTPException(
                    status_code=HTTP_403_FORBIDDEN, detail="Not authenticated"
                )
            else:
                return None
        return authorization 
開發者ID:tiangolo,項目名稱:fastapi,代碼行數:12,代碼來源:oauth2.py

示例8: __call__

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def __call__(self, request: Request) -> Optional[str]:
        api_key: str = request.headers.get(self.model.name)
        if not api_key:
            if self.auto_error:
                raise HTTPException(
                    status_code=HTTP_403_FORBIDDEN, detail="Not authenticated"
                )
            else:
                return None
        return api_key 
開發者ID:tiangolo,項目名稱:fastapi,代碼行數:12,代碼來源:api_key.py

示例9: check_comment_modification_permissions

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def check_comment_modification_permissions(
    comment: Comment = Depends(get_comment_by_id_from_path),
    user: User = Depends(authentication.get_current_user_authorizer()),
) -> None:
    if not check_user_can_modify_comment(comment, user):
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN,
            detail=strings.USER_IS_NOT_AUTHOR_OF_ARTICLE,
        ) 
開發者ID:nsidnev,項目名稱:fastapi-realworld-example-app,代碼行數:11,代碼來源:comments.py

示例10: check_article_modification_permissions

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def check_article_modification_permissions(
    current_article: Article = Depends(get_article_by_slug_from_path),
    user: User = Depends(get_current_user_authorizer()),
) -> None:
    if not check_user_can_modify_article(current_article, user):
        raise HTTPException(
            status_code=status.HTTP_403_FORBIDDEN,
            detail=strings.USER_IS_NOT_AUTHOR_OF_ARTICLE,
        ) 
開發者ID:nsidnev,項目名稱:fastapi-realworld-example-app,代碼行數:11,代碼來源:articles.py

示例11: test_base_permission_no_permission_raises_403

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def test_base_permission_no_permission_raises_403(dumb_request):
    class FailPermission(BasePermission):

        def has_required_permisions(self, request: Request) -> bool:
            return False

    with pytest.raises(HTTPException) as excinfo:
        FailPermission(request=dumb_request)

    assert excinfo.value.status_code == status.HTTP_403_FORBIDDEN
    assert excinfo.value.detail == "Forbidden." 
開發者ID:identixone,項目名稱:fastapi_contrib,代碼行數:13,代碼來源:test_permissions.py

示例12: get_current_user

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def get_current_user(
    db: Session = Depends(get_db), token: str = Security(reusable_oauth2)
):
    try:
        payload = jwt.decode(token, config.SECRET_KEY, algorithms=[ALGORITHM])
        token_data = TokenPayload(**payload)
    except PyJWTError:
        raise HTTPException(
            status_code=HTTP_403_FORBIDDEN, detail="Could not validate credentials"
        )
    user = crud.user.get(db, id=token_data.user_id)
    if not user:
        raise HTTPException(status_code=400, detail="User not found")
    return user 
開發者ID:QAX-A-Team,項目名稱:LuWu,代碼行數:16,代碼來源:security.py

示例13: __call__

# 需要導入模塊: from starlette import status [as 別名]
# 或者: from starlette.status import HTTP_403_FORBIDDEN [as 別名]
def __call__(
        self, request: Request, security_scopes: SecurityScopes, return_token=False
    ):
        if not self.enabled:
            return None
        if security_scopes.scopes:
            authenticate_value = f'Bearer scope="{security_scopes.scope_str}"'
        else:
            authenticate_value = f"Bearer"
        token: str = await oauth2_scheme(request) if not self.token else self.token
        data = (
            await models.User.join(models.Token)
            .select(models.Token.id == token)
            .gino.load((models.User, models.Token))
            .first()
        )
        if data is None:
            raise HTTPException(
                status_code=HTTP_401_UNAUTHORIZED,
                detail="Could not validate credentials",
                headers={"WWW-Authenticate": authenticate_value},
            )
        user, token = data  # first validate data, then unpack
        forbidden_exception = HTTPException(
            status_code=HTTP_403_FORBIDDEN,
            detail="Not enough permissions",
            headers={"WWW-Authenticate": authenticate_value},
        )
        if "full_control" not in token.permissions:
            for scope in security_scopes.scopes:
                if scope not in token.permissions and not check_selective_scopes(
                    request, scope, token
                ):
                    raise forbidden_exception
        if "server_management" in security_scopes.scopes and not user.is_superuser:
            raise forbidden_exception
        if return_token:
            return user, token
        return user 
開發者ID:MrNaif2018,項目名稱:bitcart,代碼行數:41,代碼來源:utils.py


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