mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-04-11 03:31:36 +00:00
MINOR: guid: restrict guid format
GUID format is unspecified to allow users to choose the naming scheme. Some restrictions however are added by this patch, mainly to ensure coherence and memory usage. The first restriction is on the length of GUID. No more than 127 characters can be used to prevent memory over consumption. The second restriction is on the character set allowed in GUID. Utility function invalid_char() is used for this : it allows alphanumeric values and '-', '_', '.' and ':'.
This commit is contained in:
parent
84fa6b344a
commit
1009ca4160
@ -4,6 +4,9 @@
|
||||
#include <import/ebtree-t.h>
|
||||
#include <haproxy/obj_type-t.h>
|
||||
|
||||
/* Maximum GUID size excluding final '\0' */
|
||||
#define GUID_MAX_LEN 127
|
||||
|
||||
struct guid_node {
|
||||
struct ebpt_node node; /* attach point into GUID global tree */
|
||||
enum obj_type *obj_type; /* pointer to GUID obj owner */
|
||||
|
13
src/guid.c
13
src/guid.c
@ -26,6 +26,18 @@ int guid_insert(enum obj_type *objt, const char *uid, char **errmsg)
|
||||
struct guid_node *dup;
|
||||
struct ebpt_node *node;
|
||||
char *dup_name = NULL;
|
||||
const char *c;
|
||||
|
||||
if (strlen(uid) > GUID_MAX_LEN) {
|
||||
memprintf(errmsg, "UID too big");
|
||||
goto err;
|
||||
}
|
||||
|
||||
c = invalid_char(uid);
|
||||
if (c) {
|
||||
memprintf(errmsg, "invalid character '%c'", c[0]);
|
||||
goto err;
|
||||
}
|
||||
|
||||
switch (obj_type(objt)) {
|
||||
default:
|
||||
@ -52,6 +64,7 @@ int guid_insert(enum obj_type *objt, const char *uid, char **errmsg)
|
||||
return 0;
|
||||
|
||||
err:
|
||||
ALREADY_CHECKED(guid);
|
||||
ha_free(&guid->node.key);
|
||||
ha_free(&dup_name);
|
||||
return 1;
|
||||
|
Loading…
Reference in New Issue
Block a user