mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-07 23:56:57 +02:00
MINOR: ssl/crtlist: alloc ssl_conf only when a valid keyword is found
crt-list will be enhanced with ckch_conf keywords, however these keywords does not fill the 'ssl_conf' structure. So we don't need to allocate the ssl_conf for every options between [ ] but only when we found a relevant one.
This commit is contained in:
parent
81e54ef197
commit
d308c9a9f6
@ -438,12 +438,6 @@ int crtlist_parse_line(char *line, char **crt_path, struct crtlist_entry *entry,
|
|||||||
cfgerr |= ERR_WARN;
|
cfgerr |= ERR_WARN;
|
||||||
}
|
}
|
||||||
|
|
||||||
ssl_conf = calloc(1, sizeof *ssl_conf);
|
|
||||||
if (!ssl_conf) {
|
|
||||||
memprintf(err, "not enough memory!");
|
|
||||||
cfgerr |= ERR_ALERT | ERR_FATAL;
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cur_arg = ssl_b ? ssl_b : 1;
|
cur_arg = ssl_b ? ssl_b : 1;
|
||||||
@ -451,6 +445,14 @@ int crtlist_parse_line(char *line, char **crt_path, struct crtlist_entry *entry,
|
|||||||
newarg = 0;
|
newarg = 0;
|
||||||
for (i = 0; ssl_crtlist_kws[i].kw != NULL; i++) {
|
for (i = 0; ssl_crtlist_kws[i].kw != NULL; i++) {
|
||||||
if (strcmp(ssl_crtlist_kws[i].kw, args[cur_arg]) == 0) {
|
if (strcmp(ssl_crtlist_kws[i].kw, args[cur_arg]) == 0) {
|
||||||
|
if (!ssl_conf)
|
||||||
|
ssl_conf = calloc(1, sizeof *ssl_conf);
|
||||||
|
if (!ssl_conf) {
|
||||||
|
memprintf(err, "not enough memory!");
|
||||||
|
cfgerr |= ERR_ALERT | ERR_FATAL;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
newarg = 1;
|
newarg = 1;
|
||||||
cfgerr |= ssl_crtlist_kws[i].parse(args, cur_arg, NULL, ssl_conf, from_cli, err);
|
cfgerr |= ssl_crtlist_kws[i].parse(args, cur_arg, NULL, ssl_conf, from_cli, err);
|
||||||
if (cur_arg + 1 + ssl_crtlist_kws[i].skip > ssl_e) {
|
if (cur_arg + 1 + ssl_crtlist_kws[i].skip > ssl_e) {
|
||||||
|
Loading…
Reference in New Issue
Block a user