mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-11-29 06:40:59 +01:00
MINOR: actions: mutualise the action keyword lookup
Each (http|tcp)-(request|response) action use the same method for looking up the action keyword during the cofiguration parsing. This patch mutualize the code.
This commit is contained in:
parent
c2bb050f7f
commit
322a124867
47
include/proto/action.h
Normal file
47
include/proto/action.h
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* 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 <types/action.h>
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* _PROTO_ACTION_H */
|
||||||
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* include/types/action.h
|
* include/types/action.h
|
||||||
* This file contains TCP protocol definitions.
|
* This file contains actions definitions.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000-2010 Willy Tarreau - w@1wt.eu
|
* Copyright (C) 2000-2010 Willy Tarreau - w@1wt.eu
|
||||||
*
|
*
|
||||||
|
|||||||
@ -42,6 +42,7 @@
|
|||||||
#include <types/global.h>
|
#include <types/global.h>
|
||||||
|
|
||||||
#include <proto/acl.h>
|
#include <proto/acl.h>
|
||||||
|
#include <proto/action.h>
|
||||||
#include <proto/arg.h>
|
#include <proto/arg.h>
|
||||||
#include <proto/auth.h>
|
#include <proto/auth.h>
|
||||||
#include <proto/backend.h>
|
#include <proto/backend.h>
|
||||||
@ -12647,21 +12648,7 @@ int parse_http_res_capture(const char **args, int *orig_arg, struct proxy *px, s
|
|||||||
*/
|
*/
|
||||||
struct action_kw *action_http_req_custom(const char *kw)
|
struct action_kw *action_http_req_custom(const char *kw)
|
||||||
{
|
{
|
||||||
if (!LIST_ISEMPTY(&http_req_keywords.list)) {
|
return action_lookup(&http_req_keywords.list, kw);
|
||||||
struct action_kw_list *kw_list;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
list_for_each_entry(kw_list, &http_req_keywords.list, 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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -12669,21 +12656,7 @@ struct action_kw *action_http_req_custom(const char *kw)
|
|||||||
*/
|
*/
|
||||||
struct action_kw *action_http_res_custom(const char *kw)
|
struct action_kw *action_http_res_custom(const char *kw)
|
||||||
{
|
{
|
||||||
if (!LIST_ISEMPTY(&http_res_keywords.list)) {
|
return action_lookup(&http_res_keywords.list, kw);
|
||||||
struct action_kw_list *kw_list;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
list_for_each_entry(kw_list, &http_res_keywords.list, 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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************/
|
/************************************************************************/
|
||||||
|
|||||||
@ -40,6 +40,7 @@
|
|||||||
#include <types/server.h>
|
#include <types/server.h>
|
||||||
|
|
||||||
#include <proto/acl.h>
|
#include <proto/acl.h>
|
||||||
|
#include <proto/action.h>
|
||||||
#include <proto/arg.h>
|
#include <proto/arg.h>
|
||||||
#include <proto/channel.h>
|
#include <proto/channel.h>
|
||||||
#include <proto/connection.h>
|
#include <proto/connection.h>
|
||||||
@ -137,62 +138,17 @@ void tcp_res_cont_keywords_register(struct action_kw_list *kw_list)
|
|||||||
*/
|
*/
|
||||||
static struct action_kw *tcp_req_conn_action(const char *kw)
|
static struct action_kw *tcp_req_conn_action(const char *kw)
|
||||||
{
|
{
|
||||||
struct action_kw_list *kw_list;
|
return action_lookup(&tcp_req_conn_keywords, kw);
|
||||||
int i;
|
|
||||||
|
|
||||||
if (LIST_ISEMPTY(&tcp_req_conn_keywords))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
list_for_each_entry(kw_list, &tcp_req_conn_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 struct action_kw *tcp_req_cont_action(const char *kw)
|
static struct action_kw *tcp_req_cont_action(const char *kw)
|
||||||
{
|
{
|
||||||
struct action_kw_list *kw_list;
|
return action_lookup(&tcp_req_cont_keywords, kw);
|
||||||
int i;
|
|
||||||
|
|
||||||
if (LIST_ISEMPTY(&tcp_req_cont_keywords))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
list_for_each_entry(kw_list, &tcp_req_cont_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 struct action_kw *tcp_res_cont_action(const char *kw)
|
static struct action_kw *tcp_res_cont_action(const char *kw)
|
||||||
{
|
{
|
||||||
struct action_kw_list *kw_list;
|
return action_lookup(&tcp_res_cont_keywords, kw);
|
||||||
int i;
|
|
||||||
|
|
||||||
if (LIST_ISEMPTY(&tcp_res_cont_keywords))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
list_for_each_entry(kw_list, &tcp_res_cont_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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Binds ipv4/ipv6 address <local> to socket <fd>, unless <flags> is set, in which
|
/* Binds ipv4/ipv6 address <local> to socket <fd>, unless <flags> is set, in which
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user