aboutsummaryrefslogtreecommitdiff
path: root/include/slweb/http.h
diff options
context:
space:
mode:
authorXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-10-10 23:21:35 +0200
committerXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-10-11 00:07:13 +0200
commit0222b75e8554796548e079aa3393c512ae30ac24 (patch)
tree5a154258ae5c1434a211ee67537e46ef64058437 /include/slweb/http.h
parent832e198f8c77970b5b923eb18201ba83d9c72b80 (diff)
downloadlibweb-0222b75e8554796548e079aa3393c512ae30ac24.tar.gz
Rename project from slweb to libwebv0.1.0-rc3
It was found out there was another project of the same name around (https://git.sr.ht/~strahinja/slweb/), also related to website generation. In order to avoid confusion, a new name has been chosen for this project. Surprisingly, libweb was not in use by any distributions (according to https://repology.org and AUR index), and it should reflect well the intention behind this project i.e., being a library to build web-related stuff.
Diffstat (limited to 'include/slweb/http.h')
-rw-r--r--include/slweb/http.h110
1 files changed, 0 insertions, 110 deletions
diff --git a/include/slweb/http.h b/include/slweb/http.h
deleted file mode 100644
index 68ffb9a..0000000
--- a/include/slweb/http.h
+++ /dev/null
@@ -1,110 +0,0 @@
-#ifndef HTTP_H
-#define HTTP_H
-
-#include <stdbool.h>
-#include <stddef.h>
-#include <stdio.h>
-
-struct http_payload
-{
- enum http_op
- {
- HTTP_OP_GET,
- HTTP_OP_POST,
- HTTP_OP_HEAD
- } op;
-
- const char *resource;
-
- struct http_cookie
- {
- const char *field, *value;
- } cookie;
-
- union
- {
- struct http_post
- {
- bool expect_continue;
- const char *data;
- size_t nfiles, npairs;
-
- const struct http_post_pair
- {
- const char *name, *value;
- } *pairs;
-
- const struct http_post_file
- {
- const char *name, *tmpname, *filename;
- } *files;
- } post;
- } u;
-
- const struct http_arg
- {
- char *key, *value;
- } *args;
-
- size_t n_args;
-};
-
-#define HTTP_STATUSES \
- X(CONTINUE, "Continue", 100) \
- X(OK, "OK", 200) \
- X(SEE_OTHER, "See other", 303) \
- X(BAD_REQUEST, "Bad Request", 400) \
- X(UNAUTHORIZED, "Unauthorized", 401) \
- X(FORBIDDEN, "Forbidden", 403) \
- X(NOT_FOUND, "Not found", 404) \
- X(PAYLOAD_TOO_LARGE, "Payload too large", 413) \
- X(INTERNAL_ERROR, "Internal Server Error", 500)
-
-struct http_response
-{
- enum http_status
- {
-#define X(x, y, z) HTTP_STATUS_##x,
- HTTP_STATUSES
-#undef X
- } status;
-
- struct http_header
- {
- char *header, *value;
- } *headers;
-
- union
- {
- const void *ro;
- void *rw;
- } buf;
-
- FILE *f;
- unsigned long long n;
- size_t n_headers;
- void (*free)(void *);
-};
-
-struct http_cfg
-{
- int (*read)(void *buf , size_t n, void *user);
- int (*write)(const void *buf, size_t n, void *user);
- int (*payload)(const struct http_payload *p, struct http_response *r,
- void *user);
- int (*length)(unsigned long long len, const struct http_cookie *c,
- struct http_response *r, void *user);
- const char *tmpdir;
- void *user;
-};
-
-struct http_ctx *http_alloc(const struct http_cfg *cfg);
-void http_free(struct http_ctx *h);
-int http_update(struct http_ctx *h, bool *write, bool *close);
-int http_response_add_header(struct http_response *r, const char *header,
- const char *value);
-char *http_cookie_create(const char *key, const char *value);
-char *http_encode_url(const char *url);
-char *http_decode_url(const char *url, bool spaces);
-
-#endif /* HTTP_H */