Merge pull request #336 from coreos-inc/swiftconnectiondrown
Always create a new connection to Swift
This commit is contained in:
		
						commit
						fc74b9569b
					
				
					 1 changed files with 5 additions and 18 deletions
				
			
		|  | @ -26,14 +26,6 @@ class SwiftStorage(BaseStorage): | ||||||
|     self._os_options = os_options or {} |     self._os_options = os_options or {} | ||||||
| 
 | 
 | ||||||
|     self._initialized = False |     self._initialized = False | ||||||
|     self._swift_connection = None |  | ||||||
| 
 |  | ||||||
|   def _initialize(self): |  | ||||||
|     if self._initialized: |  | ||||||
|       return |  | ||||||
| 
 |  | ||||||
|     self._initialized = True |  | ||||||
|     self._swift_connection = self._get_connection() |  | ||||||
| 
 | 
 | ||||||
|   def _get_connection(self): |   def _get_connection(self): | ||||||
|     return Connection( |     return Connection( | ||||||
|  | @ -69,14 +61,13 @@ class SwiftStorage(BaseStorage): | ||||||
|     return path |     return path | ||||||
| 
 | 
 | ||||||
|   def _get_container(self, path): |   def _get_container(self, path): | ||||||
|     self._initialize() |  | ||||||
|     path = self._normalize_path(path) |     path = self._normalize_path(path) | ||||||
| 
 | 
 | ||||||
|     if path and not path.endswith('/'): |     if path and not path.endswith('/'): | ||||||
|         path += '/' |         path += '/' | ||||||
| 
 | 
 | ||||||
|     try: |     try: | ||||||
|        _, container = self._swift_connection.get_container( |        _, container = self._get_connection().get_container( | ||||||
|             container=self._swift_container, |             container=self._swift_container, | ||||||
|             prefix=path, delimiter='/') |             prefix=path, delimiter='/') | ||||||
|        return container |        return container | ||||||
|  | @ -85,10 +76,9 @@ class SwiftStorage(BaseStorage): | ||||||
|       raise IOError('Unknown path: %s' % path) |       raise IOError('Unknown path: %s' % path) | ||||||
| 
 | 
 | ||||||
|   def _get_object(self, path, chunk_size=None): |   def _get_object(self, path, chunk_size=None): | ||||||
|     self._initialize() |  | ||||||
|     path = self._normalize_path(path) |     path = self._normalize_path(path) | ||||||
|     try: |     try: | ||||||
|       _, obj = self._swift_connection.get_object(self._swift_container, path, |       _, obj = self._get_connection().get_object(self._swift_container, path, | ||||||
|           resp_chunk_size=chunk_size) |           resp_chunk_size=chunk_size) | ||||||
|       return obj |       return obj | ||||||
|     except Exception: |     except Exception: | ||||||
|  | @ -96,7 +86,6 @@ class SwiftStorage(BaseStorage): | ||||||
|       raise IOError('Path %s not found' % path) |       raise IOError('Path %s not found' % path) | ||||||
| 
 | 
 | ||||||
|   def _put_object(self, path, content, chunk=None, content_type=None, content_encoding=None): |   def _put_object(self, path, content, chunk=None, content_type=None, content_encoding=None): | ||||||
|     self._initialize() |  | ||||||
|     path = self._normalize_path(path) |     path = self._normalize_path(path) | ||||||
|     headers = {} |     headers = {} | ||||||
| 
 | 
 | ||||||
|  | @ -104,7 +93,7 @@ class SwiftStorage(BaseStorage): | ||||||
|       headers['Content-Encoding'] = content_encoding |       headers['Content-Encoding'] = content_encoding | ||||||
| 
 | 
 | ||||||
|     try: |     try: | ||||||
|       self._swift_connection.put_object(self._swift_container, path, content, |       self._get_connection().put_object(self._swift_container, path, content, | ||||||
|                                         chunk_size=chunk, content_type=content_type, |                                         chunk_size=chunk, content_type=content_type, | ||||||
|                                         headers=headers) |                                         headers=headers) | ||||||
|     except ClientException: |     except ClientException: | ||||||
|  | @ -116,10 +105,9 @@ class SwiftStorage(BaseStorage): | ||||||
|       raise IOError("Could not put content: %s" % path) |       raise IOError("Could not put content: %s" % path) | ||||||
| 
 | 
 | ||||||
|   def _head_object(self, path): |   def _head_object(self, path): | ||||||
|     self._initialize() |  | ||||||
|     path = self._normalize_path(path) |     path = self._normalize_path(path) | ||||||
|     try: |     try: | ||||||
|       return self._swift_connection.head_object(self._swift_container, path) |       return self._get_connection().head_object(self._swift_container, path) | ||||||
|     except Exception: |     except Exception: | ||||||
|       logger.exception('Could not head object: %s', path) |       logger.exception('Could not head object: %s', path) | ||||||
|       return None |       return None | ||||||
|  | @ -171,10 +159,9 @@ class SwiftStorage(BaseStorage): | ||||||
|     return bool(self._head_object(path)) |     return bool(self._head_object(path)) | ||||||
| 
 | 
 | ||||||
|   def remove(self, path): |   def remove(self, path): | ||||||
|     self._initialize() |  | ||||||
|     path = self._normalize_path(path) |     path = self._normalize_path(path) | ||||||
|     try: |     try: | ||||||
|       self._swift_connection.delete_object(self._swift_container, path) |       self._get_connection().delete_object(self._swift_container, path) | ||||||
|     except Exception: |     except Exception: | ||||||
|       raise IOError('Cannot delete path: %s' % path) |       raise IOError('Cannot delete path: %s' % path) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Reference in a new issue