/* * include/proto/action.h * This file contains actions prototypes. * * Copyright (C) 2000-2010 Willy Tarreau - w@1wt.eu * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation, version 2.1 * exclusively. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef _PROTO_ACTION_H #define _PROTO_ACTION_H #include static inline struct action_kw *action_lookup(struct list *keywords, const char *kw) { struct action_kw_list *kw_list; int i; if (LIST_ISEMPTY(keywords)) return NULL; list_for_each_entry(kw_list, keywords, list) { for (i = 0; kw_list->kw[i].kw != NULL; i++) { if (kw_list->kw[i].match_pfx && strncmp(kw, kw_list->kw[i].kw, strlen(kw_list->kw[i].kw)) == 0) return &kw_list->kw[i]; if (!strcmp(kw, kw_list->kw[i].kw)) return &kw_list->kw[i]; } } return NULL; } static inline void action_build_list(struct list *keywords, struct chunk *chk) { struct action_kw_list *kw_list; int i; char *p; char *end; int l; p = chk->str; end = p + chk->size - 1; list_for_each_entry(kw_list, keywords, list) { for (i = 0; kw_list->kw[i].kw != NULL; i++) { l = snprintf(p, end - p, "'%s%s', ", kw_list->kw[i].kw, kw_list->kw[i].match_pfx ? "(*)" : ""); if (l > end - p) continue; p += l; } } if (p > chk->str) *(p-2) = '\0'; else *p = '\0'; } /* for an action ACT_ACTION_TRK_SC*, return a tracking index starting at zero * for SC0. Unknown actions also return zero. */ static inline int trk_idx(int trk_action) { return trk_action - ACT_ACTION_TRK_SC0; } /* Find and check the target table used by an action ACT_ACTION_TRK_*. This * function should be called during the configuration validity check. * * The function returns 1 in success case, otherwise, it returns 0 and err is * filled. */ int check_trk_action(struct act_rule *rule, struct proxy *px, char **err); #endif /* _PROTO_ACTION_H */