0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-20 21:32:31 -05:00
logto/packages/schemas
2023-06-28 18:02:10 +08:00
..
alterations fix(schemas): modify domain table unique index (#3954) 2023-06-14 11:12:08 +09:00
src fix(schemas): fix sendgrid email service config (#4093) 2023-06-28 18:02:10 +08:00
tables fix(schemas): modify domain table unique index (#3954) 2023-06-14 11:12:08 +09:00
.gitignore
CHANGELOG.md release: version packages (#3857) 2023-06-06 23:21:29 +08:00
generate.sh
jest.config.js
package.json chore(schemas,phrases): make zod peer dependency (#4050) 2023-06-19 11:21:13 +09:00
README.md
tsconfig.build.alterations.json
tsconfig.build.gen.json
tsconfig.build.json
tsconfig.json
tsconfig.test.json
update-next.sh

@logto/schemas

The central packages for all database schemas and their TypeScript definitions and utilities.

Table init

The Logto CLI will pick up all necessary SQL queries in tables/ and src/models/ and run them in the following order:

  1. Run tables/_before_all.sql
  2. Run tables/*.sql with the snippet /* init_order = <number> */ in ascending order of <number>
  3. Run tables/*.sql without the init_order snippet in ascending order of filename (tables/) or table name (src/models/)
  4. Run tables/_after_all.sql

Additional rules for step 2 and 3:

  • If no snippet /* no_after_each */ found, run tables/_after_each.sql after each SQL file
  • Exclude lifecycle scripts tables/_[lifecycle].sql where [lifecycle] could be one of:
    • after_all
    • after_each
    • before_all

In the after_each lifecycle script, you can use ${name} to represent the current filename (tables/) or table name (src/models/).

In all lifecycle scripts, you can use ${database} to represent the current database.