blob: 8051925e2e7aeed2a2f370e8ad21593c80662535 [file] [log] [blame]
/*
* include/haproxy/http_htx-t.h
* This file defines everything related to HTTP manipulation using the internal
* representation.
*
* Copyright (C) 2018 HAProxy Technologies, Christopher Faulet <cfaulet@haproxy.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation, version 2.1
* exclusively.
*
* 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef _HAPROXY_HTTP_HTX_T_H
#define _HAPROXY_HTTP_HTX_T_H
#include <import/ebistree.h>
#include <import/ist.h>
#include <haproxy/buf-t.h>
#include <haproxy/http-t.h>
#include <haproxy/htx-t.h>
/* Context used to find/remove an HTTP header. */
struct http_hdr_ctx {
struct htx_blk *blk;
struct ist value;
uint16_t lws_before;
uint16_t lws_after;
};
/* Structure used to build the header list of an HTTP reply */
struct http_reply_hdr {
struct ist name; /* the header name */
struct list value; /* the log-format string value */
struct list list; /* header chained list */
};
#define HTTP_REPLY_EMPTY 0x00 /* the reply has no payload */
#define HTTP_REPLY_ERRMSG 0x01 /* the reply is an error message (may be NULL) */
#define HTTP_REPLY_ERRFILES 0x02 /* the reply references an http-errors section */
#define HTTP_REPLY_RAW 0x03 /* the reply use a raw payload */
#define HTTP_REPLY_LOGFMT 0x04 /* the reply use a log-format payload */
#define HTTP_REPLY_INDIRECT 0x05 /* the reply references another http-reply (may be NULL) */
/* Uses by HAProxy to generate internal responses */
struct http_reply {
unsigned char type; /* HTTP_REPLY_* */
int status; /* The response status code */
char *ctype; /* The response content-type, may be NULL */
struct list hdrs; /* A list of http_reply_hdr */
union {
struct list fmt; /* A log-format string (type = HTTP_REPLY_LOGFMT) */
struct buffer obj; /* A raw string (type = HTTP_REPLY_RAW) */
struct buffer *errmsg; /* The error message to use as response (type = HTTP_REPLY_ERRMSG).
* may be NULL, if so rely on the proxy error messages */
struct http_reply *reply; /* The HTTP reply to use as response (type = HTTP_REPLY_INDIRECT) */
char *http_errors; /* The http-errors section to use (type = HTTP_REPLY_ERRFILES).
* Should be resolved during post-check */
} body;
struct list list; /* next http_reply in the global list.
* Only used for replies defined in a proxy section */
};
/* A custom HTTP error message load from a row file and converted in HTX. The
* node key is the file path.
*/
struct http_error_msg {
struct buffer msg;
struct ebpt_node node;
};
/* http-errors section and parameters. */
struct http_errors {
char *id; /* unique identifier */
struct {
char *file; /* file where the section appears */
int line; /* line where the section appears */
} conf; /* config information */
struct http_reply *replies[HTTP_ERR_SIZE]; /* HTTP replies for known errors */
struct list list; /* http-errors list */
};
#endif /* _HAPROXY_HTTP_HTX_T_H */