2022-05-12 15:07:10 +00:00
|
|
|
import * as admin from 'firebase-admin'
|
|
|
|
import { Bet } from '../../common/bet'
|
|
|
|
import { Contract } from '../../common/contract'
|
|
|
|
import { DAY_MS } from '../../common/util/time'
|
|
|
|
import { getValues } from './utils'
|
|
|
|
|
|
|
|
const firestore = admin.firestore()
|
|
|
|
|
|
|
|
export async function getFeedContracts() {
|
|
|
|
// Get contracts bet on or created in last week.
|
|
|
|
const [activeContracts, inactiveContracts] = await Promise.all([
|
|
|
|
getValues<Contract>(
|
|
|
|
firestore
|
|
|
|
.collection('contracts')
|
|
|
|
.where('isResolved', '==', false)
|
|
|
|
.where('volume7Days', '>', 0)
|
|
|
|
),
|
|
|
|
|
|
|
|
getValues<Contract>(
|
|
|
|
firestore
|
|
|
|
.collection('contracts')
|
|
|
|
.where('isResolved', '==', false)
|
|
|
|
.where('createdTime', '>', Date.now() - DAY_MS * 7)
|
|
|
|
.where('volume7Days', '==', 0)
|
|
|
|
),
|
|
|
|
])
|
|
|
|
|
|
|
|
const combined = [...activeContracts, ...inactiveContracts]
|
|
|
|
// Remove closed contracts.
|
|
|
|
return combined.filter((c) => (c.closeTime ?? Infinity) > Date.now())
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function getTaggedContracts(tag: string) {
|
|
|
|
const taggedContracts = await getValues<Contract>(
|
|
|
|
firestore
|
|
|
|
.collection('contracts')
|
|
|
|
.where('isResolved', '==', false)
|
|
|
|
.where('lowercaseTags', 'array-contains', tag.toLowerCase())
|
|
|
|
)
|
|
|
|
|
|
|
|
// Remove closed contracts.
|
|
|
|
return taggedContracts.filter((c) => (c.closeTime ?? Infinity) > Date.now())
|
|
|
|
}
|
|
|
|
|
2022-06-09 22:13:06 +00:00
|
|
|
export async function getRecentBetsAndComments(contractId: string) {
|
|
|
|
const contractDoc = firestore.collection('contracts').doc(contractId)
|
2022-05-12 15:07:10 +00:00
|
|
|
|
|
|
|
const [recentBets, recentComments] = await Promise.all([
|
|
|
|
getValues<Bet>(
|
|
|
|
contractDoc
|
|
|
|
.collection('bets')
|
|
|
|
.where('createdTime', '>', Date.now() - DAY_MS)
|
|
|
|
.orderBy('createdTime', 'desc')
|
|
|
|
.limit(1)
|
|
|
|
),
|
|
|
|
|
|
|
|
getValues<Comment>(
|
|
|
|
contractDoc
|
|
|
|
.collection('comments')
|
|
|
|
.where('createdTime', '>', Date.now() - 3 * DAY_MS)
|
|
|
|
.orderBy('createdTime', 'desc')
|
|
|
|
.limit(3)
|
|
|
|
),
|
|
|
|
])
|
|
|
|
|
|
|
|
return {
|
|
|
|
recentBets,
|
|
|
|
recentComments,
|
|
|
|
}
|
|
|
|
}
|