root/src/noit_rest.h

Revision ce0c8f24f23924ae8bccfbb84992fa8d8d534245, 3.5 kB (checked in by Theo Schlossnagle <jesus@omniti.com>, 4 years ago)

simple static handler, closes #235

  • Property mode set to 100644
Line 
1 /*
2  * Copyright (c) 2007, OmniTI Computer Consulting, Inc.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are
7  * met:
8  *
9  *     * Redistributions of source code must retain the above copyright
10  *       notice, this list of conditions and the following disclaimer.
11  *     * Redistributions in binary form must reproduce the above
12  *       copyright notice, this list of conditions and the following
13  *       disclaimer in the documentation and/or other materials provided
14  *       with the distribution.
15  *     * Neither the name OmniTI Computer Consulting, Inc. nor the names
16  *       of its contributors may be used to endorse or promote products
17  *       derived from this software without specific prior written
18  *       permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32
33 #include "noit_defines.h"
34 #include "noit_listener.h"
35 #include "noit_http.h"
36
37 #ifndef NOIT_REST_H
38 #define NOIT_REST_H
39
40 #define NOIT_CONTROL_GET    0x47455420 /* "GET " */
41 #define NOIT_CONTROL_HEAD   0x48454144 /* "HEAD" */
42 #define NOIT_CONTROL_POST   0x504f5354 /* "POST" */
43 #define NOIT_CONTROL_DELETE 0x44454c45 /* "DELE" */
44 #define NOIT_CONTROL_PUT    0x50555420 /* "PUT " */
45
46 typedef struct noit_http_rest_closure noit_http_rest_closure_t;
47
48 typedef int (*rest_request_handler)(noit_http_rest_closure_t *,
49                                     int npats, char **pats);
50 typedef noit_boolean (*rest_authorize_func_t)(noit_http_rest_closure_t *,
51                                               int npats, char **pats);
52 struct noit_http_rest_closure {
53   noit_http_session_ctx *http_ctx;
54   acceptor_closure_t *ac;
55   char *remote_cn;
56   rest_request_handler fastpath;
57   int nparams;
58   char **params;
59   int wants_shutdown;
60   void *call_closure;
61   void (*call_closure_free)(void *);
62 };
63
64 API_EXPORT(void) noit_http_rest_init();
65
66 API_EXPORT(noit_boolean)
67   noit_http_rest_client_cert_auth(noit_http_rest_closure_t *restc,
68                                   int npats, char **pats);
69
70 API_EXPORT(int)
71   noit_http_rest_register(const char *method, const char *base,
72                           const char *expression, rest_request_handler f);
73
74 API_EXPORT(int)
75   noit_http_rest_register_auth(const char *method, const char *base,
76                                const char *expression, rest_request_handler f,
77                                rest_authorize_func_t auth);
78
79 API_EXPORT(xmlDocPtr)
80   rest_get_xml_upload(noit_http_rest_closure_t *restc,
81                       int *mask, int *complete) ;
82
83 API_EXPORT(void)
84   noit_http_rest_closure_free(noit_http_rest_closure_t *restc);
85
86 API_EXPORT(int)
87   noit_rest_simple_file_handler(noit_http_rest_closure_t *restc,
88                                 int npats, char **pats);
89
90 #endif
Note: See TracBrowser for help on using the browser.