Viewing file: demo2.c (1.59 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* * demo2.c: sample event-driven module. */
#include <unistd.h>
#include "tuxmodule.h"
#ifdef TUXAPI_declare TUXAPI_declare; #endif
#define REPLY_HEADER "HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n" #define REPLY_HEADER_LEN (sizeof(REPLY_HEADER)-1) #define QUERY_ERROR "no query string.\n" #define QUERY_ERROR_LEN (sizeof(QUERY_ERROR)-1) #define ERROR "GET_OBJECT error.\n" #define ERROR_LEN (sizeof(ERROR)-1)
int TUXAPI_handle_events (user_req_t *req) { int ret = TUX_RETURN_USERSPACE_REQUEST;
switch (req->event) { /* * A new request starts with event code 0. */ case 0: /* * Using write() within a 'good' TUX module * is incorrect, use SEND_BUFFER instead * (see demo5.c), because simple write() can * block indefinitely. We use write() here to * simplify the example. */ write (req->sock, REPLY_HEADER, REPLY_HEADER_LEN); req->http_status = 200; if (!req->query[0]) { write (req->sock, QUERY_ERROR, QUERY_ERROR_LEN); goto abort; }
/* * set req->objectname is to the requested object * in the query string. This simulates * simple static GETs. */ strcpy(req->objectname, req->query);
req->event = 1; ret = tux(TUX_ACTION_GET_OBJECT, req); if (ret < 0 || req->error) { write (req->sock, ERROR, ERROR_LEN); goto abort; } break;
case 1: if (req->error) { write (req->sock, ERROR, ERROR_LEN); goto abort; } req->event = 2; ret = tux(TUX_ACTION_SEND_OBJECT, req); break;
case 2: abort: ret = tux(TUX_ACTION_FINISH_CLOSE_REQ, req); break; } return ret; }
|