1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
|
/******************************************************************
* $Id: nanohttp-server.h,v 1.13 2006/02/18 20:14:36 snowdrop Exp $
*
* CSOAP Project: A http client/server library in C
* Copyright (C) 2003 Ferhat Ayaz
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*
* Email: ferhatayaz@yahoo.com
******************************************************************/
#ifndef NANO_HTTP_SERVER_H
#define NANO_HTTP_SERVER_H
#include <nanohttp/nanohttp-common.h>
#include <nanohttp/nanohttp-socket.h>
#include <nanohttp/nanohttp-request.h>
#include <nanohttp/nanohttp-stream.h>
typedef struct httpd_conn
{
hsocket_t sock;
char content_type[25];
http_output_stream_t *out;
hpair_t *header;
} httpd_conn_t;
/*
Service callback
*/
typedef void (*httpd_service) (httpd_conn_t *, hrequest_t *);
typedef int (*httpd_auth) (const char *user, const char *password);
/*
* Service representation object
*/
typedef struct tag_hservice
{
char ctx[255];
httpd_service func;
httpd_auth auth;
struct tag_hservice *next;
} hservice_t;
/*
Begin httpd_* function set
*/
herror_t httpd_init(int argc, char *argv[]);
int httpd_register(const char *ctx, httpd_service service);
int httpd_register_secure(const char *ctx, httpd_service service, httpd_auth auth);
int httpd_register_default(const char *ctx, httpd_service service);
int httpd_register_secure_default(const char *ctx, httpd_service service, httpd_auth auth);
herror_t httpd_run();
void httpd_destroy();
int httpd_get_port(void);
hservice_t *httpd_services();
herror_t httpd_send_header(httpd_conn_t * res, int code, const char *text);
int httpd_set_header(httpd_conn_t * conn, const char *key, const char *value);
void httpd_set_headers(httpd_conn_t * conn, hpair_t * header);
int httpd_add_header(httpd_conn_t * conn, const char *key, const char *value);
void httpd_add_headers(httpd_conn_t * conn, const hpair_t *values);
/*
unsigned char *httpd_get_postdata(httpd_conn_t *conn,
hrequest_t *req, long *received, long max);
*/
/* --------------------------------------------------------------
MIME RELATED FUNCTIONS
---------------------------------------------------------------*/
/*
MIME support httpd_mime_* function set
*/
/**
Begin MIME multipart/related POST
Returns: HSOCKET_OK or error flag
*/
herror_t httpd_mime_send_header(httpd_conn_t * conn,
const char *related_start,
const char *related_start_info,
const char *related_type, int code,
const char *text);
/**
Send boundary and part header and continue
with next part
*/
herror_t httpd_mime_next(httpd_conn_t * conn,
const char *content_id,
const char *content_type,
const char *transfer_encoding);
/**
Send boundary and part header and continue
with next part
*/
herror_t httpd_mime_send_file(httpd_conn_t * conn,
const char *content_id,
const char *content_type,
const char *transfer_encoding,
const char *filename);
/**
Finish MIME request
Returns: HSOCKET_OK or error flag
*/
herror_t httpd_mime_end(httpd_conn_t * conn);
#endif
|