Compare commits

..

No commits in common. "d0e3507cc022a354fbdd9b1cdc30aacd908796b7" and "47e036cde6acf564fd900a403f5b99a5557de2fa" have entirely different histories.

2 changed files with 11 additions and 12 deletions

View File

@ -9,9 +9,12 @@ async function init() {
if(tmp.length === 0){ if(tmp.length === 0){
console.log('No database version info, running initial migration.'); console.log('No database version info, running initial migration.');
await require('./db/0').run(); await require('./db/0').run();
}
await bringUpToDate(); await bringUpToDate();
} }
else {
await bringUpToDate();
}
}
else { else {
console.log('Skipping database version check.'); console.log('Skipping database version check.');
} }
@ -31,19 +34,16 @@ async function init() {
} }
async function bringUpToDate(): Promise<void>{ async function bringUpToDate(): Promise<void>{
var versions: Object[] = JSON.parse(JSON.stringify(await db.query('select * from db_meta'))); //ugh, don't ask var versions: Object[] = await db.query('select * from db_meta');
var scripts: any[] = readdirSync('./src/db/', {withFileTypes: false}); var scripts: Buffer[] | string[] = readdirSync('./src/db/', {withFileTypes: false});
if(scripts.length - versions.length === 0){ var diff: number = scripts.length - versions.length
if(diff === 0){
console.log('No migration needed.'); console.log('No migration needed.');
} else { } else {
console.log('Versions differ, migrating now.'); console.log('Versions differ, migrating now.');
var diff: string[] = scripts.filter(n => { for(let i=0;i<diff;i++){
//we have to use versions.some because {version: 0} === {version: 0} returns false lmao console.log('Migration to version '+Math.floor(scripts.length-(diff-i)));
return !versions.some(o => o['version']+''=== n.substring(0, n.length - 3)) await require('./db/'+scripts[Math.floor(scripts.length-(diff-i))]).run();
});
for(let i=0;i<diff.length;i++){
console.log('Running migration '+diff[i]);
await require('./db/'+diff[i]).run();
} }
console.log('Done migrating database.'); console.log('Done migrating database.');
} }

View File

@ -3,7 +3,6 @@ import {init as clean} from "./cleanup";
import { config } from "./config"; import { config } from "./config";
async function run() { async function run() {
process.argv = process.argv.concat(['--skip-compile']);
await initDB(); await initDB();
await clean(); await clean();
} }