This repository has been archived by the owner on Apr 26, 2024. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Changes for unique emails #211
Merged
Merged
Changes from 5 commits
Commits
Show all changes
7 commits
Select commit
Hold shift + click to select a range
c77048e
Add endpoint that proxies ID server request token and errors if the g…
dbkr e124128
Bump schema version
dbkr 07ad03d
Fix tests
dbkr 883aabe
splt long line
dbkr a0dea6e
Remember to yield: not much point testing is a deferred is not None
dbkr 73605f8
Just leaving off the $ is fine. r* == registerrrrrrrrr
dbkr f43041a
Check absent before trying to access keys
dbkr File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -41,7 +41,7 @@ | |
|
||
|
||
class RegisterRestServlet(RestServlet): | ||
PATTERN = client_v2_pattern("/register") | ||
PATTERN = client_v2_pattern("/register*") | ||
|
||
def __init__(self, hs): | ||
super(RegisterRestServlet, self).__init__() | ||
|
@@ -55,6 +55,11 @@ def __init__(self, hs): | |
@defer.inlineCallbacks | ||
def on_POST(self, request): | ||
yield run_on_reactor() | ||
|
||
if '/register/email/requestToken' in request.path: | ||
ret = yield self.onEmailTokenRequest(request) | ||
defer.returnValue(ret) | ||
|
||
body = parse_json_dict_from_request(request) | ||
|
||
# we do basic sanity checks here because the auth layer will store these | ||
|
@@ -209,6 +214,29 @@ def _create_registration_details(self, user_id, token): | |
"home_server": self.hs.hostname, | ||
} | ||
|
||
@defer.inlineCallbacks | ||
def onEmailTokenRequest(self, request): | ||
body = parse_json_dict_from_request(request) | ||
|
||
required = ['id_server', 'client_secret', 'email', 'send_attempt'] | ||
absent = [] | ||
for k in required: | ||
if k not in body: | ||
absent.append(k) | ||
|
||
existingUid = yield self.hs.get_datastore().get_user_id_by_threepid( | ||
'email', body['email'] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should be be accessing keys in the body before checking the |
||
) | ||
|
||
if existingUid is not None: | ||
raise SynapseError(400, "Email is already in use", Codes.THREEPID_IN_USE) | ||
|
||
if len(absent) > 0: | ||
raise SynapseError(400, "Missing params: %r" % absent, Codes.MISSING_PARAM) | ||
|
||
ret = yield self.identity_handler.requestEmailToken(**body) | ||
defer.returnValue((200, ret)) | ||
|
||
|
||
def register_servlets(hs, http_server): | ||
RegisterRestServlet(hs).register(http_server) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
CREATE TABLE IF NOT EXISTS user_threepids2 ( | ||
user_id TEXT NOT NULL, | ||
medium TEXT NOT NULL, | ||
address TEXT NOT NULL, | ||
validated_at BIGINT NOT NULL, | ||
added_at BIGINT NOT NULL, | ||
CONSTRAINT medium_address UNIQUE (medium, address) | ||
); | ||
|
||
INSERT INTO user_threepids2 | ||
SELECT * FROM user_threepids WHERE added_at IN ( | ||
SELECT max(added_at) FROM user_threepids GROUP BY medium, address | ||
) | ||
; | ||
|
||
DROP TABLE user_threepids; | ||
ALTER TABLE user_threepids2 RENAME TO user_threepids; | ||
|
||
CREATE INDEX user_threepids_user_id ON user_threepids(user_id); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this intended? I thought these were regexps. "registerrrrrrrr"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you!