Provided by: haproxy_2.8.5-1ubuntu3.3_amd64 bug

NAME

       haproxy-lua - haproxy-lua Documentation

HAPROXY LUA RUNNING CONTEXTS

       The  Lua  code  executed in HAProxy can be processed in 2 main modes. The first one is the initialisation
       mode, and the second is the runtime mode.

       • In the initialisation mode, we can perform DNS solves, but  we  cannot  perform  socket  I/O.  In  this
         initialisation mode, HAProxy still blocked during the execution of the Lua program.

       • In  the  runtime  mode, we cannot perform DNS solves, but we can use sockets.  The execution of the Lua
         code is multiplexed with the requests processing, so the Lua code seems to be run in blocking,  but  it
         is not the case.

       The  Lua  code  is  loaded  in one or more files. These files contains main code and functions. Lua has 8
       execution contexts.

       1. The Lua file body context. It is executed during the load of the Lua  file  in  the  HAProxy  [global]
          section  with  the  directive lua-load. It is executed in initialisation mode. This section is use for
          configuring Lua bindings in HAProxy.

       2. The Lua init context. It is a Lua function executed just after the HAProxy configuration parsing.  The
          execution  is in initialisation mode. In this context the HAProxy environment are already initialized.
          It is useful to check configuration, or initializing socket connections or tasks. These functions  are
          declared in the body context with the Lua function core.register_init(). The prototype of the function
          is a simple function without return value and without parameters, like this: function fcn().

       3. The Lua task context. It is a Lua function executed after the start of the HAProxy scheduler, and just
          after  the  declaration  of  the  task with the Lua function core.register_task(). This context can be
          concurrent with the traffic processing. It is executed in runtime mode. The prototype of the  function
          is a simple function without return value and without parameters, like this: function fcn().

       4. The  action  context. It is a Lua function conditionally executed. These actions are registered by the
          Lua directives "core.register_action()". The prototype of the Lua called function is a  function  with
          doesn't returns anything and that take an object of class TXN as entry. function fcn(txn).

       5. The  sample-fetch  context.  This  function takes a TXN object as entry argument and returns a string.
          These types of function cannot execute any blocking function. They are useful  to  aggregate  some  of
          original  HAProxy  sample-fetches  and  return  the  result. The prototype of the function is function
          string fcn(txn). These functions can be registered with the Lua function core.register_fetches(). Each
          declared sample-fetch is prefixed by the string "lua.".

          NOTE:
             It is possible that  this  function  cannot  found  the  required  data  in  the  original  HAProxy
             sample-fetches, in this case, it cannot return the result. This case is not yet supported

       6. The converter context. It is a Lua function that takes a string as input and returns another string as
          output. These types of function are stateless, it cannot access to any context. They don't execute any
          blocking function.  The call prototype is function string fcn(string). This function can be registered
          with  the  Lua  function core.register_converters(). Each declared converter is prefixed by the string
          "lua.".

       7. The filter context: It is a Lua object based on  a  class  defining  filter  callback  functions.  Lua
          filters  are  registered  using core.register_filter(). Each declared filter is prefixed by the string
          "lua.".

       8. The event context: Inside a function  that  handles  events  subscribed  through  core.event_sub()  or
          Server.event_sub().

HAPROXY LUA HELLO WORLD

       HAProxy configuration file (hello_world.conf):

          global
             lua-load hello_world.lua

          listen proxy
             bind 127.0.0.1:10001
             tcp-request inspect-delay 1s
             tcp-request content use-service lua.hello_world

       HAProxy Lua file (hello_world.lua):

          core.register_service("hello_world", "tcp", function(applet)
             applet:send("hello world\n")
          end)

       How to start HAProxy for testing this configuration:

          ./haproxy -f hello_world.conf

       On other terminal, you can test with telnet:

          #:~ telnet 127.0.0.1 10001
          hello world

USAGE OF LOAD PARAMETERS

       HAProxy  lua-load(-per-thread)  directives  allow  a  list  of  parameters after the lua file name. These
       parameters are accessible through an array of args using this code local args =  table.pack(...)  in  the
       body of loaded file.

       Below, a new version of the hello world using load parameters

       HAProxy configuration file (hello_world.conf):

          global
             lua-load hello_world.lua "this is not an hello world"

          listen proxy
             bind 127.0.0.1:10001
             tcp-request inspect-delay 1s
             tcp-request content use-service lua.hello_world

       HAProxy Lua file (hello_world.lua):

          local args = table.pack(...)

          core.register_service("hello_world", "tcp", function(applet)
             applet:send(args[1] .. "\n")
          end)

       class core()
              The  "core"  class  contains  all  the  HAProxy  core functions. These function are useful for the
              controlling of the execution flow, registering hooks, manipulating global maps or ACL, ...

              "core" class is basically provided with HAProxy.  No  require  line  is  required  to  uses  these
              function.

              The "core" class is static, it is not possible to create a new object of this type.

       core.emerg

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "emergency" (0).

       core.alert

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "alert" (1).

       core.crit

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "critical" (2).

       core.err

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "error" (3).

       core.warning

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "warning" (4).

       core.notice

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "notice" (5).

       core.info

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "info" (6).

       core.debug

              Returns
                     integer

              This attribute is an integer, it contains the value of the loglevel "debug" (7).

       core.proxies
              context: init, task, action, sample-fetch, converter

              This  attribute  is a table of declared proxies (frontend and backends). Each proxy give an access
              to his list of listeners and servers. The table is indexed by proxy name, and  each  entry  is  of
              type Proxy class.

              WARNING:
                 if you declared a frontend and backend with the same name, only one of them will be listed.

              See    core.backends

              See    core.frontends

       core.backends
              context: init, task, action, sample-fetch, converter

              This  attribute  is a table of declared proxies with backend capability. Each proxy give an access
              to his list of listeners and servers. The table is indexed by the backend name, and each entry  is
              of type Proxy class.

              See    core.proxies

              See    core.frontends

       core.frontends
              context: init, task, action, sample-fetch, converter

              This  attribute is a table of declared proxies with frontend capability. Each proxy give an access
              to his list of listeners and servers. The table is indexed by the frontend name, and each entry is
              of type Proxy class.

              See    core.proxies

              See    core.backends

       core.thread
              context: task, action, sample-fetch, converter, applet

              This variable contains the executing thread number starting at 1. 0 is  a  special  case  for  the
              common lua context. So, if thread is 0, Lua scope is shared by all threads, otherwise the scope is
              dedicated to a single thread.  A program which needs to execute some parts exactly once regardless
              of the number of threads can check that core.thread is 0 or 1.

       core.log(loglevel, msg)
              context: body, init, task, action, sample-fetch, converter

              This  function sends a log. The log is sent, according with the HAProxy configuration file, to the
              loggers relevant to the current context and to stderr if it is allowed.

              The exact behaviour depends on tune.lua.log.loggers and tune.lua.log.stderr.

              Argumentsloglevel (integer()) -- Is the log level associated with the  message.  It  is  a  number
                       between 0 and 7.

                     • msg (string()) -- The log content.

              See    core.emerg,   core.alert,   core.crit,   core.err,  core.warning,  core.notice,  core.info,
                     core.debug (log level definitions)

              See    core.Debug()

              See    core.Info()

              See    core.Warning()

              See    core.Alert()

       core.Debug(msg)
              context: body, init, task, action, sample-fetch, converter

              Argumentsmsg (string()) -- The log content.

              See    core.log()

              Does the same job than:

          function Debug(msg)
            core.log(core.debug, msg)
          end

       core.Info(msg)
              context: body, init, task, action, sample-fetch, converter

              Argumentsmsg (string()) -- The log content.

              See    core.log()

          function Info(msg)
            core.log(core.info, msg)
          end

       core.Warning(msg)
              context: body, init, task, action, sample-fetch, converter

              Argumentsmsg (string()) -- The log content.

              See    core.log()

          function Warning(msg)
            core.log(core.warning, msg)
          end

       core.Alert(msg)
              context: body, init, task, action, sample-fetch, converter

              Argumentsmsg (string()) -- The log content.

              See    core.log()

          function Alert(msg)
            core.log(core.alert, msg)
          end

       core.add_acl(filename, key)
              context: init, task, action, sample-fetch, converter

              Add the ACL key in the ACLs list referenced by the file filename.

              Argumentsfilename (string()) -- the filename that reference the ACL entries.

                     • key (string()) -- the key which will be added.

       core.del_acl(filename, key)
              context: init, task, action, sample-fetch, converter

              Delete the ACL entry referenced by the key key in the list of ACLs referenced by filename.

              Argumentsfilename (string()) -- the filename that reference the ACL entries.

                     • key (string()) -- the key which will be deleted.

       core.del_map(filename, key)
              context: init, task, action, sample-fetch, converter

              Delete the map entry indexed with the specified  key  in  the  list  of  maps  referenced  by  his
              filename.

              Argumentsfilename (string()) -- the filename that reference the map entries.

                     • key (string()) -- the key which will be deleted.

       core.get_info()
              context: body, init, task, action, sample-fetch, converter

              Returns  HAProxy  core  information. We can find information like the uptime, the pid, memory pool
              usage, tasks number, ...

              This information is also returned by the management socket via the command "show  info".  See  the
              management socket documentation for more information about the content of these variables.

              Returns
                     an array of values.

       core.now()
              context: body, init, task, action

              This function returns the current time. The time returned is fixed by the HAProxy core and assures
              than  the  hour  will be monotonic and that the system call 'gettimeofday' will not be called too.
              The time is refreshed between each Lua execution  or  resume,  so  two  consecutive  call  to  the
              function "now" will probably returns the same result.

              Returns
                     a  table  which  contains  two  entries "sec" and "usec". "sec" contains the current at the
                     epoch format, and "usec" contains the current microseconds.

       core.http_date(date)
              context: body, init, task, action

              This function take a string  representing  http  date,  and  returns  an  integer  containing  the
              corresponding  date  with  a  epoch format. A valid http date me respect the format IMF, RFC850 or
              ASCTIME.

              Argumentsdate (string()) -- a date http-date formatted

              Returns
                     integer containing epoch date

              See    core.imf_date().

              See    core.rfc850_date().

              See    core.asctime_date().

              See    https://tools.ietf.org/html/rfc7231#section-7.1.1.1

       core.imf_date(date)
              context: body, init, task, action

              This function take a  string  representing  IMF  date,  and  returns  an  integer  containing  the
              corresponding date with a epoch format.

              Argumentsdate (string()) -- a date IMF formatted

              Returns
                     integer containing epoch date

              See    https://tools.ietf.org/html/rfc7231#section-7.1.1.1

              The IMF format is like this:

          Sun, 06 Nov 1994 08:49:37 GMT

       core.rfc850_date(date)
              context: body, init, task, action

              This  function  take  a  string  representing  RFC850  date, and returns an integer containing the
              corresponding date with a epoch format.

              Argumentsdate (string()) -- a date RFC859 formatted

              Returns
                     integer containing epoch date

              See    https://tools.ietf.org/html/rfc7231#section-7.1.1.1

              The RFC850 format is like this:

          Sunday, 06-Nov-94 08:49:37 GMT

       core.asctime_date(date)
              context: body, init, task, action

              This function take a string representing ASCTIME date,  and  returns  an  integer  containing  the
              corresponding date with a epoch format.

              Argumentsdate (string()) -- a date ASCTIME formatted

              Returns
                     integer containing epoch date

              See    https://tools.ietf.org/html/rfc7231#section-7.1.1.1

              The ASCTIME format is like this:

          Sun Nov  6 08:49:37 1994

       core.msleep(milliseconds)
              context: body, init, task, action

              The core.msleep() stops the Lua execution between specified milliseconds.

              Argumentsmilliseconds (integer()) -- the required milliseconds.

       core.register_action(name, actions, func[, nb_args])
              context: body

              Register  a Lua function executed as action. All the registered action can be used in HAProxy with
              the prefix "lua.". An action gets a TXN object class as input.

              Argumentsname (string()) -- is the name of the action.

                     • actions (table()) -- is a table of string describing the HAProxy actions facilities where
                       to expose the new action. Expected facilities  are: 'tcp-req', 'tcp-res',  'http-req'  or
                       'http-res'.

                     • func (function()) -- is the Lua function called to work as an action.

                     • nb_args (integer()) -- is the expected number of argument for the action.  By default the
                       value is 0.

              The prototype of the Lua function used as argument is:

          function(txn [, arg1 [, arg2]])

          •

            txn (TXN class): this is a TXN object used for manipulating the
                   current request or TCP stream.

          • argX: this is argument provided through the HAProxy configuration file.

          Here, an example of action registration. The action just send an 'Hello world' in the logs.

          core.register_action("hello-world", { "tcp-req", "http-req" }, function(txn)
             txn:Info("Hello world")
          end)
          This example code is used in HAProxy configuration like this:

          frontend tcp_frt
            mode tcp
            tcp-request content lua.hello-world

          frontend http_frt
            mode http
            http-request lua.hello-world
          A second example using arguments

          function hello_world(txn, arg)
             txn:Info("Hello world for " .. arg)
          end
          core.register_action("hello-world", { "tcp-req", "http-req" }, hello_world, 2)
          This example code is used in HAProxy configuration like this:

          frontend tcp_frt
            mode tcp
            tcp-request content lua.hello-world everybody

       core.register_converters(name, func)
              context: body

              Register  a  Lua  function  executed  as  converter.  All the registered converters can be used in
              HAProxy with the prefix "lua.". A converter gets a string as input and returns a string as output.
              The registered function can take up to 9 values as parameter. All the values are strings.

              Argumentsname (string()) -- is the name of the converter.

                     • func (function()) -- is the Lua function called to work as converter.

              The prototype of the Lua function used as argument is:

          function(str, [p1 [, p2 [, ... [, p5]]]])

          • str (string): this is the input value automatically converted in string.

          • p1 .. p5 (string): this is a list of string arguments declared in the  HAProxy  configuration  file.
            The  number  of  arguments  doesn't  exceed  5.  The order and the nature of these is conventionally
            chosen by the developer.

       core.register_fetches(name, func)
              context: body

              Register a Lua function executed as sample fetch. All the registered sample fetch can be  used  in
              HAProxy  with  the  prefix  "lua.".  A Lua sample fetch returns a string as output. The registered
              function can take up to 9 values as parameter. All the values are strings.

              Argumentsname (string()) -- is the name of the sample fetch.

                     • func (function()) -- is the Lua function called to work as sample fetch.

              The prototype of the Lua function used as argument is:

          string function(txn, [p1 [, p2 [, ... [, p5]]]])

          • txn (TXN class): this is the txn object associated with the current request.

          • p1 .. p5 (string): this is a list of string arguments declared in the  HAProxy  configuration  file.
            The  number  of  arguments  doesn't  exceed  5.  The order and the nature of these is conventionally
            chosen by the developer.

          • Returns: A string containing some data, or nil if the value cannot be returned now.

          lua example code:

          core.register_fetches("hello", function(txn)
              return "hello"
          end)
          HAProxy example configuration:

          frontend example
             http-request redirect location /%[lua.hello]

       core.register_filter(name, Flt, func)
              context: body

              Register a Lua function used to declare a filter. All  the  registered  filters  can  by  used  in
              HAProxy with the prefix "lua.".

              Argumentsname (string()) -- is the name of the filter.

                     • Flt (table()) -- is a Lua class containing the filter definition (id, flags, callbacks).

                     • func (function()) -- is the Lua function called to create the Lua filter.

              The prototype of the Lua function used as argument is:

          function(flt, args)

          • flt : Is a filter object based on the class provided in core.register_filter() function.

          • args:  Is  a  table  of  strings containing all arguments provided through the HAProxy configuration
            file, on the filter line.

          It must return the filter to use or nil to ignore it. Here, an example of filter registration.

          core.register_filter("my-filter", MyFilter, function(flt, args)
             flt.args = args -- Save arguments
             return flt
          end)
          This example code is used in HAProxy configuration like this:

          frontend http
            mode http
            filter lua.my-filter arg1 arg2 arg3

          see    Filter()

       core.register_service(name, mode, func)
              context: body

              Register a Lua function executed as a service. All the registered services can be used in  HAProxy
              with the prefix "lua.". A service gets an object class as input according with the required mode.

              Argumentsname (string()) -- is the name of the service.

                     • mode  (string())  --  is  string  describing  the required mode. Only 'tcp' or 'http' are
                       allowed.

                     • func (function()) -- is the Lua function called to work as service.

              The prototype of the Lua function used as argument is:

          function(applet)

          • applet applet  will be a AppletTCP class or a AppletHTTP class. It depends the  type  of  registered
            applet.  An  applet  registered  with the 'http' value for the mode parameter will gets a AppletHTTP
            class. If the mode value is 'tcp', the applet will gets a AppletTCP class.

          WARNING:
              Applets of type 'http' cannot be called from  'tcp-'  rulesets.  Only  the  'http-'  rulesets  are
              authorized,  this  means  that  is  not  possible  to call a HTTP applet from a proxy in tcp mode.
              Applets of type 'tcp' can be called from anywhere.

          Here, an example of service registration. The service just send an 'Hello world' as an http response.

          core.register_service("hello-world", "http", function(applet)
             local response = "Hello World !"
             applet:set_status(200)
             applet:add_header("content-length", string.len(response))
             applet:add_header("content-type", "text/plain")
             applet:start_response()
             applet:send(response)
          end)
          This example code is used in HAProxy configuration like this:

          frontend example
             http-request use-service lua.hello-world

       core.register_init(func)
              context: body

              Register a function executed after  the  configuration  parsing.  This  is  useful  to  check  any
              parameters.

              Argumentsfunc (function()) -- is the Lua function called to work as initializer.

              The prototype of the Lua function used as argument is:

          function()
          It takes no input, and no output is expected.

       core.register_task(func[, arg1[, arg2[, ...[, arg4]]]])
              context: body, init, task, action, sample-fetch, converter, event

              Register  and  start independent task. The task is started when the HAProxy main scheduler starts.
              For example this type of tasks can be executed to perform complex health checks.

              Argumentsfunc (function()) -- is the Lua function called to work as an async task.

              Up to 4 optional arguments (all types supported) may be passed to  the  function.  (They  will  be
              passed as-is to the task function)

              The prototype of the Lua function used as argument is:

          function([arg1[, arg2[, ...[, arg4]]]])
          It takes up to 4 optional arguments (provided when registering), and no output is expected.

          See also core.queue() to dynamically pass data between main context and tasks or even between tasks.

       core.register_cli([path], usage, func)
              context: body

              Register a custom cli that will be available from haproxy stats socket.

              Argumentspath (array()) -- is the sequence of word for which the cli execute the Lua binding.

                     • usage (string()) -- is the usage message displayed in the help.

                     • func (function()) -- is the Lua function called to handle the CLI commands.

              The prototype of the Lua function used as argument is:

          function(AppletTCP, [arg1, [arg2, [...]]])
          I/O  are  managed  with  the  AppletTCP  class object. Args are given as parameter. The args embed the
          registered path. If the path is declared like this:

          core.register_cli({"show", "ssl", "stats"}, "Display SSL stats..", function(applet, arg1, arg2, arg3, arg4, arg5)
               end)
          And we execute this in the prompt:

          > prompt
          > show ssl stats all
          Then, arg1, arg2 and arg3 will contains respectively "show", "ssl" and  "stats".   arg4  will  contain
          "all". arg5 contains nil.

       core.set_nice(nice)
              context: task, action, sample-fetch, converter

              Change the nice of the current task or current session.

              Argumentsnice (integer()) -- the nice value, it must be between -1024 and 1024.

       core.set_map(filename, key, value)
              context: init, task, action, sample-fetch, converter

              Set the value value associated to the key key in the map referenced by filename.

              Argumentsfilename (string()) -- the Map reference

                     • key (string()) -- the key to set or replace

                     • value (string()) -- the associated value

       core.sleep(int seconds)
              context: body, init, task, action

              The core.sleep() functions stop the Lua execution between specified seconds.

              Argumentsseconds (integer()) -- the required seconds.

       core.tcp()
              context: init, task, action

              This function returns a new object of a socket class.

              Returns
                     A Socket class object.

       core.httpclient()
              context: init, task, action

              This function returns a new object of a httpclient class.

              Returns
                     A HTTPClient class object.

       core.concat()
              context: body, init, task, action, sample-fetch, converter

              This function returns a new concat object.

              Returns
                     A Concat class object.

       core.queue()
              context: body, init, task, event, action, sample-fetch, converter

              This function returns a new queue object.

              Returns
                     A Queue class object.

       core.done(data)
              context: body, init, task, action, sample-fetch, converter

              Argumentsdata  (any())  --  Return  some data for the caller. It is useful with sample-fetches and
                       sample-converters.

              Immediately stops the current Lua execution and returns to the caller which may be a sample fetch,
              a converter or an action and returns the specified value (ignored for actions  and  init).  It  is
              used  when the LUA process finishes its work and wants to give back the control to HAProxy without
              executing the remaining code. It can be seen as a multi-level "return".

       core.yield()
              context: task, action, sample-fetch, converter

              Give back the hand at the HAProxy scheduler. It is used when the LUA processing consumes a lot  of
              processing time.

       core.parse_addr(address)
              context: body, init, task, action, sample-fetch, converter

              Argumentsnetwork  --  is  a  string  describing an ipv4 or ipv6 address and optionally its network
                       length, like this: "127.0.0.1/8" or "aaaa::1234/32".

              Returns
                     a userdata containing network or nil if an error occurs.

              Parse ipv4 or ipv6 addresses and its facultative associated network.

       core.match_addr(addr1, addr2)
              context: body, init, task, action, sample-fetch, converter

              Argumentsaddr1 -- is an address created with "core.parse_addr".

                     • addr2 -- is an address created with "core.parse_addr".

              Returns
                     boolean, true if the network of the addresses match, else returns false.

              Match two networks. For example "127.0.0.1/32" matches "127.0.0.0/8". The order of network is  not
              important.

       core.tokenize(str, separators[, noblank])
              context: body, init, task, action, sample-fetch, converter

              This  function  is useful for tokenizing an entry, or splitting some messages.  :param string str:
              The string which will be  split.   :param  string  separators:  A  string  containing  a  list  of
              separators.  :param boolean noblank: Ignore empty entries.  :returns: an array of string.

              For example:

          local array = core.tokenize("This function is useful, for tokenizing an entry.", "., ", true)
          print_r(array)
          Returns this array:

          (table) table: 0x21c01e0 [
              1: (string) "This"
              2: (string) "function"
              3: (string) "is"
              4: (string) "useful"
              5: (string) "for"
              6: (string) "tokenizing"
              7: (string) "an"
              8: (string) "entry"
          ]

       core.event_sub(event_types, func)
              context: body, init, task, action, sample-fetch, converter

              Register a function that will be called on specific system events.

              Argumentsevent_types (array()) -- array of string containing the event types you want to subscribe
                       to

                     • func (function()) -- is the Lua function called when one of the subscribed events occur.

              Returns
                     A EventSub class object.

              See    Server.event_sub().

              List of available event types :
                 SERVER Family:

                     • SERVER_ADD: when a server is added

                     • SERVER_DEL: when a server is removed

                     • SERVER_DOWN: when a server state goes from UP to DOWN

                     • SERVER_UP: when a server state goes from DOWN to UP

                     • SERVER_STATE: when a server state changes

                     • SERVER_ADMIN: when a server administrative state changes

                     • SERVER_CHECK:  when  a  server's  check  status  change  is  reported.   Be  careful when
                       subscribing to this type since many events might be generated.

                 NOTE:
                     Use SERVER in event_types to subscribe to all server events types at once. Note  that  this
                     should  only  be  used  for  testing  purposes  since a single event source could result in
                     multiple events types being generated.  (e.g.: SERVER_STATE will always  be  generated  for
                     each SERVER_DOWN or SERVER_UP)

              The prototype of the Lua function used as argument is:

          function(event, event_data, sub, when)

          • event (string): the event type (one of the event_types specified when subscribing)

          • event_data: specific to each event family (For SERVER family, a ServerEvent class object)

          • sub: class to manage the subscription from within the event (a EventSub class object)

          • when:  timestamp  corresponding  to  the  date  when  the  event  was  generated.   It is an integer
            representing the number of seconds elapsed since Epoch.  It may be provided as optional argument  to
            os.date() lua function to convert it to a string according to a given format string.

          WARNING:
              The  callback  function  will  only  be  scheduled  on  the  very  same  thread that performed the
              subscription.

              Moreover, each thread treats events sequentially. It means that if you have, let's  say  SERVER_UP
              followed  by  a  SERVER_DOWN  in a short timelapse, then the cb function will first be called with
              SERVER_UP, and once it's done handling the event, the  cb  function  will  be  called  again  with
              SERVER_DOWN.

              This is to ensure event consistency when it comes to logging / triggering logic from lua.

              Your  lua  cb  function  may  yield  if needed, but you're pleased to process the event as fast as
              possible to prevent the event queue from growing up, depending on the event flow that is  expected
              for the given subscription.

              To  prevent  abuses, if the event queue for the current subscription goes over a certain amount of
              unconsumed events, the subscription will pause itself automatically for as long as  it  takes  for
              your handler to catch up.  This would lead to events being missed, so an error will be reported in
              the  logs  to warn you about that.  This is not something you want to let happen too often, it may
              indicate that you subscribed to an event  that  is  occurring  too  frequently  or/and  that  your
              callback function is too slow to keep up the pace and you should review it.

              If  you  want  to  do some parallel processing because your callback functions are slow: you might
              want to create subtasks from lua using core.register_task() from within your callback function  to
              perform the heavy job in a dedicated task and allow remaining events to be processed more quickly.

       core.disable_legacy_mailers()
              LEGACY

              context: body, init

              Disable  the  sending  of  email alerts through the legacy email sending function when mailers are
              used in the configuration.

              Use this when sending email alerts directly from lua.

              See    Proxy.get_mailers()

       class Proxy()
              This class provides a way for manipulating proxy and retrieving information like statistics.

       Proxy.name
              Contain the name of the proxy.

              WARNING:
                 This attribute is now deprecated and will eventually be removed.  Please  use  Proxy.get_name()
                 function instead.

       Proxy.get_name()
              Returns the name of the proxy.

       Proxy.uuid
              Contain the unique identifier of the proxy.

              WARNING:
                 This  attribute  is now deprecated and will eventually be removed.  Please use Proxy.get_uuid()
                 function instead.

       Proxy.get_uuid()
              Returns the unique identifier of the proxy.

       Proxy.servers
              Contain a table with the attached servers. The table is indexed by server name,  and  each  server
              entry is an object of type Server class.

       Proxy.stktable
              Contains a stick table object of type StickTable class attached to the proxy.

       Proxy.listeners
              Contain  a table with the attached listeners. The table is indexed by listener name, and each each
              listeners entry is an object of type Listener class.

       Proxy.pause(px)
              Pause the proxy. See the management socket documentation for more information.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

       Proxy.resume(px)
              Resume the proxy. See the management socket documentation for more information.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

       Proxy.stop(px)
              Stop the proxy. See the management socket documentation for more information.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

       Proxy.shut_bcksess(px)
              Kill the session attached to a backup server. See the management  socket  documentation  for  more
              information.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

       Proxy.get_cap(px)
              Returns a string describing the capabilities of the proxy.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     a string "frontend", "backend", "proxy" or "ruleset".

       Proxy.get_mode(px)
              Returns a string describing the mode of the current proxy.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     a string "tcp", "http" or "unknown"

       Proxy.get_srv_act(px)
              Returns the number of current active servers for the current proxy that are eligible for LB.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     an integer

       Proxy.get_srv_bck(px)
              Returns the number backup servers for the current proxy that are eligible for LB.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     an integer

       Proxy.get_stats(px)
              Returns  a  table containing the proxy statistics. The statistics returned are not the same if the
              proxy is frontend or a backend.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     a key/value table containing stats

       Proxy.get_mailers(px)
              LEGACY

              Returns a table containing mailers config for  the  current  proxy  or  nil  if  mailers  are  not
              available for the proxy.

              Argumentspx (class_proxy()) -- A Proxy class which indicates the manipulated proxy.

              Returns
                     a ProxyMailers class containing proxy mailers config

       LEGACY

       class ProxyMailers()
              This class provides mailers config for a given proxy.

              If  sending emails directly from lua, please consider core.disable_legacy_mailers() to disable the
              email sending from haproxy. (Or email alerts will be sent twice...)

       ProxyMailers.track_server_health
              Boolean set to true if the option "log-health-checks" is configured on the proxy, meaning that all
              server checks event should trigger email alerts.

       ProxyMailers.log_level
              An integer, the maximum log level that triggers email alerts. It is a number between 0  and  7  as
              defined by option "email-alert level".

       ProxyMailers.mailservers
              An  array  containing the list of mail servers that should receive email alerts.  Each array entry
              is a name:desc pair where desc represents the full server address (including port) as described in
              haproxy's configuration file.

       ProxyMailers.mailservers_timeout
              An integer representing the maximum time in milliseconds to wait for the email  to  be  sent.  See
              "timeout mail" directive from "mailers" section in haproxy configuration file.

       ProxyMailers.smtp_hostname
              A  string  containing  the  hostname  to  use  for  the  SMTP  transaction.   (option "email-alert
              myhostname")

       ProxyMailers.smtp_from
              A string containing the "MAIL FROM" address to use for the SMTP transaction.  (option "email-alert
              from")

       ProxyMailers.smtp_to
              A string containing the "RCPT TO" address to use for the SMTP transaction.   (option  "email-alert
              to")

       class Server()
              This class provides a way for manipulating servers and retrieving information.

       Server.name
              Contain the name of the server.

              WARNING:
                 This  attribute is now deprecated and will eventually be removed.  Please use Server.get_name()
                 function instead.

       Server.get_name(sv)
              Returns the name of the server.

       Server.puid
              Contain the proxy unique identifier of the server.

              WARNING:
                 This attribute is now deprecated and will eventually be removed.  Please use  Server.get_puid()
                 function instead.

       Server.get_puid(sv)
              Returns the proxy unique identifier of the server.

       Server.get_rid(sv)
              Returns  the  rid  (revision ID) of the server.  It is an unsigned integer that is set upon server
              creation. Value is derived from a global counter that starts at 0 and is incremented each time one
              or multiple server deletions are followed by a server addition (meaning  that  old  name/id  reuse
              could occur).

              Combining server name/id with server rid yields a process-wide unique identifier.

       Server.is_draining(sv)
              Return true if the server is currently draining sticky connections.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     a boolean

       Server.is_backup(sv)
              Return true if the server is a backup server

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     a boolean

       Server.is_dynamic(sv)
              Return true if the server was instantiated at runtime (e.g.: from the cli)

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     a boolean

       Server.get_cur_sess(sv)
              Return the number of currently active sessions on the server

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     an integer

       Server.get_pend_conn(sv)
              Return the number of pending connections to the server

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     an integer

       Server.set_maxconn(sv, weight)
              Dynamically  change the maximum connections of the server. See the management socket documentation
              for more information about the format of the string.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

                     • maxconn (string()) -- A string describing the server maximum connections.

       Server.get_maxconn(sv, weight)
              This function returns an integer representing the server maximum connections.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     an integer.

       Server.set_weight(sv, weight)
              Dynamically change the weight of the server. See the  management  socket  documentation  for  more
              information about the format of the string.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

                     • weight (string()) -- A string describing the server weight.

       Server.get_weight(sv)
              This function returns an integer representing the server weight.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     an integer.

       Server.set_addr(sv, addr[, port])
              Dynamically  change  the  address  of the server. See the management socket documentation for more
              information about the format of the string.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

                     • addr (string()) -- A string describing the server address.

       Server.get_addr(sv)
              Returns a string describing the address of the server.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     A string

       Server.get_stats(sv)
              Returns server statistics.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     a key/value table containing stats

       Server.get_proxy(sv)
              Returns the parent proxy to which the server belongs.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     a Proxy class or nil if not available

       Server.shut_sess(sv)
              Shutdown all the sessions attached to the server. See the management socket documentation for more
              information about this function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.set_drain(sv)
              Drain sticky sessions. See the management socket documentation for  more  information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.set_maint(sv)
              Set  maintenance  mode.  See  the  management socket documentation for more information about this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.set_ready(sv)
              Set normal mode. See the management socket documentation for more information about this function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.check_enable(sv)
              Enable health checks. See the management socket documentation  for  more  information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.check_disable(sv)
              Disable  health  checks.  See  the management socket documentation for more information about this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.check_force_up(sv)
              Force health-check up. See the management socket documentation for  more  information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.check_force_nolb(sv)
              Force  health-check  nolb mode. See the management socket documentation for more information about
              this function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.check_force_down(sv)
              Force health-check down. See the management socket documentation for more information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.agent_enable(sv)
              Enable  agent  check.  See  the  management  socket  documentation for more information about this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.agent_disable(sv)
              Disable agent check. See the management socket  documentation  for  more  information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.agent_force_up(sv)
              Force  agent  check  up.  See  the management socket documentation for more information about this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.agent_force_down(sv)
              Force agent check down. See the management socket documentation for more  information  about  this
              function.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

       Server.tracking(sv)
              Check if the current server is tracking another server.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     A  Server  class  which  indicates  the  tracked  server or nil if the server doesn't track
                     another one.

       Server.get_trackers(sv)
              Check if the current server is being tracked by other servers.

              Argumentssv (class_server()) -- A Server class which indicates the manipulated server.

              Returns
                     An array of Server class which indicates the tracking servers (might be empty)

       Server.event_sub(sv, event_types, func)
              Register a function that will be  called  on  specific  server  events.   It  works  exactly  like
              core.event_sub()  except  that  the  subscription  will  be  performed within the server dedicated
              subscription list instead of the global one.  (Your callback function  will  only  be  called  for
              server events affecting sv)

              See core.event_sub() for function usage.

              A   key   advantage  to  using  Server.event_sub()  over  core.event_sub()  for  servers  is  that
              Server.event_sub() allows you to be notified for servers events  of  a  single  server  only.   It
              removes  the  needs  for extra filtering in your callback function if you only care about a single
              server, and also prevents useless wakeups.

              For instance, if you want to be notified for UP/DOWN events on a  given  set  of  servers,  it  is
              recommended  to  perform  multiple  per-server  subscriptions since it will be more efficient that
              doing a single global subscription that will filter the received events.  Unless you  really  want
              to be notified for servers events of ALL servers of course, which could make sense given you setup
              but should be avoided if you have an important number of servers as it will add a significant load
              on your haproxy process in case of multiple servers state change in a short amount of time.

              NOTE:
                 You may also combine core.event_sub() with Server.event_sub().

                 Also, don't forget that you can use core.register_task() from your callback function if needed.
                 (ie: parallel work)

              Here   is   a   working   example   combining   core.event_sub()   with   Server.event_sub()   and
              core.register_task() (This only serves as a demo, this is not necessarily useful to do so)

          core.event_sub({"SERVER_ADD"}, function(event, data, sub)
            -- in the global event handler
            if data["reference"] ~= nil then
              print("Tracking new server: ", data["name"])
              data["reference"]:event_sub({"SERVER_UP", "SERVER_DOWN"}, function(event, data, sub)
                -- in the per-server event handler
                if data["reference"] ~= nil then
                  core.register_task(function(server)
                    -- subtask to perform some async work (e.g.: HTTP API calls, sending emails...)
                    print("ASYNC: SERVER ", server:get_name(), " is ", event == "SERVER_UP" and "UP" or "DOWN")
                  end, data["reference"])
                end
              end)
            end
          end)
          In this example, we will first track global server addition events.  For each newly added server ("add
          server" on the cli), we will register a UP/DOWN server subscription.  Then, the callback function will
          schedule the event handling in an async  subtask  which  will  receive  the  server  reference  as  an
          argument.

       Listener.get_stats(ls)
              Returns server statistics.

              Argumentsls (class_listener()) -- A Listener class which indicates the manipulated listener.

              Returns
                     a key/value table containing stats

       EventSub.unsub()
              End the subscription, the callback function will not be called again.

       class ServerEvent()

       This class is provided with every SERVER events.

       See core.event_sub() for more info.

       ServerEvent.name
              Contains the name of the server.

       ServerEvent.puid
              Contains the proxy-unique uid of the server

       ServerEvent.rid
              Contains the revision ID of the server

       ServerEvent.proxy_name
              Contains the name of the proxy to which the server belongs

       ServerEvent.proxy_uuid
              Contains the uuid of the proxy to which the server belongs

       ServerEvent.reference
              Reference to the live server (A Server class).

              WARNING:
                 Not  available  if  the  server was removed in the meantime.  (Will never be set for SERVER_DEL
                 event since the server does not exist anymore)

       ServerEvent.state
              A ServerEventState class

              NOTE:
                 Only available for SERVER_STATE event

       ServerEvent.admin
              A ServerEventAdmin class

              NOTE:
                 Only available for SERVER_ADMIN event

       ServerEvent.check
              A ServerEventCheckRes class

              NOTE:
                 Only available for SERVER_CHECK event

       class ServerEventCheckRes()

       This class describes the result of a server's check.

       ServerEventCheckRes.result
              Effective check result.

              Check result is a string and will be set to one of the following values:

                     • "FAILED": the check failed

                     • "PASSED": the check succeeded

                     • "CONDPASS": the check conditionally passed

       ServerEventCheckRes.agent
              Boolean set to true if the check is an agent check.  Else it is a health check.

       ServerEventCheckRes.duration
              Check's duration in milliseconds

       ServerEventCheckRes.reason

              Check's status. An array containing three fields:short: a string representing check status short name

                     • desc: a string representing check status description

                     • code: an integer, this extra information is provided for checks  that  went  through  the
                       data analysis stage (>= layer 5)

       ServerEventCheckRes.health

              An array containing values about check's health (integers):cur: current health counter:

                              • 0 to (rise - 1) = BAD

                              • rise to (rise + fall - 1) = GOOD

                     • rise: server will be considered as operational after rise consecutive successful checks

                     • fall: server will be considered as dead after fall consecutive unsuccessful checks

       class ServerEventState()

       This class contains additional info related to SERVER_STATE event.

       ServerEventState.admin
              Boolean  set  to true if the server state change is due to an administrative change. Else it is an
              operational change.

       ServerEventState.check
              A ServerEventCheckRes class, provided if the state change is due to a server  check  (must  be  an
              operational change).

       ServerEventState.cause
              Printable state change cause. Might be empty.

       ServerEventState.new_state
              New server state due to operational or admin change.

              It is a string that can be any of the following values:

                     • "STOPPED": The server is down

                     • "STOPPING": The server is up but soft-stopping

                     • "STARTING": The server is warming up

                     • "RUNNING": The server is fully up

       ServerEventState.old_state
              Previous server state prior to the operational or admin change.

              Can be any value described in new_state, but they should differ.

       ServerEventState.requeued
              Number of connections that were requeued due to the server state change.

              For  a  server going DOWN: it is the number of pending server connections that are requeued to the
              backend (such connections will be redispatched to any server that is  suitable  according  to  the
              configured load balancing algorithm).

              For  a  server  doing  UP:  it  is  the  number  of pending connections on the backend that may be
              redispatched to the server according to the load balancing algorithm that is in use.

       class ServerEventAdmin()

       This class contains additional info related to SERVER_ADMIN event.

       ServerEventAdmin.cause
              Printable admin state change cause. Might be empty.

       ServerEventAdmin.new_admin
              New server admin state due to the admin change.

              It is an array of string containing a composition of following values:

                     • "MAINT": server is in maintenance mode

                     • "FMAINT": server is in forced maintenance mode (MAINT is also set)

                     • "IMAINT": server is in inherited maintenance mode (MAINT is also set)

                     • "RMAINT": server is in resolve maintenance mode (MAINT is also set)

                     • "CMAINT": server is in config maintenance mode (MAINT is also set)

                     • "DRAIN": server is in drain mode

                     • "FDRAIN": server is in forced drain mode (DRAIN is also set)

                     • "IDRAIN": server is in inherited drain mode (DRAIN is also set)

       ServerEventAdmin.old_admin
              Previous server admin state prior to the admin change.

              Values are presented as in new_admin, but they should differ.  (Comparing old  and  new  helps  to
              find out the change(s))

       ServerEventAdmin.requeued
              Same  as  ServerEventState.requeued but when the requeue is due to the server administrative state
              change.

       class Queue()
              This class provides a generic FIFO storage mechanism that  may  be  shared  between  multiple  lua
              contexts  to  easily pass data between them, as stock Lua doesn't provide easy methods for passing
              data between multiple coroutines.

              inter-task example:

          -- script wide shared queue
          local queue = core.queue()

          -- master task
          core.register_task(function()
            -- send the date every second
            while true do
              queue:push(os.date("%c", core.now().sec))
              core.sleep(1)
            end
          end)

          -- worker task
          core.register_task(function()
            while true do
              -- print the date sent by master
              print(queue:pop_wait())
            end
          end)
          Of course, queue may also be used as a local storage mechanism.

          Use core.queue() to get a new Queue object.

       Queue.size(queue)
              This function returns the number of items within the Queue.

              Argumentsqueue (class_queue()) -- A Queue class to the current queue

       Queue.push(queue, item)
              This function pushes the item (may be of any type) to the queue.  Pushed item  cannot  be  nil  or
              invalid, or an error will be thrown.

              Argumentsqueue (class_queue()) -- A Queue class to the current queue

              Returns
                     boolean true for success and false for error

       Queue.pop(queue)
              This  function  immediately  tries  to  pop  an item from the queue.  It returns nil of no item is
              available at the time of the call.

              Argumentsqueue (class_queue()) -- A Queue class to the current queue

              Returns
                     the item at the top of the stack (any type) or nil if no items

       Queue.pop_wait(queue)
              context: task

              This is an alternative to pop() that may be used within task contexts.

              The call waits for data if no item is currently available. This may be useful when used in a while
              loop to prevent cpu waste.

              Note that this requires yielding, thus it is only available within contexts that support  yielding
              (mainly task context).

              Argumentsqueue (class_queue()) -- A Queue class to the current queue

              Returns
                     the item at the top of the stack (any type) or nil in case of error

       class Concat()
              This  class  provides  a fast way for string concatenation. The way using native Lua concatenation
              like the code below is slow for some reasons.

          str = "string1"
          str = str .. ", string2"
          str = str .. ", string3"
          For each concatenation, Lua: - allocates memory for the result, - catenates the two string copying the
          strings in the new memory block, - frees the old memory block containing the string which is no longer
          used.

          This process does many memory move, allocation and free. In addition, the memory is not really  freed,
          it is just marked as unused and waits for the garbage collector.

          The  Concat  class  provides  an  alternative  way  to  concatenate  strings. It uses the internal Lua
          mechanism (it does not allocate memory), but it doesn't copy the data more than once.

          On my computer, the following loops spends 0.2s for the Concat method  and  18.5s  for  the  pure  Lua
          implementation. So, the Concat class is about 1000x faster than the embedded solution.

          for j = 1, 100 do
            c = core.concat()
            for i = 1, 20000 do
              c:add("#####")
            end
          end

          for j = 1, 100 do
            c = ""
            for i = 1, 20000 do
              c = c .. "#####"
            end
          end

       Concat.add(concat, string)
              This function adds a string to the current concatenated string.

              Argumentsconcat (class_concat()) -- A Concat class which contains the currently built string.

                     • string (string()) -- A new string to concatenate to the current built string.

       Concat.dump(concat)
              This function returns the concatenated string.

              Argumentsconcat (class_concat()) -- A Concat class which contains the currently built string.

              Returns
                     the concatenated string

       class Fetches()
              This  class contains a lot of internal HAProxy sample fetches. See the HAProxy "configuration.txt"
              documentation for more information.  (chapters 7.3.2 to 7.3.6)

              WARNING:
                 some sample fetches are not available in some context. These limitations are specified in  this
                 documentation when they're useful.

              See    TXN.f

              See    TXN.sf

              Fetches are useful to:

              • get system time,

              • get environment variable,

              • get random numbers,

              • know backend status like the number of users in queue or the number of connections established,

              • get client information like ip source or destination,

              • deal with stick tables,

              • fetch established SSL information,

              • fetch HTTP information like headers or method.

          function action(txn)
            -- Get source IP
            local clientip = txn.f:src()
          end

       class Converters()
              This  class  contains  a  lot of internal HAProxy sample converters. See the HAProxy documentation
              "configuration.txt" for more information about her usage. Its the chapter 7.3.1.

              See    TXN.c

              See    TXN.sc

              Converters provides stateful transformation. They are useful to:

              • convert input to base64,

              • apply hash on input string (djb2, crc32, sdbm, wt6),

              • format date,

              • json escape,

              • extract preferred language comparing two lists,

              • turn to lower or upper chars,

              • deal with stick tables.

       class Channel()
              context: action, sample-fetch, convert, filter

              HAProxy uses two buffers for the processing of the requests.  The  first  one  is  used  with  the
              request  data  (from  the client to the server) and the second is used for the response data (from
              the server to the client).

              Each buffer contains two types of data. The  first  type  is  the  incoming  data  waiting  for  a
              processing.  The second part is the outgoing data already processed. Usually, the incoming data is
              processed, after it is tagged as outgoing data, and finally it is sent.  The  following  functions
              provides tools for manipulating these data in a buffer.

              The following diagram shows where the channel class function are applied.  [image]

              WARNING:
                 It  is not possible to read from the response in request action, and it is not possible to read
                 from the request channel in response action.

              WARNING:
                 It is forbidden to alter the Channels buffer from  HTTP  contexts.   So  only  Channel.input(),
                 Channel.output(),  Channel.may_recv(),  Channel.is_full()  and  Channel.is_resp() can be called
                 from a HTTP context.

              All the functions provided by this class are available in the sample-fetches, actions and  filters
              contexts.  For  filters,  incoming  data  (offset  and  length)  are  relative to the filter. Some
              functions may yield, but only for actions. Yield is not possible  for  sample-fetches,  converters
              and filters.

       Channel.append(channel, string)
              This  function  copies  the  string  string at the end of incoming data of the channel buffer. The
              function returns the copied length on success or -1 if data cannot be copied.

              Same that Channel.insert(channel, string, channel:input())().

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • string (string()) -- The data to copy at the end of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       Channel.data(channel[, offset[, length]])
              This function returns length bytes of incoming data from  the  channel  buffer,  starting  at  the
              offset offset. The data are not removed from the buffer.

              By  default,  if no length is provided, all incoming data found, starting at the given offset, are
              returned. If length is set to -1, the function tries to retrieve a maximum of data and, if  called
              by  an action, it yields if necessary. It also waits for more data if the requested length exceeds
              the available amount of incoming data. Not providing an offset is the same as setting it to  0.  A
              positive offset is relative to the beginning of incoming data of the channel buffer while negative
              offset is relative to the end.

              If there is no incoming data and the channel can't receive more data, a 'nil' value is returned.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • offset  (integer())  --  optional  The offset in incoming data to start to get data. 0 by
                       default. May be negative to be relative to the end of incoming data.

                     • length (integer()) -- optional The expected length of data to retrieve. All incoming data
                       by default. May be set to -1 to get a maximum of data.

              Returns
                     a string containing the data found or nil.

       Channel.forward(channel, length)
              This function forwards length bytes of data from the  channel  buffer.  If  the  requested  length
              exceeds  the  available  amount of incoming data, and if called by an action, the function yields,
              waiting for more data to forward. It returns the amount of data forwarded.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • int (integer()) -- The amount of data to forward.

       Channel.input(channel)
              This function returns the length of incoming data in the channel buffer. When called by a  filter,
              this value is relative to the filter.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     an integer containing the amount of available bytes.

       Channel.insert(channel, string[, offset])
              This  function  copies  the  string  string  at  the offset offset in incoming data of the channel
              buffer. The function returns the copied length on success or -1 if data cannot be copied.

              By default, if no offset is provided, the string is copied in front of incoming data.  A  positive
              offset  is  relative to the beginning of incoming data of the channel buffer while negative offset
              is relative to their end.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • string (string()) -- The data to copy into incoming data.

                     • offset (integer()) -- optional The offset in incoming data  where  to  copy  data.  0  by
                       default. May be negative to be relative to the end of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       Channel.is_full(channel)
              This function returns true if the channel buffer is full.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a boolean

       Channel.is_resp(channel)
              This function returns true if the channel is the response one.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a boolean

       Channel.line(channel[, offset[, length]])
              This  function  parses  length  bytes  of  incoming data of the channel buffer, starting at offset
              offset, and returns the first line found, including the '\n'.  The data are not removed  from  the
              buffer. If no line is found, all data are returned.

              By  default,  if  no  length  is  provided,  all  incoming data, starting at the given offset, are
              evaluated. If length is set to -1, the function tries to retrieve a maximum of data and, if called
              by an action, yields if necessary. It also waits for more data if the requested length exceeds the
              available amount of incoming data. Not providing an offset is the same  as  setting  it  to  0.  A
              positive offset is relative to the beginning of incoming data of the channel buffer while negative
              offset is relative to the end.

              If there is no incoming data and the channel can't receive more data, a 'nil' value is returned.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • offset  (integer())  -- optional The offset in incoming data to start to parse data. 0 by
                       default. May be negative to be relative to the end of incoming data.

                     • length (integer()) -- optional The length of data to parse. All incoming data by default.
                       May be set to -1 to get a maximum of data.

              Returns
                     a string containing the line found or nil.

       Channel.may_recv(channel)
              This function returns true if the channel may still receive data.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a boolean

       Channel.output(channel)
              This function returns the length of outgoing data of the channel buffer. When called by a  filter,
              this value is relative to the filter.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     an integer containing the amount of available bytes.

       Channel.prepend(channel, string)
              This  function  copies  the  string  string  in  front of incoming data of the channel buffer. The
              function returns the copied length on success or -1 if data cannot be copied.

              Same that Channel.insert(channel, string, 0)().

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • string (string()) -- The data to copy in front of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       Channel.remove(channel[, offset[, length]])
              This function removes length bytes of incoming data of the  channel  buffer,  starting  at  offset
              offset. This function returns number of bytes removed on success.

              By  default,  if  no  length  is  provided,  all  incoming data, starting at the given offset, are
              removed. Not providing an offset is the same as setting it to 0. A positive offset is relative  to
              the beginning of incoming data of the channel buffer while negative offset is relative to the end.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • offset (integer()) -- optional The offset in incoming data where to start to remove data.
                       0 by default. May be negative to be relative to the end of incoming data.

                     • length  (integer())  --  optional  The  length  of  data  to remove. All incoming data by
                       default.

              Returns
                     an integer containing the amount of bytes removed.

       Channel.send(channel, string)
              This function requires immediate send of the string string. It means the string is copied  at  the
              beginning  of  incoming  data  of  the  channel  buffer  and  immediately forwarded. Unless if the
              connection is close, and if called by an action, this function yields to copy and forward all  the
              string.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • string (string()) -- The data to send.

              Returns
                     an integer containing the amount of bytes copied or -1.

       Channel.set(channel, string[, offset[, length]])
              This  function  replaces  length  bytes of incoming data of the channel buffer, starting at offset
              offset, by the string string. The function returns the copied length on  success  or  -1  if  data
              cannot be copied.

              By  default,  if  no  length  is  provided,  all  incoming data, starting at the given offset, are
              replaced. Not providing an offset is the same as setting it to 0. A positive offset is relative to
              the beginning of incoming data of the channel buffer while negative offset is relative to the end.

              Argumentschannel (class_channel()) -- The manipulated Channel.

                     • string (string()) -- The data to copy into incoming data.

                     • offset (integer()) -- optional The offset in  incoming  data  where  to  start  the  data
                       replacement. 0 by default. May be negative to be relative to the end of incoming data.

                     • length  (integer())  --  optional  The  length  of  data to replace. All incoming data by
                       default.

              Returns
                     an integer containing the amount of bytes copied or -1.

       Channel.dup(channel)
              DEPRECATED

              This function returns all incoming data found in the channel buffer. The data are not removed from
              the buffer and can be reprocessed later.

              If there is no incoming data and the channel can't receive more data, a 'nil' value is returned.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a string containing all data found or nil.

              WARNING:
                 This function is deprecated. Channel.data() must be used instead.

       Channel.get(channel)
              DEPRECATED

              This function returns all incoming data found in the channel  buffer  and  remove  them  from  the
              buffer.

              If there is no incoming data and the channel can't receive more data, a 'nil' value is returned.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a string containing all the data found or nil.

              WARNING:
                 This function is deprecated. Channel.data() must be used to retrieve data followed by a call to
                 Channel:remove() to remove data.

                     local data = chn:data()
                     chn:remove(0, data:len())

       Channel.getline(channel)
              DEPRECATED

              This  function  returns the first line found in incoming data of the channel buffer, including the
              '\n'. The returned data are removed from the buffer. If no line is found,  and  if  called  by  an
              action, this function yields to wait for more data, except if the channel can't receive more data.
              In this case all data are returned.

              If there is no incoming data and the channel can't receive more data, a 'nil' value is returned.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     a string containing the line found or nil.

              WARNING:
                 This  function is deprecated. Channel.line() must be used to retrieve a line followed by a call
                 to Channel:remove() to remove data.

                     local line = chn:line(0, -1)
                     chn:remove(0, line:len())

       Channel.get_in_len(channel)
              DEPRECATED

              This function returns the length of the input part of the buffer. When called by  a  filter,  this
              value is relative to the filter.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     an integer containing the amount of available bytes.

              WARNING:
                 This function is deprecated. Channel.input() must be used instead.

       Channel.get_out_len(channel)
              DEPRECATED

              This  function  returns the length of the output part of the buffer. When called by a filter, this
              value is relative to the filter.

              Argumentschannel (class_channel()) -- The manipulated Channel.

              Returns
                     an integer containing the amount of available bytes.

              WARNING:
                 This function is deprecated. Channel.output() must be used instead.

       class HTTP()
              This class contain all the HTTP manipulation functions.

       HTTP.req_get_headers(http)
              Returns a table containing all the request headers.

              Argumentshttp (class_http()) -- The related http object.

              Returns
                     table of headers.

              See    HTTP.res_get_headers()

              This is the form of the returned table:

          HTTP:req_get_headers()['<header-name>'][<header-index>] = "<header-value>"

          local hdr = HTTP:req_get_headers()
          hdr["host"][0] = "www.test.com"
          hdr["accept"][0] = "audio/basic q=1"
          hdr["accept"][1] = "audio/*, q=0.2"
          hdr["accept"][2] = "*/*, q=0.1"

       HTTP.res_get_headers(http)
              Returns a table containing all the response headers.

              Argumentshttp (class_http()) -- The related http object.

              Returns
                     table of headers.

              See    HTTP.req_get_headers()

              This is the form of the returned table:

          HTTP:res_get_headers()['<header-name>'][<header-index>] = "<header-value>"

          local hdr = HTTP:req_get_headers()
          hdr["host"][0] = "www.test.com"
          hdr["accept"][0] = "audio/basic q=1"
          hdr["accept"][1] = "audio/*, q=0.2"
          hdr["accept"][2] = "*.*, q=0.1"

       HTTP.req_add_header(http, name, value)
              Appends a HTTP header field in the request whose name is specified in "name" and  whose  value  is
              defined in "value".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

              See    HTTP.res_add_header()

       HTTP.res_add_header(http, name, value)
              Appends  a  HTTP header field in the response whose name is specified in "name" and whose value is
              defined in "value".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

              See    HTTP.req_add_header()

       HTTP.req_del_header(http, name)
              Removes all HTTP header fields in the request whose name is specified in "name".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

              See    HTTP.res_del_header()

       HTTP.res_del_header(http, name)
              Removes all HTTP header fields in the response whose name is specified in "name".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

              See    HTTP.req_del_header()

       HTTP.req_set_header(http, name, value)
              This variable replace all occurrence of all header "name", by only one containing the "value".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

              See    HTTP.res_set_header()

              This function does the same work as the following code:

          function fcn(txn)
             TXN.http:req_del_header("header")
             TXN.http:req_add_header("header", "value")
          end

       HTTP.res_set_header(http, name, value)
              This function replaces all occurrence of all header "name", by only one containing the "value".

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

              See    HTTP.req_rep_header()

       HTTP.req_rep_header(http, name, regex, replace)
              Matches the regular expression in all occurrences of header field "name" according to "regex", and
              replaces them with the "replace" argument. The replacement value can contain back references  like
              1, 2, ... This function works with the request.

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • regex (string()) -- The match regular expression.

                     • replace (string()) -- The replacement value.

              See    HTTP.res_rep_header()

       HTTP.res_rep_header(http, name, regex, string)
              Matches the regular expression in all occurrences of header field "name" according to "regex", and
              replaces  them with the "replace" argument. The replacement value can contain back references like
              1, 2, ... This function works with the request.

              Argumentshttp (class_http()) -- The related http object.

                     • name (string()) -- The header name.

                     • regex (string()) -- The match regular expression.

                     • replace (string()) -- The replacement value.

              See    HTTP.req_rep_header()

       HTTP.req_set_method(http, method)
              Rewrites the request method with the parameter "method".

              Argumentshttp (class_http()) -- The related http object.

                     • method (string()) -- The new method.

       HTTP.req_set_path(http, path)
              Rewrites the request path with the "path" parameter.

              Argumentshttp (class_http()) -- The related http object.

                     • path (string()) -- The new path.

       HTTP.req_set_query(http, query)
              Rewrites the request's query string which appears after the first question  mark  ("?")  with  the
              parameter "query".

              Argumentshttp (class_http()) -- The related http object.

                     • query (string()) -- The new query.

       HTTP.req_set_uri(http, uri)
              Rewrites the request URI with the parameter "uri".

              Argumentshttp (class_http()) -- The related http object.

                     • uri (string()) -- The new uri.

       HTTP.res_set_status(http, status[, reason])
              Rewrites the response status code with the parameter "code".

              If no custom reason is provided, it will be generated from the status.

              Argumentshttp (class_http()) -- The related http object.

                     • status (integer()) -- The new response status code.

                     • reason (string()) -- The new response reason (optional).

       class HTTPClient()
              The  httpclient  class  allows  issue  of  outbound HTTP requests through a simple API without the
              knowledge of HAProxy internals.

       HTTPClient.get(httpclient, request)

       HTTPClient.head(httpclient, request)

       HTTPClient.put(httpclient, request)

       HTTPClient.post(httpclient, request)

       HTTPClient.delete(httpclient, request)
              Send a HTTP request and wait for a response. GET, HEAD PUT, POST and DELETE methods can  be  used.
              The HTTPClient will send asynchronously the data and is able to send and receive more than HAProxy
              bufsize.

              The  HTTPClient  interface  is  not able to decompress responses, it is not recommended to send an
              Accept-Encoding in the request so the response is received uncompressed.

              Argumentshttpclient (class()) -- Is the manipulated HTTPClient.

                     • request (table()) -- Is a table containing the parameters of the  request  that  will  be
                       send.

                     • request.url (string()) -- Is a mandatory parameter for the request that contains the URL.

                     • request.body  (string())  --  Is  an optional parameter for the request that contains the
                       body to send.

                     • request.headers (table()) -- Is an optional parameter for the request that  contains  the
                       headers to send.

                     • request.dst (string()) -- Is an optional parameter for the destination in haproxy address
                       format.

                     • request.timeout  (integer()) -- Optional timeout parameter, set a "timeout server" on the
                       connections.

              Returns
                     Lua table containing the response

          local httpclient = core.httpclient()
          local response = httpclient:post{url="http://127.0.0.1", body=body, dst="unix@/var/run/http.sock"}

          response = {
             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>",
           }

       class TXN()
              The txn class contain all the functions relative to the http or tcp transaction (Note than  a  tcp
              stream  is  the  same  than  a  tcp transaction, but a HTTP transaction is not the same than a tcp
              stream).

              The usage of this class permits to retrieve data from the requests, alter it and forward it.

              All the functions provided by this class are available in the context sample-fetches, actions  and
              filters.

       TXN.c

              Returns
                     An Converters class.

              This attribute contains a Converters class object.

       TXN.sc

              Returns
                     An Converters class.

              This  attribute  contains a Converters class object. The functions of this object returns always a
              string.

       TXN.f

              Returns
                     An Fetches class.

              This attribute contains a Fetches class object.

       TXN.sf

              Returns
                     An Fetches class.

              This attribute contains a Fetches class object. The functions of  this  object  returns  always  a
              string.

       TXN.req

              Returns
                     An Channel class.

              This attribute contains a channel class object for the request buffer.

       TXN.res

              Returns
                     An Channel class.

              This attribute contains a channel class object for the response buffer.

       TXN.http

              Returns
                     An HTTP class.

              This attribute contains a HTTP class object. It is available only if the proxy has the "mode http"
              enabled.

       TXN.http_req

              Returns
                     An HTTPMessage class.

              This  attribute  contains  the request HTTPMessage class object. It is available only if the proxy
              has the "mode http" enabled and only in the filters context.

       TXN.http_res

              Returns
                     An HTTPMessage class.

              This attribute contains the response HTTPMessage class object. It is available only if  the  proxy
              has the "mode http" enabled and only in the filters context.

       TXN.log(TXN, loglevel, msg)
              This  function sends a log. The log is sent, according with the HAProxy configuration file, to the
              loggers relevant to the current context and to stderr if it is allowed.

              The exact behaviour depends on tune.lua.log.loggers and tune.lua.log.stderr.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • loglevel (integer()) -- Is the log level associated with the  message.  It  is  a  number
                       between 0 and 7.

                     • msg (string()) -- The log content.

              See    core.emerg,   core.alert,   core.crit,   core.err,  core.warning,  core.notice,  core.info,
                     core.debug (log level definitions)

              See    TXN.deflog()

              See    TXN.Debug()

              See    TXN.Info()

              See    TXN.Warning()

              See    TXN.Alert()

       TXN.deflog(TXN, msg)
              Sends a log line with the default loglevel for the proxy associated with the transaction.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • msg (string()) -- The log content.

              See    TXN.log()

       TXN.Debug(txn, msg)

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • msg (string()) -- The log content.

              See    TXN.log()

              Does the same job as:

          function Debug(txn, msg)
            TXN.log(txn, core.debug, msg)
          end

       TXN.Info(txn, msg)

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • msg (string()) -- The log content.

              See    TXN.log()

              Does the same job as:

          function Info(txn, msg)
            TXN.log(txn, core.info, msg)
          end

       TXN.Warning(txn, msg)

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • msg (string()) -- The log content.

              See    TXN.log()

              Does the same job as:

          function Warning(txn, msg)
            TXN.log(txn, core.warning, msg)
          end

       TXN.Alert(txn, msg)

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • msg (string()) -- The log content.

              See    TXN.log()

              Does the same job as:

          function Alert(txn, msg)
            TXN.log(txn, core.alert, msg)
          end

       TXN.get_priv(txn)
              Return Lua data stored in the current transaction (with the TXN.set_priv()) function. If  no  data
              are stored, it returns a nil value.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

              Returns
                     the opaque data previously stored, or nil if nothing is available.

       TXN.set_priv(txn, data)
              Store any data in the current HAProxy transaction. This action replaces the old stored data.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • data (opaque()) -- The data which is stored in the transaction.

       TXN.set_var(TXN, var, value[, ifexist])
              Converts a Lua type in a HAProxy type and store it in a variable <var>.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • var (string()) -- The variable name according with the HAProxy variable syntax.

                     • value  (type())  --  The  value  associated  to  the  variable. The type can be string or
                       integer.

                     • ifexist (boolean()) -- If this parameter is set to true the variable will only be set  if
                       it  was  defined  elsewhere  (i.e.  used within the configuration).  For global variables
                       (using the "proc" scope), they will only be updated  and  never  created.  It  is  highly
                       recommended to always set this to true.

       TXN.unset_var(TXN, var)
              Unset the variable <var>.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • var (string()) -- The variable name according with the HAProxy variable syntax.

       TXN.get_var(TXN, var)
              Returns data stored in the variable <var> converter in Lua type.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • var (string()) -- The variable name according with the HAProxy variable syntax.

       TXN.reply([reply])
              Return a new reply object

              Argumentsreply (table()) -- A table containing info to initialize the reply fields.

              Returns
                     A Reply class object.

              The table used to initialized the reply object may contain following entries :

              • status : The reply status code. the code 200 is used by default.

              • reason : The reply reason. The reason corresponding to the status code is used by default.

              • headers  :  A  list  of  headers,  indexed  by  header name. Empty by default. For a given name,
                multiple values are possible, stored in an ordered list.

              • body : The reply body, empty by default.

          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(txn[, reply])
              This function terminates processing of the transaction and the associated session  and  optionally
              reply to the client for HTTP sessions.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • reply (class_reply()) -- The class reply object to return to the client.

              This functions can be used when a critical error is detected or to terminate processing after some
              data  have  been returned to the client (eg: a redirect).  To do so, a reply may be provided. This
              object is optional and may contain a status code, a reason, a header list and a  body.  All  these
              fields  are  optional.  When  not provided, the default values are used. By default, with an empty
              reply object, an empty HTTP 200 response is  returned  to  the  client.  If  no  reply  object  is
              provided,  the transaction is terminated without any reply. If a reply object is provided, it must
              not exceed the buffer size once converted into the internal HTTP representation. Because  for  now
              there is no easy way to be sure it fits, it is probably better to keep it reasonably small.

              The reply object may be fully created in lua or the class Reply may be used to create it.

          local reply = txn:reply()
          reply:set_status(400, "Bad request")
          reply:add_header("content-type", "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)

          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>"
          }

          WARNING:
              It does not make sense to call this function from sample-fetches. In this case the behavior is the
              same  than core.done(): it finishes the Lua execution. The transaction is really aborted only from
              an action registered function.

          see    TXN.reply(), Reply()

       TXN.set_loglevel(txn, loglevel)
              Is used to change the log level of the current request. The "loglevel" must be an integer  between
              0 and 7.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • loglevel (integer()) -- The required log level. This variable can be one of

              See    core.emerg,   core.alert,   core.crit,   core.err,  core.warning,  core.notice,  core.info,
                     core.debug (log level definitions)

       TXN.set_tos(txn, tos)
              Is used to set the TOS or DSCP field value of packets sent to the client to the  value  passed  in
              "tos" on platforms which support this.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • tos (integer()) -- The new TOS os DSCP.

       TXN.set_mark(txn, mark)
              Is  used to set the Netfilter MARK on all packets sent to the client to the value passed in "mark"
              on platforms which support it.

              Argumentstxn (class_txn()) -- The class txn object containing the data.

                     • mark (integer()) -- The mark value.

       TXN.set_priority_class(txn, prio)
              This function adjusts the priority class of the transaction. The value should be within the  range
              -2047..2047. Values outside this range will be truncated.

              See  the  HAProxy  configuration.txt  file  keyword "http-request" action "set-priority-class" for
              details.

       TXN.set_priority_offset(txn, prio)
              This function adjusts the priority offset of the transaction. The value should be within the range
              -524287..524287. Values outside this range will be truncated.

              See the HAProxy configuration.txt file keyword  "http-request"  action  "set-priority-offset"  for
              details.

       class Reply()
              context: action

              This  class  represents  a  HTTP  response  message.  It  provides some methods to enrich it. Once
              converted into the internal HTTP representation, the response message must not exceed  the  buffer
              size.  Because  for  now there is no easy way to be sure it fits, it is probably better to keep it
              reasonably small.

              See tune.bufsize in the configuration manual for details.

          local reply = txn:reply({status = 400}) -- default HTTP 400 reason-phase used
          reply:add_header("content-type", "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>")

          see    TXN.reply()

       Reply.status
              The reply status code. By default, the status code is set to 200.

              Returns
                     integer

       Reply.reason
              The reason string describing the status code.

              Returns
                     string

       Reply.headers
              A table indexing all reply headers by name. To each name is associated an ordered list of values.

              Returns
                     Lua table

          {
            ["content-type"]  = { "text/html" },
            ["cache-control"] = {"no-cache", "no-store" },
            x_header_name     = { "value1", "value2", ... }
            ...
          }

       Reply.body
              The reply payload.

              Returns
                     string

       Reply.set_status(REPLY, status[, reason])
              Set the reply status code and optionally the reason-phrase. If the reason  is  not  provided,  the
              default reason corresponding to the status code is used.

              Argumentsreply (class_reply()) -- The related Reply object.

                     • status (integer()) -- The reply status code.

                     • reason (string()) -- The reply status reason (optional).

       Reply.add_header(REPLY, name, value)
              Add  a  header  to  the reply object. If the header does not already exist, a new entry is created
              with its name as index and a one-element list containing its value as value. Otherwise, the header
              value is appended to the ordered list of values associated to the header name.

              Argumentsreply (class_reply()) -- The related Reply object.

                     • name (string()) -- The header field name.

                     • value (string()) -- The header field value.

       Reply.del_header(REPLY, name)
              Remove all occurrences of a header name from the reply object.

              Argumentsreply (class_reply()) -- The related Reply object.

                     • name (string()) -- The header field name.

       Reply.set_body(REPLY, body)
              Set the reply payload.

              Argumentsreply (class_reply()) -- The related Reply object.

                     • body (string()) -- The reply payload.

       class Socket()
              This class must be compatible  with  the  Lua  Socket  class.  Only  the  'client'  functions  are
              available. See the Lua Socket documentation:

              http://w3.impa.br/~diego/software/luasocket/tcp.html

       Socket.close(socket)
              Closes  a  TCP  object.  The internal socket used by the object is closed and the local address to
              which the object was bound is made available to other applications. No further operations  (except
              for further calls to the close method) are allowed on a closed Socket.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

              Note:  It is important to close all used sockets once they are not needed, since, in many systems,
              each socket uses a file descriptor, which are limited system resources. Garbage-collected  objects
              are automatically closed before destruction, though.

       Socket.connect(socket, address[, port])
              Attempts to connect a socket object to a remote host.

              In  case  of  error,  the method returns nil followed by a string describing the error. In case of
              success, the method returns 1.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

                     • address (string()) -- can  be  an  IP  address  or  a  host  name.  See  below  for  more
                       information.

                     • port (integer()) -- must be an integer number in the range [1..64K].

              Returns
                     1 or nil.

              An  address  field extension permits to use the connect() function to connect to other stream than
              TCP. The syntax containing a simpleipv4 or ipv6 address is the  basically  expected  format.  This
              format requires the port.

              Other  format  accepted  are a socket path like "/socket/path", it permits to connect to a socket.
              Abstract namespaces are supported with the prefix "abns@", and finally a file  descriptor  can  be
              passed  with  the  prefix  "fd@".  The prefix "ipv4@", "ipv6@" and "unix@" are also supported. The
              port can be passed int the string. The  syntax  "127.0.0.1:1234"  is  valid.  In  this  case,  the
              parameter port must not be set.

       Socket.connect_ssl(socket, address, port)
              Same behavior than the function socket:connect, but uses SSL.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

              Returns
                     1 or nil.

       Socket.getpeername(socket)
              Returns information about the remote side of a connected client object.

              Returns  a  string with the IP address of the peer, followed by the port number that peer is using
              for the connection. In case of error, the method returns nil.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

              Returns
                     a string containing the server information.

       Socket.getsockname(socket)
              Returns the local address information associated to the object.

              The method returns a string with local IP address and a number with the port.  In case  of  error,
              the method returns nil.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

              Returns
                     a string containing the client information.

       Socket.receive(socket[, pattern[, prefix]])
              Reads data from a client object, according to the specified read pattern.  Patterns follow the Lua
              file I/O format, and the difference in performance between all patterns is negligible.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

                     • pattern (string|integer()) -- Describe what is required (see below).

                     • prefix (string()) -- A string which will be prefix the returned data.

              Returns
                     a string containing the required data or nil.

              Pattern can be any of the following:

              •

                `*a`: reads from the socket until the connection is closed. No
                       end-of-line translation is performed;

              •

                `*l`: reads a line of text from the Socket. The line is terminated by a
                       LF  character (ASCII 10), optionally preceded by a CR character (ASCII 13). The CR and LF
                       characters are not included in the returned line.  In fact, all CR characters are ignored
                       by the pattern. This is the default pattern.

              •

                number: causes the method to read a specified number of bytes from the
                       Socket. Prefix is an optional string to be concatenated to the beginning of any  received
                       data before return.

              • empty: If the pattern is left empty, the default option is *l.

              If  successful,  the method returns the received pattern. In case of error, the method returns nil
              followed by an error message which can be the string 'closed' in case the  connection  was  closed
              before  the  transmission was completed or the string 'timeout' in case there was a timeout during
              the operation. Also, after the error message, the function  returns  the  partial  result  of  the
              transmission.

              Important  note:  This  function was changed severely. It used to support multiple patterns (but I
              have never seen this feature used) and now  it  doesn't  anymore.   Partial  results  used  to  be
              returned  in  the  same  way  as  successful results. This last feature violated the idea that all
              functions should return nil on error.  Thus it was changed too.

       Socket.send(socket, data[, start[, end]])
              Sends data through client object.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

                     • data (string()) -- The data that will be sent.

                     • start (integer()) -- The start position in the buffer of the data which will be sent.

                     • end (integer()) -- The end position in the buffer of the data which will be sent.

              Returns
                     see below.

              Data is the string to be sent. The optional arguments i and  j  work  exactly  like  the  standard
              string.sub Lua function to allow the selection of a substring to be sent.

              If  successful,  the  method  returns the index of the last byte within [start, end] that has been
              sent. Notice that, if start is 1 or absent, this is effectively the total number of bytes sent. In
              case of error, the method returns nil, followed by an error message, followed by the index of  the
              last  byte  within  [start,  end]  that  has  been sent. You might want to try again from the byte
              following that. The error message can be 'closed' in case the connection  was  closed  before  the
              transmission  was  completed  or  the  string  'timeout'  in  case  there was a timeout during the
              operation.

              Note: Output is not buffered. For small strings, it is always better to concatenate  them  in  Lua
              (with  the  '..'  operator)  and send the result in one call instead of calling the method several
              times.

       Socket.setoption(socket, option[, value])
              Just implemented for compatibility, this cal does nothing.

       Socket.settimeout(socket, value[, mode])
              Changes the timeout values for the object. All I/O operations are blocking.  That is, any call  to
              the  methods send, receive, and accept will block indefinitely, until the operation completes. The
              settimeout method defines a limit on the amount of time the I/O methods can block. When a  timeout
              time has elapsed, the affected methods give up and fail with an error code.

              The amount of time to wait is specified as the value parameter, in seconds.

              The  timeout  modes  are not implemented, the only settable timeout is the inactivity time waiting
              for complete the internal buffer send or waiting for receive data.

              Argumentssocket (class_socket()) -- Is the manipulated Socket.

                     • value (float()) -- The timeout value. Use floating point to specify milliseconds.

       class Regex()
              This class allows the usage of HAProxy regexes because classic lua doesn't provides regexes.  This
              class  inherits  the  HAProxy compilation options, so the regexes can be libc regex, pcre regex or
              pcre JIT regex.

              The expression matching number is limited to 20 per regex.  The  only  available  option  is  case
              sensitive.

              Because  regexes  compilation  is  a heavy process, it is better to define all your regexes in the
              body context and use it during the runtime.

          -- Create the regex
          st, regex = Regex.new("needle (..) (...)", true);

          -- Check compilation errors
          if st == false then
            print "error: " .. regex
          end

          -- Match the regexes
          print(regex:exec("Looking for a needle in the haystack")) -- true
          print(regex:exec("Lokking for a cat in the haystack"))    -- false

          -- Extract words
          st, list = regex:match("Looking for a needle in the haystack")
          print(st)      -- true
          print(list[1]) -- needle in the
          print(list[2]) -- in
          print(list[3]) -- the

       Regex.new(regex, case_sensitive)
              Create and compile a regex.

              Argumentsregex (string()) -- The regular expression according with the libc or pcre standard

                     • case_sensitive (boolean()) -- Match is case sensitive or not.

              Returns
                     boolean status and Regex class or string containing fail reason.

       Regex.exec(regex, str)
              Execute the regex.

              Argumentsregex (class_regex()) -- A Regex class object.

                     • str (string()) -- The input string will be compared with the compiled regex.

              Returns
                     a boolean status according with the match result.

       Regex.match(regex, str)
              Execute the regex and return matched expressions.

              Argumentsmap (class_map()) -- A Regex class object.

                     • str (string()) -- The input string will be compared with the compiled regex.

              Returns
                     a boolean status according with the match result, and a table  containing  all  the  string
                     matched in order of declaration.

       class Map()
              This  class  permits  to do some lookups in HAProxy maps. The declared maps can be modified during
              the runtime through the HAProxy management socket.

          default = "usa"

          -- Create and load map
          geo = Map.new("geo.map", Map._ip);

          -- Create new fetch that returns the user country
          core.register_fetches("country", function(txn)
            local src;
            local loc;

            src = txn.f:fhdr("x-forwarded-for");
            if (src == nil) then
              src = txn.f:src()
              if (src == nil) then
                return default;
              end
            end

            -- Perform lookup
            loc = geo:lookup(src);

            if (loc == nil) then
              return default;
            end

            return loc;
          end);

       Map._int
              See the HAProxy configuration.txt file, chapter "Using ACLs and fetching samples"  and  subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.int is also available for compatibility.

       Map._ip
              See  the  HAProxy configuration.txt file, chapter "Using ACLs and fetching samples" and subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.ip is also available for compatibility.

       Map._str
              See the HAProxy configuration.txt file, chapter "Using ACLs and fetching samples"  and  subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.str is also available for compatibility.

       Map._beg
              See  the  HAProxy configuration.txt file, chapter "Using ACLs and fetching samples" and subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.beg is also available for compatibility.

       Map._sub
              See the HAProxy configuration.txt file, chapter "Using ACLs and fetching samples"  and  subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.sub is also available for compatibility.

       Map._dir
              See  the  HAProxy configuration.txt file, chapter "Using ACLs and fetching samples" and subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.dir is also available for compatibility.

       Map._dom
              See the HAProxy configuration.txt file, chapter "Using ACLs and fetching samples"  and  subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.dom is also available for compatibility.

       Map._end
              See  the  HAProxy configuration.txt file, chapter "Using ACLs and fetching samples" and subchapter
              "ACL basics" to understand this pattern matching method.

       Map._reg
              See the HAProxy configuration.txt file, chapter "Using ACLs and fetching samples"  and  subchapter
              "ACL basics" to understand this pattern matching method.

              Note that Map.reg is also available for compatibility.

       Map.new(file, method)
              Creates and load a map.

              Argumentsfile (string()) -- Is the file containing the map.

                     • method  (integer())  -- Is the map pattern matching method. See the attributes of the Map
                       class.

              Returns
                     a class Map object.

              See    The Map attributes: Map._int, Map._ip, Map._str, Map._beg,  Map._sub,  Map._dir,  Map._dom,
                     Map._end and Map._reg.

       Map.lookup(map, str)
              Perform a lookup in a map.

              Argumentsmap (class_map()) -- Is the class Map object.

                     • str (string()) -- Is the string used as key.

              Returns
                     a string containing the result or nil if no match.

       Map.slookup(map, str)
              Perform a lookup in a map.

              Argumentsmap (class_map()) -- Is the class Map object.

                     • str (string()) -- Is the string used as key.

              Returns
                     a string containing the result or empty string if no match.

       class AppletHTTP()
              This  class  is used with applets that requires the 'http' mode. The http applet can be registered
              with the core.register_service() function. They are used for processing an  http  request  like  a
              server in back of HAProxy.

              This is an hello world sample code:

          core.register_service("hello-world", "http", function(applet)
             local response = "Hello World !"
             applet:set_status(200)
             applet:add_header("content-length", string.len(response))
             applet:add_header("content-type", "text/plain")
             applet:start_response()
             applet:send(response)
          end)

       AppletHTTP.c

              Returns
                     A Converters class

              This attribute contains a Converters class object.

       AppletHTTP.sc

              Returns
                     A Converters class

              This  attribute  contains  a Converters class object. The functions of this object always return a
              string.

       AppletHTTP.f

              Returns
                     A Fetches class

              This attribute contains a Fetches class object. Note that the applet execution place cannot access
              to a valid HAProxy core HTTP transaction, so some sample fetches related  to  the  HTTP  dependent
              values (hdr, path, ...) are not available.

       AppletHTTP.sf

              Returns
                     A Fetches class

              This  attribute  contains  a  Fetches  class  object. The functions of this object always return a
              string. Note that the  applet  execution  place  cannot  access  to  a  valid  HAProxy  core  HTTP
              transaction,  so some sample fetches related to the HTTP dependent values (hdr, path, ...) are not
              available.

       AppletHTTP.method

              Returns
                     string

              The attribute method returns a string containing the HTTP method.

       AppletHTTP.version

              Returns
                     string

              The attribute version, returns a string containing the HTTP request version.

       AppletHTTP.path

              Returns
                     string

              The attribute path returns a string containing the HTTP request path.

       AppletHTTP.qs

              Returns
                     string

              The attribute qs returns a string containing the HTTP request query string.

       AppletHTTP.length

              Returns
                     integer

              The attribute length returns an integer containing the HTTP body length.

       AppletHTTP.headers

              Returns
                     table

              The attribute headers returns a table containing the HTTP headers. The header names are always  in
              lower  case.  As  the  header name can be encountered more than once in each request, the value is
              indexed with 0 as first index value. The table has this form:

          AppletHTTP.headers['<header-name>'][<header-index>] = "<header-value>"

          AppletHTTP.headers["host"][0] = "www.test.com"
          AppletHTTP.headers["accept"][0] = "audio/basic q=1"
          AppletHTTP.headers["accept"][1] = "audio/*, q=0.2"
          AppletHTTP.headers["accept"][2] = "*/*, q=0.1"

       AppletHTTP.set_status(applet, code[, reason])
              This function sets the HTTP status code for the response. The allowed code are from 100 to 599.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classcode (integer()) -- the status code returned to the client.

                     • reason (string()) -- the status reason returned to the client (optional).

       AppletHTTP.add_header(applet, name, value)
              This function adds a header in the response. Duplicated headers are  not  collapsed.  The  special
              header  content-length  is  used  to  determinate  the  response  length.  If it does not exist, a
              transfer-encoding: chunked is set, and all the write from the function AppletHTTP:send() become  a
              chunk.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classname (string()) -- the header name

                     • value (string()) -- the header value

       AppletHTTP.start_response(applet)
              This  function  indicates  to  the  HTTP engine that it can process and send the response headers.
              After this called we cannot add headers to the  response;  We  cannot  use  the  AppletHTTP:send()
              function if the AppletHTTP:start_response() is not called.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP class

       AppletHTTP.getline(applet)
              This  function  returns  a  string  containing  one  line from the http body. If the data returned
              doesn't contains a final '\n' its assumed than its the last  available  data  before  the  end  of
              stream.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP class

              Returns
                     a string. The string can be empty if we reach the end of the stream.

       AppletHTTP.receive(applet[, size])
              Reads  data  from the HTTP body, according to the specified read size. If the size is missing, the
              function tries to read all the content of the stream until the end. If the size is bigger than the
              http body, it returns the amount of data available.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classsize (integer()) -- the required read size.

              Returns
                     always return a string,the string can be empty is the connection is closed.

       AppletHTTP.send(applet, msg)
              Send the message msg on the http request body.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classmsg (string()) -- the message to send.

       AppletHTTP.get_priv(applet)
              Return Lua data stored in the current transaction. If no data are stored, it returns a nil value.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP class

              Returns
                     the opaque data previously stored, or nil if nothing is available.

              See    AppletHTTP.set_priv()

       AppletHTTP.set_priv(applet, data)
              Store any data in the current HAProxy transaction. This action replaces the old stored data.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classdata (opaque()) -- The data which is stored in the transaction.

              See    AppletHTTP.get_priv()

       AppletHTTP.set_var(applet, var, value[, ifexist])
              Converts a Lua type in a HAProxy type and store it in a variable <var>.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classvar (string()) -- The variable name according with the HAProxy variable syntax.

                     • value (type()) -- The value associated to the variable. The type ca be string or integer.

                     • ifexist (boolean()) -- If this parameter is set to true the variable will only be set  if
                       it  was  defined  elsewhere  (i.e.  used within the configuration).  For global variables
                       (using the "proc" scope), they will only be updated  and  never  created.  It  is  highly
                       recommended to always set this to true.

              See    AppletHTTP.unset_var()

              See    AppletHTTP.get_var()

       AppletHTTP.unset_var(applet, var)
              Unset the variable <var>.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classvar (string()) -- The variable name according with the HAProxy variable syntax.

              See    AppletHTTP.set_var()

              See    AppletHTTP.get_var()

       AppletHTTP.get_var(applet, var)
              Returns data stored in the variable <var> converter in Lua type.

              Argumentsapplet (class_AppletHTTP()) -- An AppletHTTP classvar (string()) -- The variable name according with the HAProxy variable syntax.

              See    AppletHTTP.set_var()

              See    AppletHTTP.unset_var()

       class AppletTCP()
              This  class  is  used  with applets that requires the 'tcp' mode. The tcp applet can be registered
              with the core.register_service() function. They are used for processing a tcp stream like a server
              in back of HAProxy.

       AppletTCP.c

              Returns
                     A Converters class

              This attribute contains a Converters class object.

       AppletTCP.sc

              Returns
                     A Converters class

              This attribute contains a Converters class object. The functions of this object  always  return  a
              string.

       AppletTCP.f

              Returns
                     A Fetches class

              This attribute contains a Fetches class object.

       AppletTCP.sf

              Returns
                     A Fetches class

              This attribute contains a Fetches class object.

       AppletTCP.getline(applet)
              This  function  returns a string containing one line from the stream. If the data returned doesn't
              contains a final '\n' its assumed than its the last available data before the end of stream.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP class

              Returns
                     a string. The string can be empty if we reach the end of the stream.

       AppletTCP.receive(applet[, size])
              Reads data from the TCP stream, according to the specified read size. If the size is missing,  the
              function tries to read all the content of the stream until the end.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classsize (integer()) -- the required read size.

              Returns
                     always return a string, the string can be empty if the connection is closed.

       AppletTCP.send(appletmsg)
              Send the message on the stream.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classmsg (string()) -- the message to send.

       AppletTCP.get_priv(applet)
              Return Lua data stored in the current transaction. If no data are stored, it returns a nil value.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP class

              Returns
                     the opaque data previously stored, or nil if nothing is available.

              See    AppletTCP.set_priv()

       AppletTCP.set_priv(applet, data)
              Store any data in the current HAProxy transaction. This action replaces the old stored data.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classdata (opaque()) -- The data which is stored in the transaction.

              See    AppletTCP.get_priv()

       AppletTCP.set_var(applet, var, value[, ifexist])
              Converts a Lua type in a HAProxy type and stores it in a variable <var>.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classvar (string()) -- The variable name according with the HAProxy variable syntax.

                     • value  (type())  --  The  value  associated  to  the  variable. The type can be string or
                       integer.

                     • ifexist (boolean()) -- If this parameter is set to true the variable will only be set  if
                       it  was  defined  elsewhere  (i.e.  used within the configuration).  For global variables
                       (using the "proc" scope), they will only be updated  and  never  created.  It  is  highly
                       recommended to always set this to true.

              See    AppletTCP.unset_var()

              See    AppletTCP.get_var()

       AppletTCP.unset_var(applet, var)
              Unsets the variable <var>.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classvar (string()) -- The variable name according with the HAProxy variable syntax.

              See    AppletTCP.unset_var()

              See    AppletTCP.set_var()

       AppletTCP.get_var(applet, var)
              Returns data stored in the variable <var> converter in Lua type.

              Argumentsapplet (class_AppletTCP()) -- An AppletTCP classvar (string()) -- The variable name according with the HAProxy variable syntax.

              See    AppletTCP.unset_var()

              See    AppletTCP.set_var()

       class StickTable()
              context: task, action, sample-fetch

              This class can be used to access the HAProxy stick tables from Lua.

       StickTable.info()
              Returns  stick  table  attributes  as a Lua table. See HAProxy documentation for "stick-table" for
              canonical info, or check out example below.

              Returns
                     Lua table

              Assume our table has IPv4 key and gpc0 and conn_rate "columns":

          {
            expire=<int>,  # Value in ms
            size=<int>,    # Maximum table size
            used=<int>,    # Actual number of entries in table
            data={         # Data columns, with types as key, and periods as values
                             (-1 if type is not rate counter)
              conn_rate=<int>,
              gpc0=-1
            },
            length=<int>,  # max string length for string table keys, key length
                           # otherwise
            nopurge=<boolean>, # purge oldest entries when table is full
            type="ip"      # can be "ip", "ipv6", "integer", "string", "binary"
          }

       StickTable.lookup(key)
              Returns stick table entry for given <key>

              Argumentskey (string()) -- Stick table key (IP addresses and strings are supported)

              Returns
                     Lua table

       StickTable.dump([filter])
              Returns all entries in stick table. An optional  filter  can  be  used  to  extract  entries  with
              specific  data  values. Filter is a table with valid comparison operators as keys followed by data
              type name and value pairs.  Check out the HAProxy docs for "show table" for more details. For  the
              reference, the supported operators are:
                 "eq", "ne", "le", "lt", "ge", "gt"

              For  large tables, execution of this function can take a long time (for HAProxy standards). That's
              also true when filter is used, so take care and measure the impact.

              Argumentsfilter (table()) -- Stick table filter

              Returns
                     Stick table entries (table)

              See below for example filter, which contains 4  entries  (or  comparisons).   (Maximum  number  of
              filter entries is 4, defined in the source code)

          local filter = {
            {"gpc0", "gt", 30}, {"gpc1", "gt", 20}}, {"conn_rate", "le", 10}
          }

       class Act()
              context: action

              This  class  contains  all  return codes an action may return. It is the lua equivalent to HAProxy
              "ACT_RET_*" code.

          core.register_action("deny", { "http-req" }, function (txn)
              return act.DENY
           end)

       act.CONTINUE
              This attribute is an integer (0). It instructs HAProxy to continue the current ruleset  processing
              on the message. It is the default return code for a lua action.

              Returns
                     integer

       act.STOP
              This  attribute  is an integer (1). It instructs HAProxy to stop the current ruleset processing on
              the message.

       act.YIELD
              This attribute is  an  integer  (2).  It  instructs  HAProxy  to  temporarily  pause  the  message
              processing. It will be resumed later on the same rule. The corresponding lua script is re-executed
              for the start.

       act.ERROR
              This attribute is an integer (3). It triggers an internal errors The message processing is stopped
              and the transaction is terminated. For HTTP streams, an HTTP 500 error is returned to the client.

              Returns
                     integer

       act.DONE
              This attribute is an integer (4). It instructs HAProxy to stop the message processing.

              Returns
                     integer

       act.DENY
              This attribute is an integer (5). It denies the current message. The message processing is stopped
              and  the  transaction is terminated. For HTTP streams, an HTTP 403 error is returned to the client
              if the deny is returned during the request analysis. During the  response  analysis,  a  HTTP  502
              error is returned and the server response is discarded.

              Returns
                     integer

       act.ABORT
              This attribute is an integer (6). It aborts the current message. The message processing is stopped
              and  the  transaction is terminated. For HTTP streams, HAProxy assumes a response was already sent
              to the client. From the Lua actions point of view, when this code  is  used,  the  transaction  is
              terminated with no reply.

              Returns
                     integer

       act.INVALID
              This  attribute  is  an  integer  (7).  It  triggers an internal errors. The message processing is
              stopped and the transaction is terminated. For HTTP streams, an HTTP 400 error is returned to  the
              client  if the error is returned during the request analysis. During the response analysis, a HTTP
              502 error is returned and the server response is discarded.

              Returns
                     integer

       act:wake_time(milliseconds)
              context: action

              Set the script pause timeout to the specified time, defined in milliseconds.

              Argumentsmilliseconds (integer()) -- the required milliseconds.

              This function may be used when a lua action returns act.YIELD, to force its wake-up at most  after
              the specified number of milliseconds.

       class filter()
              context: filter

              This  class  contains  return  codes  some  filter callback functions may return. It also contains
              configuration flags and some helper functions.  To  understand  how  the  filter  API  works,  see
              doc/internal/filters.txt documentation.

       filter.CONTINUE
              This attribute is an integer (1). It may be returned by some filter callback functions to instruct
              this filtering step is finished for this filter.

       filter.WAIT
              This attribute is an integer (0). It may be returned by some filter callback functions to instruct
              the  filtering  must  be  paused, waiting for more data or for an external event depending on this
              filter.

       filter.ERROR
              This attribute is an integer (-1). It may be returned by some filter callback functions to trigger
              an error.

       filter.FLT_CFG_FL_HTX
              This attribute is a flag corresponding to the filter flag FLT_CFG_FL_HTX. When it  is  set  for  a
              filter, it means the filter is able to filter HTTP streams.

       filter.register_data_filter(chn)
              context: filter

              Enable  the data filtering on the channel chn for the current filter. It may be called at any time
              from any callback functions proceeding the data analysis.

              Argumentschn (class_Channel()) -- A Channel class.

       filter.unregister_data_filter(chn)
              context: filter

              Disable the data filtering on the channel chn for the current filter. It may be called at any time
              from any callback functions.

              Argumentschn (class_Channel()) -- A Channel class.

       filter.wake_time(milliseconds)
              context: filter

              Set the script pause timeout to the specified time, defined in milliseconds.

              Argumentsmilliseconds (integer()) -- the required milliseconds.

              This function may be used from any lua filter callback function to force its wake-up at most after
              the specified number of milliseconds. Especially, when filter.CONTINUE is returned.

       A filters is declared  using  core.register_filter()  function.  The  provided  class  will  be  used  to
       instantiate filters. It may define following attributes:

       •

         id: The filter identifier. It is a string that identifies the filter and is
                optional.

       •

         flags: The filter flags. Only filter.FLT_CFG_FL_HTX may be set
                for now.

       Such  filter  class  must  also  define  all required callback functions in the following list. Note that
       Filter.new() must be defined otherwise the filter is ignored. Others are optional.

       •

         FILTER.new()

         Called to instantiate a new filter. This function must be defined.

         returns
                a Lua object that will be used as filter instance for the current stream.

       •

         FILTER.start_analyze(flt, txn, chn)

         Called when the analysis starts on the channel chn.

       •

         FILTER.end_analyze(flt, txn, chn)

         Called when the analysis ends on the channel chn.

       •

         FILTER.http_headers(flt, txn, http_msg)

         Called just before the HTTP payload analysis and after any processing on  the  HTTP  message  http_msg.
         This callback functions is only called for HTTP streams.

       •

         FILTER.http_payload(flt, txn, http_msg)

         Called  during  the HTTP payload analysis on the HTTP message http_msg. This callback functions is only
         called for HTTP streams.

       •

         FILTER.http_end(flt, txn, http_msg)

         Called after the HTTP payload analysis on the HTTP message http_msg. This callback  functions  is  only
         called for HTTP streams.

       •

         FILTER.tcp_payload(flt, txn, chn)

         Called during the TCP payload analysis on the channel chn.

       Here is a full example:

          Trace = {}
          Trace.id = "Lua trace filter"
          Trace.flags = filter.FLT_CFG_FL_HTX;
          Trace.__index = Trace

          function Trace:new()
              local trace = {}
              setmetatable(trace, Trace)
              trace.req_len = 0
              trace.res_len = 0
              return trace
          end

          function Trace:start_analyze(txn, chn)
              if chn:is_resp() then
                  print("Start response analysis")
              else
                  print("Start request analysis")
              end
              filter.register_data_filter(self, chn)
          end

          function Trace:end_analyze(txn, chn)
              if chn:is_resp() then
                  print("End response analysis: "..self.res_len.." bytes filtered")
              else
                  print("End request analysis: "..self.req_len.." bytes filtered")
              end
          end

          function Trace:http_headers(txn, http_msg)
              stline  = http_msg:get_stline()
              if http_msg.channel:is_resp() then
                  print("response:")
                  print(stline.version.." "..stline.code.." "..stline.reason)
              else
                  print("request:")
                  print(stline.method.." "..stline.uri.." "..stline.version)
              end

              for n, hdrs in pairs(http_msg:get_headers()) do
                  for i,v in pairs(hdrs) do
                      print(n..": "..v)
                  end
              end
              return filter.CONTINUE
          end

          function Trace:http_payload(txn, http_msg)
              body = http_msg:body(-20000)
              if http_msg.channel:is_resp() then
                  self.res_len = self.res_len + body:len()
              else
                  self.req_len = self.req_len + body:len()
              end
          end

          core.register_filter("trace", Trace, function(trace, args)
              return trace
          end)

       class HTTPMessage()
              context: filter

              This  class  contains  all  functions  to  manipulate  a HTTP message. For now, this class is only
              available from a filter context.

       HTTPMessage.add_header(http_msg, name, value)
              Appends a HTTP header field in the HTTP message http_msg whose name is specified in name and whose
              value is defined in value.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

       HTTPMessage.append(http_msg, string)
              This function copies the string string at the end of incoming data of the HTTP  message  http_msg.
              The function returns the copied length on success or -1 if data cannot be copied.

              Same that HTTPMessage.insert(http_msg, string, http_msg:input())().

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • string (string()) -- The data to copy at the end of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       HTTPMessage.body(http_msgl[, offset[, length]])
              This  function  returns  length bytes of incoming data from the HTTP message http_msg, starting at
              the offset offset. The data are not removed from the buffer.

              By default, if no length is provided, all incoming data found, starting at the given  offset,  are
              returned.  If length is set to -1, the function tries to retrieve a maximum of data. Because it is
              called in the filter context, it never yield. Not providing an offset is the same as setting it to
              0. A positive offset is relative to the beginning of incoming  data  of  the  http_message  buffer
              while negative offset is relative to their end.

              If  there  is  no  incoming  data  and  the HTTP message can't receive more data, a 'nil' value is
              returned.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • offset (integer()) -- optional The offset in incoming data to start to  get  data.  0  by
                       default. May be negative to be relative to the end of incoming data.

                     • length  (integer())  --  optional  The expected length of data to retrieve.  All incoming
                       data by default. May be set to -1 to get a maximum of data.

              Returns
                     a string containing the data found or nil.

       HTTPMessage.eom(http_msg)
              This function returns true if the end of message is reached for the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     an integer containing the amount of available bytes.

       HTTPMessage.del_header(http_msg, name)
              Removes all HTTP header fields in the HTTP message http_msg whose name is specified in name.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated http message.

                     • name (string()) -- The header name.

       HTTPMessage.get_headers(http_msg)
              Returns a table containing all the headers of the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated http message.

              Returns
                     table of headers.

              This is the form of the returned table:

          http_msg:get_headers()['<header-name>'][<header-index>] = "<header-value>"

          local hdr = http_msg:get_headers()
          hdr["host"][0] = "www.test.com"
          hdr["accept"][0] = "audio/basic q=1"
          hdr["accept"][1] = "audio/*, q=0.2"
          hdr["accept"][2] = "*.*, q=0.1"

       HTTPMessage.get_stline(http_msg)
              Returns a table containing the start-line of the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated http message.

              Returns
                     the start-line.

              This is the form of the returned table:

          -- for the request :
          {"method" = string, "uri" = string, "version" = string}

          -- for the response:
          {"version" = string, "code" = string, "reason" = string}

       HTTPMessage.forward(http_msg, length)
              This function forwards length bytes of data from the HTTP message http_msg. Because it  is  called
              in  the  filter  context, it never yields. Only available incoming data may be forwarded, event if
              the requested length exceeds the available amount of incoming data. It returns the amount of  data
              forwarded.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • int (integer()) -- The amount of data to forward.

       HTTPMessage.input(http_msg)
              This  function  returns  the  length of incoming data in the HTTP message http_msg from the filter
              point of view.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     an integer containing the amount of available bytes.

       HTTPMessage.insert(http_msg, string[, offset])
              This function copies the string string at the offset offset in incoming data of the  HTTP  message
              http_msg. The function returns the copied length on success or -1 if data cannot be copied.

              By  default,  if no offset is provided, the string is copied in front of incoming data. A positive
              offset is relative to the beginning of incoming data of the HTTP message while negative offset  is
              relative to their end.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • string (string()) -- The data to copy into incoming data.

                     • offset  (integer())  --  optional  The  offset  in incoming data where to copy data. 0 by
                       default. May be negative to be relative to the end of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       HTTPMessage.is_full(http_msg)
              This function returns true if the HTTP message http_msg is full.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     a boolean

       HTTPMessage.is_resp(http_msg)
              This function returns true if the HTTP message http_msg is the response one.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     a boolean

       HTTPMessage.may_recv(http_msg)
              This function returns true if the HTTP message http_msg may still receive data.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     a boolean

       HTTPMessage.output(http_msg)
              This function returns the length of outgoing data of the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

              Returns
                     an integer containing the amount of available bytes.

       HTTPMessage.prepend(http_msg, string)
              This function copies the string string in front of incoming data of the HTTP message http_msg. The
              function returns the copied length on success or -1 if data cannot be copied.

              Same that HTTPMessage.insert(http_msg, string, 0)().

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • string (string()) -- The data to copy in front of incoming data.

              Returns
                     an integer containing the amount of bytes copied or -1.

       HTTPMessage.remove(http_msg[, offset[, length]])
              This function removes length bytes of incoming data of the  HTTP  message  http_msg,  starting  at
              offset offset. This function returns number of bytes removed on success.

              By  default,  if  no  length  is  provided,  all  incoming data, starting at the given offset, are
              removed. Not providing an offset is the same that setting it to 0. A positive offset  is  relative
              to  the  beginning  of  incoming data of the HTTP message while negative offset is relative to the
              end.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • offset (integer()) -- optional The offset in incoming data where to start to remove data.
                       0 by default. May be negative to be relative to the end of incoming data.

                     • length (integer()) -- optional The length  of  data  to  remove.  All  incoming  data  by
                       default.

              Returns
                     an integer containing the amount of bytes removed.

       HTTPMessage.rep_header(http_msg, name, regex, replace)
              Matches  the  regular expression in all occurrences of header field name according to regex regex,
              and replaces them with the string replace.  The replacement value can contain back references like
              1, 2, ... This function acts on whole header lines, regardless of the number of  values  they  may
              contain.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • name (string()) -- The header name.

                     • regex (string()) -- The match regular expression.

                     • replace (string()) -- The replacement value.

       HTTPMessage.rep_value(http_msg, name, regex, replace)
              Matches  the  regular  expression on every comma-delimited value of header field name according to
              regex regex, and replaces them with the string replace.  The replacement value  can  contain  back
              references like 1, 2, ...

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • name (string()) -- The header name.

                     • regex (string()) -- The match regular expression.

                     • replace (string()) -- The replacement value.

       HTTPMessage.send(http_msg, string)
              This  function  requires immediate send of the string string. It means the string is copied at the
              beginning of incoming data of the HTTP message http_msg and immediately forwarded. Because  it  is
              called in the filter context, it never yields.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • string (string()) -- The data to send.

              Returns
                     an integer containing the amount of bytes copied or -1.

       HTTPMessage.set(http_msg, string[, offset[, length]])
              This  function  replaces  length  bytes of incoming data of the HTTP message http_msg, starting at
              offset offset, by the string string. The function returns the copied length on success  or  -1  if
              data cannot be copied.

              By  default,  if  no  length  is  provided,  all  incoming data, starting at the given offset, are
              replaced. Not providing an offset is the same as setting it to 0. A positive offset is relative to
              the beginning of incoming data of the HTTP message while negative offset is relative to the end.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • string (string()) -- The data to copy into incoming data.

                     • offset (integer()) -- optional The offset in  incoming  data  where  to  start  the  data
                       replacement. 0 by default. May be negative to be relative to the end of incoming data.

                     • length  (integer())  --  optional  The  length  of  data to replace. All incoming data by
                       default.

              Returns
                     an integer containing the amount of bytes copied or -1.

       HTTPMessage.set_eom(http_msg)
              This function set the end of message for the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

       HTTPMessage.set_header(http_msg, name, value)
              This variable replace all occurrence of all header matching the name name, by only one  containing
              the value value.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • name (string()) -- The header name.

                     • value (string()) -- The header value.

              This function does the same work as the following code:

          http_msg:del_header("header")
          http_msg:add_header("header", "value")

       HTTPMessage.set_method(http_msg, method)
              Rewrites the request method with the string method. The HTTP message http_msg must be the request.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • method (string()) -- The new method.

       HTTPMessage.set_path(http_msg, path)
              Rewrites the request path with the string path. The HTTP message http_msg must be the request.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • method (string()) -- The new method.

       HTTPMessage.set_query(http_msg, query)
              Rewrites  the  request's  query  string which appears after the first question mark ("?") with the
              string query. The HTTP message http_msg must be the request.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • query (string()) -- The new query.

       HTTPMessage.set_status(http_msg, status[, reason])
              Rewrites the response status code with the integer code and optional  the  reason  reason.  If  no
              custom reason is provided, it will be generated from the status. The HTTP message http_msg must be
              the response.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • status (integer()) -- The new response status code.

                     • reason (string()) -- The new response reason (optional).

       HTTPMessage.set_uri(http_msg, uri)
              Rewrites the request URI with the string uri. The HTTP message http_msg must be the request.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

                     • uri (string()) -- The new uri.

       HTTPMessage.unset_eom(http_msg)
              This function remove the end of message for the HTTP message http_msg.

              Argumentshttp_msg (class_httpmessage()) -- The manipulated HTTP message.

       class CertCache()
              This  class allows to update an SSL certificate file in the memory of the current HAProxy process.
              It will do the same as "set ssl cert" + "commit ssl cert" over the HAProxy CLI.

       CertCache.set(certificate)
              This function updates a certificate in memory.

              Argumentscertificate (table()) -- A table containing the fields to update.

                     • certificate.filename (string()) -- The mandatory filename of the certificate  to  update,
                       it must already exist in memory.

                     • certificate.crt  (string())  --  A  certificate  in the PEM format. It can also contain a
                       private key.

                     • certificate.key (string()) -- A private key in the PEM format.

                     • certificate.ocsp (string()) -- An OCSP response in base64. (cf management.txt)

                     • certificate.issuer (string()) -- The certificate of the OCSP issuer.

                     • certificate.sctl (string()) -- An SCTL file.

          CertCache.set{filename="certs/localhost9994.pem.rsa", crt=crt}

       A lot of useful lua libraries can be found here:

       • Lua toolbox has been superseded by https://luarocks.org/

         The old  lua  toolbox  source  code  is  still  available  here  https://github.com/catwell/lua-toolbox
         (DEPRECATED)

       Redis client library:

       • https://github.com/nrk/redis-lua

       This  is  an  example  about  the  usage of the Redis library within HAProxy.  Note that each call to any
       function of this library can throw an error if the socket connection fails.

          -- load the redis library
          local redis = require("redis");

          function do_something(txn)

             -- create and connect new tcp socket
             local tcp = core.tcp();
             tcp:settimeout(1);
             tcp:connect("127.0.0.1", 6379);

             -- use the redis library with this new socket
             local client = redis.connect({socket=tcp});
             client:ping();

          end

       OpenSSL:

       • http://mkottman.github.io/luacrypto/index.htmlhttps://github.com/brunoos/luasec/wiki

AUTHOR

       Thierry FOURNIER

COPYRIGHT

       2025, Thierry FOURNIER

1.0                                               Apr 09, 2025                                    HAPROXY-LUA(1)