overleaf/services/web/migrations/20200729120824_update_subscriptions_manager_ids_index.mjs
Liangjun Song 492fe24a75 Merge pull request #20480 from overleaf/ls-convert-migration-scripts-to-esm
Convert migration scripts to ESM

GitOrigin-RevId: 46f04a1837ebb8244b1156af2d58162d024b6b2d
2024-10-14 10:56:57 +00:00

50 lines
942 B
JavaScript

/* eslint-disable no-unused-vars */
import Helpers from './lib/helpers.mjs'
const tags = ['saas']
const oldIndex = {
unique: true,
key: {
manager_ids: 1,
},
name: 'manager_ids_1',
partialFilterExpression: {
manager_ids: {
$exists: true,
},
},
}
const newIndex = {
key: {
manager_ids: 1,
},
name: 'manager_ids_1',
sparse: true,
}
const migrate = async client => {
const { db } = client
await Helpers.dropIndexesFromCollection(db.subscriptions, [oldIndex])
await Helpers.addIndexesToCollection(db.subscriptions, [newIndex])
}
const rollback = async client => {
const { db } = client
try {
await Helpers.dropIndexesFromCollection(db.subscriptions, [newIndex])
await Helpers.addIndexesToCollection(db.subscriptions, [oldIndex])
} catch (err) {
console.error('Something went wrong rolling back the migrations', err)
}
}
export default {
tags,
migrate,
rollback,
}