Files
overleaf-cep/services/web/scripts/mark_migration.mjs
Brian Gough 729e0f5ac9 move migrations to shared location (#28306)
* fix: correct typedef for Document in helpers.mjs

* add move-migrations codemod

* update migration paths to use shared migrations directory

* move migrations to shared location

* fix: update Dockerfile and docker-compose.ci.yml to include migrations directory

* feat: add migrations tool to workspaces in package.json

* [monorepo] Fix order of docker ignore rules

* [web] remove unused docker ignore file

* [monorepo] replace old references to migrations folder

* [server-ce] copy migrations from new place

* [migrations] Inline web scripts

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [migrations] move three web scripts over

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [migrations] add missing collection

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [migrations] remove lodash dependency

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [migrations] avoid mongodb-legacy dependency

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [monorepo] run migrations from tools/migrations

Co-authored-by: Brian Gough <brian.gough@overleaf.com>

* [migrations] simplify migration for adding gitBridge feature to users

* [monorepo] run migrations from tests in all the services

* [migrations] add Jenkins pipeline for linting/formatting

* [monorepo] fixup running web migrations everywhere

* [monorepo] trigger Jenkins builds on changes to mongo migrations

* [migrations] add Jenkins pipeline for linting/formatting

* [monorepo] build scripts: update devDependencies before deps scanning

* [monorepo] build scripts: formerly depend on tools/migrations

* [monorepo] run eslint on .mjs files

* [migrations] enable more eslint rules and fix all the errors

* [rake] fix migrations:list task

---------

Co-authored-by: Jakob Ackermann <jakob.ackermann@overleaf.com>
GitOrigin-RevId: 14cf69cc1b9405bbc75adbb9a000e555500e0614
2025-10-16 08:07:37 +00:00

71 lines
1.7 KiB
JavaScript

import Adapter from '../../../tools/migrations/lib/adapter.mjs'
import { promises as fs } from 'node:fs'
import { join, dirname } from 'node:path'
import { fileURLToPath } from 'node:url'
const __dirname = dirname(fileURLToPath(import.meta.url))
async function main(args) {
if (
!args ||
args.length === 0 ||
args.includes('help') ||
args.includes('--help') ||
args.includes('-h')
) {
console.log('')
console.log('usage: node ./scripts/mark_migration.mjs migration state')
console.log('')
console.log(' migration: name of migration file')
console.log(' state: executed | unexecuted')
console.log('')
return
}
const migration = args[0]
if (!migration) {
throw new Error('Error: migration must be supplied')
}
const state = args[1]
if (!state) {
throw new Error('Error: migration state must be supplied')
}
try {
await fs.access(join(__dirname, '../migrations', `${migration}.mjs`))
} catch (err) {
throw new Error(
`Error: migration ${migration} does not exist on disk: ${err}`
)
}
console.log(`Marking ${migration} as ${state}`)
process.env.SKIP_TAG_CHECK = 'true'
const adapter = new Adapter()
await adapter.connect()
switch (state) {
case 'executed':
await adapter.markExecuted(migration)
break
case 'unexecuted':
await adapter.unmarkExecuted(migration)
break
default:
throw new Error(`invalid state "${state}"`)
}
console.log('Done')
}
if (fileURLToPath(import.meta.url) === process.argv[1]) {
const args = process.argv.slice(2)
main(args)
.then(() => {
process.exit(0)
})
.catch(err => {
console.error(err)
process.exit(1)
})
}