Add userId to bets in API (#530)

* add userid to bets

* allBets -> bets

* revert one

Co-authored-by: wasabipesto <21313833+wasabipesto@users.noreply.github.com>
This commit is contained in:
Marshall Polaris 2022-06-17 00:35:38 -07:00 committed by GitHub
parent 172f14c16f
commit 732a474cc9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 5 additions and 17 deletions

View File

@ -43,7 +43,7 @@ export type ApiAnswer = Answer & {
} }
export type FullMarket = LiteMarket & { export type FullMarket = LiteMarket & {
bets: Exclude<Bet, 'userId'>[] bets: Bet[]
comments: Comment[] comments: Comment[]
answers?: ApiAnswer[] answers?: ApiAnswer[]
} }

View File

@ -1,5 +1,5 @@
import { NextApiRequest, NextApiResponse } from 'next' import { NextApiRequest, NextApiResponse } from 'next'
import { Bet, listAllBets } from 'web/lib/firebase/bets' import { listAllBets } from 'web/lib/firebase/bets'
import { listAllComments } from 'web/lib/firebase/comments' import { listAllComments } from 'web/lib/firebase/comments'
import { getContractFromId } from 'web/lib/firebase/contracts' import { getContractFromId } from 'web/lib/firebase/contracts'
import { applyCorsHeaders, CORS_UNRESTRICTED } from 'web/lib/api/cors' import { applyCorsHeaders, CORS_UNRESTRICTED } from 'web/lib/api/cors'
@ -13,18 +13,12 @@ export default async function handler(
const { id } = req.query const { id } = req.query
const contractId = id as string const contractId = id as string
const [contract, allBets, comments] = await Promise.all([ const [contract, bets, comments] = await Promise.all([
getContractFromId(contractId), getContractFromId(contractId),
listAllBets(contractId), listAllBets(contractId),
listAllComments(contractId), listAllComments(contractId),
]) ])
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const bets = allBets.map(({ userId, ...bet }) => bet) as Exclude<
Bet,
'userId'
>[]
if (!contract) { if (!contract) {
res.status(404).json({ error: 'Contract not found' }) res.status(404).json({ error: 'Contract not found' })
return return

View File

@ -1,6 +1,6 @@
import { NextApiRequest, NextApiResponse } from 'next' import { NextApiRequest, NextApiResponse } from 'next'
import { applyCorsHeaders, CORS_UNRESTRICTED } from 'web/lib/api/cors' import { applyCorsHeaders, CORS_UNRESTRICTED } from 'web/lib/api/cors'
import { Bet, listAllBets } from 'web/lib/firebase/bets' import { listAllBets } from 'web/lib/firebase/bets'
import { listAllComments } from 'web/lib/firebase/comments' import { listAllComments } from 'web/lib/firebase/comments'
import { getContractFromSlug } from 'web/lib/firebase/contracts' import { getContractFromSlug } from 'web/lib/firebase/contracts'
import { FullMarket, ApiError, toFullMarket } from '../_types' import { FullMarket, ApiError, toFullMarket } from '../_types'
@ -19,17 +19,11 @@ export default async function handler(
return return
} }
const [allBets, comments] = await Promise.all([ const [bets, comments] = await Promise.all([
listAllBets(contract.id), listAllBets(contract.id),
listAllComments(contract.id), listAllComments(contract.id),
]) ])
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const bets = allBets.map(({ userId, ...bet }) => bet) as Exclude<
Bet,
'userId'
>[]
// Cache on Vercel edge servers for 2min // Cache on Vercel edge servers for 2min
res.setHeader('Cache-Control', 'max-age=0, s-maxage=120') res.setHeader('Cache-Control', 'max-age=0, s-maxage=120')
return res.status(200).json(toFullMarket(contract, comments, bets)) return res.status(200).json(toFullMarket(contract, comments, bets))