mirror of
https://github.com/element-hq/synapse.git
synced 2024-12-18 17:10:43 +03:00
Merge branch 'rav/fix_gdpr_consent' into matrix-org-hotfixes
This commit is contained in:
commit
638c0bf49b
1 changed files with 11 additions and 2 deletions
|
@ -175,7 +175,7 @@ class ConsentResource(Resource):
|
||||||
"""
|
"""
|
||||||
version = parse_string(request, "v", required=True)
|
version = parse_string(request, "v", required=True)
|
||||||
username = parse_string(request, "u", required=True)
|
username = parse_string(request, "u", required=True)
|
||||||
userhmac = parse_string(request, "h", required=True)
|
userhmac = parse_string(request, "h", required=True, encoding=None)
|
||||||
|
|
||||||
self._check_hash(username, userhmac)
|
self._check_hash(username, userhmac)
|
||||||
|
|
||||||
|
@ -210,9 +210,18 @@ class ConsentResource(Resource):
|
||||||
finish_request(request)
|
finish_request(request)
|
||||||
|
|
||||||
def _check_hash(self, userid, userhmac):
|
def _check_hash(self, userid, userhmac):
|
||||||
|
"""
|
||||||
|
Args:
|
||||||
|
userid (unicode):
|
||||||
|
userhmac (bytes):
|
||||||
|
|
||||||
|
Raises:
|
||||||
|
SynapseError if the hash doesn't match
|
||||||
|
|
||||||
|
"""
|
||||||
want_mac = hmac.new(
|
want_mac = hmac.new(
|
||||||
key=self._hmac_secret,
|
key=self._hmac_secret,
|
||||||
msg=userid,
|
msg=userid.encode('utf-8'),
|
||||||
digestmod=sha256,
|
digestmod=sha256,
|
||||||
).hexdigest()
|
).hexdigest()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue