disable Zope rewrite, create specific rewrite rule for 'generic' purpose

generic rewrite rule applies when proxying not zope-based websites
parent b2d75bd0
No related merge requests found
...@@ -64,13 +64,14 @@ class Recipe(BaseSlapRecipe): ...@@ -64,13 +64,14 @@ class Recipe(BaseSlapRecipe):
rewrite_rule_list = [] rewrite_rule_list = []
slave_dict = {} slave_dict = {}
service_dict = {} service_dict = {}
base_url = "https://%s:%s/" % (frontend_domain_name, frontend_port_number) base_url = "%s:%s/" % (frontend_domain_name, frontend_port_number)
for slave_instance in slave_instance_list: for slave_instance in slave_instance_list:
url = slave_instance.get("url") url = slave_instance.get("url")
if url is None: if url is None:
continue continue
reference = slave_instance.get("slave_reference") reference = slave_instance.get("slave_reference")
slave_dict[reference] = "%s%s" % (base_url, reference.replace("-", "")) slave_dict[reference] = "https://%s.%s" % (reference.replace("-", ""),
base_url)
enable_cache = slave_instance.get("enable_cache", "") enable_cache = slave_instance.get("enable_cache", "")
if enable_cache.upper() in ('1', 'TRUE'): if enable_cache.upper() in ('1', 'TRUE'):
...@@ -378,8 +379,12 @@ class Recipe(BaseSlapRecipe): ...@@ -378,8 +379,12 @@ class Recipe(BaseSlapRecipe):
return stunnel_conf return stunnel_conf
def installFrontendApache(self, ip_list, port, key, certificate, def installFrontendApache(self, ip_list, port, key, certificate,
name, rewrite_rule_list, access_control_string=None): name, rewrite_rule_list, rewrite_rule_zope_list,
access_control_string=None):
apachemap_name = "apachemap.txt" apachemap_name = "apachemap.txt"
# XXX-Cedric : implement zope specific rewrites list. Current apachemap is
# generic and does not use VirtualHost Monster.
apachemapzope_name = "apachemapzope.txt"
self.createConfigurationFile(apachemap_name, "\n".join(rewrite_rule_list)) self.createConfigurationFile(apachemap_name, "\n".join(rewrite_rule_list))
apache_conf = self._getApacheConfigurationDict(name, ip_list, port) apache_conf = self._getApacheConfigurationDict(name, ip_list, port)
......
...@@ -37,10 +37,15 @@ CustomLog "%(access_log)s" common ...@@ -37,10 +37,15 @@ CustomLog "%(access_log)s" common
%(path_enable)s %(path_enable)s
RewriteMap apachemap txt:%(apachemap_path)s
# Magic of Zope related rewrite # Magic of Zope related rewrite
RewriteEngine On #RewriteMap apachemapzope txt:%(apachemapzope_path)s
RewriteRule ^/(\w+)($|/.*) ${apachemap:$1}/VirtualHostBase/https/%(apache_domain)s:%(port)s/VirtualHostRoot/_vh_$1$2 [L,P] #RewriteEngine On
# XXX-Cedric : apply only known apachemapzope rules.
#RewriteRule ^/(\w+)($|/.*) ${apachemapzope:$1}/VirtualHostBase/https/%(apache_domain)s:%(port)s/VirtualHostRoot/_vh_$1$2 [L,P]
# Sadly, Zope isn't used everywhere. So let's add a generic purpose rule
RewriteMap apachemapgeneric txt:%(apachemap_path)s
RewriteRule ^/(\w+)($|/.*) ${apachemapgeneric:$1}/$2 [L,P]
# List of modules # List of modules
LoadModule authz_host_module modules/mod_authz_host.so LoadModule authz_host_module modules/mod_authz_host.so
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment