2023-07-20 09:56:28 +02:00
|
|
|
import pkg/metrics
|
2025-02-19 11:18:45 +11:00
|
|
|
import ../../logutils
|
|
|
|
import ../../utils/exceptions
|
2022-09-27 16:27:40 +02:00
|
|
|
import ../statemachine
|
|
|
|
import ./submitted
|
2025-02-19 11:18:45 +11:00
|
|
|
import ./error
|
2022-09-27 16:27:40 +02:00
|
|
|
|
2023-11-03 17:21:54 +02:00
|
|
|
declareCounter(codex_purchases_pending, "codex purchases pending")
|
2023-07-20 09:56:28 +02:00
|
|
|
|
2025-02-19 11:18:45 +11:00
|
|
|
type PurchasePending* = ref object of PurchaseState
|
2022-09-27 16:27:40 +02:00
|
|
|
|
2023-06-05 10:48:06 +02:00
|
|
|
method `$`*(state: PurchasePending): string =
|
2022-11-08 02:10:17 -05:00
|
|
|
"pending"
|
2023-06-05 10:48:06 +02:00
|
|
|
|
2025-02-19 11:18:45 +11:00
|
|
|
method run*(
|
|
|
|
state: PurchasePending, machine: Machine
|
|
|
|
): Future[?State] {.async: (raises: []).} =
|
2023-11-03 17:21:54 +02:00
|
|
|
codex_purchases_pending.inc()
|
2023-06-05 10:48:06 +02:00
|
|
|
let purchase = Purchase(machine)
|
2025-02-19 11:18:45 +11:00
|
|
|
try:
|
|
|
|
let request = !purchase.request
|
|
|
|
await purchase.market.requestStorage(request)
|
|
|
|
return some State(PurchaseSubmitted())
|
|
|
|
except CancelledError as e:
|
|
|
|
trace "PurchasePending.run was cancelled", error = e.msgDetail
|
|
|
|
except CatchableError as e:
|
|
|
|
error "Error during PurchasePending.run", error = e.msgDetail
|
|
|
|
return some State(PurchaseErrored(error: e))
|