withdraw liquidity: redeem surplus shares, adjust total depostits, adjust amount for current prob, set isLiquidityProvision for surplus bets, error handling

This commit is contained in:
mantikoros 2022-06-09 12:46:47 -05:00
parent 699bddcb2a
commit 3858f8fbea

View File

@ -11,6 +11,7 @@ import { getProbability } from '../../common/calculate'
import { noFees } from '../../common/fees'
import { APIError } from './api'
import { redeemShares } from './redeem-shares'
export const withdrawLiquidity = functions
.runWith({ minInstances: 1 })
@ -28,7 +29,8 @@ export const withdrawLiquidity = functions
if (!contractId)
return { status: 'error', message: 'Missing contract id' }
const result = await firestore.runTransaction(async (trans) => {
return await firestore
.runTransaction(async (trans) => {
const lpDoc = firestore.doc(`users/${userId}`)
const lpSnap = await trans.get(lpDoc)
if (!lpSnap.exists) throw new APIError(400, 'User not found.')
@ -36,7 +38,8 @@ export const withdrawLiquidity = functions
const contractDoc = firestore.doc(`contracts/${contractId}`)
const contractSnap = await trans.get(contractDoc)
if (!contractSnap.exists) throw new APIError(400, 'Contract not found.')
if (!contractSnap.exists)
throw new APIError(400, 'Contract not found.')
const contract = contractSnap.data() as CPMMContract
const liquidityCollection = firestore.collection(
@ -49,13 +52,18 @@ export const withdrawLiquidity = functions
(doc) => doc.data() as LiquidityProvision
)
const userShares = getUserLiquidityShares(userId, contract, liquidities)
const userShares = getUserLiquidityShares(
userId,
contract,
liquidities
)
// zero all added amounts for now
// can add support for partial withdrawals in the future
liquiditiesSnap.docs
.filter(
(_, i) => !liquidities[i].isAnte && liquidities[i].userId === userId
(_, i) =>
!liquidities[i].isAnte && liquidities[i].userId === userId
)
.forEach((doc) => trans.update(doc.ref, { amount: 0 }))
@ -63,7 +71,11 @@ export const withdrawLiquidity = functions
if (payout <= 0) return {}
const newBalance = lp.balance + payout
trans.update(lpDoc, { balance: newBalance })
const newTotalDeposits = lp.totalDeposits + payout
trans.update(lpDoc, {
balance: newBalance,
totalDeposits: newTotalDeposits,
} as Partial<User>)
const newPool = subtractObjects(contract.pool, userShares)
const newTotalLiquidity = contract.totalLiquidity - payout
@ -82,12 +94,14 @@ export const withdrawLiquidity = functions
: ({
userId: userId,
contractId: contract.id,
amount: shares - payout,
amount:
(outcome === 'YES' ? prob : 1 - prob) * (shares - payout),
shares: shares - payout,
outcome,
probBefore: prob,
probAfter: prob,
createdTime: Date.now(),
isLiquidityProvision: true,
fees: noFees,
} as Omit<Bet, 'id'>)
)
@ -102,9 +116,16 @@ export const withdrawLiquidity = functions
return userShares
})
.then(async (result) => {
// redeem surplus bet with pre-existing bets
await redeemShares(userId, contractId)
console.log('userid', userId, 'withdraws', result)
return { status: 'success', userShares: result }
})
.catch((e) => {
return { status: 'error', message: e.message }
})
}
)