146b60278c
* wip adding cowboy credits * invite gift paid action * remove balance limit * remove p2p zap withdrawal notifications * credits typedefs * squash migrations * remove wallet limit stuff * CCs in item detail * comments with meCredits * begin including CCs in item stats/notifications * buy credits ui/mutation * fix old /settings/wallets paths * bios don't get sats * fix settings * make invites work with credits * restore migration from master * inform backend of send wallets on zap * satistics header * default receive options to true and squash migrations * fix paidAction query * add nav for credits * fix forever stacked count * ek suggested fixes * fix lint * fix freebies wrt CCs * add back disable freebies * trigger cowboy hat job on CC depletion * fix meMsats+meMcredits * Update api/paidAction/README.md Co-authored-by: ekzyis <ek@stacker.news> * remove expireBoost migration that doesn't work --------- Co-authored-by: ekzyis <ek@stacker.news>
82 lines
2.1 KiB
JavaScript
82 lines
2.1 KiB
JavaScript
import { retryPaidAction } from '../paidAction'
|
|
import { USER_ID } from '@/lib/constants'
|
|
|
|
function paidActionType (actionType) {
|
|
switch (actionType) {
|
|
case 'ITEM_CREATE':
|
|
case 'ITEM_UPDATE':
|
|
return 'ItemPaidAction'
|
|
case 'ZAP':
|
|
case 'DOWN_ZAP':
|
|
case 'BOOST':
|
|
return 'ItemActPaidAction'
|
|
case 'TERRITORY_CREATE':
|
|
case 'TERRITORY_UPDATE':
|
|
case 'TERRITORY_BILLING':
|
|
case 'TERRITORY_UNARCHIVE':
|
|
return 'SubPaidAction'
|
|
case 'DONATE':
|
|
return 'DonatePaidAction'
|
|
case 'POLL_VOTE':
|
|
return 'PollVotePaidAction'
|
|
case 'RECEIVE':
|
|
return 'ReceivePaidAction'
|
|
case 'BUY_CREDITS':
|
|
return 'BuyCreditsPaidAction'
|
|
default:
|
|
throw new Error('Unknown action type')
|
|
}
|
|
}
|
|
|
|
export default {
|
|
Query: {
|
|
paidAction: async (parent, { invoiceId }, { models, me }) => {
|
|
const invoice = await models.invoice.findUnique({
|
|
where: {
|
|
id: invoiceId,
|
|
userId: me?.id ?? USER_ID.anon
|
|
}
|
|
})
|
|
if (!invoice) {
|
|
throw new Error('Invoice not found')
|
|
}
|
|
|
|
return {
|
|
type: paidActionType(invoice.actionType),
|
|
invoice,
|
|
result: invoice.actionResult,
|
|
paymentMethod: invoice.actionOptimistic ? 'OPTIMISTIC' : 'PESSIMISTIC'
|
|
}
|
|
}
|
|
},
|
|
Mutation: {
|
|
retryPaidAction: async (parent, { invoiceId }, { models, me, lnd }) => {
|
|
if (!me) {
|
|
throw new Error('You must be logged in')
|
|
}
|
|
|
|
const invoice = await models.invoice.findUnique({ where: { id: invoiceId, userId: me.id } })
|
|
if (!invoice) {
|
|
throw new Error('Invoice not found')
|
|
}
|
|
|
|
if (invoice.actionState !== 'FAILED') {
|
|
if (invoice.actionState === 'PAID') {
|
|
throw new Error('Invoice is already paid')
|
|
}
|
|
throw new Error(`Invoice is not in failed state: ${invoice.actionState}`)
|
|
}
|
|
|
|
const result = await retryPaidAction(invoice.actionType, { invoice }, { models, me, lnd })
|
|
|
|
return {
|
|
...result,
|
|
type: paidActionType(invoice.actionType)
|
|
}
|
|
}
|
|
},
|
|
PaidAction: {
|
|
__resolveType: obj => obj.type
|
|
}
|
|
}
|