Proxy: renamed some "proxy_redirect" related declarations to a more general and
reusable. No functional changes.
This commit is contained in:
parent
ddcad9e656
commit
f1dc99c4b9
1 changed files with 45 additions and 45 deletions
|
@ -10,20 +10,20 @@
|
||||||
#include <ngx_http.h>
|
#include <ngx_http.h>
|
||||||
|
|
||||||
|
|
||||||
typedef struct ngx_http_proxy_redirect_s ngx_http_proxy_redirect_t;
|
typedef struct ngx_http_proxy_rewrite_s ngx_http_proxy_rewrite_t;
|
||||||
|
|
||||||
typedef ngx_int_t (*ngx_http_proxy_redirect_pt)(ngx_http_request_t *r,
|
typedef ngx_int_t (*ngx_http_proxy_rewrite_pt)(ngx_http_request_t *r,
|
||||||
ngx_table_elt_t *h, size_t prefix, ngx_http_proxy_redirect_t *pr);
|
ngx_table_elt_t *h, size_t prefix, ngx_http_proxy_rewrite_t *pr);
|
||||||
|
|
||||||
struct ngx_http_proxy_redirect_s {
|
struct ngx_http_proxy_rewrite_s {
|
||||||
ngx_http_proxy_redirect_pt handler;
|
ngx_http_proxy_rewrite_pt handler;
|
||||||
|
|
||||||
union {
|
union {
|
||||||
ngx_http_complex_value_t complex;
|
ngx_http_complex_value_t complex;
|
||||||
#if (NGX_PCRE)
|
#if (NGX_PCRE)
|
||||||
ngx_http_regex_t *regex;
|
ngx_http_regex_t *regex;
|
||||||
#endif
|
#endif
|
||||||
} redirect;
|
} pattern;
|
||||||
|
|
||||||
ngx_http_complex_value_t replacement;
|
ngx_http_complex_value_t replacement;
|
||||||
};
|
};
|
||||||
|
@ -2274,8 +2274,8 @@ ngx_http_proxy_rewrite_redirect(ngx_http_request_t *r, ngx_table_elt_t *h,
|
||||||
{
|
{
|
||||||
ngx_int_t rc;
|
ngx_int_t rc;
|
||||||
ngx_uint_t i;
|
ngx_uint_t i;
|
||||||
|
ngx_http_proxy_rewrite_t *pr;
|
||||||
ngx_http_proxy_loc_conf_t *plcf;
|
ngx_http_proxy_loc_conf_t *plcf;
|
||||||
ngx_http_proxy_redirect_t *pr;
|
|
||||||
|
|
||||||
plcf = ngx_http_get_module_loc_conf(r, ngx_http_proxy_module);
|
plcf = ngx_http_get_module_loc_conf(r, ngx_http_proxy_module);
|
||||||
|
|
||||||
|
@ -2298,20 +2298,20 @@ ngx_http_proxy_rewrite_redirect(ngx_http_request_t *r, ngx_table_elt_t *h,
|
||||||
|
|
||||||
|
|
||||||
static ngx_int_t
|
static ngx_int_t
|
||||||
ngx_http_proxy_rewrite_redirect_complex(ngx_http_request_t *r,
|
ngx_http_proxy_rewrite_complex_handler(ngx_http_request_t *r,
|
||||||
ngx_table_elt_t *h, size_t prefix, ngx_http_proxy_redirect_t *pr)
|
ngx_table_elt_t *h, size_t prefix, ngx_http_proxy_rewrite_t *pr)
|
||||||
{
|
{
|
||||||
size_t len;
|
size_t len;
|
||||||
u_char *data, *p;
|
u_char *data, *p;
|
||||||
ngx_str_t redirect, replacement;
|
ngx_str_t pattern, replacement;
|
||||||
|
|
||||||
if (ngx_http_complex_value(r, &pr->redirect.complex, &redirect) != NGX_OK) {
|
if (ngx_http_complex_value(r, &pr->pattern.complex, &pattern) != NGX_OK) {
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (redirect.len > h->value.len - prefix
|
if (pattern.len > h->value.len - prefix
|
||||||
|| ngx_rstrncmp(h->value.data + prefix, redirect.data,
|
|| ngx_rstrncmp(h->value.data + prefix, pattern.data,
|
||||||
redirect.len) != 0)
|
pattern.len) != 0)
|
||||||
{
|
{
|
||||||
return NGX_DECLINED;
|
return NGX_DECLINED;
|
||||||
}
|
}
|
||||||
|
@ -2320,7 +2320,7 @@ ngx_http_proxy_rewrite_redirect_complex(ngx_http_request_t *r,
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
len = replacement.len + h->value.len - redirect.len;
|
len = replacement.len + h->value.len - pattern.len;
|
||||||
|
|
||||||
data = ngx_pnalloc(r->pool, len);
|
data = ngx_pnalloc(r->pool, len);
|
||||||
if (data == NULL) {
|
if (data == NULL) {
|
||||||
|
@ -2333,8 +2333,8 @@ ngx_http_proxy_rewrite_redirect_complex(ngx_http_request_t *r,
|
||||||
p = ngx_copy(p, replacement.data, replacement.len);
|
p = ngx_copy(p, replacement.data, replacement.len);
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_memcpy(p, h->value.data + prefix + redirect.len,
|
ngx_memcpy(p, h->value.data + prefix + pattern.len,
|
||||||
h->value.len - redirect.len - prefix);
|
h->value.len - pattern.len - prefix);
|
||||||
|
|
||||||
h->value.len = len;
|
h->value.len = len;
|
||||||
h->value.data = data;
|
h->value.data = data;
|
||||||
|
@ -2346,17 +2346,17 @@ ngx_http_proxy_rewrite_redirect_complex(ngx_http_request_t *r,
|
||||||
#if (NGX_PCRE)
|
#if (NGX_PCRE)
|
||||||
|
|
||||||
static ngx_int_t
|
static ngx_int_t
|
||||||
ngx_http_proxy_rewrite_redirect_regex(ngx_http_request_t *r, ngx_table_elt_t *h,
|
ngx_http_proxy_rewrite_regex_handler(ngx_http_request_t *r, ngx_table_elt_t *h,
|
||||||
size_t prefix, ngx_http_proxy_redirect_t *pr)
|
size_t prefix, ngx_http_proxy_rewrite_t *pr)
|
||||||
{
|
{
|
||||||
size_t len;
|
size_t len;
|
||||||
u_char *data;
|
u_char *data;
|
||||||
ngx_str_t redirect, replacement;
|
ngx_str_t pattern, replacement;
|
||||||
|
|
||||||
redirect.len = h->value.len - prefix;
|
pattern.len = h->value.len - prefix;
|
||||||
redirect.data = h->value.data + prefix;
|
pattern.data = h->value.data + prefix;
|
||||||
|
|
||||||
if (ngx_http_regex_exec(r, pr->redirect.regex, &redirect) != NGX_OK) {
|
if (ngx_http_regex_exec(r, pr->pattern.regex, &pattern) != NGX_OK) {
|
||||||
return NGX_DECLINED;
|
return NGX_DECLINED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2507,7 +2507,7 @@ ngx_http_proxy_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
|
||||||
size_t size;
|
size_t size;
|
||||||
ngx_hash_init_t hash;
|
ngx_hash_init_t hash;
|
||||||
ngx_http_core_loc_conf_t *clcf;
|
ngx_http_core_loc_conf_t *clcf;
|
||||||
ngx_http_proxy_redirect_t *pr;
|
ngx_http_proxy_rewrite_t *pr;
|
||||||
ngx_http_script_compile_t sc;
|
ngx_http_script_compile_t sc;
|
||||||
|
|
||||||
if (conf->upstream.store != 0) {
|
if (conf->upstream.store != 0) {
|
||||||
|
@ -2760,7 +2760,7 @@ ngx_http_proxy_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
|
||||||
if (conf->redirects == NULL && conf->url.data) {
|
if (conf->redirects == NULL && conf->url.data) {
|
||||||
|
|
||||||
conf->redirects = ngx_array_create(cf->pool, 1,
|
conf->redirects = ngx_array_create(cf->pool, 1,
|
||||||
sizeof(ngx_http_proxy_redirect_t));
|
sizeof(ngx_http_proxy_rewrite_t));
|
||||||
if (conf->redirects == NULL) {
|
if (conf->redirects == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -2770,27 +2770,27 @@ ngx_http_proxy_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_memzero(&pr->redirect.complex,
|
ngx_memzero(&pr->pattern.complex,
|
||||||
sizeof(ngx_http_complex_value_t));
|
sizeof(ngx_http_complex_value_t));
|
||||||
|
|
||||||
ngx_memzero(&pr->replacement, sizeof(ngx_http_complex_value_t));
|
ngx_memzero(&pr->replacement, sizeof(ngx_http_complex_value_t));
|
||||||
|
|
||||||
pr->handler = ngx_http_proxy_rewrite_redirect_complex;
|
pr->handler = ngx_http_proxy_rewrite_complex_handler;
|
||||||
|
|
||||||
if (conf->vars.uri.len) {
|
if (conf->vars.uri.len) {
|
||||||
pr->redirect.complex.value = conf->url;
|
pr->pattern.complex.value = conf->url;
|
||||||
pr->replacement.value = conf->location;
|
pr->replacement.value = conf->location;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
pr->redirect.complex.value.len = conf->url.len
|
pr->pattern.complex.value.len = conf->url.len
|
||||||
+ sizeof("/") - 1;
|
+ sizeof("/") - 1;
|
||||||
|
|
||||||
p = ngx_pnalloc(cf->pool, pr->redirect.complex.value.len);
|
p = ngx_pnalloc(cf->pool, pr->pattern.complex.value.len);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr->redirect.complex.value.data = p;
|
pr->pattern.complex.value.data = p;
|
||||||
|
|
||||||
p = ngx_cpymem(p, conf->url.data, conf->url.len);
|
p = ngx_cpymem(p, conf->url.data, conf->url.len);
|
||||||
*p = '/';
|
*p = '/';
|
||||||
|
@ -3285,7 +3285,7 @@ ngx_http_proxy_redirect(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
||||||
|
|
||||||
u_char *p;
|
u_char *p;
|
||||||
ngx_str_t *value;
|
ngx_str_t *value;
|
||||||
ngx_http_proxy_redirect_t *pr;
|
ngx_http_proxy_rewrite_t *pr;
|
||||||
ngx_http_compile_complex_value_t ccv;
|
ngx_http_compile_complex_value_t ccv;
|
||||||
|
|
||||||
if (plcf->redirect == 0) {
|
if (plcf->redirect == 0) {
|
||||||
|
@ -3320,7 +3320,7 @@ ngx_http_proxy_redirect(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
||||||
|
|
||||||
if (plcf->redirects == NULL) {
|
if (plcf->redirects == NULL) {
|
||||||
plcf->redirects = ngx_array_create(cf->pool, 1,
|
plcf->redirects = ngx_array_create(cf->pool, 1,
|
||||||
sizeof(ngx_http_proxy_redirect_t));
|
sizeof(ngx_http_proxy_rewrite_t));
|
||||||
if (plcf->redirects == NULL) {
|
if (plcf->redirects == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -3346,25 +3346,25 @@ ngx_http_proxy_redirect(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr->handler = ngx_http_proxy_rewrite_redirect_complex;
|
pr->handler = ngx_http_proxy_rewrite_complex_handler;
|
||||||
|
|
||||||
ngx_memzero(&pr->redirect.complex, sizeof(ngx_http_complex_value_t));
|
ngx_memzero(&pr->pattern.complex, sizeof(ngx_http_complex_value_t));
|
||||||
|
|
||||||
ngx_memzero(&pr->replacement, sizeof(ngx_http_complex_value_t));
|
ngx_memzero(&pr->replacement, sizeof(ngx_http_complex_value_t));
|
||||||
|
|
||||||
if (plcf->vars.uri.len) {
|
if (plcf->vars.uri.len) {
|
||||||
pr->redirect.complex.value = plcf->url;
|
pr->pattern.complex.value = plcf->url;
|
||||||
pr->replacement.value = plcf->location;
|
pr->replacement.value = plcf->location;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
pr->redirect.complex.value.len = plcf->url.len + sizeof("/") - 1;
|
pr->pattern.complex.value.len = plcf->url.len + sizeof("/") - 1;
|
||||||
|
|
||||||
p = ngx_pnalloc(cf->pool, pr->redirect.complex.value.len);
|
p = ngx_pnalloc(cf->pool, pr->pattern.complex.value.len);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr->redirect.complex.value.data = p;
|
pr->pattern.complex.value.data = p;
|
||||||
|
|
||||||
p = ngx_cpymem(p, plcf->url.data, plcf->url.len);
|
p = ngx_cpymem(p, plcf->url.data, plcf->url.len);
|
||||||
*p = '/';
|
*p = '/';
|
||||||
|
@ -3396,12 +3396,12 @@ ngx_http_proxy_redirect(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
||||||
rc.err.len = NGX_MAX_CONF_ERRSTR;
|
rc.err.len = NGX_MAX_CONF_ERRSTR;
|
||||||
rc.err.data = errstr;
|
rc.err.data = errstr;
|
||||||
|
|
||||||
pr->redirect.regex = ngx_http_regex_compile(cf, &rc);
|
pr->pattern.regex = ngx_http_regex_compile(cf, &rc);
|
||||||
if (pr->redirect.regex == NULL) {
|
if (pr->pattern.regex == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr->handler = ngx_http_proxy_rewrite_redirect_regex;
|
pr->handler = ngx_http_proxy_rewrite_regex_handler;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
|
@ -3416,13 +3416,13 @@ ngx_http_proxy_redirect(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
||||||
|
|
||||||
ccv.cf = cf;
|
ccv.cf = cf;
|
||||||
ccv.value = &value[1];
|
ccv.value = &value[1];
|
||||||
ccv.complex_value = &pr->redirect.complex;
|
ccv.complex_value = &pr->pattern.complex;
|
||||||
|
|
||||||
if (ngx_http_compile_complex_value(&ccv) != NGX_OK) {
|
if (ngx_http_compile_complex_value(&ccv) != NGX_OK) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr->handler = ngx_http_proxy_rewrite_redirect_complex;
|
pr->handler = ngx_http_proxy_rewrite_complex_handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue