本文整理匯總了Python中httplib.UNAUTHORIZED屬性的典型用法代碼示例。如果您正苦於以下問題:Python httplib.UNAUTHORIZED屬性的具體用法?Python httplib.UNAUTHORIZED怎麽用?Python httplib.UNAUTHORIZED使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類httplib
的用法示例。
在下文中一共展示了httplib.UNAUTHORIZED屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: get
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def get(self, url, headers=None, can_retry=True):
"""
Issue REST GET request to a given URL. Can throw ApiClientError or its subclass.
Arguments:
url (str): API url to fetch a resource from.
headers (dict): Headers necessary as per API, e.g. authorization bearer to perform authorised requests.
can_retry (bool): True if in a case of authentication error it can refresh access token and retry a call.
Returns:
Response in python native data format.
"""
headers_ = {'Authorization': 'Bearer ' + str(self.access_token)}
if headers is not None:
headers_.update(headers)
resp = requests.get(url, headers=headers_)
if resp.status_code == httplib.OK:
return resp.json()
elif resp.status_code == httplib.UNAUTHORIZED and can_retry:
self.access_token = self._refresh_access_token()
return self.get(url, headers, can_retry=False)
else:
raise BrightcoveApiClientError
示例2: authenticate_api
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def authenticate_api(self, **kwargs):
"""
Call a sample Wistia API url to check on authentication success.
Reference:
https://wistia.com/doc/data-api#authentication
Arguments:
kwargs (dict): Wistia master token key-value pair.
Returns:
auth_data (dict): Master token, provided by a user, which is to be stored in Wistia's player metadata.
error_status_message (str): Message with authentication outcomes for the sake of verbosity.
"""
token, media_id = kwargs.get('token'), kwargs.get('video_id') # pylint: disable=unused-variable
auth_data, error_message = {}, ''
auth_data['token'] = token
url = self.captions_api.get('auth_sample_url').format(token=str(token))
response = requests.get('https://' + url)
if response.status_code == httplib.UNAUTHORIZED:
error_message = "Authentication failed. " \
"Please ensure you have provided a valid master token, using Video API Token field."
return auth_data, error_message
示例3: __call__
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def __call__(self, callback):
def wrapper(*args, **kwargs):
if not is_local_request():
self._logger.info('Dropping request with bad Host header.')
abort(httplib.UNAUTHORIZED,
'Unauthorized, received request from non-local Host.')
return
if not self.is_request_authenticated():
self._logger.info('Dropping request with bad HMAC.')
abort(httplib.UNAUTHORIZED, 'Unauthorized, received bad HMAC.')
return
body = callback(*args, **kwargs)
self.sign_response_headers(response.headers, body)
return body
return wrapper
示例4: VerifyCredentials
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def VerifyCredentials(self):
'''Returns a twitter.User instance if the authenticating user is valid.
Returns:
A twitter.User instance representing that user if the
credentials are valid, None otherwise.
'''
if not self._username:
raise TwitterError("Api instance must first be given user credentials.")
url = 'http://twitter.com/account/verify_credentials.json'
try:
json = self._FetchUrl(url, no_cache=True)
except urllib2.HTTPError, http_error:
if http_error.code == httplib.UNAUTHORIZED:
return None
else:
raise http_error
示例5: post
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def post(self): # pylint:disable-msg=invalid-name
"""Handles HTTP POST requests."""
if not users.is_current_user_admin():
self.response.set_status(httplib.UNAUTHORIZED)
return
key = self.request.data['key']
url = self.request.data['url']
client_id = self.request.data.get('client_id')
client_secret = self.request.data.get('client_secret')
if client_id and client_secret:
credential = model.SetOAuth2Credential(key, client_id, client_secret)
else:
credential = model.GetOAuth2Credential(key) or model.OAuth2Credential()
r = {
'key': key,
'url': url,
'client_id': credential.client_id,
'client_secret': credential.client_secret,
}
return r
示例6: test_no_user
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def test_no_user(self):
self.logout_user()
response = self.testapp.get(r'/', expect_errors=True)
self.assertEqual(response.status_int, httplib.UNAUTHORIZED)
示例7: get
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def get(self, path):
user = users.get_current_user()
if not user:
self.response.status = httplib.UNAUTHORIZED
self.response.out.write('You must be logged in to access this app.')
return
elif user.email().split('@')[1] not in constants.APP_DOMAINS:
self.response.status = httplib.FORBIDDEN
self.response.out.write('Forbidden.')
return
if path == '/application.js':
self._serve_frontend_javascript()
return
if self.bootstrap_completed or re.match(
r'^/(bootstrap|authorization)', path):
self._serve_frontend()
else:
self._sync_roles_if_necessary()
# Re-checks if the bootstrap status did not change since the handler was
# first loaded.
self.bootstrap_completed = bootstrap.is_bootstrap_completed()
if self.bootstrap_completed:
self.redirect(path)
else:
datastore_user = user_model.User.get_user(user.email())
if (permissions.Permissions.BOOTSTRAP in
datastore_user.get_permissions()):
self.redirect(BOOTSTRAP_URL)
else:
self.redirect('/maintenance')
示例8: _handle_missing_api_key
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def _handle_missing_api_key(self, app_info, start_response):
code = httplib.UNAUTHORIZED
detail = self._NO_API_KEY_MSG
_logger.warn(u'Check not performed %d, %s', code, detail)
app_info.response_code = code
app_info.api_key_valid = False
return self._return_simple_http_response(start_response, code, detail)
示例9: request
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def request(self, connection, url, headers, data=None, timeout=0):
result = response = None
try:
if data: connection.request('POST', url, data, headers)
else: connection.request('GET', url, headers=headers)
response = self.timeout_response(connection, timeout)
if not response:
return None
if response.status == httplib.UNAUTHORIZED:
say_line('Wrong username or password for %s', self.server().name)
self.authorization_failed = True
raise NotAuthorized()
r = self.max_redirects
while response.status == httplib.TEMPORARY_REDIRECT:
response.read()
url = response.getheader('Location', '')
if r == 0 or url == '': raise HTTPException('Too much or bad redirects')
connection.request('GET', url, headers=headers)
response = self.timeout_response(connection, timeout)
r -= 1
self.long_poll_url = response.getheader('X-Long-Polling', '')
self.switch.update_time = bool(response.getheader('X-Roll-NTime', ''))
hostList = response.getheader('X-Host-List', '')
self.stratum_header = response.getheader('x-stratum', '')
if (not self.options.nsf) and hostList: self.switch.add_servers(loads(hostList))
result = loads(response.read())
if result['error']:
say_line('server error: %s', result['error']['message'])
raise RPCError(result['error']['message'])
return (connection, result)
finally:
if not result or not response or (response.version == 10 and response.getheader('connection', '') != 'keep-alive') or response.getheader('connection', '') == 'close':
connection.close()
connection = None
示例10: post
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def post(self, url, payload, headers=None, can_retry=True):
"""
Issue REST POST request to a given URL. Can throw ApiClientError or its subclass.
Arguments:
url (str): API url to fetch a resource from.
payload (dict): POST data.
headers (dict): Headers necessary as per API, e.g. authorization bearer to perform authorised requests.
can_retry (bool): True if in a case of authentication error it can refresh access token and retry a call.
Returns:
Response in Python native data format.
"""
headers_ = {
'Authorization': 'Bearer ' + self.access_token,
'Content-type': 'application/json'
}
if headers is not None:
headers_.update(headers)
resp = requests.post(url, data=payload, headers=headers_)
log.debug("BC response status: {}".format(resp.status_code))
if resp.status_code in (httplib.OK, httplib.CREATED):
return resp.json()
elif resp.status_code == httplib.UNAUTHORIZED and can_retry:
self.access_token = self._refresh_access_token()
return self.post(url, payload, headers, can_retry=False)
try:
resp_dict = resp.json()[0]
log.warn("API error code: %s - %s", resp_dict.get(u'error_code'), resp_dict.get(u'message'))
except (ValueError, IndexError):
message = _("Can't parse unexpected response during POST request to Brightcove API!")
log.exception(message)
resp_dict = {"message": message}
return resp_dict
示例11: _PerformCsrfRequestValidation
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def _PerformCsrfRequestValidation(session, environ):
session_xsrf = session['xsrf']
client_xsrf = environ.get(_XSRF_TOKEN_HEADER)
if not client_xsrf:
Abort(httplib.UNAUTHORIZED, 'Missing client XSRF token.')
if client_xsrf != session_xsrf:
# do not log tokens in production
if common.IsDevMode():
logging.error('Client XSRF token={0!r}, session XSRF token={1!r}'
.format(client_xsrf, session_xsrf))
Abort(httplib.UNAUTHORIZED,
'Client XSRF token does not match session XSRF token.')
示例12: __call__
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def __call__(self, environ, start_response):
if appids.TWO_COLLABORATING_APP_IDS:
self._AssertCollaboratingAppIdAccessCheck(environ)
if environ['PATH_INFO'] in common.CONTROL_PATHS_REQUIRING_TREE:
if shared.IsHttpReadMethod(environ):
if not shared.HasProjectReadAccess(environ):
Abort(httplib.UNAUTHORIZED, 'no project read access to mimic control')
else:
if not shared.HasProjectWriteAccess(environ):
Abort(httplib.UNAUTHORIZED,
'no project write access to mimic control')
return self.app(environ, start_response)
示例13: PerformAccessCheck
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def PerformAccessCheck(self):
if not shared.HasProjectReadAccess(self.request.environ):
Abort(httplib.UNAUTHORIZED, 'no project read access')
示例14: download_pdf
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def download_pdf(self, qbbo, item_id):
if self.session is None:
raise exceptions.QuickbooksException('No session')
url = "{0}/company/{1}/{2}/{3}/pdf".format(
self.api_url, self.company_id, qbbo.lower(), item_id)
headers = {
'Content-Type': 'application/pdf',
'Accept': 'application/pdf, application/json',
'User-Agent': 'python-quickbooks V3 library'
}
response = self.process_request("GET", url, headers=headers)
if response.status_code != httplib.OK:
if response.status_code == httplib.UNAUTHORIZED:
# Note that auth errors have different result structure which can't be parsed by handle_exceptions()
raise exceptions.AuthorizationException("Application authentication failed", detail=response.text)
try:
result = response.json()
except:
raise exceptions.QuickbooksException("Error reading json response: {0}".format(response.text), 10000)
self.handle_exceptions(result["Fault"])
else:
return response.content
示例15: test_missing_credentials
# 需要導入模塊: import httplib [as 別名]
# 或者: from httplib import UNAUTHORIZED [as 別名]
def test_missing_credentials(self):
self._enable_basic_auth(self.default_username, self.default_password)
resp = self.client.get('/')
self.assertEqual(resp.status_code, httplib.UNAUTHORIZED)