diff --git a/analyze.go b/analyze.go index d057c970..039af5f1 100644 --- a/analyze.go +++ b/analyze.go @@ -42,7 +42,7 @@ package crossplane //go:generate sh -c "sh ./scripts/generate/generate.sh --url https://github.com/leev/ngx_http_geoip2_module.git --config-path ./scripts/generate/configs/geoip2_config.json > ./analyze_geoip2_directives.gen.go" // Update for NPlus. -// NPlus source code is private. Please ensure you have the correct access +// NPlus source code is private. Please ensure you have the correct access // and set the URL and branch in the environment variables NPLUS_URL and NPLUS_BRANCH. // Filter in config is the directives not in https://nginx.org/en/docs/dirindex.html but in source code. // Override for NPlus R33 and the latest version is for mgmt directives and if directive. @@ -50,6 +50,7 @@ package crossplane // For the "if" directive, we create a bitmask ngxConfExpr in crossplane, which is not included in the source code. //go:generate sh -c "sh ./scripts/generate/generate.sh --url $NPLUS_URL --config-path ./scripts/generate/configs/nplus_latest_config.json --branch $NPLUS_BRANCH --path ./src > ./analyze_nplus_latest_directives.gen.go" //go:generate sh -c "sh ./scripts/generate/generate.sh --url $NPLUS_URL --config-path ./scripts/generate/configs/nplus_R33_config.json --branch $NPLUS_BRANCH --path ./src > analyze_nplus_R33_directives.gen.go" +//go:generate sh -c "sh ./scripts/generate/generate.sh --url $NPLUS_URL --config-path ./scripts/generate/configs/nplus_R34_config.json --branch $NPLUS_BRANCH --path ./src > analyze_nplus_R34_directives.gen.go" import ( "fmt" diff --git a/analyze_lua_directives.gen.go b/analyze_lua_directives.gen.go index d30e0b29..5c04ac8d 100644 --- a/analyze_lua_directives.gen.go +++ b/analyze_lua_directives.gen.go @@ -181,6 +181,9 @@ var luaDirectives = map[string][]uint{ "lua_ssl_crl": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "lua_ssl_key_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, "lua_ssl_protocols": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, }, diff --git a/analyze_njs_directives.gen.go b/analyze_njs_directives.gen.go index 94ebbb6f..711e55d0 100644 --- a/analyze_njs_directives.gen.go +++ b/analyze_njs_directives.gen.go @@ -29,6 +29,10 @@ var njsDirectives = map[string][]uint{ ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, }, + "js_context_reuse_max_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, "js_engine": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, diff --git a/analyze_nplus_R34_directives.gen.go b/analyze_nplus_R34_directives.gen.go new file mode 100644 index 00000000..9d7deca6 --- /dev/null +++ b/analyze_nplus_R34_directives.gen.go @@ -0,0 +1,2259 @@ +/** + * Copyright (c) F5, Inc. + * + * This source code is licensed under the Apache License, Version 2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +// Code generated by generator; DO NOT EDIT. +// All the definitions are extracted from the source code +// Each bit mask describes these behaviors: +// - how many arguments the directive can take +// - whether or not it is a block directive +// - whether this is a flag (takes one argument that's either "on" or "off") +// - which contexts it's allowed to be in + +package crossplane + +var nginxPlusR34Directives = map[string][]uint{ + "absolute_redirect": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "accept_mutex": { + ngxEventConf | ngxConfFlag, + }, + "accept_mutex_delay": { + ngxEventConf | ngxConfTake1, + }, + "access_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxHTTPLmtConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "add_after_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "add_before_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "add_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake23, + }, + "add_trailer": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake23, + }, + "addition_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "aio": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "aio_write": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "alias": { + ngxHTTPLocConf | ngxConfTake1, + }, + "allow": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ancient_browser": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "ancient_browser_value": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "api": { + ngxHTTPLocConf | ngxConfNoArgs | ngxConfTake1, + }, + "auth_basic": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_basic_user_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_delay": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "auth_http": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "auth_http_header": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake2, + }, + "auth_http_pass_client_cert": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + }, + "auth_http_timeout": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "auth_jwt": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake12, + }, + "auth_jwt_claim_set": { + ngxHTTPMainConf | ngxConf2More, + }, + "auth_jwt_header_set": { + ngxHTTPMainConf | ngxConf2More, + }, + "auth_jwt_key_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_jwt_key_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_jwt_key_request": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_jwt_leeway": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_jwt_require": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConf1More, + }, + "auth_jwt_type": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "auth_oidc": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "auth_request": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "auth_request_set": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "autoindex": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "autoindex_exact_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "autoindex_format": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "autoindex_localtime": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "break": { + ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfNoArgs, + }, + "charset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "charset_map": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake2, + }, + "charset_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "chunked_transfer_encoding": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "client_body_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "client_body_in_file_only": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "client_body_in_single_buffer": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "client_body_temp_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "client_body_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "client_header_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "client_header_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "client_id": { + ngxConfTake1, + }, + "client_max_body_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "client_secret": { + ngxConfTake1, + }, + "config_url": { + ngxConfTake1, + }, + "connect_timeout": { + ngxMgmtMainConf | ngxConfTake1, + }, + "connection_pool_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "cookie_name": { + ngxConfTake1, + }, + "create_full_put_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "daemon": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, + "dav_access": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "dav_methods": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "debug_connection": { + ngxEventConf | ngxConfTake1, + }, + "debug_points": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "default_type": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "deny": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "directio": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "directio_alignment": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "disable_symlinks": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "empty_gif": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "enforce_initial_report": { + ngxMgmtMainConf | ngxConfFlag, + }, + "env": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "error_log": { + ngxMainConf | ngxConf1More, + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "error_page": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConf2More, + }, + "etag": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "events": { + ngxMainConf | ngxConfBlock | ngxConfNoArgs, + }, + "expires": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake12, + }, + "extra_auth_args": { + ngxConfTake1, + }, + "f4f": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "f4f_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "fastcgi_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "fastcgi_busy_buffers_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_background_update": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_cache_bypass": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_cache_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_lock": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_cache_lock_age": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_lock_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_max_range_offset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_methods": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_cache_min_uses": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_cache_path": { + ngxHTTPMainConf | ngxConf2More, + }, + "fastcgi_cache_purge": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_cache_revalidate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_cache_use_stale": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_cache_valid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_catch_stderr": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_force_ranges": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_hide_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_ignore_client_abort": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_ignore_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_index": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_intercept_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_keep_conn": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_max_temp_file_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_no_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "fastcgi_param": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake23, + }, + "fastcgi_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "fastcgi_pass_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_pass_request_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_pass_request_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_request_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_send_lowat": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "fastcgi_split_path_info": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_store": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_store_access": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "fastcgi_temp_file_write_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "fastcgi_temp_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "flv": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "geo": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake12, + ngxStreamMainConf | ngxConfBlock | ngxConfTake12, + }, + "geoip_city": { + ngxHTTPMainConf | ngxConfTake12, + ngxStreamMainConf | ngxConfTake12, + }, + "geoip_country": { + ngxHTTPMainConf | ngxConfTake12, + ngxStreamMainConf | ngxConfTake12, + }, + "geoip_org": { + ngxHTTPMainConf | ngxConfTake12, + ngxStreamMainConf | ngxConfTake12, + }, + "geoip_proxy": { + ngxHTTPMainConf | ngxConfTake1, + }, + "geoip_proxy_recursive": { + ngxHTTPMainConf | ngxConfFlag, + }, + "google_perftools_profiles": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "grpc_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "grpc_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_hide_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ignore_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "grpc_intercept_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "grpc_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "grpc_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "grpc_pass_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_set_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "grpc_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "grpc_ssl_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "grpc_ssl_certificate_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_ciphers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_conf_command": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "grpc_ssl_crl": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_key_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_password_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_protocols": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "grpc_ssl_server_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "grpc_ssl_session_reuse": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "grpc_ssl_trusted_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "grpc_ssl_verify": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "grpc_ssl_verify_depth": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "gunzip": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "gunzip_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "gzip": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "gzip_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "gzip_comp_level": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "gzip_disable": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "gzip_http_version": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "gzip_min_length": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "gzip_proxied": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "gzip_static": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "gzip_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "gzip_vary": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "hash": { + ngxHTTPUpsConf | ngxConfTake12, + ngxStreamUpsConf | ngxConfTake12, + }, + "health_check": { + ngxHTTPLocConf | ngxConfAny, + ngxStreamSrvConf | ngxConfAny, + }, + "health_check_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "hls": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "hls_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "hls_forward_args": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "hls_fragment": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "hls_mp4_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "hls_mp4_max_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "http": { + ngxMainConf | ngxConfBlock | ngxConfNoArgs, + }, + "http2": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "http2_body_preread_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_chunk_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "http2_idle_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_max_concurrent_pushes": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_max_concurrent_streams": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_max_field_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_max_header_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_max_requests": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http2_push": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "http2_push_preload": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "http2_recv_buffer_size": { + ngxHTTPMainConf | ngxConfTake1, + }, + "http2_recv_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http3": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "http3_hq": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "http3_max_concurrent_streams": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "http3_stream_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "if": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfBlock | ngxConfExpr | ngxConf1More, + }, + "if_modified_since": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "ignore_invalid_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "image_filter": { + ngxHTTPLocConf | ngxConfTake123, + }, + "image_filter_buffer": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "image_filter_interlace": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "image_filter_jpeg_quality": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "image_filter_sharpen": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "image_filter_transparency": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "image_filter_webp_quality": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "imap_auth": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "imap_capabilities": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "imap_client_buffer": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "include": { + ngxAnyConf | ngxConfTake1, + }, + "index": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "internal": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "internal_redirect": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "ip_hash": { + ngxHTTPUpsConf | ngxConfNoArgs, + }, + "issuer": { + ngxConfTake1, + }, + "keepalive": { + ngxHTTPUpsConf | ngxConfTake1, + }, + "keepalive_disable": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "keepalive_min_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "keepalive_requests": { + ngxHTTPUpsConf | ngxConfTake1, + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "keepalive_time": { + ngxHTTPUpsConf | ngxConfTake1, + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "keepalive_timeout": { + ngxHTTPUpsConf | ngxConfTake1, + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "keyval": { + ngxHTTPMainConf | ngxConfTake3 | ngxConfTake4, + ngxStreamMainConf | ngxConfTake3 | ngxConfTake4, + }, + "keyval_zone": { + ngxHTTPMainConf | ngxConf1More, + ngxStreamMainConf | ngxConf1More, + }, + "large_client_header_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake2, + }, + "least_conn": { + ngxHTTPUpsConf | ngxConfNoArgs, + ngxStreamUpsConf | ngxConfNoArgs, + }, + "least_time": { + ngxHTTPUpsConf | ngxConfTake12, + ngxStreamUpsConf | ngxConfTake12, + }, + "license_token": { + ngxMgmtMainConf | ngxConfTake1, + }, + "limit_conn": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "limit_conn_dry_run": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "limit_conn_log_level": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "limit_conn_status": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "limit_conn_zone": { + ngxHTTPMainConf | ngxConfTake2, + ngxStreamMainConf | ngxConfTake2, + }, + "limit_except": { + ngxHTTPLocConf | ngxConfBlock | ngxConf1More, + }, + "limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "limit_rate_after": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "limit_req": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "limit_req_dry_run": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "limit_req_log_level": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "limit_req_status": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "limit_req_zone": { + ngxHTTPMainConf | ngxConfTake3 | ngxConfTake4, + }, + "lingering_close": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "lingering_time": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "lingering_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "listen": { + ngxHTTPSrvConf | ngxConf1More, + ngxMailSrvConf | ngxConf1More, + ngxStreamSrvConf | ngxConf1More, + }, + "load_module": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "location": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfBlock | ngxConfTake12, + }, + "lock_file": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "log_format": { + ngxHTTPMainConf | ngxConf2More, + ngxStreamMainConf | ngxConf2More, + }, + "log_not_found": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "log_subrequest": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "mail": { + ngxMainConf | ngxConfBlock | ngxConfNoArgs, + }, + "map": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake2, + ngxStreamMainConf | ngxConfBlock | ngxConfTake2, + }, + "map_hash_bucket_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "map_hash_max_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "master_process": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, + "match": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake12, + ngxStreamMainConf | ngxConfBlock | ngxConfTake1, + }, + "max_errors": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "max_ranges": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "memcached_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_gzip_flag": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "memcached_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "memcached_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "memcached_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "merge_slashes": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "mgmt": { + ngxMainConf | ngxDirectConf | ngxConfBlock | ngxConfNoArgs, + }, + "min_delete_depth": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mirror": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mirror_request_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "modern_browser": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "modern_browser_value": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mp4": { + ngxHTTPLocConf | ngxConfNoArgs, + }, + "mp4_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mp4_limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mp4_limit_rate_after": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mp4_max_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "mp4_start_key_frame": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "mqtt": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "mqtt_buffers": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "mqtt_preread": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "mqtt_rewrite_buffer_size": { + ngxStreamSrvConf | ngxConfFlag, + }, + "mqtt_set_connect": { + ngxStreamSrvConf | ngxConfTake2, + }, + "msie_padding": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "msie_refresh": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "multi_accept": { + ngxEventConf | ngxConfFlag, + }, + "ntlm": { + ngxHTTPUpsConf | ngxConfNoArgs, + }, + "oidc_provider": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake1, + }, + "open_file_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "open_file_cache_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "open_file_cache_min_uses": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "open_file_cache_valid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "open_log_file_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1234, + }, + "output_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "override_charset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "pass": { + ngxStreamSrvConf | ngxConfTake1, + }, + "pcre_jit": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, + "perl": { + ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, + }, + "perl_modules": { + ngxHTTPMainConf | ngxConfTake1, + }, + "perl_require": { + ngxHTTPMainConf | ngxConfTake1, + }, + "perl_set": { + ngxHTTPMainConf | ngxConfTake2, + }, + "pid": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "pop3_auth": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "pop3_capabilities": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "port_in_redirect": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "postpone_output": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "preread_buffer_size": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "preread_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "protocol": { + ngxMailSrvConf | ngxConfTake1, + }, + "proxy": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + ngxMgmtMainConf | ngxConfTake1, + }, + "proxy_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake12, + }, + "proxy_buffer": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "proxy_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "proxy_busy_buffers_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_background_update": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_cache_bypass": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_cache_convert_head": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_cache_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_lock": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_cache_lock_age": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_lock_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_max_range_offset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_methods": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_cache_min_uses": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_cache_path": { + ngxHTTPMainConf | ngxConf2More, + }, + "proxy_cache_purge": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_cache_revalidate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_cache_use_stale": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_cache_valid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_cookie_domain": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "proxy_cookie_flags": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "proxy_cookie_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "proxy_download_rate": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_force_ranges": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_half_close": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_headers_hash_bucket_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_headers_hash_max_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_hide_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_http_version": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_ignore_client_abort": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_ignore_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_intercept_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_max_temp_file_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_method": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_no_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "proxy_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxHTTPLmtConf | ngxConfTake1, + ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_pass_error_message": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + }, + "proxy_pass_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_pass_request_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_pass_request_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_pass_trailers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_password": { + ngxMgmtMainConf | ngxConfTake1, + }, + "proxy_protocol": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_protocol_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_redirect": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "proxy_request_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "proxy_requests": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_responses": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_send_lowat": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_session_drop": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_set_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_set_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "proxy_smtp_auth": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + }, + "proxy_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_ssl": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_ssl_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake123, + }, + "proxy_ssl_certificate_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_ciphers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_conf_command": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "proxy_ssl_crl": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_key_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_password_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_protocols": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "proxy_ssl_server_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_ssl_session_reuse": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_ssl_trusted_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_ssl_verify": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "proxy_ssl_verify_depth": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_store": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_store_access": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "proxy_temp_file_write_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "proxy_temp_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "proxy_timeout": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_upload_rate": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "proxy_username": { + ngxMgmtMainConf | ngxConfTake1, + }, + "queue": { + ngxHTTPUpsConf | ngxConfTake12, + }, + "quic_active_connection_id_limit": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "quic_bpf": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, + "quic_gso": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "quic_host_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "quic_retry": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "random": { + ngxHTTPUpsConf | ngxConfNoArgs | ngxConfTake12, + ngxStreamUpsConf | ngxConfNoArgs | ngxConfTake12, + }, + "random_index": { + ngxHTTPLocConf | ngxConfFlag, + }, + "read_ahead": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "read_timeout": { + ngxMgmtMainConf | ngxConfTake1, + }, + "real_ip_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "real_ip_recursive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "recursive_error_pages": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "redirect_uri": { + ngxConfTake1, + }, + "referer_hash_bucket_size": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "referer_hash_max_size": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "request_pool_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "reset_timedout_connection": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "resolver": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + ngxHTTPUpsConf | ngxConf1More, + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + ngxMgmtMainConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + ngxStreamUpsConf | ngxConf1More, + }, + "resolver_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxHTTPUpsConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + ngxStreamUpsConf | ngxConfTake1, + }, + "return": { + ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake12, + ngxStreamSrvConf | ngxConfTake1, + }, + "rewrite": { + ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake23, + }, + "rewrite_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "root": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "satisfy": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "scgi_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "scgi_busy_buffers_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_background_update": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_cache_bypass": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_cache_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_lock": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_cache_lock_age": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_lock_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_max_range_offset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_methods": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_cache_min_uses": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_cache_path": { + ngxHTTPMainConf | ngxConf2More, + }, + "scgi_cache_purge": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_cache_revalidate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_cache_use_stale": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_cache_valid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_force_ranges": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_hide_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_ignore_client_abort": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_ignore_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_intercept_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_max_temp_file_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_no_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "scgi_param": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake23, + }, + "scgi_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "scgi_pass_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_pass_request_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_pass_request_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_request_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "scgi_store": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_store_access": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "scgi_temp_file_write_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "scgi_temp_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "scope": { + ngxConf1More, + }, + "secure_link": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "secure_link_md5": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "secure_link_secret": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "send_lowat": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + }, + "sendfile": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "sendfile_max_chunk": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "server": { + ngxHTTPMainConf | ngxConfBlock | ngxConfNoArgs, + ngxHTTPUpsConf | ngxConf1More, + ngxMailMainConf | ngxConfBlock | ngxConfNoArgs, + ngxStreamMainConf | ngxConfBlock | ngxConfNoArgs, + ngxStreamUpsConf | ngxConf1More, + }, + "server_name": { + ngxHTTPSrvConf | ngxConf1More, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamSrvConf | ngxConf1More, + }, + "server_name_in_redirect": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "server_names_hash_bucket_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "server_names_hash_max_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "server_tokens": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "session_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "session_log_format": { + ngxHTTPMainConf | ngxConf2More, + }, + "session_log_zone": { + ngxHTTPMainConf | ngxConf2More, + }, + "session_store": { + ngxConfTake1, + }, + "session_timeout": { + ngxConf1More, + }, + "set": { + ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake2, + ngxStreamSrvConf | ngxConfTake2, + }, + "set_real_ip_from": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "slice": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "smtp_auth": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "smtp_capabilities": { + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + }, + "smtp_client_buffer": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "smtp_greeting_delay": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "source_charset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "split_clients": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake2, + ngxStreamMainConf | ngxConfBlock | ngxConfTake2, + }, + "ssi": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "ssi_last_modified": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "ssi_min_file_chunk": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "ssi_silent_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "ssi_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "ssi_value_length": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "ssl": { + ngxMgmtMainConf | ngxConfFlag, + }, + "ssl_alpn": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "ssl_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + }, + "ssl_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake123, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake123, + }, + "ssl_certificate_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_ciphers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_client_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_conf_command": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake2, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake2, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "ssl_crl": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + ngxConfTake1, + }, + "ssl_dhparam": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_early_data": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "ssl_ecdh_curve": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_engine": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "ssl_handshake_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_key_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_name": { + ngxMgmtMainConf | ngxConfTake1, + }, + "ssl_object_cache_inheritable": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, + "ssl_ocsp": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_ocsp_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_ocsp_responder": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_password_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_prefer_server_ciphers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_preread": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_protocols": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConf1More, + ngxMailMainConf | ngxMailSrvConf | ngxConf1More, + ngxMgmtMainConf | ngxConf1More, + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "ssl_reject_handshake": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_server_name": { + ngxMgmtMainConf | ngxConfFlag, + }, + "ssl_session_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake12, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake12, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake12, + }, + "ssl_session_ticket_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_session_tickets": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_session_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_stapling": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_stapling_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_stapling_responder": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_stapling_verify": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "ssl_trusted_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + ngxConfTake1, + }, + "ssl_verify": { + ngxMgmtMainConf | ngxConfFlag, + }, + "ssl_verify_client": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "ssl_verify_depth": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + ngxMgmtMainConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "starttls": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "state": { + ngxHTTPUpsConf | ngxConfTake1, + ngxStreamUpsConf | ngxConfTake1, + }, + "state_path": { + ngxMgmtMainConf | ngxConfTake1, + }, + "status": { + ngxConf1More, + }, + "status_zone": { + ngxHTTPSrvConf | ngxConfTake1, + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + ngxStreamSrvConf | ngxConfTake1, + }, + "sticky": { + ngxHTTPUpsConf | ngxConf2More, + }, + "stream": { + ngxMainConf | ngxConfBlock | ngxConfNoArgs, + }, + "stub_status": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfNoArgs | ngxConfTake1, + }, + "sub_filter": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "sub_filter_last_modified": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "sub_filter_once": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "sub_filter_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "subrequest_output_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "tcp_nodelay": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "tcp_nopush": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "thread_pool": { + ngxMainConf | ngxDirectConf | ngxConfTake23, + }, + "timeout": { + ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, + }, + "timer_resolution": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "try_files": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf2More, + }, + "types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfBlock | ngxConfNoArgs, + }, + "types_hash_bucket_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "types_hash_max_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "underscores_in_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, + }, + "uninitialized_variable_warn": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfFlag, + }, + "upstream": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake1, + ngxStreamMainConf | ngxConfBlock | ngxConfTake1, + }, + "usage_report": { + ngxMgmtMainConf | ngxConfNoArgs | ngxConfTake12, + }, + "use": { + ngxEventConf | ngxConfTake1, + }, + "user": { + ngxMainConf | ngxDirectConf | ngxConfTake12, + }, + "userid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_domain": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_expires": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_flags": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "userid_mark": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_p3p": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "userid_service": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uuid_file": { + ngxMgmtMainConf | ngxConfNoArgs | ngxConfTake1, + }, + "uwsgi_bind": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, + }, + "uwsgi_buffer_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_buffers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "uwsgi_busy_buffers_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_background_update": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_bypass": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_cache_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_lock": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_cache_lock_age": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_lock_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_max_range_offset": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_methods": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_cache_min_uses": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_cache_path": { + ngxHTTPMainConf | ngxConf2More, + }, + "uwsgi_cache_purge": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_cache_revalidate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_cache_use_stale": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_cache_valid": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_connect_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_force_ranges": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_hide_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ignore_client_abort": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_ignore_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_intercept_errors": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_limit_rate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_max_temp_file_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_modifier1": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_modifier2": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_next_upstream": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_next_upstream_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_next_upstream_tries": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_no_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_param": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake23, + }, + "uwsgi_pass": { + ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake1, + }, + "uwsgi_pass_header": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_pass_request_body": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_pass_request_headers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_read_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_request_buffering": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_send_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_socket_keepalive": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_ssl_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "uwsgi_ssl_certificate_key": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_ciphers": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_conf_command": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "uwsgi_ssl_crl": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_key_log": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_password_file": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_protocols": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "uwsgi_ssl_server_name": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_ssl_session_reuse": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_ssl_trusted_certificate": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_ssl_verify": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "uwsgi_ssl_verify_depth": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_store": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_store_access": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, + "uwsgi_temp_file_write_size": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "uwsgi_temp_path": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, + }, + "valid_referers": { + ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "variables_hash_bucket_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "variables_hash_max_size": { + ngxHTTPMainConf | ngxConfTake1, + ngxStreamMainConf | ngxConfTake1, + }, + "worker_aio_requests": { + ngxEventConf | ngxConfTake1, + }, + "worker_connections": { + ngxEventConf | ngxConfTake1, + }, + "worker_cpu_affinity": { + ngxMainConf | ngxDirectConf | ngxConf1More, + }, + "worker_priority": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "worker_processes": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "worker_rlimit_core": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "worker_rlimit_nofile": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "worker_shutdown_timeout": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "working_directory": { + ngxMainConf | ngxDirectConf | ngxConfTake1, + }, + "xclient": { + ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, + }, + "xml_entities": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, + "xslt_last_modified": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, + }, + "xslt_param": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "xslt_string_param": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, + }, + "xslt_stylesheet": { + ngxHTTPLocConf | ngxConf1More, + }, + "xslt_types": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, + "zone": { + ngxHTTPUpsConf | ngxConfTake12, + ngxStreamUpsConf | ngxConfTake12, + }, + "zone_sync": { + ngxStreamSrvConf | ngxConfNoArgs, + }, + "zone_sync_buffers": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "zone_sync_connect_retry_interval": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_connect_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_interval": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_recv_buffer_size": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_server": { + ngxStreamSrvConf | ngxConfTake12, + }, + "zone_sync_ssl": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "zone_sync_ssl_certificate": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_certificate_key": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_ciphers": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_conf_command": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake2, + }, + "zone_sync_ssl_crl": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_name": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_password_file": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_protocols": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConf1More, + }, + "zone_sync_ssl_server_name": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "zone_sync_ssl_trusted_certificate": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_ssl_verify": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, + }, + "zone_sync_ssl_verify_depth": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "zone_sync_timeout": { + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, +} + +// MatchNginxPlusR34 contains directives in Nginx Plus R34 source code(including GEOIP, Perl, and XSLT) +func MatchNginxPlusR34(directive string) ([]uint, bool) { + m, ok := nginxPlusR34Directives[directive] + return m, ok +} diff --git a/analyze_nplus_latest_directives.gen.go b/analyze_nplus_latest_directives.gen.go index 2bcf4720..3918c4dd 100644 --- a/analyze_nplus_latest_directives.gen.go +++ b/analyze_nplus_latest_directives.gen.go @@ -114,12 +114,18 @@ var nginxPlusLatestDirectives = map[string][]uint{ "auth_jwt_type": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConfTake1, }, + "auth_oidc": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, "auth_request": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, "auth_request_set": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake2, }, + "auth_require": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLmtConf | ngxConf1More, + }, "autoindex": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, @@ -168,15 +174,27 @@ var nginxPlusLatestDirectives = map[string][]uint{ "client_header_timeout": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, }, + "client_id": { + ngxConfTake1, + }, "client_max_body_size": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "client_secret": { + ngxConfTake1, + }, + "config_url": { + ngxConfTake1, + }, "connect_timeout": { ngxMgmtMainConf | ngxConfTake1, }, "connection_pool_size": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, }, + "cookie_name": { + ngxConfTake1, + }, "create_full_put_path": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, @@ -211,6 +229,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "disable_symlinks": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, }, + "early_hints": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, "empty_gif": { ngxHTTPLocConf | ngxConfNoArgs, }, @@ -238,6 +259,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "expires": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake12, }, + "extra_auth_args": { + ngxConfTake1, + }, "f4f": { ngxHTTPLocConf | ngxConfNoArgs, }, @@ -470,6 +494,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "grpc_ssl_certificate": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "grpc_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, "grpc_ssl_certificate_key": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, @@ -682,12 +709,18 @@ var nginxPlusLatestDirectives = map[string][]uint{ "ip_hash": { ngxHTTPUpsConf | ngxConfNoArgs, }, + "issuer": { + ngxConfTake1, + }, "keepalive": { ngxHTTPUpsConf | ngxConfTake1, }, "keepalive_disable": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, }, + "keepalive_min_timeout": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, + }, "keepalive_requests": { ngxHTTPUpsConf | ngxConfTake1, ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, @@ -798,6 +831,12 @@ var nginxPlusLatestDirectives = map[string][]uint{ "log_subrequest": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, + "logout_token_hint": { + ngxConfFlag, + }, + "logout_uri": { + ngxConfTake1, + }, "mail": { ngxMainConf | ngxConfBlock | ngxConfNoArgs, }, @@ -925,6 +964,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "ntlm": { ngxHTTPUpsConf | ngxConfNoArgs, }, + "oidc_provider": { + ngxHTTPMainConf | ngxConfBlock | ngxConfTake1, + }, "open_file_cache": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, }, @@ -977,6 +1019,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "port_in_redirect": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, + "post_logout_uri": { + ngxConfTake1, + }, "postpone_output": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, @@ -1103,6 +1148,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "proxy_limit_rate": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "proxy_location": { + ngxConfTake1, + }, "proxy_max_temp_file_size": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, @@ -1143,6 +1191,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "proxy_pass_trailers": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, + "proxy_password": { + ngxConfTake1, + }, "proxy_protocol": { ngxMailMainConf | ngxMailSrvConf | ngxConfFlag, ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, @@ -1194,6 +1245,10 @@ var nginxPlusLatestDirectives = map[string][]uint{ ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, }, + "proxy_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake123, + }, "proxy_ssl_certificate_key": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, @@ -1265,6 +1320,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "proxy_upload_rate": { ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, }, + "proxy_username": { + ngxConfTake1, + }, "queue": { ngxHTTPUpsConf | ngxConfTake12, }, @@ -1305,6 +1363,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "recursive_error_pages": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfFlag, }, + "redirect_uri": { + ngxConfTake1, + }, "referer_hash_bucket_size": { ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, @@ -1484,6 +1545,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "scgi_temp_path": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1234, }, + "scope": { + ngxConf1More, + }, "secure_link": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, @@ -1541,6 +1605,12 @@ var nginxPlusLatestDirectives = map[string][]uint{ "session_log_zone": { ngxHTTPMainConf | ngxConf2More, }, + "session_store": { + ngxConfTake1, + }, + "session_timeout": { + ngxConf1More, + }, "set": { ngxHTTPSrvConf | ngxHTTPSifConf | ngxHTTPLocConf | ngxHTTPLifConf | ngxConfTake2, ngxStreamSrvConf | ngxConfTake2, @@ -1605,6 +1675,10 @@ var nginxPlusLatestDirectives = map[string][]uint{ ngxMgmtMainConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, }, + "ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake123, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake123, + }, "ssl_certificate_key": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, @@ -1659,6 +1733,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "ssl_name": { ngxMgmtMainConf | ngxConfTake1, }, + "ssl_object_cache_inheritable": { + ngxMainConf | ngxDirectConf | ngxConfFlag, + }, "ssl_ocsp": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfFlag, ngxStreamMainConf | ngxStreamSrvConf | ngxConfFlag, @@ -1754,6 +1831,13 @@ var nginxPlusLatestDirectives = map[string][]uint{ ngxMgmtMainConf | ngxConfTake1, ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, }, + "ssl_verify_digests": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxConfTake1, + ngxStreamMainConf | ngxStreamSrvConf | ngxConfTake1, + }, + "stall_threshold": { + ngxEventConf | ngxConfTake1, + }, "starttls": { ngxMailMainConf | ngxMailSrvConf | ngxConfTake1, }, @@ -1870,6 +1954,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "userid_service": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "userinfo": { + ngxConfTake1, + }, "uuid_file": { ngxMgmtMainConf | ngxConfNoArgs | ngxConfTake1, }, @@ -2005,6 +2092,9 @@ var nginxPlusLatestDirectives = map[string][]uint{ "uwsgi_ssl_certificate": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "uwsgi_ssl_certificate_cache": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake123, + }, "uwsgi_ssl_certificate_key": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, diff --git a/analyze_oss_latest_directives.gen.go b/analyze_oss_latest_directives.gen.go index 9beb8add..d5cfd1dc 100644 --- a/analyze_oss_latest_directives.gen.go +++ b/analyze_oss_latest_directives.gen.go @@ -178,6 +178,9 @@ var ossLatestDirectives = map[string][]uint{ "disable_symlinks": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake12, }, + "early_hints": { + ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConf1More, + }, "empty_gif": { ngxHTTPLocConf | ngxConfNoArgs, }, diff --git a/analyze_otel_directives.gen.go b/analyze_otel_directives.gen.go index 5047bf39..3f018af1 100644 --- a/analyze_otel_directives.gen.go +++ b/analyze_otel_directives.gen.go @@ -16,9 +16,15 @@ package crossplane var otelDirectives = map[string][]uint{ + "header": { + ngxConfTake2, + }, "otel_exporter": { ngxHTTPMainConf | ngxConfBlock | ngxConfNoArgs, }, + "otel_resource_attr": { + ngxHTTPMainConf | ngxConfTake2, + }, "otel_service_name": { ngxHTTPMainConf | ngxConfTake1, }, @@ -34,6 +40,9 @@ var otelDirectives = map[string][]uint{ "otel_trace_context": { ngxHTTPMainConf | ngxHTTPSrvConf | ngxHTTPLocConf | ngxConfTake1, }, + "trusted_certificate": { + ngxConfTake1, + }, } // MatchOtelLatest is a MatchFunc for latest version of otel. diff --git a/analyze_test.go b/analyze_test.go index 331c9777..4dac1716 100644 --- a/analyze_test.go +++ b/analyze_test.go @@ -2694,7 +2694,7 @@ func TestAnalyze_geoip2(t *testing.T) { }, }, }, - blockCtx{"http", "stream"}, + blockCtx{"http"}, false, }, @@ -2781,7 +2781,11 @@ func TestAnalyze_geoip2(t *testing.T) { tc := tc t.Run(name, func(t *testing.T) { t.Parallel() - err := analyze("nginx.conf", tc.stmt, ";", tc.ctx, &ParseOptions{ + terminator := ";" + if tc.stmt.Directive == "geoip2" { + terminator = "{" + } + err := analyze("nginx.conf", tc.stmt, terminator, tc.ctx, &ParseOptions{ DirectiveSources: []MatchFunc{MatchNginxPlusLatest, MatchGeoip2Latest}, }) @@ -2795,3 +2799,122 @@ func TestAnalyze_geoip2(t *testing.T) { }) } } + +//nolint:funlen +func TestAnalyze_oidc(t *testing.T) { + t.Parallel() + testcases := map[string]struct { + stmt *Directive + ctx blockCtx + wantErr bool + }{ + "oidc ok": { + &Directive{ + Directive: "oidc_provider", + Args: []string{"my_idp"}, + Line: 5, + Block: Directives{ + { + Directive: "issuer", + Args: []string{"https://provider.domain"}, + Line: 6, + Block: Directives{}, + }, + { + Directive: "client_id", + Args: []string{"unique_id"}, + Line: 7, + Block: Directives{}, + }, + { + Directive: "client_secret", + Args: []string{"unique_secret"}, + Line: 8, + Block: Directives{}, + }, + }, + }, + blockCtx{"http"}, + false, + }, + + "oidc not ok": { + &Directive{ + Directive: "oidc_provider", + Args: []string{"my_idp"}, + Line: 5, + Block: Directives{ + { + Directive: "issuer", + Args: []string{"https://provider.domain"}, + Line: 6, + Block: Directives{}, + }, + { + Directive: "client_id", + Args: []string{"unique_id"}, + Line: 7, + Block: Directives{}, + }, + { + Directive: "client_secret", + Args: []string{"unique_secret"}, + Line: 8, + Block: Directives{}, + }, + }, + }, + blockCtx{"stream"}, + true, + }, + "auth_oidc ok": { + &Directive{ + Directive: "auth_oidc", + Args: []string{"my_idp"}, + Line: 5, + }, + blockCtx{"http"}, + false, + }, + "auth_oidc args not ok": { + &Directive{ + Directive: "auth_oidc", + Args: []string{"my_idp", "my_realm"}, + Line: 5, + }, + blockCtx{"http"}, + true, + }, + "auth_oidc not ok": { + &Directive{ + Directive: "auth_oidc", + Args: []string{"203.0.113.0/24"}, + Line: 5, + }, + blockCtx{"stream"}, + true, + }, + } + + for name, tc := range testcases { + tc := tc + t.Run(name, func(t *testing.T) { + t.Parallel() + terminator := ";" + if tc.stmt.Directive == "oidc_provider" { + terminator = "{" + } + err := analyze("nginx.conf", tc.stmt, terminator, tc.ctx, &ParseOptions{ + DirectiveSources: []MatchFunc{MatchNginxPlusR34}, + }) + + if !tc.wantErr && err != nil { + t.Fatal(err) + } + + if tc.wantErr && err == nil { + t.Fatal("expected error, got nil") + } + }) + } +} diff --git a/parse_test.go b/parse_test.go index efc4af5d..86e5ba41 100644 --- a/parse_test.go +++ b/parse_test.go @@ -2024,7 +2024,11 @@ var parseFixtures = []parseFixture{ }, }, }}, - {"limit-req-zone", "", ParseOptions{SingleFile: true}, Payload{ + {"limit-req-zone", "", ParseOptions{ + SingleFile: true, + ErrorOnUnknownDirectives: true, + DirectiveSources: []MatchFunc{MatchNginxPlusR33}, + }, Payload{ Status: "ok", Errors: []PayloadError{}, Config: []Config{ @@ -2297,6 +2301,82 @@ var parseFixtures = []parseFixture{ }, }, }}, + {"oidc", "", ParseOptions{ + SingleFile: true, + ErrorOnUnknownDirectives: true, + DirectiveSources: []MatchFunc{MatchNginxPlusR34}, + }, Payload{ + Status: "ok", + Errors: []PayloadError{}, + Config: []Config{ + { + File: getTestConfigPath("oidc", "nginx.conf"), + Status: "ok", + Parsed: Directives{ + { + Directive: "http", + Line: 1, + Args: []string{}, + Block: Directives{ + { + Directive: "oidc_provider", + Line: 2, + Args: []string{"my_idp"}, + Block: Directives{ + { + Directive: "issuer", + Args: []string{"https://provider.domain"}, + Line: 3, + Block: Directives{}, + }, + { + Directive: "client_id", + Args: []string{"unique_id"}, + Line: 4, + Block: Directives{}, + }, + { + Directive: "client_secret", + Args: []string{"unique_secret"}, + Line: 5, + Block: Directives{}, + }, + }, + }, + { + Directive: "server", + Line: 7, + Args: []string{}, + Block: Directives{ + { + Directive: "auth_oidc", + Line: 8, + Args: []string{"my_idp"}, + Block: Directives{}, + }, + { + Directive: "location", + Line: 9, + Args: []string{"/"}, + Block: Directives{ + { + Directive: "return", + Line: 10, + Args: []string{ + "200", + "Hello", + }, + }, + }, + }, + }, + }, + }, + }, + }, + }, + }, + }}, } func TestParse(t *testing.T) { diff --git a/scripts/generate/configs/nplus_R34_config.json b/scripts/generate/configs/nplus_R34_config.json new file mode 100644 index 00000000..4b50bfa3 --- /dev/null +++ b/scripts/generate/configs/nplus_R34_config.json @@ -0,0 +1,134 @@ +{ + "directiveMapName":"nginxPlusR34Directives", + "matchFuncName":"MatchNginxPlusR34", + "filter":[ + "epoll_events", + "health_check_header", + "body", + "body_size", + "http2_pool_size", + "post_action", + "pcre_buffer", + "degrade", + "gzip_window", + "proxy_downstream_buffer", + "degradation", + "ssi_ignore_recycled_buffers", + "uwsgi_string", + "proxy_ssl_session_cache", + "proxy_upstream_buffer", + "eventport_events", + "expect", + "gzip_hash", + "require", + "proxy_keepalive", + "http2_streams_index_size", + "send", + "kqueue_changes", + "header", + "devpoll_events", + "kqueue_events", + "postpone_gzipping", + "acceptex_read", + "iocp_threads", + "devpoll_changes", + "post_acceptex", + "open_file_cache_events", + "gzip_no_buffer", + "deployment_context", + "proxy_location" + ], + "override":{ + "if":[[ "ngxHTTPSrvConf", "ngxHTTPLocConf", "ngxConfBlock", "ngxConfExpr", "ngxConf1More"]], + "connect_timeout": [["ngxMgmtMainConf", "ngxConfTake1"]], + "read_timeout": [["ngxMgmtMainConf", "ngxConfTake1"]], + "resolver": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxHTTPLocConf", "ngxConf1More"], + ["ngxHTTPUpsConf", "ngxConf1More"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConf1More"], + ["ngxMgmtMainConf", "ngxConf1More"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConf1More"], + ["ngxStreamUpsConf", "ngxConf1More"] + ], + "resolver_timeout":[ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxHTTPLocConf", "ngxConfTake1"], + ["ngxHTTPUpsConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"], + ["ngxStreamUpsConf", "ngxConfTake1"] + ], + "send_timeout": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxHTTPLocConf", "ngxConfTake1"], + ["ngxMgmtMainConf","ngxConfTake1"] + ], + "ssl": [["ngxMgmtMainConf", "ngxConfFlag"]], + "ssl_certificate": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"] + ], + "ssl_certificate_key": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"] + ], + "ssl_ciphers": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf" , "ngxConfTake1"] + ], + "ssl_crl": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"], + ["ngxConfTake1"] + ], + "ssl_name": [["ngxMgmtMainConf", "ngxConfTake1"]], + "ssl_password_file": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"] + ], + "ssl_protocols": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConf1More"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConf1More"], + ["ngxMgmtMainConf", "ngxConf1More"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConf1More"] + ], + "ssl_server_name": [["ngxMgmtMainConf", "ngxConfFlag"]], + "ssl_trusted_certificate": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"], + ["ngxConfTake1"] + ], + "ssl_verify": [["ngxMgmtMainConf", "ngxConfFlag"]], + "ssl_verify_depth": [ + ["ngxHTTPMainConf", "ngxHTTPSrvConf", "ngxConfTake1"], + ["ngxMailMainConf", "ngxMailSrvConf", "ngxConfTake1"], + ["ngxMgmtMainConf", "ngxConfTake1"], + ["ngxStreamMainConf", "ngxStreamSrvConf", "ngxConfTake1"] + ], + "usage_report": [["ngxMgmtMainConf", "ngxConfNoArgs", "ngxConfTake12"]], + "uuid_file": [["ngxMgmtMainConf", "ngxConfNoArgs", "ngxConfTake1"]], + "enforce_initial_report": [["ngxMgmtMainConf","ngxConfFlag"]], + "license_token": [["ngxMgmtMainConf","ngxConfTake1"]], + "state_path": [["ngxMgmtMainConf","ngxConfTake1"]], + "zone_sync": [["ngxStreamSrvConf","ngxConfNoArgs"]], + "proxy":[ + ["ngxMailMainConf","ngxMailSrvConf","ngxConfFlag"], + ["ngxMgmtMainConf","ngxConfTake1"] + ], + "proxy_username": [["ngxMgmtMainConf","ngxConfTake1"]], + "proxy_password": [["ngxMgmtMainConf","ngxConfTake1"]] + }, + + "matchFuncComment":"MatchNginxPlusR34 contains directives in Nginx Plus R34 source code(including GEOIP, Perl, and XSLT)" +} diff --git a/testdata/configs/oidc/nginx.conf b/testdata/configs/oidc/nginx.conf new file mode 100644 index 00000000..7e97211b --- /dev/null +++ b/testdata/configs/oidc/nginx.conf @@ -0,0 +1,13 @@ +http { + oidc_provider my_idp { + issuer "https://provider.domain"; + client_id "unique_id"; + client_secret "unique_secret"; + } + server { + auth_oidc my_idp; + location / { + return 200 "Hello"; + } + } +}