summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/nxt_conf_validation.c136
1 files changed, 122 insertions, 14 deletions
diff --git a/src/nxt_conf_validation.c b/src/nxt_conf_validation.c
index 4863d163..ab383abb 100644
--- a/src/nxt_conf_validation.c
+++ b/src/nxt_conf_validation.c
@@ -22,13 +22,12 @@ typedef nxt_int_t (*nxt_conf_vldt_member_t)(nxt_str_t *name,
static nxt_int_t nxt_conf_vldt_listener(nxt_str_t *name,
nxt_conf_value_t *value);
static nxt_int_t nxt_conf_vldt_app(nxt_str_t *name, nxt_conf_value_t *value);
-static nxt_int_t nxt_conf_vldt_app_type(nxt_conf_value_t *value, void *data);
static nxt_int_t nxt_conf_vldt_object(nxt_conf_value_t *value, void *data);
static nxt_int_t nxt_conf_vldt_object_iterator(nxt_conf_value_t *value,
void *data);
-static const nxt_conf_vldt_object_t nxt_conf_root_members[] = {
+static nxt_conf_vldt_object_t nxt_conf_vldt_root_members[] = {
{ nxt_string("listeners"),
NXT_CONF_OBJECT,
&nxt_conf_vldt_object_iterator,
@@ -43,7 +42,7 @@ static const nxt_conf_vldt_object_t nxt_conf_root_members[] = {
};
-static const nxt_conf_vldt_object_t nxt_conf_listener_members[] = {
+static nxt_conf_vldt_object_t nxt_conf_vldt_listener_members[] = {
{ nxt_string("application"),
NXT_CONF_STRING,
NULL,
@@ -53,10 +52,10 @@ static const nxt_conf_vldt_object_t nxt_conf_listener_members[] = {
};
-static const nxt_conf_vldt_object_t nxt_conf_application_members[] = {
+static nxt_conf_vldt_object_t nxt_conf_vldt_python_members[] = {
{ nxt_string("type"),
NXT_CONF_STRING,
- &nxt_conf_vldt_app_type,
+ NULL,
NULL },
{ nxt_string("workers"),
@@ -64,11 +63,96 @@ static const nxt_conf_vldt_object_t nxt_conf_application_members[] = {
NULL,
NULL },
+ { nxt_string("user"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("group"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
{ nxt_string("path"),
NXT_CONF_STRING,
NULL,
NULL },
+ { nxt_string("module"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_null_string, 0, NULL, NULL }
+};
+
+
+static nxt_conf_vldt_object_t nxt_conf_vldt_php_members[] = {
+ { nxt_string("type"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("workers"),
+ NXT_CONF_INTEGER,
+ NULL,
+ NULL },
+
+ { nxt_string("user"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("group"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("root"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("script"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("index"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_null_string, 0, NULL, NULL }
+};
+
+
+static nxt_conf_vldt_object_t nxt_conf_vldt_go_members[] = {
+ { nxt_string("type"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("workers"),
+ NXT_CONF_INTEGER,
+ NULL,
+ NULL },
+
+ { nxt_string("user"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("group"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
+ { nxt_string("executable"),
+ NXT_CONF_STRING,
+ NULL,
+ NULL },
+
{ nxt_null_string, 0, NULL, NULL }
};
@@ -80,29 +164,53 @@ nxt_conf_validate(nxt_conf_value_t *value)
return NXT_ERROR;
}
- return nxt_conf_vldt_object(value, (void *) nxt_conf_root_members);
+ return nxt_conf_vldt_object(value, nxt_conf_vldt_root_members);
}
static nxt_int_t
nxt_conf_vldt_listener(nxt_str_t *name, nxt_conf_value_t *value)
{
- return nxt_conf_vldt_object(value, (void *) nxt_conf_listener_members);
+ return nxt_conf_vldt_object(value, nxt_conf_vldt_listener_members);
}
static nxt_int_t
nxt_conf_vldt_app(nxt_str_t *name, nxt_conf_value_t *value)
{
- return nxt_conf_vldt_object(value, (void *) nxt_conf_application_members);
-}
+ nxt_str_t type;
+ nxt_conf_value_t *type_value;
+ static nxt_str_t type_str = nxt_string("type");
+ static nxt_str_t python_str = nxt_string("python");
+ static nxt_str_t php_str = nxt_string("php");
+ static nxt_str_t go_str = nxt_string("go");
-static nxt_int_t
-nxt_conf_vldt_app_type(nxt_conf_value_t *value, void *data)
-{
- // TODO
- return NXT_OK;
+ type_value = nxt_conf_get_object_member(value, &type_str, NULL);
+
+ if (nxt_slow_path(type_value == NULL)) {
+ return NXT_ERROR;
+ }
+
+ if (nxt_conf_type(type_value) != NXT_CONF_STRING) {
+ return NXT_ERROR;
+ }
+
+ nxt_conf_get_string(type_value, &type);
+
+ if (nxt_strcasestr_eq(&type, &python_str)) {
+ return nxt_conf_vldt_object(value, nxt_conf_vldt_python_members);
+ }
+
+ if (nxt_strcasestr_eq(&type, &php_str)) {
+ return nxt_conf_vldt_object(value, nxt_conf_vldt_php_members);
+ }
+
+ if (nxt_strcasestr_eq(&type, &go_str)) {
+ return nxt_conf_vldt_object(value, nxt_conf_vldt_go_members);
+ }
+
+ return NXT_ERROR;
}