0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-13 21:30:30 -05:00
logto/packages/schemas/tables/users.sql

47 lines
1.7 KiB
MySQL
Raw Normal View History

2023-01-19 20:27:01 +08:00
/* init_order = 1 */
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,
id varchar(12) not null,
username varchar(128),
primary_email varchar(128),
primary_phone varchar(128),
2021-07-02 21:09:08 +08:00
password_encrypted varchar(128),
password_encryption_method users_password_encryption_method,
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. */
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,
application_id varchar(21),
2022-02-09 12:55:06 +08:00
identities jsonb /* @use Identities */ not null default '{}'::jsonb,
custom_data jsonb /* @use JsonObject */ not null default '{}'::jsonb,
logto_config jsonb /* @use JsonObject */ not null default '{}'::jsonb,
mfa_verifications jsonb /* @use MfaVerifications */ not null default '[]'::jsonb,
is_suspended boolean not null default false,
last_sign_in_at timestamptz,
created_at timestamptz not null default (now()),
2024-03-19 22:51:26 +08:00
updated_at timestamptz not null default (now()),
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
);
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);
create trigger set_updated_at
before update on users
for each row
execute procedure set_updated_at();