 e65a0fbb2a
			
		
	
	e65a0fbb2a
	
	
	
		
			
			The api managers don't need a reference to the client that created them. Indeed this is circular and can cause problems with garbage collection later. Only pass the http_client that the managers actually use to the managers. Change-Id: I9f7e79c2fbc23bc0e69ed5d0f752ad74b6ce09c5
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright 2014 - Mirantis, Inc.
 | |
| # Copyright 2015 - StackStorm, Inc.
 | |
| #
 | |
| #    Licensed under the Apache License, Version 2.0 (the "License");
 | |
| #    you may not use this file except in compliance with the License.
 | |
| #    You may obtain a copy of the License at
 | |
| #
 | |
| #        http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| #    Unless required by applicable law or agreed to in writing, software
 | |
| #    distributed under the License is distributed on an "AS IS" BASIS,
 | |
| #    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| #    See the License for the specific language governing permissions and
 | |
| #    limitations under the License.
 | |
| 
 | |
| from mistralclient.api import base
 | |
| from mistralclient import utils
 | |
| 
 | |
| 
 | |
| class Workbook(base.Resource):
 | |
|     resource_name = 'Workbook'
 | |
| 
 | |
| 
 | |
| class WorkbookManager(base.ResourceManager):
 | |
|     resource_class = Workbook
 | |
| 
 | |
|     def create(self, definition):
 | |
|         self._ensure_not_empty(definition=definition)
 | |
| 
 | |
|         # If the specified definition is actually a file, read in the
 | |
|         # definition file
 | |
|         definition = utils.get_contents_if_file(definition)
 | |
| 
 | |
|         resp = self.http_client.post(
 | |
|             '/workbooks',
 | |
|             definition,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 | |
| 
 | |
|         if resp.status_code != 201:
 | |
|             self._raise_api_exception(resp)
 | |
| 
 | |
|         return self.resource_class(self, base.extract_json(resp, None))
 | |
| 
 | |
|     def update(self, definition):
 | |
|         self._ensure_not_empty(definition=definition)
 | |
| 
 | |
|         # If the specified definition is actually a file, read in the
 | |
|         # definition file
 | |
|         definition = utils.get_contents_if_file(definition)
 | |
| 
 | |
|         resp = self.http_client.put(
 | |
|             '/workbooks',
 | |
|             definition,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 | |
| 
 | |
|         if resp.status_code != 200:
 | |
|             self._raise_api_exception(resp)
 | |
| 
 | |
|         return self.resource_class(self, base.extract_json(resp, None))
 | |
| 
 | |
|     def list(self):
 | |
|         return self._list('/workbooks', response_key='workbooks')
 | |
| 
 | |
|     def get(self, name):
 | |
|         self._ensure_not_empty(name=name)
 | |
| 
 | |
|         return self._get('/workbooks/%s' % name)
 | |
| 
 | |
|     def delete(self, name):
 | |
|         self._ensure_not_empty(name=name)
 | |
| 
 | |
|         self._delete('/workbooks/%s' % name)
 | |
| 
 | |
|     def validate(self, definition):
 | |
|         self._ensure_not_empty(definition=definition)
 | |
| 
 | |
|         # If the specified definition is actually a file, read in the
 | |
|         # definition file
 | |
|         definition = utils.get_contents_if_file(definition)
 | |
| 
 | |
|         resp = self.http_client.post(
 | |
|             '/workbooks/validate',
 | |
|             definition,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 | |
| 
 | |
|         if resp.status_code != 200:
 | |
|             self._raise_api_exception(resp)
 | |
| 
 | |
|         return base.extract_json(resp, None)
 |