+static int ubus_lua_defer_request(lua_State *L)
+{
+ struct ubus_lua_connection *c = luaL_checkudata(L, 1, METANAME);
+ struct ubus_request_data *req = lua_touserdata(L, 2);
+ struct ubus_request_data *new_req = lua_newuserdata(L, sizeof(struct ubus_request_data));
+ ubus_defer_request(c->ctx, req, new_req);
+
+ return 1;
+}
+
+static int ubus_lua_complete_deferred_request(lua_State *L)
+{
+ struct ubus_lua_connection *c = luaL_checkudata(L, 1, METANAME);
+ struct ubus_request_data *req = lua_touserdata(L, 2);
+ int ret = luaL_checkinteger(L, 3);
+ ubus_complete_deferred_request(c->ctx, req, ret);
+
+ return 0;
+}
+