mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
feat(core): update migration state after db init
This commit is contained in:
parent
bb4bfd3d41
commit
f904b88f56
3 changed files with 22 additions and 5 deletions
|
@ -8,6 +8,7 @@ import { createPool, parseDsn, sql, stringifyDsn } from 'slonik';
|
|||
import { createInterceptors } from 'slonik-interceptor-preset';
|
||||
import { raw } from 'slonik-sql-tag-raw';
|
||||
|
||||
import { updateDatabaseTimestamp } from '@/migration';
|
||||
import { buildApplicationSecret } from '@/utils/id';
|
||||
|
||||
import { convertToPrimitiveOrSql } from './utils';
|
||||
|
@ -79,6 +80,9 @@ export const createDatabaseCli = async (dsn: string) => {
|
|||
await pool.query(sql`${raw(query)}`);
|
||||
console.log(`${chalk.blue('[create-tables]')} Run ${file} succeeded.`);
|
||||
}
|
||||
|
||||
await updateDatabaseTimestamp(pool);
|
||||
console.log(`${chalk.blue('[create-tables]')} Update migration state succeeded.`);
|
||||
};
|
||||
|
||||
const seedTables = async () => {
|
||||
|
|
|
@ -82,8 +82,7 @@ function createEnvSet() {
|
|||
pool = await createPoolByEnv(values.isTest);
|
||||
await addConnectors(values.connectorDirectory);
|
||||
|
||||
// FIXME: @sijie temparaly disable migration for integration test
|
||||
if (pool && !values.isIntegrationTest) {
|
||||
if (pool) {
|
||||
await checkMigrationState(pool);
|
||||
}
|
||||
},
|
||||
|
|
|
@ -51,13 +51,13 @@ export const createLogtoConfigsTable = async (pool: DatabasePool) => {
|
|||
await pool.query(sql`${raw(tableQuery)}`);
|
||||
};
|
||||
|
||||
export const updateDatabaseTimestamp = async (pool: DatabasePool, timestamp: number) => {
|
||||
export const updateDatabaseTimestamp = async (pool: DatabasePool, timestamp?: number) => {
|
||||
if (!(await isLogtoConfigsTableExists(pool))) {
|
||||
await createLogtoConfigsTable(pool);
|
||||
}
|
||||
|
||||
const value: MigrationState = {
|
||||
timestamp,
|
||||
timestamp: timestamp ?? (await getLatestMigrationTiemstamp()),
|
||||
updatedAt: new Date().toISOString(),
|
||||
};
|
||||
|
||||
|
@ -70,6 +70,18 @@ export const updateDatabaseTimestamp = async (pool: DatabasePool, timestamp: num
|
|||
);
|
||||
};
|
||||
|
||||
export const getLatestMigrationTiemstamp = async () => {
|
||||
const files = await getMigrationFiles();
|
||||
|
||||
const latestFile = files[files.length - 1];
|
||||
|
||||
if (!latestFile) {
|
||||
throw new Error('No migration files found.');
|
||||
}
|
||||
|
||||
return getTimestampFromFileName(latestFile);
|
||||
};
|
||||
|
||||
export const getMigrationFiles = async () => {
|
||||
if (!existsSync(migrationFilesDirectory)) {
|
||||
return [];
|
||||
|
@ -78,7 +90,9 @@ export const getMigrationFiles = async () => {
|
|||
const directory = await readdir(migrationFilesDirectory);
|
||||
const files = directory.filter((file) => migrationFileNameRegex.test(file));
|
||||
|
||||
return files;
|
||||
return files
|
||||
.slice()
|
||||
.sort((file1, file2) => getTimestampFromFileName(file1) - getTimestampFromFileName(file2));
|
||||
};
|
||||
|
||||
export const getUndeployedMigrations = async (pool: DatabasePool) => {
|
||||
|
|
Loading…
Reference in a new issue