Files
overleaf/tools/migrations/20190912145032_create_users_indexes.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

171 lines
2.9 KiB
JavaScript

/* eslint-disable no-unused-vars */
import Helpers from './lib/helpers.mjs'
const tags = ['server-ce', 'server-pro', 'saas']
const indexes = [
{
unique: true,
key: {
email: 1,
},
name: 'email_case_insensitive',
collation: {
locale: 'en',
caseLevel: false,
caseFirst: 'off',
strength: 2,
numericOrdering: false,
alternate: 'non-ignorable',
maxVariable: 'punct',
normalization: false,
backwards: false,
version: '57.1',
},
},
{
key: {
'dropbox.access_token.oauth_token_secret': 1,
},
name: 'has dropbox',
},
{
unique: true,
key: {
'overleaf.id': 1,
},
name: 'overleaf.id_1',
partialFilterExpression: {
'overleaf.id': {
$exists: true,
},
},
},
{
unique: true,
key: {
'thirdPartyIdentifiers.externalUserId': 1,
'thirdPartyIdentifiers.providerId': 1,
},
name: 'thirdPartyIdentifiers.externalUserId_1_thirdPartyIdentifiers.providerId_1',
sparse: true,
},
{
key: {
'subscription.freeTrialDowngraded': 1,
},
name: 'subscription.freeTrialDowngraded_1',
},
{
key: {
signUpDate: 1,
},
name: 'signUpDate',
},
{
unique: true,
key: {
'emails.email': 1,
},
name: 'emails_email_1',
partialFilterExpression: {
'emails.email': {
$exists: true,
},
},
},
{
unique: true,
key: {
'emails.email': 1,
},
name: 'emails_email_case_insensitive',
partialFilterExpression: {
'emails.email': {
$exists: true,
},
},
collation: {
locale: 'en',
caseLevel: false,
caseFirst: 'off',
strength: 2,
numericOrdering: false,
alternate: 'non-ignorable',
maxVariable: 'punct',
normalization: false,
backwards: false,
version: '57.1',
},
},
{
unique: true,
key: {
'dropbox.access_token.uid': 1,
},
name: 'dropbox.access_token.uid_unique',
sparse: true,
},
{
key: {
password: 1,
email: 1,
},
name: 'password_and_email',
},
{
key: {
referal_id: 1,
},
name: 'referal_id',
},
{
key: {
'subscription.freeTrialExpiresAt': 1,
},
name: 'subscription.freeTrialExpiresAt_1',
},
{
key: {
auth_token: 1,
},
name: 'auth_token_1',
},
{
unique: true,
key: {
email: 1,
},
name: 'email_1',
},
{
key: {
'emails.reversedHostname': 1,
},
name: 'emails.reversedHostname_1',
},
]
const migrate = async client => {
const { db } = client
await Helpers.addIndexesToCollection(db.users, indexes)
}
const rollback = async client => {
const { db } = client
try {
await Helpers.dropIndexesFromCollection(db.users, indexes)
} catch (err) {
console.error('Something went wrong rolling back the migrations', err)
}
}
export default {
tags,
migrate,
rollback,
}