Write script to fix old comments without IDs and user IDs (#680)
This commit is contained in:
parent
64f2dbbe71
commit
6c8c068327
55
functions/src/scripts/backfill-comment-ids.ts
Normal file
55
functions/src/scripts/backfill-comment-ids.ts
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
// We have some old comments without IDs and user IDs. Let's fill them in.
|
||||||
|
// Luckily, this was back when all comments had associated bets, so it's possible
|
||||||
|
// to retrieve the user IDs through the bets.
|
||||||
|
|
||||||
|
import * as admin from 'firebase-admin'
|
||||||
|
import { QueryDocumentSnapshot } from 'firebase-admin/firestore'
|
||||||
|
import { initAdmin } from './script-init'
|
||||||
|
import { log, writeAsync } from '../utils'
|
||||||
|
import { Bet } from '../../../common/bet'
|
||||||
|
|
||||||
|
initAdmin()
|
||||||
|
const firestore = admin.firestore()
|
||||||
|
|
||||||
|
const getUserIdsByCommentId = async (comments: QueryDocumentSnapshot[]) => {
|
||||||
|
const bets = await firestore.collectionGroup('bets').get()
|
||||||
|
log(`Loaded ${bets.size} bets.`)
|
||||||
|
const betsById = Object.fromEntries(
|
||||||
|
bets.docs.map((b) => [b.id, b.data() as Bet])
|
||||||
|
)
|
||||||
|
return Object.fromEntries(
|
||||||
|
comments.map((c) => [c.id, betsById[c.data().betId].userId])
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (require.main === module) {
|
||||||
|
const commentsQuery = firestore.collectionGroup('comments')
|
||||||
|
commentsQuery.get().then(async (commentSnaps) => {
|
||||||
|
log(`Loaded ${commentSnaps.size} comments.`)
|
||||||
|
const needsFilling = commentSnaps.docs.filter((ct) => {
|
||||||
|
return !('id' in ct.data()) || !('userId' in ct.data())
|
||||||
|
})
|
||||||
|
log(`${needsFilling.length} comments need IDs.`)
|
||||||
|
const userIdNeedsFilling = needsFilling.filter((ct) => {
|
||||||
|
return !('userId' in ct.data())
|
||||||
|
})
|
||||||
|
log(`${userIdNeedsFilling.length} comments need user IDs.`)
|
||||||
|
const userIdsByCommentId =
|
||||||
|
userIdNeedsFilling.length > 0
|
||||||
|
? await getUserIdsByCommentId(userIdNeedsFilling)
|
||||||
|
: {}
|
||||||
|
const updates = needsFilling.map((ct) => {
|
||||||
|
const fields: { [k: string]: unknown } = {}
|
||||||
|
if (!ct.data().id) {
|
||||||
|
fields.id = ct.id
|
||||||
|
}
|
||||||
|
if (!ct.data().userId && userIdsByCommentId[ct.id]) {
|
||||||
|
fields.userId = userIdsByCommentId[ct.id]
|
||||||
|
}
|
||||||
|
return { doc: ct.ref, fields }
|
||||||
|
})
|
||||||
|
log(`Updating ${updates.length} comments.`)
|
||||||
|
await writeAsync(firestore, updates)
|
||||||
|
log(`Updated all comments.`)
|
||||||
|
})
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user