mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2024-12-17 08:54:41 +00:00
haproxy public development tree
700d9e88ad
It is now possible to intercept HTTP messages from a lua action and reply to clients. To do so, a reply object must be provided to the function txn:done(). It may contain a status code with a reason, a header list and a body. By default, if an empty reply object is used, an empty 200 response is returned. If no reply is passed when txn:done() is called, the previous behaviour is respected, the transaction is terminated and nothing is returned to the client. The same is done for TCP streams. When txn:done() is called, the action is terminated with the code ACT_RET_DONE on success and ACT_RET_ERR on error, interrupting the message analysis. The reply object may be created for the lua, by hand. Or txn:reply() may be called. If so, this object provides some methods to fill it: * Reply:set_status(<status> [ <reason>]) : Set the status and optionally the reason. If no reason is provided, the default one corresponding to the status code is used. * Reply:add_header(<name>, <value>) : Add a header. For a given name, the values are stored in an ordered list. * Reply:del_header(<name>) : Removes all occurrences of a header name. * Reply:set_body(<body>) : Set the reply body. Here are some examples, all doing the same: -- ex. 1 txn:done{ status = 400, reason = "Bad request", headers = { ["content-type"] = { "text/html" }, ["cache-control"] = { "no-cache", "no-store" }, }, body = "<html><body><h1>invalid request<h1></body></html>" } -- ex. 2 local reply = txn:reply{ status = 400, reason = "Bad request", headers = { ["content-type"] = { "text/html" }, ["cache-control"] = { "no-cache", "no-store" } }, body = "<html><body><h1>invalid request<h1></body></html>" } txn:done(reply) -- ex. 3 local reply = txn:reply() reply:set_status(400, "Bad request") reply:add_header("content-length", "text/html") reply:add_header("cache-control", "no-cache") reply:add_header("cache-control", "no-store") reply:set_body("<html><body><h1>invalid request<h1></body></html>") txn:done(reply) |
||
---|---|---|
.github | ||
contrib | ||
doc | ||
ebtree | ||
examples | ||
include | ||
reg-tests | ||
scripts | ||
src | ||
tests | ||
.cirrus.yml | ||
.gitignore | ||
.travis.yml | ||
BRANCHES | ||
CHANGELOG | ||
CONTRIBUTING | ||
INSTALL | ||
LICENSE | ||
MAINTAINERS | ||
Makefile | ||
README | ||
ROADMAP | ||
SUBVERS | ||
VERDATE | ||
VERSION |
The HAProxy documentation has been split into a number of different files for ease of use. Please refer to the following files depending on what you're looking for : - INSTALL for instructions on how to build and install HAProxy - BRANCHES to understand the project's life cycle and what version to use - LICENSE for the project's license - CONTRIBUTING for the process to follow to submit contributions The more detailed documentation is located into the doc/ directory : - doc/intro.txt for a quick introduction on HAProxy - doc/configuration.txt for the configuration's reference manual - doc/lua.txt for the Lua's reference manual - doc/SPOE.txt for how to use the SPOE engine - doc/network-namespaces.txt for how to use network namespaces under Linux - doc/management.txt for the management guide - doc/regression-testing.txt for how to use the regression testing suite - doc/peers.txt for the peers protocol reference - doc/coding-style.txt for how to adopt HAProxy's coding style - doc/internals for developer-specific documentation (not all up to date)