Only redirect on multiple polls

This commit is contained in:
ekzyis 2023-11-09 04:25:20 +01:00
parent 9b33690494
commit c4f70015d5
1 changed files with 15 additions and 8 deletions

View File

@ -2,7 +2,7 @@
<div class="flex flex-col"> <div class="flex flex-col">
<router-link v-if="success" :to="callbackUrl" class="label success font-mono"> <router-link v-if="success" :to="callbackUrl" class="label success font-mono">
<div>Paid</div> <div>Paid</div>
<small>Redirecting in {{ redirectTimeout }} ...</small> <small v-if="redirectTimeout > 0">Redirecting in {{ redirectTimeout }} ...</small>
</router-link> </router-link>
<div class="font-mono my-3"> <div class="font-mono my-3">
Payment Required Payment Required
@ -60,21 +60,27 @@ import { useRoute, useRouter } from 'vue-router'
const router = useRouter() const router = useRouter()
const route = useRoute() const route = useRoute()
// TODO validate callback url // TODO validate callback url
const callbackUrl = route.params.callbackUrl ?? '/' const callbackUrl = ref('/')
let pollCount = 0
const INVOICE_POLL = 2000 const INVOICE_POLL = 2000
const poll = async () => { const poll = async () => {
pollCount++
const url = window.origin + '/api/invoice/' + route.params.id const url = window.origin + '/api/invoice/' + route.params.id
const res = await fetch(url) const res = await fetch(url)
const body = await res.json() const body = await res.json()
if (body.ConfirmedAt) { if (body.ConfirmedAt) {
success.value = true success.value = true
clearInterval(interval) clearInterval(interval)
if (pollCount > 1) {
// only redirect if the invoice was not immediately paid
setInterval(() => { setInterval(() => {
if (--redirectTimeout.value === 0) { if (--redirectTimeout.value === 0) {
router.push(callbackUrl) router.push(callbackUrl.value)
} }
}, 1000) }, 1000)
} else {
redirectTimeout.value = -1
}
} }
} }
@ -108,6 +114,7 @@ await (async () => {
if (marketId) { if (marketId) {
body.DescriptionMarketId = marketId body.DescriptionMarketId = marketId
body.Description = body.Description.replace(regexp, '') body.Description = body.Description.replace(regexp, '')
callbackUrl.value = '/market/' + marketId
} }
} }
invoice.value = body invoice.value = body