48 #define PRINTF(...) printf(__VA_ARGS__)
49 #define PRINT6ADDR(addr) PRINTF("[%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x]", ((uint8_t *)addr)[0], ((uint8_t *)addr)[1], ((uint8_t *)addr)[2], ((uint8_t *)addr)[3], ((uint8_t *)addr)[4], ((uint8_t *)addr)[5], ((uint8_t *)addr)[6], ((uint8_t *)addr)[7], ((uint8_t *)addr)[8], ((uint8_t *)addr)[9], ((uint8_t *)addr)[10], ((uint8_t *)addr)[11], ((uint8_t *)addr)[12], ((uint8_t *)addr)[13], ((uint8_t *)addr)[14], ((uint8_t *)addr)[15])
50 #define PRINTLLADDR(lladdr) PRINTF("[%02x:%02x:%02x:%02x:%02x:%02x]", (lladdr)->addr[0], (lladdr)->addr[1], (lladdr)->addr[2], (lladdr)->addr[3], (lladdr)->addr[4], (lladdr)->addr[5])
53 #define PRINT6ADDR(addr)
54 #define PRINTLLADDR(addr)
57 PROCESS(rest_engine_process,
"REST Engine");
59 LIST(restful_services);
60 LIST(restful_periodic_services);
75 REST.set_service_callback(rest_invoke_restful_service);
97 list_add(restful_services, resource);
99 PRINTF(
"Activating: %s\n", resource->url);
102 if(resource->flags & IS_PERIODIC && resource->periodic->periodic_handler
103 && resource->periodic->period) {
104 PRINTF(
"Periodic resource: %p (%s)\n", resource->periodic,
105 resource->periodic->resource->url);
106 list_add(restful_periodic_services, resource->periodic);
115 return restful_services;
119 rest_invoke_restful_service(
void *request,
void *response, uint8_t *buffer,
120 uint16_t buffer_size, int32_t *offset)
125 resource_t *resource =
NULL;
126 const char *url =
NULL;
128 for(resource = (resource_t *)
list_head(restful_services);
129 resource; resource = resource->next) {
132 if((REST.get_url(request, &url) == strlen(resource->url)
133 || (REST.get_url(request, &url) > strlen(resource->url)
134 && (resource->flags & HAS_SUB_RESOURCES)))
135 && strncmp(resource->url, url, strlen(resource->url)) == 0) {
139 PRINTF(
"/%s, method %u, resource->flags %u\n", resource->url,
140 (uint16_t)method, resource->flags);
142 if((method & METHOD_GET) && resource->get_handler !=
NULL) {
144 resource->get_handler(request, response, buffer, buffer_size, offset);
145 }
else if((method & METHOD_POST) && resource->post_handler !=
NULL) {
147 resource->post_handler(request, response, buffer, buffer_size,
149 }
else if((method & METHOD_PUT) && resource->put_handler !=
NULL) {
151 resource->put_handler(request, response, buffer, buffer_size, offset);
152 }
else if((method & METHOD_DELETE) && resource->delete_handler !=
NULL) {
154 resource->delete_handler(request, response, buffer, buffer_size,
158 REST.set_response_status(response, REST.status.METHOD_NOT_ALLOWED);
164 REST.set_response_status(response, REST.status.NOT_FOUND);
167 if(resource->flags & IS_OBSERVABLE) {
168 REST.subscription_handler(resource, request, response);
171 return found & allowed;
182 periodic_resource_t *periodic_resource =
NULL;
184 for(periodic_resource =
185 (periodic_resource_t *)
list_head(restful_periodic_services);
186 periodic_resource; periodic_resource = periodic_resource->next) {
187 if(periodic_resource->periodic_handler && periodic_resource->period) {
188 PRINTF(
"Periodic: Set timer for /%s to %lu\n",
189 periodic_resource->resource->url, periodic_resource->period);
190 etimer_set(&periodic_resource->periodic_timer,
191 periodic_resource->period);
197 if(ev == PROCESS_EVENT_TIMER) {
198 for(periodic_resource =
199 (periodic_resource_t *)
list_head(restful_periodic_services);
200 periodic_resource; periodic_resource = periodic_resource->next) {
201 if(periodic_resource->period
204 PRINTF(
"Periodic: etimer expired for /%s (period: %lu)\n",
205 periodic_resource->resource->url, periodic_resource->period);
208 (periodic_resource->periodic_handler)();
int etimer_expired(struct etimer *et)
Check if an event timer has expired.
list_t rest_get_resources(void)
Returns the list of registered RESTful resources.
rest_resource_flags_t
Resource flags for allowed methods and special functionalities.
#define PROCESS_BEGIN()
Define the beginning of a process.
void ** list_t
The linked list type.
An abstraction layer for RESTful Web services (Erbium).
#define NULL
The null pointer.
#define PROCESS_THREAD(name, ev, data)
Define the body of a process.
#define PROCESS_END()
Define the end of a process.
void list_init(list_t list)
Initialize a list.
void rest_activate_resource(resource_t *resource, char *path)
Makes a resource available under the given URI path.
void * list_head(list_t list)
Get a pointer to the first element of a list.
#define PROCESS_PAUSE()
Yield the process for a short while.
void list_add(list_t list, void *item)
Add an item at the end of a list.
#define PROCESS_WAIT_EVENT()
Wait for an event to be posted to the process.
#define PROCESS(name, strname)
Declare a process.
#define LIST(name)
Declare a linked list.
void etimer_reset(struct etimer *et)
Reset an event timer with the same interval as was previously set.
void process_start(struct process *p, process_data_t data)
Start a process.
void etimer_set(struct etimer *et, clock_time_t interval)
Set an event timer.
void rest_init_engine(void)
Initializes and starts the REST Engine process.