Make container name prefix more generic
Currently the proxy expects the container name as the first element of the path. It then adds a prefix followed by a "-" character to the container name before using it. To additionally support the case where no prefix is desired (so that the path that the Zuul base job returns is the entire path used by the proxy), remove the automatic addition of the "-" character. This means that if no prefix is supplied, then the path is used as given. To obtain the previous behavior, add a "-" character to the end of the CONTAINER_PREFIX environment variable. Change-Id: Ia480a11f78621ea0b2417f4b47878640f52db5da
This commit is contained in:
parent
022c80a9a2
commit
7b2cba8657
@ -156,12 +156,12 @@ def swift_proxy(environ, start_response, clouds, container_prefix):
|
|||||||
return
|
return
|
||||||
|
|
||||||
if len(components) < 2:
|
if len(components) < 2:
|
||||||
# no path inside tenant given, redirect to root index
|
# no container or path given, redirect to root index
|
||||||
return redirect_directory(start_response, path)
|
return redirect_directory(start_response, path)
|
||||||
|
|
||||||
tenant = components[0]
|
container = components[0]
|
||||||
path = components[1]
|
path = components[1]
|
||||||
container = '-'.join([container_prefix, tenant])
|
container = container_prefix + container
|
||||||
|
|
||||||
print('%s request %s/%s' % (method, container, path))
|
print('%s request %s/%s' % (method, container, path))
|
||||||
try:
|
try:
|
||||||
@ -195,8 +195,10 @@ class CloudCache(object):
|
|||||||
for cloud_name in cloud_names:
|
for cloud_name in cloud_names:
|
||||||
self.log.warning('Using cloud %s', cloud_name)
|
self.log.warning('Using cloud %s', cloud_name)
|
||||||
self.clouds.append(openstack.connect(cloud=cloud_name))
|
self.clouds.append(openstack.connect(cloud=cloud_name))
|
||||||
self.container_prefix = os.environ['CONTAINER_PREFIX']
|
self.container_prefix = os.environ.get('CONTAINER_PREFIX', '')
|
||||||
self.log.warning('Using container prefix %s', self.container_prefix)
|
if self.container_prefix:
|
||||||
|
self.log.warning('Using container prefix %s',
|
||||||
|
self.container_prefix)
|
||||||
|
|
||||||
def __call__(self, environ, start_response):
|
def __call__(self, environ, start_response):
|
||||||
for chunk in self.app(environ, start_response, self.clouds,
|
for chunk in self.app(environ, start_response, self.clouds,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user