Initial proxy support.
This commit is contained in:
@@ -62,6 +62,8 @@ static nxt_int_t nxt_conf_vldt_action(nxt_conf_validation_t *vldt,
|
||||
nxt_conf_value_t *value, void *data);
|
||||
static nxt_int_t nxt_conf_vldt_pass(nxt_conf_validation_t *vldt,
|
||||
nxt_conf_value_t *value, void *data);
|
||||
static nxt_int_t nxt_conf_vldt_proxy(nxt_conf_validation_t *vldt,
|
||||
nxt_conf_value_t *value, void *data);
|
||||
static nxt_int_t nxt_conf_vldt_routes(nxt_conf_validation_t *vldt,
|
||||
nxt_conf_value_t *value, void *data);
|
||||
static nxt_int_t nxt_conf_vldt_routes_member(nxt_conf_validation_t *vldt,
|
||||
@@ -316,6 +318,11 @@ static nxt_conf_vldt_object_t nxt_conf_vldt_action_members[] = {
|
||||
NULL,
|
||||
NULL },
|
||||
|
||||
{ nxt_string("proxy"),
|
||||
NXT_CONF_VLDT_STRING,
|
||||
&nxt_conf_vldt_proxy,
|
||||
NULL },
|
||||
|
||||
NXT_CONF_VLDT_END
|
||||
};
|
||||
|
||||
@@ -885,10 +892,11 @@ nxt_conf_vldt_action(nxt_conf_validation_t *vldt, nxt_conf_value_t *value,
|
||||
void *data)
|
||||
{
|
||||
nxt_int_t ret;
|
||||
nxt_conf_value_t *pass_value, *share_value;
|
||||
nxt_conf_value_t *pass_value, *share_value, *proxy_value;
|
||||
|
||||
static nxt_str_t pass_str = nxt_string("pass");
|
||||
static nxt_str_t share_str = nxt_string("share");
|
||||
static nxt_str_t proxy_str = nxt_string("proxy");
|
||||
|
||||
ret = nxt_conf_vldt_object(vldt, value, nxt_conf_vldt_action_members);
|
||||
|
||||
@@ -898,11 +906,12 @@ nxt_conf_vldt_action(nxt_conf_validation_t *vldt, nxt_conf_value_t *value,
|
||||
|
||||
pass_value = nxt_conf_get_object_member(value, &pass_str, NULL);
|
||||
share_value = nxt_conf_get_object_member(value, &share_str, NULL);
|
||||
proxy_value = nxt_conf_get_object_member(value, &proxy_str, NULL);
|
||||
|
||||
if (pass_value == NULL && share_value == NULL) {
|
||||
if (pass_value == NULL && share_value == NULL && proxy_value == NULL) {
|
||||
return nxt_conf_vldt_error(vldt, "The \"action\" object must have "
|
||||
"either \"pass\" or \"share\" "
|
||||
"option set.");
|
||||
"either \"pass\" or \"share\" or "
|
||||
"\"proxy\" option set.");
|
||||
}
|
||||
|
||||
return NXT_OK;
|
||||
@@ -992,6 +1001,30 @@ error:
|
||||
}
|
||||
|
||||
|
||||
static nxt_int_t
|
||||
nxt_conf_vldt_proxy(nxt_conf_validation_t *vldt, nxt_conf_value_t *value,
|
||||
void *data)
|
||||
{
|
||||
nxt_str_t name;
|
||||
nxt_sockaddr_t *sa;
|
||||
|
||||
nxt_conf_get_string(value, &name);
|
||||
|
||||
if (nxt_str_start(&name, "http://", 7)) {
|
||||
name.length -= 7;
|
||||
name.start += 7;
|
||||
|
||||
sa = nxt_sockaddr_parse(vldt->pool, &name);
|
||||
if (sa != NULL) {
|
||||
return NXT_OK;
|
||||
}
|
||||
}
|
||||
|
||||
return nxt_conf_vldt_error(vldt, "The \"proxy\" address is invalid \"%V\"",
|
||||
&name);
|
||||
}
|
||||
|
||||
|
||||
static nxt_int_t
|
||||
nxt_conf_vldt_routes(nxt_conf_validation_t *vldt, nxt_conf_value_t *value,
|
||||
void *data)
|
||||
|
||||
Reference in New Issue
Block a user