 051e9fa22b
			
		
	
	051e9fa22b
	
	
	
		
			
			Refactor the base class so they can use these methods Change-Id: I8455772eee4865d535b3002e2d922149fb8f8a6e Closes-bug: #1765087
		
			
				
	
	
		
			109 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			3.4 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 _get_workbooks_url(self, resource=None, namespace=None, scope=None):
 | |
|         path = '/workbooks'
 | |
| 
 | |
|         if resource:
 | |
|             path += '/%s' % resource
 | |
| 
 | |
|         if scope and namespace:
 | |
|             path += '?scope=%s&namespace=%s' % (scope, namespace)
 | |
|         elif scope:
 | |
|             path += '?scope=%s' % scope
 | |
|         elif namespace:
 | |
|             path += '?namespace=%s' % namespace
 | |
| 
 | |
|         return path
 | |
| 
 | |
|     def create(self, definition, namespace='', scope='private'):
 | |
|         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)
 | |
| 
 | |
|         return self._create(
 | |
|             self._get_workbooks_url(None, namespace, scope),
 | |
|             definition,
 | |
|             dump_json=False,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 | |
| 
 | |
|     def update(self, definition, namespace='', scope='private'):
 | |
|         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)
 | |
| 
 | |
|         return self._update(
 | |
|             self._get_workbooks_url(None, namespace, scope),
 | |
|             definition,
 | |
|             dump_json=False,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 | |
| 
 | |
|     def list(self, namespace='', marker='', limit=None, sort_keys='',
 | |
|              sort_dirs='', fields='', **filters):
 | |
|         query_string = self._build_query_params(
 | |
|             marker=marker,
 | |
|             limit=limit,
 | |
|             sort_keys=sort_keys,
 | |
|             sort_dirs=sort_dirs,
 | |
|             filters=filters,
 | |
|             namespace=namespace
 | |
|         )
 | |
| 
 | |
|         return self._list('/workbooks{}'.format(query_string),
 | |
|                           response_key='workbooks')
 | |
| 
 | |
|     def get(self, name, namespace=''):
 | |
|         self._ensure_not_empty(name=name)
 | |
| 
 | |
|         return self._get(
 | |
|             self._get_workbooks_url(name, namespace)
 | |
|         )
 | |
| 
 | |
|     def delete(self, name, namespace=''):
 | |
|         self._ensure_not_empty(name=name)
 | |
| 
 | |
|         self._delete(self._get_workbooks_url(name, namespace))
 | |
| 
 | |
|     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)
 | |
| 
 | |
|         return self._validate(
 | |
|             '/workbooks/validate',
 | |
|             definition,
 | |
|             dump_json=False,
 | |
|             headers={'content-type': 'text/plain'}
 | |
|         )
 |