gzip_disable degradation

This commit is contained in:
Igor Sysoev 2010-10-04 15:03:00 +00:00
parent 81aa52829a
commit 5fffff997f
4 changed files with 60 additions and 8 deletions

View File

@ -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

View File

@ -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);

View File

@ -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
} }

View File

@ -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;