Skip to content
Snippets Groups Projects
Commit 74c46d81 authored by Erik Johnston's avatar Erik Johnston
Browse files

Only require consent for events with an associated request

There are a number of instances where a server or admin may puppet a
user to join/leave rooms, which we don't want to fail if the user has
not consented to the privacy policy. We fix this by adding a check to
test if the requester has an associated access_token, which is used as a
proxy to answer the question of whether the action is being done on
behalf of a real request from the user.
parent 67d618e1
No related branches found
No related tags found
No related merge requests found
...@@ -316,8 +316,12 @@ class EventCreationHandler(object): ...@@ -316,8 +316,12 @@ class EventCreationHandler(object):
target, e target, e
) )
# Check if the user has accepted the privacy policy. We only do this if
# the requester has an associated access_token_id, which indicates that
# this action came from a user request rather than an automatice server
# or admin action.
is_exempt = yield self._is_exempt_from_privacy_policy(builder, requester) is_exempt = yield self._is_exempt_from_privacy_policy(builder, requester)
if not is_exempt: if requester.access_token_id and not is_exempt:
yield self.assert_accepted_privacy_policy(requester) yield self.assert_accepted_privacy_policy(requester)
if token_id is not None: if token_id is not None:
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment