lib/phusion_passenger/nginx/config_options.rb



#  Phusion Passenger - https://www.phusionpassenger.com/
#  Copyright (c) 2013 Phusion
#
#  "Phusion Passenger" is a trademark of Hongli Lai & Ninh Bui.
#
#  Permission is hereby granted, free of charge, to any person obtaining a copy
#  of this software and associated documentation files (the "Software"), to deal
#  in the Software without restriction, including without limitation the rights
#  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
#  copies of the Software, and to permit persons to whom the Software is
#  furnished to do so, subject to the following conditions:
#
#  The above copyright notice and this permission notice shall be included in
#  all copies or substantial portions of the Software.
#
#  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
#  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
#  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
#  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
#  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
#  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
#  THE SOFTWARE.

# This file defines all supported Nginx per-location configuration options. The
# build system automatically generates the corresponding Nginx module boilerplate
# code from the definitions in this file.
# 
# Main configuration options are not defined in this file, but are defined in
# ext/nginx/Configuraion.c instead.
# 
# The following boilerplate code is generated:
# 
#  * ngx_command_t array members (ConfigurationCommands.c.erb)
#  * Location configuration structure definition (ConfigurationFields.h.erb)
#  * Location configuration structure initialization (CreateLocationConfig.c.erb)
#  * Location configuration merging (MergeLocationConfig.c.erb)
#  * Conversion of configuration options to CGI headers (CacheLocationConfig.c.erb)
# 
# Options:
# 
#  * name - The configuration option name. Required.
#  * context - The context in which this configuration option is valid.
#              Defaults to [:main, :srv, :loc, :lif]
#  * type - This configuration option's value type. Allowed types:
#           :string, :integer, :flag, :string_array, :string_keyval, :path
#  * take - Tells Nginx how many parameters and what kind of parameter
#           this configuration option takes. It should be set to a string
#           such as "NGX_CONF_FLAG".
#           By default this is automatically inferred from `type`: for
#           example if `type` is :string then ConfigurationCommands.c.erb
#           will infer that `NGX_CONF_TAKE1` should be used.
#  * function - The name of the function that should be used to store the
#               configuration value into the corresponding structure. This function
#               is not auto-generated, so it must be the name of an existing
#               function. By default, the function name is automatically inferred
#               from `type`. For example if `type` is string then `function` is
#               inferred to be `ngx_conf_set_str_slot`.
#               If you set this to a string then you are responsible for defining
#               said function in Configuration.c.
#  * struct - The type of the struct that the field is contained in. Something like
#             "NGX_HTTP_LOC_CONF_OFFSET" (which is also the default).
#  * field - The name that should be used for the auto-generated field in
#            the location configuration structure. Defaults to the configuration
#            name without the 'passenger_' prefix. Set this to nil if you do not
#            want a structure field to be auto-generated. If the field name contains
#            a dot (.e.g `upstream_config.pass_headers`) then the structure field will
#            also not be auto-generated, because it is assumed to belong to an existing
#            structure field.
#  * header - The name of the corresponding CGI header. By default CGI header
#             generation code is automatically generated, using the configuration
#             option's name in uppercase as the CGI header name.
#             Setting this to nil, or setting `field` to a value containing a dot,
#             will disable auto-generation of CGI header generation code. You are
#             then responsible for writing CGI header passing code yourself in
#             ContentHandler.c.
#  * auto_generate_nginx_merge_code - Whether location configuration merging
#            code should be automatically generated. Defaults to true. If you set
#            this to false then you are responsible for writing merging code
#            yourself in Configuration.c.
#  * alias_for - Set this if this configuration option is an alias for another
#                option. Alias definitions must only have the `name` and `alias_for`
#                fields, nothing else.


LOCATION_CONFIGURATION_OPTIONS = [
	{
		:name     => 'passenger_enabled',
		:context  => [:srv, :loc, :lif],
		:type     => :flag,
		:function => 'passenger_enabled',
		:field    => 'enabled',
		:header   => nil
	},
	{
		:name    => 'passenger_ruby',
		:context => [:srv, :loc, :lif],
		:type    => :string
	},
	{
		:name  => 'passenger_python',
		:type  => :string
	},
	{
		:name  => 'passenger_nodejs',
		:type  => :string
	},
	{
		:name  => 'passenger_app_env',
		:type  => :string,
		:field => 'environment'
	},
	{
		:name  => 'passenger_friendly_error_pages',
		:type  => :flag
	},
	{
		:name   => 'passenger_min_instances',
		:type   => :integer,
		:header => 'PASSENGER_MIN_PROCESSES'
	},
	{
		:name     => 'passenger_max_instances_per_app',
		:context  => [:main],
		:type     => :integer,
		:header   => 'PASSENGER_MAX_PROCESSES'
	},
	{
		:name  => 'passenger_max_requests',
		:type  => :integer
	},
	{
		:name  => 'passenger_start_timeout',
		:type  => :integer
	},
	{
		:name   => 'passenger_base_uri',
		:type   => :string_array,
		:field  => 'base_uris',
		:header => nil,
		:auto_generate_nginx_merge_code => false
	},
	{
		:name   => 'passenger_document_root',
		:type   => :string,
		:header => nil
	},
	{
		:name  => 'passenger_user',
		:type  => :string
	},
	{
		:name  => 'passenger_group',
		:type  => :string
	},
	{
		:name  => 'passenger_app_group_name',
		:type  => :string
	},
	{
		:name  => 'passenger_app_root',
		:type  => :string
	},
	{
		:name => 'passenger_app_rights',
		:type => :string
	},
	{
		:name  => 'union_station_support',
		:type  => :flag
	},
	{
		:name     => 'union_station_filter',
		:take     => 'NGX_CONF_TAKE1',
		:type     => :string_array,
		:function => 'union_station_filter',
		:field    => 'union_station_filters',
		:header   => nil,
		:auto_generate_nginx_merge_code => false
	},
	{
		:name  => 'passenger_debugger',
		:type  => :flag
	},
	{
		:name  => 'passenger_show_version_in_header',
		:type  => :flag
	},
	{
		:name  => 'passenger_max_preloader_idle_time',
		:type  => :integer
	},
	{
		:name     => 'passenger_ignore_headers',
		:take     => 'NGX_CONF_1MORE',
		:function => 'ngx_conf_set_bitmask_slot',
		:field    => 'upstream_config.ignore_headers'
	},
	{
		:name   => 'passenger_set_cgi_param',
		:context => [:srv, :loc, :lif],
		:type   => :string_keyval,
		:field  => 'vars_source',
		:header => nil,
		:auto_generate_nginx_merge_code => false
	},
	{
		:name  => 'passenger_pass_header',
		:type  => :string_array,
		:field => 'upstream_config.pass_headers'
	},
	{
		:name  => 'passenger_ignore_client_abort',
		:type  => :flag,
		:field => 'upstream_config.ignore_client_abort'
	},
	{
		:name  => 'passenger_buffer_response',
		:type  => :flag,
		:field => 'upstream_config.buffering'
	},
	{
		:name     => 'passenger_buffer_size',
		:take     => 'NGX_CONF_TAKE1',
		:function => 'ngx_conf_set_size_slot',
		:field    => 'upstream_config.buffer_size'
	},
	{
		:name     => 'passenger_buffers',
		:take     => 'NGX_CONF_TAKE2',
		:function => 'ngx_conf_set_bufs_slot',
		:field    => 'upstream_config.bufs'
	},
	{
		:name     => 'passenger_busy_buffers_size',
		:take     => 'NGX_CONF_TAKE1',
		:function => 'ngx_conf_set_size_slot',
		:field    => 'upstream_config.busy_buffers_size_conf'
	},
	{
		:name     => 'passenger_intercept_errors',
		:type     => :flag,
		:field    => 'upstream_config.intercept_errors'
	},
	{
		:name  => 'passenger_spawn_method',
		:type  => :string
	},
	{
		:name  => 'passenger_load_shell_envvars',
		:type  => :flag
	},
	{
		:name  => 'union_station_key',
		:type  => :string
	},
	{
		:name  => 'passenger_max_request_queue_size',
		:type  => :integer
	},
	{
		:name  => 'passenger_request_queue_overflow_status_code',
		:type  => :integer
	},
	{
		:name  => 'passenger_restart_dir',
		:type  => :string
	},
	{
		:name   => 'passenger_app_type',
		:type   => :string,
		:header => nil
	},
	{
		:name   => 'passenger_startup_file',
		:type   => :string
	},

	###### Enterprise features ######
	{
		:context  => [:main],
		:name     => 'passenger_fly_with',
		:type     => :string,
		:struct   => "NGX_HTTP_MAIN_CONF_OFFSET",
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_max_instances',
		:type     => :integer,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_max_request_time',
		:type     => :integer,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_memory_limit',
		:type     => :integer,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_concurrency_model',
		:type     => :string,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_thread_count',
		:type     => :integer,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_rolling_restarts',
		:type     => :flag,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},
	{
		:name     => 'passenger_resist_deployment_errors',
		:type     => :flag,
		:function => 'passenger_enterprise_only',
		:field    => nil
	},

	###### Aliases for backwards compatibility ######
	{
		:name      => 'rails_spawn_method',
		:alias_for => 'passenger_spawn_method'
	},
	{
		:name      => 'rails_env',
		:alias_for => 'passenger_app_env'
	},
	{
		:name      => 'rack_env',
		:alias_for => 'passenger_app_env'
	},
	{
		:name      => 'rails_app_spawner_idle_time',
		:alias_for => 'passenger_max_preloader_idle_time'
	},

	###### Obsolete options ######
	{
		:name     => 'rails_framework_spawner_idle_time',
		:take     => 'NGX_CONF_TAKE1',
		:function => 'rails_framework_spawner_idle_time',
		:field    => nil
	},
	{
		:name     => 'passenger_use_global_queue',
		:take     => 'NGX_CONF_FLAG',
		:function => 'passenger_use_global_queue',
		:field    => nil
	}
]