Unify handle_get/handle_head in decrypter
Change-Id: I7058e3b5cd7a7fe7f2f0c3304e4e8b3d97dfec4a
This commit is contained in:
parent
83a7ce8ce0
commit
0d774861cb
@ -294,7 +294,7 @@ class DecrypterObjContext(BaseDecrypterContext):
|
|||||||
body='Error decrypting object', content_type='text/plain')
|
body='Error decrypting object', content_type='text/plain')
|
||||||
return crypto_meta
|
return crypto_meta
|
||||||
|
|
||||||
def handle_get(self, req, start_response):
|
def handle(self, req, start_response):
|
||||||
app_resp = self._app_call(req.environ)
|
app_resp = self._app_call(req.environ)
|
||||||
|
|
||||||
put_crypto_meta = self._read_crypto_meta(
|
put_crypto_meta = self._read_crypto_meta(
|
||||||
@ -311,7 +311,8 @@ class DecrypterObjContext(BaseDecrypterContext):
|
|||||||
|
|
||||||
mod_resp_headers = self.decrypt_resp_headers(put_keys, post_keys)
|
mod_resp_headers = self.decrypt_resp_headers(put_keys, post_keys)
|
||||||
|
|
||||||
if put_crypto_meta and is_success(self._get_status_int()):
|
if put_crypto_meta and req.method == 'GET' and \
|
||||||
|
is_success(self._get_status_int()):
|
||||||
# 2xx response and encrypted body
|
# 2xx response and encrypted body
|
||||||
body_key = self.get_unwrapped_key(
|
body_key = self.get_unwrapped_key(
|
||||||
put_crypto_meta, put_keys['object'])
|
put_crypto_meta, put_keys['object'])
|
||||||
@ -341,34 +342,13 @@ class DecrypterObjContext(BaseDecrypterContext):
|
|||||||
|
|
||||||
return resp_iter
|
return resp_iter
|
||||||
|
|
||||||
def handle_head(self, req, start_response):
|
|
||||||
app_resp = self._app_call(req.environ)
|
|
||||||
put_crypto_meta = self._read_crypto_meta(
|
|
||||||
'X-Object-Sysmeta-Crypto-Body-Meta', True)
|
|
||||||
put_keys = self.get_decryption_keys(req, put_crypto_meta)
|
|
||||||
post_crypto_meta = self._read_crypto_meta(
|
|
||||||
'X-Object-Transient-Sysmeta-Crypto-Meta', False)
|
|
||||||
post_keys = self.get_decryption_keys(req, post_crypto_meta)
|
|
||||||
|
|
||||||
if put_keys is None and post_keys is None:
|
|
||||||
# skip decryption
|
|
||||||
start_response(self._response_status, self._response_headers,
|
|
||||||
self._response_exc_info)
|
|
||||||
else:
|
|
||||||
mod_resp_headers = self.decrypt_resp_headers(put_keys, post_keys)
|
|
||||||
mod_resp_headers = purge_crypto_sysmeta_headers(mod_resp_headers)
|
|
||||||
start_response(self._response_status, mod_resp_headers,
|
|
||||||
self._response_exc_info)
|
|
||||||
|
|
||||||
return app_resp
|
|
||||||
|
|
||||||
|
|
||||||
class DecrypterContContext(BaseDecrypterContext):
|
class DecrypterContContext(BaseDecrypterContext):
|
||||||
def __init__(self, decrypter, logger):
|
def __init__(self, decrypter, logger):
|
||||||
super(DecrypterContContext, self).__init__(
|
super(DecrypterContContext, self).__init__(
|
||||||
decrypter, 'container', logger)
|
decrypter, 'container', logger)
|
||||||
|
|
||||||
def handle_get(self, req, start_response):
|
def handle(self, req, start_response):
|
||||||
app_resp = self._app_call(req.environ)
|
app_resp = self._app_call(req.environ)
|
||||||
|
|
||||||
if is_success(self._get_status_int()):
|
if is_success(self._get_status_int()):
|
||||||
@ -449,12 +429,10 @@ class Decrypter(object):
|
|||||||
except ValueError:
|
except ValueError:
|
||||||
return self.app(env, start_response)
|
return self.app(env, start_response)
|
||||||
|
|
||||||
if parts[3] and req.method == 'GET':
|
if parts[3] and req.method in ('GET', 'HEAD'):
|
||||||
handler = DecrypterObjContext(self, self.logger).handle_get
|
handler = DecrypterObjContext(self, self.logger).handle
|
||||||
elif parts[3] and req.method == 'HEAD':
|
|
||||||
handler = DecrypterObjContext(self, self.logger).handle_head
|
|
||||||
elif parts[2] and req.method == 'GET':
|
elif parts[2] and req.method == 'GET':
|
||||||
handler = DecrypterContContext(self, self.logger).handle_get
|
handler = DecrypterContContext(self, self.logger).handle
|
||||||
else:
|
else:
|
||||||
# url and/or request verb is not handled by decrypter
|
# url and/or request verb is not handled by decrypter
|
||||||
return self.app(env, start_response)
|
return self.app(env, start_response)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user