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


Python RUNTIME.check_permission方法代碼示例

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


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

示例1: post

# 需要導入模塊: from empower.main import RUNTIME [as 別名]
# 或者: from empower.main.RUNTIME import check_permission [as 別名]
 def post(self):
     username = self.get_argument("username", "")
     password = self.get_argument("password", "")
     if RUNTIME.check_permission(username, password):
         self.set_secure_cookie("user", username)
         self.redirect(self.get_argument("next", "/"))
     else:
         error_msg = "Login incorrect."
         self.redirect("/auth/login/" +
                       "?error=" +
                       tornado.escape.url_escape(error_msg))
開發者ID:gastontelfe,項目名稱:empower-runtime,代碼行數:13,代碼來源:restserver.py

示例2: prepare

# 需要導入模塊: from empower.main import RUNTIME [as 別名]
# 或者: from empower.main.RUNTIME import check_permission [as 別名]
    def prepare(self):
        """Prepare to handler reply."""

        self.set_header('Content-Type', 'application/json')

        if not self.RIGHTS[self.request.method]:
            return

        auth_header = self.request.headers.get('Authorization')

        if auth_header is None or not auth_header.startswith('Basic '):
            self.set_header('WWW-Authenticate', 'Basic realm=Restricted')
            self.send_error(401)
            return

        auth_bytes = bytes(auth_header[6:], 'utf-8')
        auth_decoded = base64.b64decode(auth_bytes).decode()
        username, password = auth_decoded.split(':', 2)

        # account does not exists
        if not RUNTIME.check_permission(username, password):
            self.send_error(401)
            return

        self.account = RUNTIME.get_account(username)

        if self.account.role in self.RIGHTS[self.request.method]:

            if self.account.role == ROLE_ADMIN:
                return

            if self.request.uri.startswith("/api/v1/accounts"):

                pattern = re.compile("/api/v1/accounts/([a-zA-Z0-9:-]*)/?")
                match = pattern.match(self.request.uri)

                if match and match.group(1):
                    if match.group(1) in RUNTIME.accounts:
                        account = RUNTIME.accounts[match.group(1)]
                        if self.account.username == account.username:
                            return
                        else:
                            self.send_error(401)
                            return

                return

            if self.request.uri.startswith("/api/v1/pending"):
                pattern = re.compile("/api/v1/pending/([a-zA-Z0-9-]*)/?")
                match = pattern.match(self.request.uri)
                if match and match.group(1):
                    try:
                        tenant_id = UUID(match.group(1))
                    except ValueError:
                        self.send_error(400)
                        return
                    pending = RUNTIME.load_pending_tenant(tenant_id)
                    if pending:
                        if self.account.username == pending.owner:
                            return
                        self.send_error(401)
                        return

                return

            if self.request.uri.startswith("/api/v1/tenants"):

                pattern = re.compile("/api/v1/tenants/([a-zA-Z0-9-]*)/?")
                match = pattern.match(self.request.uri)

                if match and match.group(1):
                    tenant_id = UUID(match.group(1))
                    if tenant_id in RUNTIME.tenants:
                        tenant = RUNTIME.tenants[tenant_id]
                        if self.account.username == tenant.owner:
                            return
                        self.send_error(401)
                        return

                return

        self.send_error(401)
        return
開發者ID:herlesupreeth,項目名稱:5G-Controller,代碼行數:85,代碼來源:apihandlers.py


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