diff options
author | Kali Kaneko <kali@leap.se> | 2016-04-26 21:35:21 -0400 |
---|---|---|
committer | Kali Kaneko <kali@leap.se> | 2016-04-26 21:35:21 -0400 |
commit | 63a3b1355a5c7cf031ddfa58736e83908c539cdb (patch) | |
tree | 4ee952b7d1d5a2f7b1bd2f622989ae913c19eb8d /src/pixelated/resources/keys_resource.py | |
parent | 0868bc168ee5286f1842bde41a4a984497e6885e (diff) | |
parent | 3b3731d873664db00c02603363f61d34c41a3990 (diff) |
Merge branch 'debian/experimental-pix' into debian/experimental
Diffstat (limited to 'src/pixelated/resources/keys_resource.py')
-rw-r--r-- | src/pixelated/resources/keys_resource.py | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/pixelated/resources/keys_resource.py b/src/pixelated/resources/keys_resource.py new file mode 100644 index 00000000..9075ab9e --- /dev/null +++ b/src/pixelated/resources/keys_resource.py @@ -0,0 +1,30 @@ +from email.utils import parseaddr +from pixelated.resources import respond_json_deferred, BaseResource +from twisted.web import server + + +class KeysResource(BaseResource): + + isLeaf = True + + def __init__(self, services_factory): + BaseResource.__init__(self, services_factory) + + def render_GET(self, request): + _keymanager = self.keymanager(request) + + def finish_request(key): + if key.private: + respond_json_deferred(None, request, status_code=401) + else: + respond_json_deferred(key.get_active_json(), request) + + def key_not_found(_): + respond_json_deferred(None, request, status_code=404) + + _, key_to_find = parseaddr(request.args.get('search')[0]) + d = _keymanager.fetch_key(key_to_find) + d.addCallback(finish_request) + d.addErrback(key_not_found) + + return server.NOT_DONE_YET |