vhost: Add support for custom matchers and specifying response status
This commit is contained in:
@@ -2,53 +2,67 @@
|
||||
{{ vhost_domains | join(' ') }} {
|
||||
{% for location in _vhost_locations_complete %}
|
||||
handle {{ location.path }} {
|
||||
{% for header in location.delete_headers %}
|
||||
header -{{ header }}
|
||||
{% endfor %}
|
||||
{% for header in location.headers | dict2items %}
|
||||
header {{ header.key }} `{{ header.value }}`
|
||||
{% endfor %}
|
||||
{% if location.basicauth %}
|
||||
basicauth {
|
||||
{% for user in location.basicauth_users | dict2items %}
|
||||
{{ user.key }} {{ user.value }}
|
||||
{% for matcher in location.matchers %}
|
||||
{% if matcher.name != '' %}
|
||||
@{{ matcher.name }} {
|
||||
{% if matcher.match_methods | length > 0 %}
|
||||
method {{ matcher.match_methods | join(' ') }}
|
||||
{% endif %}
|
||||
{% for header in matcher.match_headers | dict2items %}
|
||||
header{{ '_regexp' if header.value.startswith('^') and header.value.endswith('$') else '' }} {{ header.key }} {{ header.value }}
|
||||
{% endfor %}
|
||||
}
|
||||
{% endif %}
|
||||
{% if location.type == 'reverse_proxy' %}
|
||||
reverse_proxy {
|
||||
{% if location.proxy_target_netproto == 'tcp' %}
|
||||
to tcp/{{ location.proxy_target_host }}:{{ location.proxy_target_port }}
|
||||
{% else %}
|
||||
to unix/{{ location.proxy_target_socket }}
|
||||
{% endif %}
|
||||
{% if location.proxy_target_protocol == 'https' %}
|
||||
transport http {
|
||||
tls
|
||||
{% if location.proxy_target_host == 'localhost' %}
|
||||
tls_insecure_skip_verify
|
||||
{% endif %}
|
||||
handle{{ ' @' ~ matcher.name if matcher.name != '' else '' }} {
|
||||
{% for header in matcher.delete_headers %}
|
||||
header -{{ header }}
|
||||
{% endfor %}
|
||||
{% for header in matcher.headers | dict2items %}
|
||||
header {{ header.key }} `{{ header.value }}`
|
||||
{% endfor %}
|
||||
{% if matcher.basicauth %}
|
||||
basicauth {
|
||||
{% for user in matcher.basicauth_users | dict2items %}
|
||||
{{ user.key }} {{ user.value }}
|
||||
{% endfor %}
|
||||
}
|
||||
{% endif %}
|
||||
{% for header in location.proxy_delete_headers %}
|
||||
header_up -{{ header }}
|
||||
{% endfor %}
|
||||
{% for header in location.proxy_headers | dict2items %}
|
||||
header_up {{ header.key }} `{{ header.value }}`
|
||||
{% endfor %}
|
||||
{% if (not location.proxy_pass_host_header) and ('host' not in location.proxy_headers | map('lower')) %}
|
||||
header_up Host {upstream_hostport}
|
||||
{% if matcher.type == 'reverse_proxy' %}
|
||||
reverse_proxy {
|
||||
{% if matcher.proxy_target_netproto == 'tcp' %}
|
||||
to tcp/{{ matcher.proxy_target_host }}:{{ matcher.proxy_target_port }}
|
||||
{% else %}
|
||||
to unix/{{ matcher.proxy_target_socket }}
|
||||
{% endif %}
|
||||
{% if matcher.proxy_target_protocol == 'https' %}
|
||||
transport http {
|
||||
tls
|
||||
{% if matcher.proxy_target_host == 'localhost' %}
|
||||
tls_insecure_skip_verify
|
||||
{% endif %}
|
||||
}
|
||||
{% endif %}
|
||||
{% for header in matcher.proxy_delete_headers %}
|
||||
header_up -{{ header }}
|
||||
{% endfor %}
|
||||
{% for header in matcher.proxy_headers | dict2items %}
|
||||
header_up {{ header.key }} `{{ header.value }}`
|
||||
{% endfor %}
|
||||
{% if (not matcher.proxy_pass_host_header) and ('host' not in matcher.proxy_headers | map('lower')) %}
|
||||
header_up Host {upstream_hostport}
|
||||
{% endif %}
|
||||
}
|
||||
{% elif matcher.type == 'redirect' %}
|
||||
redir * {{ matcher.redirect_target }}{{ '{path}' if matcher.redirect_preserve_path }}{{ '?{query}' if matcher.redirect_preserve_query }} {{ matcher.redirect_type }}
|
||||
{% elif matcher.type == 'respond' %}
|
||||
{% if matcher.respond_content_type == 'json' %}
|
||||
respond `{{ matcher.respond_content | to_json }}`
|
||||
{% else %}
|
||||
respond `{{ matcher.respond_content }}` {{ matcher.respond_status }}
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
}
|
||||
{% elif location.type == 'redirect' %}
|
||||
redir * {{ location.redirect_target }}{{ '{path}' if location.redirect_preserve_path }}{{ '?{query}' if location.redirect_preserve_query }} {{ location.redirect_type }}
|
||||
{% elif location.type == 'respond' %}
|
||||
{% if location.respond_content_type == 'json' %}
|
||||
respond `{{ location.respond_content | to_json }}`
|
||||
{% else %}
|
||||
respond `{{ location.respond_content }}`
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
}
|
||||
{% endfor %}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user