2022-03-29 03:19:33 -04:00
|
|
|
import databasePath from "@lib/get-database-path"
|
2022-03-28 15:13:22 -04:00
|
|
|
import { Sequelize } from "sequelize-typescript"
|
|
|
|
import { SequelizeStorage, Umzug } from "umzug"
|
|
|
|
|
|
|
|
export const sequelize = new Sequelize({
|
|
|
|
dialect: "sqlite",
|
|
|
|
database: "drift",
|
2022-03-29 03:19:33 -04:00
|
|
|
storage: process.env.MEMORY_DB === "true" ? ":memory:" : databasePath,
|
2022-03-28 15:13:22 -04:00
|
|
|
models: [__dirname + "/lib/models"],
|
|
|
|
logging: true
|
|
|
|
})
|
|
|
|
|
2022-03-28 19:19:53 -04:00
|
|
|
if (process.env.MEMORY_DB !== "true") {
|
|
|
|
console.log(`Database path: ${databasePath}`)
|
|
|
|
} else {
|
|
|
|
console.log("Using in-memory database")
|
|
|
|
}
|
|
|
|
|
2022-03-28 15:13:22 -04:00
|
|
|
const umzug = new Umzug({
|
2022-03-29 03:19:33 -04:00
|
|
|
migrations: {
|
|
|
|
glob:
|
|
|
|
process.env.NODE_ENV === "production"
|
|
|
|
? __dirname + "/migrations/*.js"
|
|
|
|
: __dirname + "/migrations/*.ts"
|
|
|
|
},
|
2022-03-28 15:13:22 -04:00
|
|
|
context: sequelize.getQueryInterface(),
|
|
|
|
storage: new SequelizeStorage({ sequelize }),
|
|
|
|
logger: console
|
|
|
|
})
|
|
|
|
|
|
|
|
export type Migration = typeof umzug._types.migration
|
2022-03-29 03:19:33 -04:00
|
|
|
;(async () => {
|
|
|
|
// Checks migrations and run them if they are not already applied. To keep
|
|
|
|
// track of the executed migrations, a table (and sequelize model) called SequelizeMeta
|
|
|
|
// will be automatically created (if it doesn't exist already) and parsed.
|
|
|
|
console.log("Checking migrations...")
|
|
|
|
const migrations = await umzug.up()
|
|
|
|
if (migrations.length > 0) {
|
|
|
|
console.log("Migrations applied:")
|
|
|
|
console.log(migrations)
|
|
|
|
} else {
|
|
|
|
console.log("No migrations applied.")
|
|
|
|
}
|
|
|
|
})()
|