mirror of
https://github.com/nginx/nginx.git
synced 2025-01-06 14:13:00 -06:00
gzip_disable degradation
This commit is contained in:
parent
81aa52829a
commit
5fffff997f
@ -322,6 +322,7 @@ if [ $HTTP_SECURE_LINK = YES ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $HTTP_DEGRADATION = YES ]; then
|
if [ $HTTP_DEGRADATION = YES ]; then
|
||||||
|
have=NGX_HTTP_DEGRADATION . auto/have
|
||||||
HTTP_MODULES="$HTTP_MODULES $HTTP_DEGRADATION_MODULE"
|
HTTP_MODULES="$HTTP_MODULES $HTTP_DEGRADATION_MODULE"
|
||||||
HTTP_SRCS="$HTTP_SRCS $HTTP_DEGRADATION_SRCS"
|
HTTP_SRCS="$HTTP_SRCS $HTTP_DEGRADATION_SRCS"
|
||||||
fi
|
fi
|
||||||
|
@ -258,6 +258,18 @@ ngx_http_gzip_header_filter(ngx_http_request_t *r)
|
|||||||
|
|
||||||
r->gzip_vary = 1;
|
r->gzip_vary = 1;
|
||||||
|
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
{
|
||||||
|
ngx_http_core_loc_conf_t *clcf;
|
||||||
|
|
||||||
|
clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
|
||||||
|
|
||||||
|
if (clcf->gzip_disable_degradation && ngx_http_degraded(r)) {
|
||||||
|
return ngx_http_next_header_filter(r);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!r->gzip_tested) {
|
if (!r->gzip_tested) {
|
||||||
if (ngx_http_gzip_ok(r) != NGX_OK) {
|
if (ngx_http_gzip_ok(r) != NGX_OK) {
|
||||||
return ngx_http_next_header_filter(r);
|
return ngx_http_next_header_filter(r);
|
||||||
|
@ -3113,6 +3113,9 @@ ngx_http_core_create_loc_conf(ngx_conf_t *cf)
|
|||||||
clcf->gzip_disable = NGX_CONF_UNSET_PTR;
|
clcf->gzip_disable = NGX_CONF_UNSET_PTR;
|
||||||
#endif
|
#endif
|
||||||
clcf->gzip_disable_msie6 = 3;
|
clcf->gzip_disable_msie6 = 3;
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
clcf->gzip_disable_degradation = 3;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return clcf;
|
return clcf;
|
||||||
@ -3373,6 +3376,15 @@ ngx_http_core_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
|
|||||||
(prev->gzip_disable_msie6 == 3) ? 0 : prev->gzip_disable_msie6;
|
(prev->gzip_disable_msie6 == 3) ? 0 : prev->gzip_disable_msie6;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
|
||||||
|
if (conf->gzip_disable_degradation == 3) {
|
||||||
|
conf->gzip_disable_degradation =
|
||||||
|
(prev->gzip_disable_degradation == 3) ?
|
||||||
|
0 : prev->gzip_disable_degradation;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return NGX_CONF_OK;
|
return NGX_CONF_OK;
|
||||||
@ -4394,6 +4406,15 @@ ngx_http_gzip_disable(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
|
||||||
|
if (ngx_strcmp(value[i].data, "degradation") == 0) {
|
||||||
|
clcf->gzip_disable_degradation = 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
re = ngx_array_push(clcf->gzip_disable);
|
re = ngx_array_push(clcf->gzip_disable);
|
||||||
if (re == NULL) {
|
if (re == NULL) {
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
@ -4414,20 +4435,35 @@ ngx_http_gzip_disable(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
return NGX_CONF_OK;
|
return NGX_CONF_OK;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
ngx_str_t *value;
|
ngx_str_t *value;
|
||||||
|
ngx_uint_t i;
|
||||||
|
|
||||||
value = cf->args->elts;
|
value = cf->args->elts;
|
||||||
|
|
||||||
if (cf->args->nelts == 2 && ngx_strcmp(value[1].data, "msie6") == 0) {
|
for (i = 1; i < cf->args->nelts; i++) {
|
||||||
clcf->gzip_disable_msie6 = 1;
|
if (ngx_strcmp(value[i].data, "msie6") == 0) {
|
||||||
return NGX_CONF_OK;
|
clcf->gzip_disable_msie6 = 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
|
||||||
|
if (ngx_strcmp(value[i].data, "degradation") == 0) {
|
||||||
|
clcf->gzip_disable_degradation = 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
|
"without PCRE library \"gzip_disable\" supports "
|
||||||
|
"builtin \"msie6\" and \"degradation\" mask only");
|
||||||
|
|
||||||
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
return NGX_CONF_OK;
|
||||||
"without PCRE library \"gzip_disable\" supports "
|
|
||||||
"builtin \"msie6\" mask only");
|
|
||||||
|
|
||||||
return NGX_CONF_ERROR;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,6 +295,9 @@ struct ngx_http_core_loc_conf_s {
|
|||||||
unsigned auto_redirect:1;
|
unsigned auto_redirect:1;
|
||||||
#if (NGX_HTTP_GZIP)
|
#if (NGX_HTTP_GZIP)
|
||||||
unsigned gzip_disable_msie6:2;
|
unsigned gzip_disable_msie6:2;
|
||||||
|
#if (NGX_HTTP_DEGRADATION)
|
||||||
|
unsigned gzip_disable_degradation:2;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ngx_http_location_tree_node_t *static_locations;
|
ngx_http_location_tree_node_t *static_locations;
|
||||||
|
Loading…
Reference in New Issue
Block a user