- struct stat st;
- int rc;
-
- rc = stat(path, &st);
- if (rc < 0)
- fprintf(stderr, "Invalid plugin path [%s]: %m\n", path);
- else if (S_ISDIR(st.st_mode))
- rc = afb_apis_add_directory(path);
- else
- rc = afb_apis_add_plugin(path);
- return rc;
-}
-
-int afb_apis_add_pathset(const char *pathset)
-{
- static char sep[] = ":";
- char *ps, *p;
- int rc;
-
- ps = strdupa(pathset);
- for (;;) {
- p = strsep(&ps, sep);
- if (!p)
- return 0;
- rc = afb_apis_add_path(p);
- };
-}
-
-// Check of apiurl is declare in this plugin and call it
-extern __thread sigjmp_buf *error_handler;
-static int callPluginApi(AFB_request * request)
-{
- volatile int status, timerset;
- timer_t timerid;
- sigjmp_buf jmpbuf, *older;
- struct sigevent sevp;
- struct itimerspec its;
-
- // save context before calling the API
- timerset = 0;
- older = error_handler;
- status = setjmp(jmpbuf);
- if (status != 0) {
- status = 0;
- }
- else {
- error_handler = &jmpbuf;
- if (request->config->apiTimeout > 0) {
- timerset = 1; /* TODO: check statuses */
- sevp.sigev_notify = SIGEV_THREAD_ID;
- sevp.sigev_signo = SIGALRM;
-#if defined(sigev_notify_thread_id)
- sevp.sigev_notify_thread_id = syscall(SYS_gettid);
-#else
- sevp._sigev_un._tid = syscall(SYS_gettid);
-#endif
- timer_create(CLOCK_THREAD_CPUTIME_ID, &sevp, &timerid);
- its.it_interval.tv_sec = 0;
- its.it_interval.tv_nsec = 0;
- its.it_value.tv_sec = 15;
- its.it_value.tv_nsec = 0;
- timer_settime(timerid, 0, &its, NULL);
- }
-
- //doCallPluginApi(request, apiidx, verbidx, context);
- status = 1;
- }
- if (timerset)
- timer_delete(timerid);
- error_handler = older;
-
- return status;
-}
-
-static void handle(struct afb_req req, const struct api_desc *api, const struct AFB_restapi *verb)
-{
- json_object *jresp, *jcall, *jreqt;
-
- AFB_request request;
-
- request.uuid = request.url = "fake";
- request.prefix = api->prefix;
- request.method = verb->name;
- request.context = NULL;
- request.restfull = 0;
- request.errcode = 0;
- request.config = NULL;
- request.areq = &req;
-
- switch(verb->session) {
- case AFB_SESSION_CREATE:
- case AFB_SESSION_RENEW:
- /*if (check) new*/
- break;
- case AFB_SESSION_CLOSE:
- case AFB_SESSION_CHECK:
- /*check*/
- break;
- case AFB_SESSION_NONE:
- default:
- break;
- }
- verb->callback(&request, NULL);
-
- if (verb->session == AFB_SESSION_CLOSE)
- /*close*/;
-}
-
-int afb_apis_handle(struct afb_req req, const char *api, size_t lenapi, const char *verb, size_t lenverb)
-{
- int i, j;