From f395017227aae1dd1d9c032fd22eb3240c7cdfbc Mon Sep 17 00:00:00 2001 From: Willy Tarreau Date: Sat, 10 Oct 2009 18:35:51 +0200 Subject: [PATCH] [MINOR] proxy: provide function to retrieve backend/server pointers int get_backend_server(const char *bk_name, const char *sv_name, struct proxy **bk, struct server **sv); This function scans the list of backends and servers to retrieve the first backend and the first server with the given names, and sets them in both parameters. It returns zero if either is not found, or non-zero and sets the ones it did not found to NULL. If a NULL pointer is passed for the backend, only the pointer to the server will be updated. --- include/proto/proxy.h | 2 ++ src/proxy.c | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 34 insertions(+) diff --git a/include/proto/proxy.h b/include/proto/proxy.h index bab3da7e4..d4d4c854c 100644 --- a/include/proto/proxy.h +++ b/include/proto/proxy.h @@ -42,6 +42,8 @@ const char *proxy_mode_str(int mode); struct proxy *findproxy(const char *name, int mode, int cap); struct server *findserver(const struct proxy *px, const char *name); int proxy_cfg_ensure_no_http(struct proxy *curproxy); +int get_backend_server(const char *bk_name, const char *sv_name, + struct proxy **bk, struct server **sv); /* * This function returns a string containing the type of the proxy in a format diff --git a/src/proxy.c b/src/proxy.c index fa6a1973d..e44d3d905 100644 --- a/src/proxy.c +++ b/src/proxy.c @@ -76,6 +76,38 @@ const char *proxy_mode_str(int mode) { return "unknown"; } +/* + * This function scans the list of backends and servers to retrieve the first + * backend and the first server with the given names, and sets them in both + * parameters. It returns zero if either is not found, or non-zero and sets + * the ones it did not found to NULL. If a NULL pointer is passed for the + * backend, only the pointer to the server will be updated. + */ +int get_backend_server(const char *bk_name, const char *sv_name, + struct proxy **bk, struct server **sv) +{ + struct proxy *p; + struct server *s; + + *sv = NULL; + + for (p = proxy; p; p = p->next) + if ((p->cap & PR_CAP_BE) && (strcmp(p->id, bk_name) == 0)) + break; + if (bk) + *bk = p; + if (!p) + return 0; + + for (s = p->srv; s; s = s->next) + if (strcmp(s->id, sv_name) == 0) + break; + *sv = s; + if (!s) + return 0; + return 1; +} + /* This function parses a "timeout" statement in a proxy section. It returns * -1 if there is any error, 1 for a warning, otherwise zero. If it does not * return zero, it may write an error message into the buffer, for at