2024-05-22 17:26:02 +02:00
|
|
|
WITH auth_methods AS (
|
|
|
|
SELECT
|
|
|
|
user_id
|
|
|
|
, method_type
|
|
|
|
, token_id
|
|
|
|
, state
|
|
|
|
, instance_id
|
|
|
|
, name
|
|
|
|
FROM
|
2024-10-10 18:50:53 +02:00
|
|
|
projections.user_auth_methods5
|
2024-05-22 17:26:02 +02:00
|
|
|
WHERE
|
|
|
|
instance_id = $1
|
|
|
|
AND user_id = $2
|
|
|
|
),
|
|
|
|
verified_auth_methods AS (
|
|
|
|
SELECT
|
|
|
|
method_type
|
|
|
|
FROM
|
|
|
|
auth_methods
|
|
|
|
WHERE state = 2
|
|
|
|
)
|
|
|
|
SELECT
|
|
|
|
u.id
|
|
|
|
, u.creation_date
|
|
|
|
, LEAST(u.change_date, au.change_date) AS change_date
|
|
|
|
, u.resource_owner
|
|
|
|
, u.state AS user_state
|
|
|
|
, au.password_set
|
|
|
|
, h.password_change_required
|
|
|
|
, au.password_change
|
|
|
|
, au.last_login
|
|
|
|
, u.username AS user_name
|
|
|
|
, (SELECT array_agg(ll.login_name) login_names FROM projections.login_names3 ll
|
|
|
|
WHERE u.instance_id = ll.instance_id AND u.id = ll.user_id
|
|
|
|
GROUP BY ll.user_id, ll.instance_id) AS login_names
|
2024-05-29 17:45:46 +02:00
|
|
|
, l.login_name as preferred_login_name
|
2024-05-22 17:26:02 +02:00
|
|
|
, h.first_name
|
|
|
|
, h.last_name
|
|
|
|
, h.nick_name
|
|
|
|
, h.display_name
|
|
|
|
, h.preferred_language
|
|
|
|
, h.gender
|
|
|
|
, h.email
|
|
|
|
, h.is_email_verified
|
|
|
|
, h.phone
|
|
|
|
, h.is_phone_verified
|
|
|
|
, (SELECT COALESCE((SELECT state FROM auth_methods WHERE method_type = 1), 0)) AS otp_state
|
|
|
|
, CASE
|
|
|
|
WHEN EXISTS (SELECT true FROM verified_auth_methods WHERE method_type = 3) THEN 2
|
|
|
|
WHEN EXISTS (SELECT true FROM verified_auth_methods WHERE method_type = 2) THEN 1
|
|
|
|
ELSE 0
|
|
|
|
END AS mfa_max_set_up
|
|
|
|
, au.mfa_init_skipped
|
|
|
|
, u.sequence
|
|
|
|
, au.init_required
|
|
|
|
, au.username_change_required
|
|
|
|
, m.name AS machine_name
|
|
|
|
, m.description AS machine_description
|
|
|
|
, u.type AS user_type
|
|
|
|
, (SELECT
|
|
|
|
JSONB_AGG(json_build_object('webAuthNTokenId', token_id, 'webAuthNTokenName', name, 'state', state))
|
|
|
|
FROM auth_methods
|
|
|
|
WHERE method_type = 2
|
|
|
|
) AS u2f_tokens
|
|
|
|
, (SELECT
|
|
|
|
JSONB_AGG(json_build_object('webAuthNTokenId', token_id, 'webAuthNTokenName', name, 'state', state))
|
|
|
|
FROM auth_methods
|
|
|
|
WHERE method_type = 3
|
|
|
|
) AS passwordless_tokens
|
|
|
|
, h.avatar_key
|
|
|
|
, au.passwordless_init_required
|
|
|
|
, au.password_init_required
|
|
|
|
, u.instance_id
|
|
|
|
, (SELECT EXISTS (SELECT true FROM verified_auth_methods WHERE method_type = 6)) AS otp_sms_added
|
|
|
|
, (SELECT EXISTS (SELECT true FROM verified_auth_methods WHERE method_type = 7)) AS otp_email_added
|
2024-06-18 13:27:44 +02:00
|
|
|
FROM projections.users13 u
|
|
|
|
LEFT JOIN projections.users13_humans h
|
2024-05-22 17:26:02 +02:00
|
|
|
ON u.instance_id = h.instance_id
|
|
|
|
AND u.id = h.user_id
|
|
|
|
LEFT JOIN projections.login_names3 l
|
|
|
|
ON u.instance_id = l.instance_id
|
|
|
|
AND u.id = l.user_id
|
|
|
|
AND l.is_primary = true
|
2024-06-18 13:27:44 +02:00
|
|
|
LEFT JOIN projections.users13_machines m
|
2024-05-22 17:26:02 +02:00
|
|
|
ON u.instance_id = m.instance_id
|
|
|
|
AND u.id = m.user_id
|
|
|
|
LEFT JOIN auth.users3 au
|
|
|
|
ON u.instance_id = au.instance_id
|
|
|
|
AND u.id = au.id
|
|
|
|
WHERE
|
|
|
|
u.instance_id = $1
|
|
|
|
AND u.id = $2
|
|
|
|
LIMIT 1;
|