- 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 void trapping_handle(AFB_request * request, struct json_object *(*cb)(AFB_request *,void*))
-{
- volatile int signum, 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;
- signum = setjmp(jmpbuf);
- if (signum != 0) {
- afb_req_fail_f(*request->areq, "aborted", "signal %d caught", signum);
- }
- else {
- error_handler = &jmpbuf;
- if (api_timeout > 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 = (pid_t)syscall(SYS_gettid);
-#else
- sevp._sigev_un._tid = (pid_t)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 = api_timeout;
- its.it_value.tv_nsec = 0;
- timer_settime(timerid, 0, &its, NULL);
- }
-
- cb(request, NULL);
- }
- if (timerset)
- timer_delete(timerid);
- error_handler = older;
-}
-
-static void handle(struct afb_req req, const struct api_desc *api, const struct AFB_restapi *verb)
-{
- 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;
- }
- trapping_handle(&request, verb->callback);
-
- 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;