1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
#
# Copyright (c) 2014 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/>.
import json
from twisted.web.http import UNAUTHORIZED
from twisted.web.resource import Resource
from twisted.logger import Logger
from pixelated.resources.session import IPixelatedSession
from twisted.web.http import INTERNAL_SERVER_ERROR, SERVICE_UNAVAILABLE
log = Logger()
class SetEncoder(json.JSONEncoder):
def default(self, obj):
if isinstance(obj, set):
return list(obj)
return super(SetEncoder, self).default(obj)
def respond_json(entity, request, status_code=200):
json_response = json.dumps(entity, cls=SetEncoder)
request.responseHeaders.setRawHeaders(b"content-type", [b"application/json"])
request.code = status_code
return json_response
def respond_json_deferred(entity, request, status_code=200):
json_response = json.dumps(entity, cls=SetEncoder)
request.responseHeaders.setRawHeaders(b"content-type", [b"application/json"])
request.code = status_code
request.write(json_response)
request.finish()
def handle_error_deferred(e, request):
log.error(e)
request.setResponseCode(INTERNAL_SERVER_ERROR)
request.write('Something went wrong!')
request.finish()
class BaseResource(Resource):
def __init__(self, services_factory):
Resource.__init__(self)
self._services_factory = services_factory
def _get_user_id_from_request(self, request):
if self._services_factory.mode.is_single_user:
return None # it doesn't matter
session = self.get_session(request)
if session.is_logged_in():
return session.user_uuid
raise ValueError('Not logged in')
def is_logged_in(self, request):
session = self.get_session(request)
return session.is_logged_in() and self._services_factory.has_session(session.user_uuid)
def get_session(self, request):
return IPixelatedSession(request.getSession())
def is_admin(self, request):
services = self._services(request)
return services._leap_session.user_auth.is_admin()
def _services(self, request):
user_id = self._get_user_id_from_request(request)
return self._services_factory.services(user_id)
def _service(self, request, attribute):
return getattr(self._services(request), attribute)
def keymanager(self, request):
return self._service(request, 'keymanager')
def mail_service(self, request):
return self._service(request, 'mail_service')
def search_engine(self, request):
return self._service(request, 'search_engine')
def draft_service(self, request):
return self._service(request, 'draft_service')
def feedback_service(self, request):
return self._service(request, 'feedback_service')
class UnAuthorizedResource(Resource):
def __init__(self):
Resource.__init__(self)
def render_GET(self, request):
request.setResponseCode(UNAUTHORIZED)
return "Unauthorized!"
def render_POST(self, request):
request.setResponseCode(UNAUTHORIZED)
return "Unauthorized!"
class UnavailableResource(Resource):
def __init__(self):
Resource.__init__(self)
def render(self, request):
request.setResponseCode(SERVICE_UNAVAILABLE)
return "Service Unavailable"
|