aboutsummaryrefslogtreecommitdiff
path: root/examples/echo.c
diff options
context:
space:
mode:
Diffstat (limited to 'examples/echo.c')
-rw-r--r--examples/echo.c99
1 files changed, 43 insertions, 56 deletions
diff --git a/examples/echo.c b/examples/echo.c
index 16e9d56..95219fc 100644
--- a/examples/echo.c
+++ b/examples/echo.c
@@ -2,6 +2,7 @@
#include <cookie.h>
#include <param.h>
#include <request.h>
+#include <response.h>
#include <stdio.h>
#include <stdlib.h>
@@ -9,94 +10,75 @@
void proceed_cookies(struct magi_cookie_list * cookies,
struct magi_response * response)
{
- magi_response_content(response, "<h2>Cookies:</h2>");
+ magi_response_add(response, "<h2>Cookies:</h2>");
while (cookies) {
- magi_response_content(response, "Cookie with name [");
- magi_response_content(response, cookies->item.name);
+ magi_response_add(response, "Cookie with name [");
+ magi_response_add(response, cookies->item.name);
if (cookies->item.data) {
- magi_response_content(response, "] is [");
- magi_response_content(response, cookies->item.data);
+ magi_response_add(response, "] is [");
+ magi_response_add(response, cookies->item.data);
}
if (cookies->item.domain) {
- magi_response_content(response, "] for domain [");
- magi_response_content(response, cookies->item.domain);
+ magi_response_add(response, "] for domain [");
+ magi_response_add(response, cookies->item.domain);
}
if (cookies->item.port) {
- magi_response_content(response, "] for port [");
- magi_response_content(response, cookies->item.port);
+ magi_response_add(response, "] for port [");
+ magi_response_add(response, cookies->item.port);
}
if (cookies->item.path) {
- magi_response_content(response, "] for path [");
- magi_response_content(response, cookies->item.path);
+ magi_response_add(response, "] for path [");
+ magi_response_add(response, cookies->item.path);
}
- magi_response_content(response, "]<br/>");
+ magi_response_add(response, "]<br/>");
cookies = cookies->next;
}
- magi_response_content(response, "<hr/>");
-}
-
-void proceed_fields(struct magi_field_list * fields,
- struct magi_response * response)
-{
- magi_response_content(response, "<h2>Feilds:</h2>");
- while (fields) {
- magi_response_content(response, "Feild [");
- magi_response_content(response, fields->item.name);
- magi_response_content(response, "] = [");
- magi_response_content(response, fields->item.data);
- magi_response_content(response, "]<br/>");
- fields = fields->next;
- }
- magi_response_content(response, "<hr/>");
+ magi_response_add(response, "<hr/>");
}
void proceed_params(struct magi_param_list * params,
struct magi_response * response)
{
- magi_response_content(response, "<h2>HTTP Parameters:</h2>");
while (params) {
- magi_response_content(response, "Param [");
- magi_response_content(response, params->item.name);
- magi_response_content(response, "] is [");
- magi_response_content(response, params->item.data);
- magi_response_content(response, "]<br/>");
+ magi_response_add_format(response, "[%s] is [%s]<br/>",
+ params->item.name, params->item.data);
params = params->next;
}
- magi_response_content(response, "<hr/>");
+ magi_response_add(response, "<hr/>");
}
void process_meta(struct magi_request * req, struct magi_response * res)
{
- magi_response_content(res, "<h1>Echo CGI Script</h1>"
- "I was called with method [");
- magi_response_content(res, req->method);
+ magi_response_add(res,
+ "<h1>Echo CGI Script</h1>I was called with method [%s",
+ req->method);
if (req->uri) {
- magi_response_content(res, "] with URL [");
- magi_response_content(res, req->uri);
+ magi_response_add(res, "] with URL [");
+ magi_response_add(res, req->uri);
}
if (req->server_name) {
- magi_response_content(res, "] for server [");
- magi_response_content(res, req->server_name);
+ magi_response_add(res, "] for server [");
+ magi_response_add(res, req->server_name);
}
if (req->server_port) {
- magi_response_content(res, "] on port [");
- magi_response_content(res, req->server_port);
+ magi_response_add(res, "] on port [");
+ magi_response_add(res, req->server_port);
}
if (req->server_protocol) {
- magi_response_content(res, "] with protocol [");
- magi_response_content(res, req->server_protocol);
+ magi_response_add(res, "] with protocol [");
+ magi_response_add(res, req->server_protocol);
}
if (req->server_software) {
- magi_response_content(res, "] and I am running on software [");
- magi_response_content(res, req->server_software);
+ magi_response_add(res, "] and I am running on software [");
+ magi_response_add(res, req->server_software);
}
- magi_response_content(res, "]<br/>");
+ magi_response_add(res, "]<br/>");
}
void response_request(struct magi_request * req, struct magi_response * res)
{
magi_response_content_type(res, magi_xhtml);
- magi_response_content(
+ magi_response_add(
res, "<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0 Strict//EN' "
"'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'>"
"<html xmlns='http://www.w3.org/1999/xhtml'>"
@@ -104,21 +86,26 @@ void response_request(struct magi_request * req, struct magi_response * res)
"<body>");
process_meta(req, res);
proceed_cookies(req->cookies, res);
- proceed_fields(req->fields, res);
+ magi_response_add(res, "<h2>Parameters:</h2>");
+ proceed_params(req->params, res);
+ magi_response_add(res, "<h2>URL Parameters:</h2>");
+ proceed_params(req->url_params, res);
+ magi_response_add(res, "<h2>HTTP Parameters:</h2>");
proceed_params(req->http_params, res);
- magi_response_content(res, "</body></html>");
+ magi_response_add(res, "</body></html>");
}
int main(int argc, char const * argv[])
{
struct magi_request request;
- if (magi_cgi(&request, 0, 0, 0)) {
+ magi_request_setup(&request);
+ if (magi_request_cgi(&request)) {
struct magi_response response;
response_request(&request, &response);
- magi_cgi_response(&response);
- magi_response_destroy();
+ magi_response_cgi(&response);
+ magi_response_destroy(&response);
} else {
- magi_cgi_error(request.error);
+ magi_error_cgi(request.error);
}
magi_request_destroy(&request);
return 0;