2021-05-19 20:09:32 -05:00
|
|
|
const { UserInputError } = require('apollo-server-micro')
|
2021-05-20 12:21:11 -05:00
|
|
|
const retry = require('async-retry')
|
2021-05-19 20:09:32 -05:00
|
|
|
|
|
|
|
async function serialize (models, call) {
|
2021-05-20 14:11:58 -05:00
|
|
|
return await retry(async bail => {
|
2021-05-20 12:21:11 -05:00
|
|
|
try {
|
|
|
|
const [, result] = await models.$transaction([
|
|
|
|
models.$executeRaw(SERIALIZE),
|
|
|
|
call
|
|
|
|
])
|
|
|
|
return result
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error)
|
|
|
|
if (error.message.includes('SN_INSUFFICIENT_FUNDS')) {
|
|
|
|
bail(new UserInputError('insufficient funds'))
|
|
|
|
}
|
|
|
|
if (error.message.includes('SN_NOT_SERIALIZABLE')) {
|
|
|
|
bail(new Error('wallet balance transaction is not serializable'))
|
|
|
|
}
|
2021-07-10 09:16:40 -05:00
|
|
|
if (error.message.includes('SN_CONFIRMED_WITHDRAWL_EXISTS')) {
|
2021-08-19 16:42:21 -05:00
|
|
|
bail(new Error('withdrawal invoice already confirmed (to withdraw again create a new invoice)'))
|
2021-07-10 09:16:40 -05:00
|
|
|
}
|
|
|
|
if (error.message.includes('SN_PENDING_WITHDRAWL_EXISTS')) {
|
2021-08-19 16:42:21 -05:00
|
|
|
bail(new Error('withdrawal invoice exists and is pending'))
|
2021-07-10 09:16:40 -05:00
|
|
|
}
|
2021-05-20 12:21:11 -05:00
|
|
|
if (error.message.includes('40001')) {
|
|
|
|
throw new Error('wallet balance serialization failure - retry again')
|
|
|
|
}
|
|
|
|
bail(error)
|
2021-05-19 20:09:32 -05:00
|
|
|
}
|
2021-05-20 12:21:11 -05:00
|
|
|
}, {
|
|
|
|
minTimeout: 100,
|
|
|
|
factor: 1.1,
|
|
|
|
retries: 5
|
|
|
|
})
|
2021-05-19 20:09:32 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
const SERIALIZE = 'SET TRANSACTION ISOLATION LEVEL SERIALIZABLE'
|
|
|
|
|
|
|
|
module.exports = serialize
|