summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_conf.c
diff options
context:
space:
mode:
authorKonstantin Pavlov <thresh@nginx.com>2019-09-19 19:04:16 +0300
committerKonstantin Pavlov <thresh@nginx.com>2019-09-19 19:04:16 +0300
commitdeb26fa47a9ab1b358938134a8ced8bbc4a083e1 (patch)
tree0bedf8829f003fa4c0101e3421b7184acc1c8343 /src/nxt_conf.c
parentfcb1f851d0b5d1774a6cb876288ea29cfef58618 (diff)
parentdb777d1e7f607d1b0f01dfb73ad0bac12987202b (diff)
downloadunit-deb26fa47a9ab1b358938134a8ced8bbc4a083e1.tar.gz
unit-deb26fa47a9ab1b358938134a8ced8bbc4a083e1.tar.bz2
Merged with the default branch.
Diffstat (limited to 'src/nxt_conf.c')
-rw-r--r--src/nxt_conf.c73
1 files changed, 49 insertions, 24 deletions
diff --git a/src/nxt_conf.c b/src/nxt_conf.c
index 57870838..59eddd77 100644
--- a/src/nxt_conf.c
+++ b/src/nxt_conf.c
@@ -16,6 +16,8 @@
#define NXT_CONF_MAX_SHORT_STRING 14
#define NXT_CONF_MAX_STRING NXT_INT32_T_MAX
+#define NXT_CONF_MAX_TOKEN_LEN 256
+
typedef enum {
NXT_CONF_VALUE_NULL = 0,
@@ -90,6 +92,17 @@ struct nxt_conf_op_s {
};
+typedef struct {
+ u_char *start;
+ u_char *end;
+ nxt_bool_t last;
+ u_char buf[NXT_CONF_MAX_TOKEN_LEN];
+} nxt_conf_path_parse_t;
+
+
+static nxt_int_t nxt_conf_path_next_token(nxt_conf_path_parse_t *parse,
+ nxt_str_t *token);
+
static u_char *nxt_conf_json_skip_space(u_char *start, u_char *end);
static u_char *nxt_conf_json_parse_value(nxt_mp_t *mp, nxt_conf_value_t *value,
u_char *start, u_char *end, nxt_conf_json_error_t *error);
@@ -402,22 +415,11 @@ nxt_conf_type(nxt_conf_value_t *value)
}
-typedef struct {
- u_char *start;
- u_char *end;
- nxt_bool_t last;
-} nxt_conf_path_parse_t;
-
-
-static void nxt_conf_path_next_token(nxt_conf_path_parse_t *parse,
- nxt_str_t *token);
-
-
nxt_conf_value_t *
nxt_conf_get_path(nxt_conf_value_t *value, nxt_str_t *path)
{
nxt_str_t token;
- nxt_int_t index;
+ nxt_int_t ret, index;
nxt_conf_path_parse_t parse;
parse.start = path->start;
@@ -425,7 +427,10 @@ nxt_conf_get_path(nxt_conf_value_t *value, nxt_str_t *path)
parse.last = 0;
do {
- nxt_conf_path_next_token(&parse, &token);
+ ret = nxt_conf_path_next_token(&parse, &token);
+ if (nxt_slow_path(ret != NXT_OK)) {
+ return NULL;
+ }
if (token.length == 0) {
@@ -466,24 +471,38 @@ nxt_conf_get_path(nxt_conf_value_t *value, nxt_str_t *path)
}
-static void
+static nxt_int_t
nxt_conf_path_next_token(nxt_conf_path_parse_t *parse, nxt_str_t *token)
{
- u_char *p, *end;
+ u_char *p, *start, *end;
+ size_t length;
- end = parse->end;
- p = parse->start + 1;
+ start = parse->start + 1;
- token->start = p;
+ p = start;
- while (p < end && *p != '/') {
+ while (p < parse->end && *p != '/') {
p++;
}
parse->start = p;
- parse->last = (p >= end);
+ parse->last = (p >= parse->end);
+
+ length = p - start;
+
+ if (nxt_slow_path(length > NXT_CONF_MAX_TOKEN_LEN)) {
+ return NXT_ERROR;
+ }
+
+ end = nxt_decode_uri(parse->buf, start, length);
+ if (nxt_slow_path(end == NULL)) {
+ return NXT_ERROR;
+ }
- token->length = p - token->start;
+ token->length = end - parse->buf;
+ token->start = parse->buf;
+
+ return NXT_OK;
}
@@ -742,7 +761,7 @@ nxt_conf_op_compile(nxt_mp_t *mp, nxt_conf_op_t **ops, nxt_conf_value_t *root,
nxt_str_t *path, nxt_conf_value_t *value, nxt_bool_t add)
{
nxt_str_t token;
- nxt_int_t index;
+ nxt_int_t ret, index;
nxt_conf_op_t *op, **parent;
nxt_conf_value_t *node;
nxt_conf_path_parse_t parse;
@@ -763,7 +782,10 @@ nxt_conf_op_compile(nxt_mp_t *mp, nxt_conf_op_t **ops, nxt_conf_value_t *root,
*parent = op;
parent = (nxt_conf_op_t **) &op->ctx;
- nxt_conf_path_next_token(&parse, &token);
+ ret = nxt_conf_path_next_token(&parse, &token);
+ if (nxt_slow_path(ret != NXT_OK)) {
+ return NXT_CONF_OP_ERROR;
+ }
switch (root->type) {
@@ -857,7 +879,10 @@ nxt_conf_op_compile(nxt_mp_t *mp, nxt_conf_op_t **ops, nxt_conf_value_t *root,
return NXT_CONF_OP_ERROR;
}
- nxt_conf_set_string(&member->name, &token);
+ ret = nxt_conf_set_string_dup(&member->name, mp, &token);
+ if (nxt_slow_path(ret != NXT_OK)) {
+ return NXT_CONF_OP_ERROR;
+ }
member->value = *value;