summaryrefslogtreecommitdiff
path: root/src/pixelated/resources/user_settings_resource.py
diff options
context:
space:
mode:
authorKali Kaneko <kali@leap.se>2016-04-26 21:35:21 -0400
committerKali Kaneko <kali@leap.se>2016-04-26 21:35:21 -0400
commit63a3b1355a5c7cf031ddfa58736e83908c539cdb (patch)
tree4ee952b7d1d5a2f7b1bd2f622989ae913c19eb8d /src/pixelated/resources/user_settings_resource.py
parent0868bc168ee5286f1842bde41a4a984497e6885e (diff)
parent3b3731d873664db00c02603363f61d34c41a3990 (diff)
Merge branch 'debian/experimental-pix' into debian/experimental
Diffstat (limited to 'src/pixelated/resources/user_settings_resource.py')
-rw-r--r--src/pixelated/resources/user_settings_resource.py45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/pixelated/resources/user_settings_resource.py b/src/pixelated/resources/user_settings_resource.py
new file mode 100644
index 00000000..7420a406
--- /dev/null
+++ b/src/pixelated/resources/user_settings_resource.py
@@ -0,0 +1,45 @@
+#
+# Copyright (c) 2015 ThoughtWorks, Inc.
+#
+# Pixelated is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Pixelated is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
+
+from pixelated.resources import respond_json_deferred, BaseResource
+from twisted.web import server
+
+FINGERPRINT_NOT_FOUND = 'Fingerprint not found'
+
+
+class UserSettingsResource(BaseResource):
+ isLeaf = True
+
+ def __init__(self, services_factory):
+ BaseResource.__init__(self, services_factory)
+
+ def render_GET(self, request):
+ _account_email = self.mail_service(request).account_email
+
+ def finish_request(key):
+ _fingerprint = key.fingerprint
+ respond_json_deferred(
+ {'account_email': _account_email, 'fingerprint': _fingerprint}, request)
+
+ def key_not_found(_):
+ respond_json_deferred(
+ {'account_email': _account_email, 'fingerprint': FINGERPRINT_NOT_FOUND}, request)
+
+ d = self.keymanager(request).fetch_key(_account_email)
+ d.addCallback(finish_request)
+ d.addErrback(key_not_found)
+
+ return server.NOT_DONE_YET