mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-25 08:12:40 +01:00
2a0af8e299
Summary: Ref T7152. This builds the core of email invites and implements all the hard logic for them, covering it with a pile of tests. There's no UI to create these yet, so users can't actually get invites (and administrators can't send them). This stuff is a complicated mess because there are so many interactions between accounts, email addresses, email verification, email primary-ness, and user verification. However, I think I got it right and got test coverage everwhere. The degree to which this is exception-driven is a little icky, but I think it's a reasonable way to get the testability we want while still making it hard for callers to get the flow wrong. In particular, I expect there to be at least two callers (one invite flow in the upstream, and one derived invite flow in Instances) so I believe there is merit in burying as much of this logic inside the Engine as is reasonably possible. Test Plan: Unit tests only. Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T7152 Differential Revision: https://secure.phabricator.com/D11723
11 lines
478 B
SQL
11 lines
478 B
SQL
CREATE TABLE {$NAMESPACE}_user.user_authinvite (
|
|
id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
|
authorPHID VARBINARY(64) NOT NULL,
|
|
emailAddress VARCHAR(128) NOT NULL COLLATE {$COLLATE_SORT},
|
|
verificationHash BINARY(12) NOT NULL,
|
|
acceptedByPHID VARBINARY(64),
|
|
dateCreated INT UNSIGNED NOT NULL,
|
|
dateModified INT UNSIGNED NOT NULL,
|
|
UNIQUE KEY `key_address` (emailAddress),
|
|
UNIQUE KEY `key_code` (verificationHash)
|
|
) ENGINE=InnoDB, COLLATE {$COLLATE_TEXT};
|