manifold/functions/src/utils.ts

67 lines
1.9 KiB
TypeScript
Raw Normal View History

2021-12-11 00:06:17 +00:00
import * as admin from 'firebase-admin'
import { Contract } from '../../common/contract'
import { User } from '../../common/user'
2021-12-11 00:06:17 +00:00
export const getValue = async <T>(collection: string, doc: string) => {
2022-01-07 00:05:48 +00:00
const snap = await admin.firestore().collection(collection).doc(doc).get()
2021-12-11 00:06:17 +00:00
2022-01-07 00:05:48 +00:00
return snap.exists ? (snap.data() as T) : undefined
}
export const getValues = async <T>(query: admin.firestore.Query) => {
const snap = await query.get()
return snap.docs.map((doc) => doc.data() as T)
2021-12-11 00:06:17 +00:00
}
export const getContract = (contractId: string) => {
return getValue<Contract>('contracts', contractId)
}
export const getUser = (userId: string) => {
return getValue<User>('users', userId)
2022-01-07 00:05:48 +00:00
}
2022-01-10 22:48:48 +00:00
export const getUserByUsername = async (username: string) => {
const snap = await firestore
.collection('users')
.where('username', '==', username)
.get()
return snap.empty ? undefined : (snap.docs[0].data() as User)
}
2022-01-10 22:48:48 +00:00
const firestore = admin.firestore()
const updateUserBalance = (userId: string, delta: number) => {
return firestore.runTransaction(async (transaction) => {
const userDoc = firestore.doc(`users/${userId}`)
const userSnap = await transaction.get(userDoc)
if (!userSnap.exists) return
const user = userSnap.data() as User
const newUserBalance = user.balance + delta
if (newUserBalance < 0)
throw new Error(
`User (${userId}) balance cannot be negative: ${newUserBalance}`
)
transaction.update(userDoc, { balance: newUserBalance })
})
}
export const payUser = (userId: string, payout: number) => {
if (!isFinite(payout) || payout <= 0)
throw new Error('Payout is not positive: ' + payout)
return updateUserBalance(userId, payout)
}
export const chargeUser = (userId: string, charge: number) => {
if (!isFinite(charge) || charge <= 0)
throw new Error('User charge is not positive: ' + charge)
return updateUserBalance(userId, -charge)
}