blob: a9b6498f383ffe376d2e5a013377761ba219d320 [file] [log] [blame]
Thierry FOURNIER6f1fd482015-01-23 14:06:13 +01001#ifndef _TYPES_HLUA_H
2#define _TYPES_HLUA_H
3
Thierry FOURNIERa718b292015-03-04 16:48:34 +01004#ifdef USE_LUA
5
Thierry FOURNIER6f1fd482015-01-23 14:06:13 +01006#include <lua.h>
Thierry FOURNIER7e7ac322015-02-16 19:27:16 +01007#include <lauxlib.h>
8
9#include <types/proxy.h>
10#include <types/server.h>
Thierry FOURNIER6f1fd482015-01-23 14:06:13 +010011
Thierry FOURNIER0efc94c2015-09-16 21:22:28 +020012#define CLASS_CORE "Core"
13#define CLASS_TXN "TXN"
14#define CLASS_FETCHES "Fetches"
15#define CLASS_CONVERTERS "Converters"
16#define CLASS_SOCKET "Socket"
17#define CLASS_CHANNEL "Channel"
18#define CLASS_HTTP "HTTP"
19#define CLASS_MAP "Map"
Thierry FOURNIERf0a64b62015-09-19 12:36:17 +020020#define CLASS_APPLET_TCP "AppletTCP"
Thierry FOURNIERa30b5db2015-09-18 09:04:27 +020021#define CLASS_APPLET_HTTP "AppletHTTP"
Thierry FOURNIER65f34c62015-02-16 20:11:43 +010022
Willy Tarreau87b09662015-04-03 00:22:06 +020023struct stream;
Thierry FOURNIER2ba18a22015-01-23 14:07:08 +010024
Thierry FOURNIERa097fdf2015-03-03 15:17:35 +010025#define HLUA_RUN 0x00000001
Thierry FOURNIER4abd3ae2015-03-03 17:29:06 +010026#define HLUA_CTRLYIELD 0x00000002
Thierry FOURNIERef6a2112015-03-05 17:45:34 +010027#define HLUA_WAKERESWR 0x00000004
Thierry FOURNIER53e08ec2015-03-06 00:35:53 +010028#define HLUA_WAKEREQWR 0x00000008
Thierry FOURNIER0a99b892015-08-26 00:14:17 +020029#define HLUA_EXIT 0x00000010
Thierry FOURNIER7c39ab42015-09-27 22:53:33 +020030#define HLUA_MUST_GC 0x00000020
Thierry FOURNIER380d0932015-01-23 14:27:52 +010031
32enum hlua_exec {
33 HLUA_E_OK = 0,
34 HLUA_E_AGAIN, /* LUA yield, must resume the stack execution later, when
35 the associatedtask is waked. */
36 HLUA_E_ERRMSG, /* LUA stack execution failed with a string error message
37 in the top of stack. */
38 HLUA_E_ERR, /* LUA stack execution failed without error message. */
39};
40
41struct hlua {
42 lua_State *T; /* The LUA stack. */
43 int Tref; /* The reference of the stack in coroutine case.
44 -1 for the main lua stack. */
45 int Mref; /* The reference of the memory context in coroutine case.
46 -1 if the memory context is not used. */
47 int nargs; /* The number of arguments in the stack at the start of execution. */
Thierry FOURNIERa097fdf2015-03-03 15:17:35 +010048 unsigned int flags; /* The current execution flags. */
Thierry FOURNIERc42c1ae2015-03-03 17:17:55 +010049 int wake_time; /* The lua wants to be waked at this time, or before. */
Thierry FOURNIER10770fa2015-09-29 01:59:42 +020050 unsigned int max_time; /* The max amount of execution time for an Lua process, in ms. */
51 unsigned int start_time; /* The ms time when the Lua starts the last execution. */
52 unsigned int run_time; /* Lua total execution time in ms. */
Thierry FOURNIER380d0932015-01-23 14:27:52 +010053 struct task *task; /* The task associated with the lua stack execution.
54 We must wake this task to continue the task execution */
Thierry FOURNIER9ff7e6e2015-01-23 11:08:20 +010055 struct list com; /* The list head of the signals attached to this task. */
Thierry FOURNIER380d0932015-01-23 14:27:52 +010056 struct ebpt_node node;
57};
58
Thierry FOURNIER9ff7e6e2015-01-23 11:08:20 +010059struct hlua_com {
60 struct list purge_me; /* Part of the list of signals to be purged in the
61 case of the LUA execution stack crash. */
62 struct list wake_me; /* Part of list of signals to be targeted if an
63 event occurs. */
64 struct task *task; /* The task to be wake if an event occurs. */
65};
66
Thierry FOURNIERa4a0f3d2015-01-23 12:08:30 +010067/* This is a part of the list containing references to functions
68 * called at the initialisation time.
69 */
70struct hlua_init_function {
71 struct list l;
72 int function_ref;
73};
74
Thierry FOURNIERfa0e5dd2015-02-16 20:19:18 +010075/* This struct contains the lua data used to bind
76 * Lua function on HAProxy hook like sample-fetches
77 * or actions.
78 */
79struct hlua_function {
80 char *name;
81 int function_ref;
82};
83
Thierry FOURNIER258d8aa2015-02-16 20:23:40 +010084/* This struct is used with the structs:
85 * - http_req_rule
86 * - http_res_rule
87 * - tcp_rule
88 * It contains the lua execution configuration.
89 */
90struct hlua_rule {
91 struct hlua_function fcn;
92 char **args;
93};
94
Thierry FOURNIER65f34c62015-02-16 20:11:43 +010095/* This struct contains the pointer provided on the most
96 * of internal HAProxy calls during the processing of
97 * rules, converters and sample-fetches. This struct is
98 * associated with the lua object called "TXN".
99 */
100struct hlua_txn {
Willy Tarreau87b09662015-04-03 00:22:06 +0200101 struct stream *s;
Thierry FOURNIER65f34c62015-02-16 20:11:43 +0100102 struct proxy *p;
Thierry FOURNIERc4eebc82015-11-02 10:01:59 +0100103 int dir; /* SMP_OPT_DIR_{REQ,RES} */
Thierry FOURNIER65f34c62015-02-16 20:11:43 +0100104};
105
Thierry FOURNIERf0a64b62015-09-19 12:36:17 +0200106/* This struct contains the applet context. */
107struct hlua_appctx {
108 struct appctx *appctx;
109 luaL_Buffer b; /* buffer used to prepare strings. */
110 struct hlua_txn htxn;
111};
112
Thierry FOURNIER2694a1a2015-03-11 20:13:36 +0100113/* This struc is used with sample fetches and sample converters. */
114struct hlua_smp {
Willy Tarreau87b09662015-04-03 00:22:06 +0200115 struct stream *s;
Thierry FOURNIER2694a1a2015-03-11 20:13:36 +0100116 struct proxy *p;
Thierry FOURNIER2694a1a2015-03-11 20:13:36 +0100117 int stringsafe;
Thierry FOURNIERc4eebc82015-11-02 10:01:59 +0100118 int dir; /* SMP_OPT_DIR_{REQ,RES} */
Thierry FOURNIER2694a1a2015-03-11 20:13:36 +0100119};
120
Thierry FOURNIER5b8608f2015-02-16 19:43:25 +0100121/* This struct contains data used with sleep functions. */
122struct hlua_sleep {
123 struct task *task; /* task associated with sleep. */
124 struct list com; /* list of signal to wake at the end of sleep. */
125 unsigned int wakeup_ms; /* hour to wakeup. */
126};
127
Thierry FOURNIER7e7ac322015-02-16 19:27:16 +0100128/* This struct is used to create coprocess doing TCP or
Willy Tarreau87b09662015-04-03 00:22:06 +0200129 * SSL I/O. It uses a fake stream.
Thierry FOURNIER7e7ac322015-02-16 19:27:16 +0100130 */
131struct hlua_socket {
Willy Tarreau87b09662015-04-03 00:22:06 +0200132 struct stream *s; /* Stream used for socket I/O. */
Thierry FOURNIER7e7ac322015-02-16 19:27:16 +0100133 luaL_Buffer b; /* buffer used to prepare strings. */
134};
135
Thierry FOURNIERa718b292015-03-04 16:48:34 +0100136#else /* USE_LUA */
137
138/* Empty struct for compilation compatibility */
139struct hlua { };
140struct hlua_socket { };
Thierry FOURNIER231ef1d2015-07-30 19:03:55 +0200141struct hlua_rule { };
Thierry FOURNIERa718b292015-03-04 16:48:34 +0100142
143#endif /* USE_LUA */
144
Thierry FOURNIER6f1fd482015-01-23 14:06:13 +0100145#endif /* _TYPES_HLUA_H */