-
Notifications
You must be signed in to change notification settings - Fork 29
/
ureq.h
89 lines (79 loc) · 2.46 KB
/
ureq.h
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
/*
* https://github.com/solusipse/ureq
*
* The MIT License (MIT)
*
* Copyright (c) 2015-2016 solusipse
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#ifndef UREQ_H
#define UREQ_H
#include "include/ureq_defines.h"
#include "include/ureq_http_types.h"
/**
* @brief: Register a function into the system that maps to a url with
* the corresponding http method
*
* @url: URL to associate with the specified function
* @func: Function to register into the system that maps to the url
* @method: HTTP method
*/
void ureq_serve(char *url, char *(*func)(HttpRequest*), char *method);
/**
* @brief: Retrieve an object from the system containing information
* about the request
*
* @req: Character input stream containing the request
*
* @return: An object representing an HTTP request message
*/
HttpRequest ureq_init(const char *req);
/**
* @brief: Process the request
*
* @req: Object containing information about the request message
*
* @see: ureq_init
*/
int ureq_run(HttpRequest *req);
/**
* @brief: Clean up system resources associated with the object
*
* @req: Processed HTTP request object
*
* @see: ureq_run
*/
void ureq_close(HttpRequest *req);
/**
* @brief: Shutdown the system to allow cleanup
*/
void ureq_finish();
/**
* @brief:
*
* @req:
*
* @dst:
*
* @cnt:
*/
void ureq_template(HttpRequest *req, char *dst, char *cnt);
#include "include/ureq_core.h"
#endif