0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2024-12-16 20:26:19 -05:00
logto/packages/schemas/alterations/1.0.0_beta.11-1664462389-correct-user-created-at-column-by-user-logs.ts
2024-03-16 19:04:55 +08:00

25 lines
770 B
TypeScript

import { sql } from '@silverhand/slonik';
import type { AlterationScript } from '../lib/types/alteration.js';
const alteration: AlterationScript = {
up: async (pool) => {
await pool.query(sql`
update users
set created_at = user_logs.registered_at
from (
select logs.payload ->> 'userId' as user_id, max(logs.created_at) as registered_at
from logs
where logs.type in ('RegisterUsernamePassword', 'RegisterEmail', 'RegisterSms', 'RegisterSocial')
and logs.payload ->> 'result' = 'Success'
group by logs.payload ->> 'userId'
) as user_logs
where users.id = user_logs.user_id;
`);
},
down: async (pool) => {
// It cannot be reverted automatically.
},
};
export default alteration;