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) }