manifold/web/lib/firebase/api-call.ts
2022-06-04 15:19:46 -07:00

55 lines
1.6 KiB
TypeScript

import { auth } from './users'
import { FIREBASE_CONFIG } from 'common/envs/constants'
export class APIError extends Error {
code: number
constructor(code: number, message: string) {
super(message)
this.code = code
this.name = 'APIError'
}
}
export async function call(url: string, method: string, params: any) {
const user = auth.currentUser
if (user == null) {
throw new Error('Must be signed in to make API calls.')
}
const token = await user.getIdToken()
const req = new Request(url, {
headers: {
Authorization: `Bearer ${token}`,
'Content-Type': 'application/json',
},
method: method,
body: JSON.stringify(params),
})
return await fetch(req).then(async (resp) => {
const json = (await resp.json()) as { [k: string]: any }
if (!resp.ok) {
throw new APIError(resp.status, json?.message)
}
return json
})
}
// Our users access the API through the Vercel proxy routes at /api/v0/blah,
// but right now at least until we get performance under control let's have the
// app just hit the cloud functions directly -- there's no difference and it's
// one less hop
export function getFunctionUrl(name: string) {
const { projectId, region } = FIREBASE_CONFIG
return process.env.NEXT_PUBLIC_FIREBASE_EMULATE
? `http://localhost:5001/${projectId}/${region}/${name}`
: `https://${region}-${projectId}.cloudfunctions.net/${name}`
}
export function createContract(params: any) {
return call(getFunctionUrl('createContract'), 'POST', params)
}
export function placeBet(params: any) {
return call(getFunctionUrl('placeBet'), 'POST', params)
}