summaryrefslogtreecommitdiffhomepage
path: root/lib
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@nbd.name>2025-01-01 15:19:48 +0100
committerFelix Fietkau <nbd@nbd.name>2025-02-04 18:26:04 +0100
commit9da8b8aa4ad0ff12bc150892965cedf1a507064d (patch)
treee1d7b5accf196d4118d6bc72215fff37feae75f8 /lib
parentf0e865fe3dddb4c6681c7f5be25438f1d0f4ae68 (diff)
ubus: add defer.await() method
This can be used to synchronously complete a deferred ubus request, waiting for completion or timeout. Signed-off-by: Felix Fietkau <nbd@nbd.name>
Diffstat (limited to 'lib')
-rw-r--r--lib/ubus.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/ubus.c b/lib/ubus.c
index 78838f1..b49a134 100644
--- a/lib/ubus.c
+++ b/lib/ubus.c
@@ -1981,6 +1981,29 @@ uc_ubus_defer_completed(uc_vm_t *vm, size_t nargs)
}
static uc_value_t *
+uc_ubus_defer_await(uc_vm_t *vm, size_t nargs)
+{
+ uc_ubus_deferred_t *d = uc_fn_thisval("ubus.deferred");
+ int64_t remaining;
+
+ if (!d)
+ err_return(UBUS_STATUS_INVALID_ARGUMENT, "Invalid deferred context");
+
+ if (d->complete)
+ ok_return(ucv_boolean_new(false));
+
+#ifdef HAVE_ULOOP_TIMEOUT_REMAINING64
+ remaining = uloop_timeout_remaining64(&d->timeout);
+#else
+ remaining = uloop_timeout_remaining(&d->timeout);
+#endif
+
+ ubus_complete_request(d->ctx, &d->request, remaining);
+
+ ok_return(ucv_boolean_new(true));
+}
+
+static uc_value_t *
uc_ubus_defer_abort(uc_vm_t *vm, size_t nargs)
{
uc_ubus_deferred_t **d = uc_fn_this("ubus.deferred");
@@ -2026,6 +2049,7 @@ static const uc_function_list_t conn_fns[] = {
};
static const uc_function_list_t defer_fns[] = {
+ { "await", uc_ubus_defer_await },
{ "completed", uc_ubus_defer_completed },
{ "abort", uc_ubus_defer_abort },
};