+ afb_req_fail(request, "bad-request", "missing 'runid'");
+ return;
+ }
+ obj = jbus_call_sj_sync(jbus, method, id);
+ if (interface->verbosity)
+ fprintf(stderr, "(afm-main-plugin) %s(%s) -> %s\n", method, id,
+ obj ? json_object_to_json_string(obj) : "NULL");
+ if (obj == NULL) {
+ afb_req_fail(request, "failed", "framework daemon failure");
+ return;
+ }
+ obj = json_object_get(obj);
+ afb_req_success(request, obj, NULL);
+}
+
+/************************** entries ******************************/
+
+static void runnables(struct afb_req request)
+{
+ embed_call_void(request, _runnables_);
+}
+
+static void detail(struct afb_req request)
+{
+ call_appid(request, _detail_);
+}
+
+static void start(struct afb_req request)
+{
+ struct json_object *obj;
+ const char *id, *mode;
+ char *query;
+ int rc;
+
+ /* get the id */
+ id = afb_req_value(request, _id_);
+ if (id == NULL) {
+ afb_req_fail(request, "bad-request", "missing 'id'");
+ return;
+ }
+ /* get the mode */
+ mode = afb_req_value(request, _mode_);
+ if (mode == NULL || !strcmp(mode, _auto_)) {
+ mode = interface->mode == AFB_MODE_REMOTE ? _remote_ : _local_;
+ }
+
+ /* create the query */
+ rc = asprintf(&query, "{\"id\":\"%s\",\"mode\":\"%s\"}", id, mode);
+ if (rc < 0) {
+ afb_req_fail(request, "server-error", "out of memory");
+ return;
+ }
+
+ /* calls the service */
+ obj = jbus_call_sj_sync(jbus, _start_, query);
+ if (interface->verbosity)
+ fprintf(stderr, "(afm-main-plugin) start(%s) -> %s\n", query,
+ obj ? json_object_to_json_string(obj) : "NULL");
+ free(query);
+
+ /* check status */
+ obj = json_object_get(obj);
+ if (obj == NULL) {
+ afb_req_fail(request, "failed", "framework daemon failure");
+ return;