blob: 19312db406b4a09a5cd591fea428835e4f329abb [file] [log] [blame]
Thierry FOURNIER322a1242015-08-19 09:07:47 +02001/*
2 * include/proto/action.h
3 * This file contains actions prototypes.
4 *
5 * Copyright (C) 2000-2010 Willy Tarreau - w@1wt.eu
6 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation, version 2.1
10 * exclusively.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
22#ifndef _PROTO_ACTION_H
23#define _PROTO_ACTION_H
24
25#include <types/action.h>
26
27static inline struct action_kw *action_lookup(struct list *keywords, const char *kw)
28{
29 struct action_kw_list *kw_list;
30 int i;
31
32 if (LIST_ISEMPTY(keywords))
33 return NULL;
34
35 list_for_each_entry(kw_list, keywords, list) {
36 for (i = 0; kw_list->kw[i].kw != NULL; i++) {
37 if (kw_list->kw[i].match_pfx &&
38 strncmp(kw, kw_list->kw[i].kw, strlen(kw_list->kw[i].kw)) == 0)
39 return &kw_list->kw[i];
40 if (!strcmp(kw, kw_list->kw[i].kw))
41 return &kw_list->kw[i];
42 }
43 }
44 return NULL;
45}
46
Willy Tarreau83061a82018-07-13 11:56:34 +020047static inline void action_build_list(struct list *keywords,
48 struct buffer *chk)
Thierry FOURNIERab95e652015-10-02 08:24:51 +020049{
50 struct action_kw_list *kw_list;
51 int i;
52 char *p;
53 char *end;
54 int l;
55
Willy Tarreau843b7cb2018-07-13 10:54:26 +020056 p = chk->area;
Thierry FOURNIERab95e652015-10-02 08:24:51 +020057 end = p + chk->size - 1;
58 list_for_each_entry(kw_list, keywords, list) {
59 for (i = 0; kw_list->kw[i].kw != NULL; i++) {
60 l = snprintf(p, end - p, "'%s%s', ", kw_list->kw[i].kw, kw_list->kw[i].match_pfx ? "(*)" : "");
61 if (l > end - p)
62 continue;
63 p += l;
64 }
65 }
Willy Tarreau843b7cb2018-07-13 10:54:26 +020066 if (p > chk->area)
Thierry FOURNIERab95e652015-10-02 08:24:51 +020067 *(p-2) = '\0';
68 else
69 *p = '\0';
70}
71
Christopher Faulet7421b142017-09-18 11:54:51 +020072/* for an action ACT_ACTION_TRK_SC*, return a tracking index starting at zero
73 * for SC0. Unknown actions also return zero.
74 */
75static inline int trk_idx(int trk_action)
76{
77 return trk_action - ACT_ACTION_TRK_SC0;
78}
79
Christopher Faulet78880fb2017-09-18 14:43:55 +020080/* Find and check the target table used by an action ACT_ACTION_TRK_*. This
81 * function should be called during the configuration validity check.
82 *
83 * The function returns 1 in success case, otherwise, it returns 0 and err is
84 * filled.
85 */
86int check_trk_action(struct act_rule *rule, struct proxy *px, char **err);
87
Thierry FOURNIER322a1242015-08-19 09:07:47 +020088#endif /* _PROTO_ACTION_H */