当前位置: 首页>>代码示例>>Python>>正文


Python Request.headers['X-Auth-Token']方法代码示例

本文整理汇总了Python中swift.common.swob.Request.headers['X-Auth-Token']方法的典型用法代码示例。如果您正苦于以下问题:Python Request.headers['X-Auth-Token']方法的具体用法?Python Request.headers['X-Auth-Token']怎么用?Python Request.headers['X-Auth-Token']使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在swift.common.swob.Request的用法示例。


在下文中一共展示了Request.headers['X-Auth-Token']方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: __call__

# 需要导入模块: from swift.common.swob import Request [as 别名]
# 或者: from swift.common.swob.Request import headers['X-Auth-Token'] [as 别名]

#.........这里部分代码省略.........
                self._logger.debug('Invalid Authorization header: %s - '
                                   'deferring reject downstream', auth_header)
                return self._app(environ, start_response)
            else:
                self._logger.debug('Invalid Authorization header: %s - '
                                   'rejecting request', auth_header)
                return self._deny_request('InvalidURI')(
                    environ, start_response)

        # NOTE(chmou): This is to handle the special case with nova
        # when we have the option s3_affix_tenant. We will force it to
        # connect to another account than the one
        # authenticated. Before people start getting worried about
        # security, I should point that we are connecting with
        # username/token specified by the user but instead of
        # connecting to its own account we will force it to go to an
        # another account. In a normal scenario if that user don't
        # have the reseller right it will just fail but since the
        # reseller account can connect to every account it is allowed
        # by the swift_auth middleware.
        force_tenant = None
        if ':' in access:
            access, force_tenant = access.split(':')

        # Authenticate request.
        creds = {'credentials': {'access': access,
                                 'token': token,
                                 'signature': signature}}
        creds_json = json.dumps(creds)
        self._logger.debug('Connecting to Keystone sending this JSON: %s',
                           creds_json)
        # NOTE(vish): We could save a call to keystone by having
        #             keystone return token, tenant, user, and roles
        #             from this call.
        #
        # NOTE(chmou): We still have the same problem we would need to
        #              change token_auth to detect if we already
        #              identified and not doing a second query and just
        #              pass it through to swiftauth in this case.
        try:
            # NB: requests.Response, not swob.Response
            resp = self._json_request(creds_json)
        except HTTPException as e_resp:
            if self._delay_auth_decision:
                msg = 'Received error, deferring rejection based on error: %s'
                self._logger.debug(msg, e_resp.status)
                return self._app(environ, start_response)
            else:
                msg = 'Received error, rejecting request with error: %s'
                self._logger.debug(msg, e_resp.status)
                # NB: swob.Response, not requests.Response
                return e_resp(environ, start_response)

        self._logger.debug('Keystone Reply: Status: %d, Output: %s',
                           resp.status_code, resp.content)

        try:
            access_info = resp.json()['access']
            # Populate the environment similar to auth_token,
            # so we don't have to contact Keystone again.
            #
            # Note that although the strings are unicode following json
            # deserialization, Swift's HeaderEnvironProxy handles ensuring
            # they're stored as native strings
            req.headers.update({
                'X-Identity-Status': 'Confirmed',
                'X-Roles': ','.join(r['name']
                                    for r in access_info['user']['roles']),
                'X-User-Id': access_info['user']['id'],
                'X-User-Name': access_info['user']['name'],
                'X-Tenant-Id': access_info['token']['tenant']['id'],
                'X-Tenant-Name': access_info['token']['tenant']['name'],
                'X-Project-Id': access_info['token']['tenant']['id'],
                'X-Project-Name': access_info['token']['tenant']['name'],
            })
            token_id = access_info['token'].get('id')
            tenant = access_info['token']['tenant']
            req.environ['keystone.token_info'] = resp.json()
        except (ValueError, KeyError, TypeError):
            if self._delay_auth_decision:
                error = ('Error on keystone reply: %d %s - '
                         'deferring rejection downstream')
                self._logger.debug(error, resp.status_code, resp.content)
                return self._app(environ, start_response)
            else:
                error = ('Error on keystone reply: %d %s - '
                         'rejecting request')
                self._logger.debug(error, resp.status_code, resp.content)
                return self._deny_request('InvalidURI')(
                    environ, start_response)

        req.headers['X-Auth-Token'] = token_id
        tenant_to_connect = force_tenant or tenant['id']
        if six.PY2 and isinstance(tenant_to_connect, six.text_type):
            tenant_to_connect = tenant_to_connect.encode('utf-8')
        self._logger.debug('Connecting with tenant: %s', tenant_to_connect)
        new_tenant_name = '%s%s' % (self._reseller_prefix, tenant_to_connect)
        environ['PATH_INFO'] = environ['PATH_INFO'].replace(account,
                                                            new_tenant_name)
        return self._app(environ, start_response)
开发者ID:notmyname,项目名称:swift3,代码行数:104,代码来源:s3_token_middleware.py


注:本文中的swift.common.swob.Request.headers['X-Auth-Token']方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。