2023-01-19 20:27:01 +08:00
|
|
|
/* init_order = 1 */
|
|
|
|
|
2024-08-06 15:12:47 +08:00
|
|
|
create type users_password_encryption_method as enum ('Argon2i', 'Argon2id', 'Argon2d', 'SHA1', 'SHA256', 'MD5', 'Bcrypt');
|
2021-07-03 19:13:05 +08:00
|
|
|
|
2021-07-02 21:09:08 +08:00
|
|
|
create table users (
|
2023-01-19 20:27:01 +08:00
|
|
|
tenant_id varchar(21) not null
|
|
|
|
references tenants (id) on update cascade on delete cascade,
|
2022-04-18 15:27:58 +08:00
|
|
|
id varchar(12) not null,
|
2023-02-11 14:38:16 +08:00
|
|
|
username varchar(128),
|
|
|
|
primary_email varchar(128),
|
|
|
|
primary_phone varchar(128),
|
2021-07-02 21:09:08 +08:00
|
|
|
password_encrypted varchar(128),
|
2022-02-24 18:01:17 +08:00
|
|
|
password_encryption_method users_password_encryption_method,
|
2022-02-14 16:03:13 +08:00
|
|
|
name varchar(128),
|
2024-03-19 22:51:26 +08:00
|
|
|
/** The URL that points to the user's profile picture. Mapped to OpenID Connect's `picture` claim. */
|
2022-06-17 17:04:04 +08:00
|
|
|
avatar varchar(2048),
|
2024-03-19 22:51:26 +08:00
|
|
|
/** Additional OpenID Connect standard claims that are not included in user's properties. */
|
|
|
|
profile jsonb /* @use UserProfile */ not null default '{}'::jsonb,
|
2022-05-26 17:44:32 +08:00
|
|
|
application_id varchar(21),
|
2022-02-09 12:55:06 +08:00
|
|
|
identities jsonb /* @use Identities */ not null default '{}'::jsonb,
|
2023-04-24 11:11:27 +08:00
|
|
|
custom_data jsonb /* @use JsonObject */ not null default '{}'::jsonb,
|
2023-11-02 16:16:21 +08:00
|
|
|
logto_config jsonb /* @use JsonObject */ not null default '{}'::jsonb,
|
2023-09-15 11:16:47 +08:00
|
|
|
mfa_verifications jsonb /* @use MfaVerifications */ not null default '[]'::jsonb,
|
2022-11-04 10:10:01 +08:00
|
|
|
is_suspended boolean not null default false,
|
2022-05-05 16:22:43 +08:00
|
|
|
last_sign_in_at timestamptz,
|
2022-09-29 15:32:43 +08:00
|
|
|
created_at timestamptz not null default (now()),
|
2024-03-19 22:51:26 +08:00
|
|
|
updated_at timestamptz not null default (now()),
|
2023-02-11 14:38:16 +08:00
|
|
|
primary key (id),
|
|
|
|
constraint users__username
|
|
|
|
unique (tenant_id, username),
|
|
|
|
constraint users__primary_email
|
|
|
|
unique (tenant_id, primary_email),
|
|
|
|
constraint users__primary_phone
|
|
|
|
unique (tenant_id, primary_phone)
|
2021-07-02 21:09:08 +08:00
|
|
|
);
|
2022-09-29 15:32:43 +08:00
|
|
|
|
2023-01-19 20:27:01 +08:00
|
|
|
create index users__id
|
|
|
|
on users (tenant_id, id);
|
|
|
|
|
|
|
|
create index users__name
|
|
|
|
on users (tenant_id, name);
|
2024-03-20 13:16:23 +08:00
|
|
|
|
|
|
|
create trigger set_updated_at
|
|
|
|
before update on users
|
|
|
|
for each row
|
|
|
|
execute procedure set_updated_at();
|