Columns
| Column | Type | Size | Nulls | Auto | Default | Children | Parents | Comments | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| text | 2147483647 | null |
|
|
Email адрес (уникальный, используется для входа) |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| password_hash | text | 2147483647 | null |
|
|
Хеш пароля (bcrypt) |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| first_name | text | 2147483647 | √ | null |
|
|
Имя пользователя |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| last_name | text | 2147483647 | √ | null |
|
|
Фамилия пользователя |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| avatar_url | text | 2147483647 | √ | null |
|
|
URL аватара в MinIO |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| totp_secret | text | 2147483647 | √ | null |
|
|
Секретный ключ для TOTP 2FA |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| is_2fa_enabled | bool | 1 | null |
|
|
Флаг включенной двухфакторной аутентификации |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| is_2fa_email_enabled | bool | 1 | null |
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| preferred_2fa_method | text | 2147483647 | √ | null |
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| phone | text | 2147483647 | √ | null |
|
|
Номер телефона |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| preferred_transport | text | 2147483647 | √ | null |
|
|
Предпочитаемая транспортная компания (FK на transport_companies) |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| default_pvz_address | text | 2147483647 | √ | null |
|
|
Адрес ПВЗ по умолчанию |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| pvz_addresses | jsonb | 2147483647 | √ | null |
|
|
JSONB: адреса доставки по транспортным компаниям ({tc_id: {address, is_home_delivery, comment}}) |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| is_active | bool | 1 | null |
|
|
Флаг активности пользователя |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| is_verified | bool | 1 | null |
|
|
Флаг подтвержденного email |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| is_admin | bool | 1 | null |
|
|
Глобальный админ системы (только через БД, нет API) |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| last_login | timestamptz | 35,6 | √ | null |
|
|
Дата последнего входа |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| id | uuid | 2147483647 | null |
|
|
Уникальный идентификатор пользователя (UUID) |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| created_at | timestamptz | 35,6 | now() |
|
|
Дата регистрации |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| updated_at | timestamptz | 35,6 | now() |
|
|
Дата последнего обновления профиля |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| birthday | date | 13 | √ | null |
|
|
Дата рождения пользователя для уведомлений друзьям |
Indexes
| Constraint Name | Type | Sort | Column(s) |
|---|---|---|---|
| users_pkey | Primary key | Asc | id |
| ix_users_created_at | Performance | Asc | created_at |
| ix_users_email | Must be unique | Asc | |
| ix_users_is_active | Performance | Asc | is_active |
| ix_users_preferred_transport | Performance | Asc | preferred_transport |
Check Constraints
| Constraint Name | Constraint |
|---|---|
| chk_users_email_format | (email ~* '^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}$'::text) |
| chk_users_phone_format | ((phone IS NULL) OR (phone ~ '^\+?[0-9\s\-\(\)]+$'::text)) |

