Merge "Add API Reference for Watcher"
This commit is contained in:
		
							
								
								
									
										90
									
								
								api-ref/source/conf.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								api-ref/source/conf.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | |||||||
|  | # 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. | ||||||
|  | # | ||||||
|  | # nova documentation build configuration file, created by | ||||||
|  | # sphinx-quickstart on Sat May  1 15:17:47 2010. | ||||||
|  | # | ||||||
|  | # This file is execfile()d with the current directory set to | ||||||
|  | # its containing dir. | ||||||
|  | # | ||||||
|  | # Note that not all possible configuration values are present in this | ||||||
|  | # autogenerated file. | ||||||
|  | # | ||||||
|  | # All configuration values have a default; values that are commented out | ||||||
|  | # serve to show the default. | ||||||
|  |  | ||||||
|  | from watcher import version as watcher_version | ||||||
|  |  | ||||||
|  |  | ||||||
|  | extensions = [ | ||||||
|  |     'openstackdocstheme', | ||||||
|  |     'os_api_ref', | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | # -- General configuration ---------------------------------------------------- | ||||||
|  |  | ||||||
|  | # Add any Sphinx extension module names here, as strings. They can be | ||||||
|  | # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones. | ||||||
|  |  | ||||||
|  | # The suffix of source filenames. | ||||||
|  | source_suffix = '.rst' | ||||||
|  |  | ||||||
|  | # The master toctree document. | ||||||
|  | master_doc = 'index' | ||||||
|  |  | ||||||
|  | # General information about the project. | ||||||
|  | project = u'Infrastructure Optimization API Reference' | ||||||
|  | copyright = u'2010-present, OpenStack Foundation' | ||||||
|  |  | ||||||
|  | # openstackdocstheme options | ||||||
|  | repository_name = 'openstack/watcher' | ||||||
|  | bug_project = 'watcher' | ||||||
|  | bug_tag = '' | ||||||
|  |  | ||||||
|  | # The version info for the project you're documenting, acts as replacement for | ||||||
|  | # |version| and |release|, also used in various other places throughout the | ||||||
|  | # built documents. | ||||||
|  | # | ||||||
|  | # The full version, including alpha/beta/rc tags. | ||||||
|  | release = watcher_version.version_info.release_string() | ||||||
|  | # The short X.Y version. | ||||||
|  | version = watcher_version.version_string | ||||||
|  |  | ||||||
|  | # The name of the Pygments (syntax highlighting) style to use. | ||||||
|  | pygments_style = 'sphinx' | ||||||
|  |  | ||||||
|  | # -- Options for HTML output -------------------------------------------------- | ||||||
|  |  | ||||||
|  | # The theme to use for HTML and HTML Help pages.  Major themes that come with | ||||||
|  | # Sphinx are currently 'default' and 'sphinxdoc'. | ||||||
|  | html_theme = 'openstackdocs' | ||||||
|  |  | ||||||
|  | # Theme options are theme-specific and customize the look and feel of a theme | ||||||
|  | # further.  For a list of options available for each theme, see the | ||||||
|  | # documentation. | ||||||
|  | html_theme_options = { | ||||||
|  |     "sidebar_mode": "toc", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # If not '', a 'Last updated on:' timestamp is inserted at every page bottom, | ||||||
|  | # using the given strftime format. | ||||||
|  | html_last_updated_fmt = '%Y-%m-%d %H:%M' | ||||||
|  |  | ||||||
|  | # -- Options for LaTeX output ------------------------------------------------- | ||||||
|  |  | ||||||
|  | # Grouping the document tree into LaTeX files. List of tuples | ||||||
|  | # (source start file, target name, title, author, documentclass | ||||||
|  | # [howto/manual]). | ||||||
|  | latex_documents = [ | ||||||
|  |     ('index', 'Watcher.tex', u'Infrastructure Optimization API Reference', | ||||||
|  |      u'OpenStack Foundation', 'manual'), | ||||||
|  | ] | ||||||
							
								
								
									
										16
									
								
								api-ref/source/index.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								api-ref/source/index.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | :tocdepth: 2 | ||||||
|  |  | ||||||
|  | =========== | ||||||
|  | Watcher API | ||||||
|  | =========== | ||||||
|  |  | ||||||
|  | .. rest_expand_all:: | ||||||
|  |  | ||||||
|  | .. include:: watcher-api-v1-audittemplates.inc | ||||||
|  | .. include:: watcher-api-v1-audits.inc | ||||||
|  | .. include:: watcher-api-v1-actionplans.inc | ||||||
|  | .. include:: watcher-api-v1-actions.inc | ||||||
|  | .. include:: watcher-api-v1-goals.inc | ||||||
|  | .. include:: watcher-api-v1-strategies.inc | ||||||
|  | .. include:: watcher-api-v1-services.inc | ||||||
|  | .. include:: watcher-api-v1-scoring_engines.inc | ||||||
							
								
								
									
										411
									
								
								api-ref/source/parameters.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										411
									
								
								api-ref/source/parameters.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,411 @@ | |||||||
|  | # Path | ||||||
|  | action_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID of the Action. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | actionplan_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID of the Action Plan. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | audit_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Audit. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | audittemplate_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Audit Template. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | goal_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Goal. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | scoring_engine_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Scoring Engine. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | service_ident: | ||||||
|  |   description: | | ||||||
|  |     The ID or name of the Service. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | strategy_ident: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Strategy. | ||||||
|  |   in: path | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Query body | ||||||
|  | limit: | ||||||
|  |   description: | | ||||||
|  |     Requests a page size of items. Returns a number of items up to a ``limit`` | ||||||
|  |     value. Use the limit parameter to make an initial limited request and use | ||||||
|  |     the ID of the last-seen item from the response as the ``marker`` parameter | ||||||
|  |     value in a subsequent limited request.  | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: integer | ||||||
|  | marker: | ||||||
|  |   description: | | ||||||
|  |     The ID of the last-seen item. Use the ``limit`` parameter to make an | ||||||
|  |     initial limited request and use the ID of the last-seen item from the | ||||||
|  |     response as the ``marker`` parameter value in a subsequent limited request. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | r_action_plan: | ||||||
|  |   description: | | ||||||
|  |     UUID of the action plan used for filtering. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | r_audit: | ||||||
|  |   description: | | ||||||
|  |     Optional UUID of an audit, to get only actions for that audit. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | r_goal: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Goal. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | r_strategy: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Strategy. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | sort_dir: | ||||||
|  |   description: | | ||||||
|  |     Sorts the response by the requested sort direction. | ||||||
|  |     A valid value is ``asc`` (ascending) or ``desc`` (descending). | ||||||
|  |     Default is ``asc``. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | sort_key: | ||||||
|  |   description: | | ||||||
|  |     Sorts the response by the this attribute value. Default is ``id``. | ||||||
|  |   in: query | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # variables in the API response body | ||||||
|  |  | ||||||
|  | # Action | ||||||
|  | action_action_plan_uuid: | ||||||
|  |   description: | | ||||||
|  |     The action plan this action belongs to. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | action_description: | ||||||
|  |   description: | | ||||||
|  |     Action description. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | action_input_parameters: | ||||||
|  |   description: | | ||||||
|  |     Input parameters which are used by appropriate action type. For example, | ||||||
|  |     ``migration`` action takes into account such parameters as | ||||||
|  |     ``migration_type``, ``destination_node``, ``resource_id`` and | ||||||
|  |     ``source_node``. To see a list of supported action types and their input | ||||||
|  |     parameters visit `Action plugins page <https://docs.openstack.org/watcher/latest/contributor/plugin/plugins.html#actions>`_. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: JSON | ||||||
|  | action_parents: | ||||||
|  |   description: | | ||||||
|  |     UUIDs of parent actions. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: array | ||||||
|  | action_state: | ||||||
|  |   description: | | ||||||
|  |     State of Action. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | action_type: | ||||||
|  |   description: | | ||||||
|  |     Action type based on specific API action. Actions in Watcher are | ||||||
|  |     pluggable, to see a list of supported action types visit | ||||||
|  |     `Action plugins page <https://docs.openstack.org/watcher/latest/contributor/plugin/plugins.html#actions>`_. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Action Plan | ||||||
|  | actionplan_audit_uuid: | ||||||
|  |   description: | | ||||||
|  |     The UUID of the audit this acton plan belongs to. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | actionplan_efficacy_indicators: | ||||||
|  |   description: | | ||||||
|  |     The list of efficacy indicators associated to this action plan. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: array | ||||||
|  | actionplan_global_efficacy: | ||||||
|  |   description: | | ||||||
|  |     The global efficacy of this action plan. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: array | ||||||
|  | actionplan_state: | ||||||
|  |   description: | | ||||||
|  |     State of this action plan. To get more information about states and | ||||||
|  |     action plan's lifecycle, visit `Action Plan State Machine page <https://docs.openstack.org/watcher/latest/architecture.html#action-plan-state-machine>`_. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Audit | ||||||
|  | audit_autotrigger: | ||||||
|  |   description: | | ||||||
|  |     Autoexecute action plan once audit is succeeded. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: boolean | ||||||
|  | audit_goal: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Goal. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audit_interval: | ||||||
|  |   description: | | ||||||
|  |     Time interval between audit's execution. | ||||||
|  |     Can be set either in seconds or cron syntax. | ||||||
|  |     Should be defined only for CONTINUOUS audits. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audit_name: | ||||||
|  |   description: | | ||||||
|  |     Name of this audit. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audit_next_run_time: | ||||||
|  |   description: | | ||||||
|  |     The next time audit launch. Defined only for CONTINUOUS audits. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audit_parameters: | ||||||
|  |   description: | | ||||||
|  |     The strategy parameters for this audit. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: JSON | ||||||
|  | audit_state: | ||||||
|  |   description: | | ||||||
|  |     State of this audit. To get more information about states and | ||||||
|  |     audit's lifecycle, visit `Audit State Machine page <https://docs.openstack.org/watcher/latest/architecture.html#audit-state-machine>`_. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | audit_strategy: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Strategy. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audit_type: | ||||||
|  |   description: | | ||||||
|  |     Type of this audit. Can be either ONESHOT or CONTINUOUS. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Audit Template | ||||||
|  | audittemplate_description: | ||||||
|  |   description: | | ||||||
|  |     Short description of the Audit Template. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  | audittemplate_goal: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Goal. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | audittemplate_name: | ||||||
|  |   description: | | ||||||
|  |     The name of the Audit template. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | audittemplate_scope: | ||||||
|  |   description: | | ||||||
|  |     Audit Scope. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: JSON | ||||||
|  | audittemplate_strategy: | ||||||
|  |   description: | | ||||||
|  |     The UUID or name of the Strategy. | ||||||
|  |   in: body | ||||||
|  |   required: false | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Goal | ||||||
|  | goal_display_name: | ||||||
|  |   description: | | ||||||
|  |     Localized name of the goal. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | goal_efficacy_specification: | ||||||
|  |   description: | | ||||||
|  |     Efficacy specifications as result of stategy's execution. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: array | ||||||
|  | goal_name: | ||||||
|  |   description: | | ||||||
|  |     Name of the goal. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | goal_uuid: | ||||||
|  |   description: | | ||||||
|  |     Unique UUID for this goal. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | links: | ||||||
|  |   description: | | ||||||
|  |     A list of relative links. Includes the self and bookmark links. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: array | ||||||
|  |  | ||||||
|  | # Scoring Engine | ||||||
|  | scoring_engine_description: | ||||||
|  |   description: | | ||||||
|  |     A human readable description of the Scoring Engine. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | scoring_engine_metainfo: | ||||||
|  |   description: | | ||||||
|  |     A metadata associated with the scoring engine | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | scoring_engine_name: | ||||||
|  |   description: | | ||||||
|  |     The name of the scoring engine. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | # Service | ||||||
|  | service_host: | ||||||
|  |   description: | | ||||||
|  |     Name of host where service is placed on. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | service_id: | ||||||
|  |   description: | | ||||||
|  |     ID of service. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: integer | ||||||
|  | service_last_seen_up: | ||||||
|  |   description: | | ||||||
|  |     Time when Watcher service sent latest heartbeat. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | service_name: | ||||||
|  |   description: | | ||||||
|  |     Name of service like ``watcher-applier``. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | service_status: | ||||||
|  |   description: | | ||||||
|  |     State of service. It can be either in ACTIVE or FAILED state. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | # Strategy | ||||||
|  | strategy_check_comment: | ||||||
|  |   description: | | ||||||
|  |     Requirement comment. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | strategy_check_mandatory: | ||||||
|  |   description: | | ||||||
|  |     Whether this requirement mandatory or not. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: boolean | ||||||
|  | strategy_check_state: | ||||||
|  |   description: | | ||||||
|  |     State of requirement for Strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string or JSON | ||||||
|  | strategy_check_type: | ||||||
|  |   description: | | ||||||
|  |     Type of requirement for Strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | strategy_display_name: | ||||||
|  |   description: | | ||||||
|  |     Localized name of the strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | strategy_name: | ||||||
|  |   description: | | ||||||
|  |     Name of the strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  | strategy_parameters_spec: | ||||||
|  |   description: | | ||||||
|  |     Parameters specifications for this strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: JSON | ||||||
|  | strategy_uuid: | ||||||
|  |   description: | | ||||||
|  |     Unique UUID for this strategy. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
|  |  | ||||||
|  | uuid: | ||||||
|  |   description: | | ||||||
|  |     The UUID for the resource. | ||||||
|  |   in: body | ||||||
|  |   required: true | ||||||
|  |   type: string | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "op": "replace", | ||||||
|  |         "value": "CANCELLING", | ||||||
|  |         "path": "/state" | ||||||
|  |     } | ||||||
|  | ] | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "op": "replace", | ||||||
|  |         "value": "CANCELLED", | ||||||
|  |         "path": "/state" | ||||||
|  |     } | ||||||
|  | ] | ||||||
							
								
								
									
										24
									
								
								api-ref/source/samples/actionplan-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								api-ref/source/samples/actionplan-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | { | ||||||
|  |     "action_plans": [ | ||||||
|  |         { | ||||||
|  |             "state": "ONGOING", | ||||||
|  |             "efficacy_indicators": [], | ||||||
|  |             "strategy_uuid": "7dae0eea-9df7-42b8-bb3e-313958ff2242", | ||||||
|  |             "global_efficacy": [], | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "updated_at": "2018-04-10T11:59:52.640067+00:00", | ||||||
|  |             "strategy_name": "dummy_with_resize", | ||||||
|  |             "uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf", | ||||||
|  |             "audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										20
									
								
								api-ref/source/samples/actionplan-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								api-ref/source/samples/actionplan-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | { | ||||||
|  |     "state": "ONGOING", | ||||||
|  |     "efficacy_indicators": [], | ||||||
|  |     "strategy_uuid": "7dae0eea-9df7-42b8-bb3e-313958ff2242", | ||||||
|  |     "global_efficacy": [], | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "updated_at": "2018-04-10T11:59:52.640067+00:00", | ||||||
|  |     "strategy_name": "dummy_with_resize", | ||||||
|  |     "uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf", | ||||||
|  |     "audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a" | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								api-ref/source/samples/actionplan-start-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								api-ref/source/samples/actionplan-start-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | { | ||||||
|  |     "state": "PENDING", | ||||||
|  |     "efficacy_indicators": [], | ||||||
|  |     "strategy_uuid": "7dae0eea-9df7-42b8-bb3e-313958ff2242", | ||||||
|  |     "global_efficacy": [], | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/action_plans/4cbc4ede-0d25-481b-b86e-998dbbd4f8bf" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "updated_at": "2018-04-10T11:59:41.602430+00:00", | ||||||
|  |     "strategy_name": "dummy_with_resize", | ||||||
|  |     "uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf", | ||||||
|  |     "audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a", | ||||||
|  |     "created_at": "2018-04-10T11:59:12.592729+00:00", | ||||||
|  |     "deleted_at": null | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								api-ref/source/samples/actions-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								api-ref/source/samples/actions-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | { | ||||||
|  |     "actions": [ | ||||||
|  |         { | ||||||
|  |             "state": "PENDING", | ||||||
|  |             "description": "Wait for a given interval in seconds.", | ||||||
|  |             "parents": [ | ||||||
|  |                 "8119d16e-b419-4729-b015-fc04c4e45783" | ||||||
|  |             ], | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/actions/7182a988-e6c4-4152-a0d6-067119475c83" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/actions/7182a988-e6c4-4152-a0d6-067119475c83" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "action_plan_uuid": "c6bba9ed-a7eb-4370-9993-d873e5e22cba", | ||||||
|  |             "uuid": "7182a988-e6c4-4152-a0d6-067119475c83", | ||||||
|  |             "deleted_at": null, | ||||||
|  |             "updated_at": null, | ||||||
|  |             "input_parameters": { | ||||||
|  |                 "duration": 3.2 | ||||||
|  |             }, | ||||||
|  |             "action_type": "sleep", | ||||||
|  |             "created_at": "2018-03-26T11:56:08.235226+00:00" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										23
									
								
								api-ref/source/samples/actions-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								api-ref/source/samples/actions-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | { | ||||||
|  |     "actions": [ | ||||||
|  |         { | ||||||
|  |             "state": "PENDING", | ||||||
|  |             "parents": [ | ||||||
|  |                 "8119d16e-b419-4729-b015-fc04c4e45783" | ||||||
|  |             ], | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/actions/7182a988-e6c4-4152-a0d6-067119475c83" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/actions/7182a988-e6c4-4152-a0d6-067119475c83" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "action_plan_uuid": "c6bba9ed-a7eb-4370-9993-d873e5e22cba", | ||||||
|  |             "uuid": "7182a988-e6c4-4152-a0d6-067119475c83", | ||||||
|  |             "action_type": "sleep" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								api-ref/source/samples/actions-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								api-ref/source/samples/actions-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | { | ||||||
|  |     "state": "SUCCEEDED", | ||||||
|  |     "description": "Logging a NOP message", | ||||||
|  |     "parents": [ | ||||||
|  |         "b4529294-1de6-4302-b57a-9b5d5dc363c6" | ||||||
|  |     ], | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "action_plan_uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf", | ||||||
|  |     "uuid": "54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "updated_at": "2018-04-10T11:59:44.026973+00:00", | ||||||
|  |     "input_parameters": { | ||||||
|  |         "message": "Welcome" | ||||||
|  |     }, | ||||||
|  |     "action_type": "nop", | ||||||
|  |     "created_at": "2018-04-10T11:59:12.725147+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								api-ref/source/samples/audit-cancel-request.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								api-ref/source/samples/audit-cancel-request.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "op": "replace", | ||||||
|  |         "value": "CANCELLED", | ||||||
|  |         "path": "/state" | ||||||
|  |     } | ||||||
|  | ] | ||||||
							
								
								
									
										51
									
								
								api-ref/source/samples/audit-cancel-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								api-ref/source/samples/audit-cancel-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | { | ||||||
|  |     "interval": "*/2 * * * *", | ||||||
|  |     "strategy_uuid": "6b3b3902-8508-4cb0-bb85-67f32866b086", | ||||||
|  |     "goal_uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |     "name": "audit1", | ||||||
|  |     "parameters": { | ||||||
|  |         "host_choice": "retry", | ||||||
|  |         "instance_metrics": { | ||||||
|  |             "cpu_util": "compute.node.cpu.percent", | ||||||
|  |             "memory.resident": "hardware.memory.used" | ||||||
|  |         }, | ||||||
|  |         "granularity": 300, | ||||||
|  |         "weights": { | ||||||
|  |             "cpu_util_weight": 1.0, | ||||||
|  |             "memory.resident_weight": 1.0 | ||||||
|  |         }, | ||||||
|  |         "retry_count": 1, | ||||||
|  |         "metrics": [ | ||||||
|  |             "cpu_util" | ||||||
|  |         ], | ||||||
|  |         "periods": { | ||||||
|  |             "instance": 720, | ||||||
|  |             "node": 600 | ||||||
|  |         }, | ||||||
|  |         "thresholds": { | ||||||
|  |             "cpu_util": 0.2, | ||||||
|  |             "memory.resident": 0.2 | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "uuid": "65a5da84-5819-4aea-8278-a28d2b489028", | ||||||
|  |     "goal_name": "workload_balancing", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-06T07:27:27.820460+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "state": "CANCELLED", | ||||||
|  |     "audit_type": "CONTINUOUS", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": "workload_stabilization", | ||||||
|  |     "next_run_time": "2018-04-06T11:56:00", | ||||||
|  |     "updated_at": "2018-04-06T11:54:01.266447+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								api-ref/source/samples/audit-create-request-continuous.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								api-ref/source/samples/audit-create-request-continuous.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | { | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "audit_template_uuid": "76fddfee-a9c4-40b0-8da0-c19ad6904f09", | ||||||
|  |     "name": "test_audit", | ||||||
|  |     "parameters": { | ||||||
|  |         "metrics": [ | ||||||
|  |             "cpu_util" | ||||||
|  |         ] | ||||||
|  |     }, | ||||||
|  |     "audit_type": "CONTINUOUS", | ||||||
|  |     "interval": "*/2 * * * *" | ||||||
|  | } | ||||||
							
								
								
									
										5
									
								
								api-ref/source/samples/audit-create-request-oneshot.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								api-ref/source/samples/audit-create-request-oneshot.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | { | ||||||
|  |     "audit_type": "ONESHOT", | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "audit_template_uuid": "5e70a156-ced7-4012-b1c6-88fcb02ee0c1" | ||||||
|  | } | ||||||
							
								
								
									
										51
									
								
								api-ref/source/samples/audit-create-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								api-ref/source/samples/audit-create-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | { | ||||||
|  |     "interval": "*/2 * * * *", | ||||||
|  |     "strategy_uuid": "6b3b3902-8508-4cb0-bb85-67f32866b086", | ||||||
|  |     "goal_uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |     "name": "test_audit", | ||||||
|  |     "parameters": { | ||||||
|  |         "host_choice": "retry", | ||||||
|  |         "granularity": 300, | ||||||
|  |         "thresholds": { | ||||||
|  |             "cpu_util": 0.2, | ||||||
|  |             "memory.resident": 0.2 | ||||||
|  |         }, | ||||||
|  |         "periods": { | ||||||
|  |             "node": 600, | ||||||
|  |             "instance": 720 | ||||||
|  |         }, | ||||||
|  |         "retry_count": 1, | ||||||
|  |         "metrics": [ | ||||||
|  |             "cpu_util" | ||||||
|  |         ], | ||||||
|  |         "weights": { | ||||||
|  |             "cpu_util_weight": 1.0, | ||||||
|  |             "memory.resident_weight": 1.0 | ||||||
|  |         }, | ||||||
|  |         "instance_metrics": { | ||||||
|  |             "cpu_util": "compute.node.cpu.percent", | ||||||
|  |             "memory.resident": "hardware.memory.used" | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "uuid": "65a5da84-5819-4aea-8278-a28d2b489028", | ||||||
|  |     "goal_name": "workload_balancing", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-06T07:27:27.820460+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "state": "PENDING", | ||||||
|  |     "audit_type": "CONTINUOUS", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": "workload_stabilization", | ||||||
|  |     "next_run_time": null, | ||||||
|  |     "updated_at": null | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								api-ref/source/samples/audit-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								api-ref/source/samples/audit-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | { | ||||||
|  |     "audits": [ | ||||||
|  |         { | ||||||
|  |             "interval": "*/2 * * * *", | ||||||
|  |             "strategy_uuid": "6b3b3902-8508-4cb0-bb85-67f32866b086", | ||||||
|  |             "goal_uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |             "name": "test_audit", | ||||||
|  |             "parameters": { | ||||||
|  |                 "host_choice": "retry", | ||||||
|  |                 "instance_metrics": { | ||||||
|  |                     "cpu_util": "compute.node.cpu.percent", | ||||||
|  |                     "memory.resident": "hardware.memory.used" | ||||||
|  |                 }, | ||||||
|  |                 "granularity": 300, | ||||||
|  |                 "weights": { | ||||||
|  |                     "cpu_util_weight": 1.0, | ||||||
|  |                     "memory.resident_weight": 1.0 | ||||||
|  |                 }, | ||||||
|  |                 "retry_count": 1, | ||||||
|  |                 "metrics": [ | ||||||
|  |                     "cpu_util" | ||||||
|  |                 ], | ||||||
|  |                 "periods": { | ||||||
|  |                     "instance": 720, | ||||||
|  |                     "node": 600 | ||||||
|  |                 }, | ||||||
|  |                 "thresholds": { | ||||||
|  |                     "cpu_util": 0.2, | ||||||
|  |                     "memory.resident": 0.2 | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "auto_trigger": false, | ||||||
|  |             "uuid": "65a5da84-5819-4aea-8278-a28d2b489028", | ||||||
|  |             "goal_name": "workload_balancing", | ||||||
|  |             "scope": [], | ||||||
|  |             "created_at": "2018-04-06T07:27:27.820460+00:00", | ||||||
|  |             "deleted_at": null, | ||||||
|  |             "state": "ONGOING", | ||||||
|  |             "audit_type": "CONTINUOUS", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "strategy_name": "workload_stabilization", | ||||||
|  |             "next_run_time": "2018-04-06T09:46:00", | ||||||
|  |             "updated_at": "2018-04-06T09:44:01.604146+00:00" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										28
									
								
								api-ref/source/samples/audit-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								api-ref/source/samples/audit-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | { | ||||||
|  |     "audits": [ | ||||||
|  |         { | ||||||
|  |             "interval": null, | ||||||
|  |             "strategy_uuid": "e311727b-b9b3-43ef-a5f7-8bd7ea80df25", | ||||||
|  |             "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |             "name": "dummy-2018-03-26T11:56:07.950400", | ||||||
|  |             "auto_trigger": false, | ||||||
|  |             "uuid": "ccc69a5f-114e-46f4-b15e-a77eaa337b01", | ||||||
|  |             "goal_name": "dummy", | ||||||
|  |             "scope": [], | ||||||
|  |             "state": "SUCCEEDED", | ||||||
|  |             "audit_type": "ONESHOT", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/audits/ccc69a5f-114e-46f4-b15e-a77eaa337b01" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/audits/ccc69a5f-114e-46f4-b15e-a77eaa337b01" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "strategy_name": "dummy", | ||||||
|  |             "next_run_time": null | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										51
									
								
								api-ref/source/samples/audit-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								api-ref/source/samples/audit-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | { | ||||||
|  |     "interval": "*/2 * * * *", | ||||||
|  |     "strategy_uuid": "6b3b3902-8508-4cb0-bb85-67f32866b086", | ||||||
|  |     "goal_uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |     "name": "test_audit", | ||||||
|  |     "parameters": { | ||||||
|  |         "host_choice": "retry", | ||||||
|  |         "instance_metrics": { | ||||||
|  |             "cpu_util": "compute.node.cpu.percent", | ||||||
|  |             "memory.resident": "hardware.memory.used" | ||||||
|  |         }, | ||||||
|  |         "granularity": 300, | ||||||
|  |         "weights": { | ||||||
|  |             "cpu_util_weight": 1.0, | ||||||
|  |             "memory.resident_weight": 1.0 | ||||||
|  |         }, | ||||||
|  |         "retry_count": 1, | ||||||
|  |         "metrics": [ | ||||||
|  |             "cpu_util" | ||||||
|  |         ], | ||||||
|  |         "periods": { | ||||||
|  |             "instance": 720, | ||||||
|  |             "node": 600 | ||||||
|  |         }, | ||||||
|  |         "thresholds": { | ||||||
|  |             "cpu_util": 0.2, | ||||||
|  |             "memory.resident": 0.2 | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "uuid": "65a5da84-5819-4aea-8278-a28d2b489028", | ||||||
|  |     "goal_name": "workload_balancing", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-06T07:27:27.820460+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "state": "ONGOING", | ||||||
|  |     "audit_type": "CONTINUOUS", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": "workload_stabilization", | ||||||
|  |     "next_run_time": "2018-04-06T11:56:00", | ||||||
|  |     "updated_at": "2018-04-06T11:54:01.266447+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										12
									
								
								api-ref/source/samples/audit-update-request.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								api-ref/source/samples/audit-update-request.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "value": "CANCELLED", | ||||||
|  |         "path": "/state", | ||||||
|  |         "op": "replace" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "value": "audit1", | ||||||
|  |         "path": "/name", | ||||||
|  |         "op": "replace" | ||||||
|  |     } | ||||||
|  | ] | ||||||
							
								
								
									
										51
									
								
								api-ref/source/samples/audit-update-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								api-ref/source/samples/audit-update-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | { | ||||||
|  |     "interval": "*/2 * * * *", | ||||||
|  |     "strategy_uuid": "6b3b3902-8508-4cb0-bb85-67f32866b086", | ||||||
|  |     "goal_uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |     "name": "audit1", | ||||||
|  |     "parameters": { | ||||||
|  |         "host_choice": "retry", | ||||||
|  |         "instance_metrics": { | ||||||
|  |             "cpu_util": "compute.node.cpu.percent", | ||||||
|  |             "memory.resident": "hardware.memory.used" | ||||||
|  |         }, | ||||||
|  |         "granularity": 300, | ||||||
|  |         "weights": { | ||||||
|  |             "cpu_util_weight": 1.0, | ||||||
|  |             "memory.resident_weight": 1.0 | ||||||
|  |         }, | ||||||
|  |         "retry_count": 1, | ||||||
|  |         "metrics": [ | ||||||
|  |             "cpu_util" | ||||||
|  |         ], | ||||||
|  |         "periods": { | ||||||
|  |             "instance": 720, | ||||||
|  |             "node": 600 | ||||||
|  |         }, | ||||||
|  |         "thresholds": { | ||||||
|  |             "cpu_util": 0.2, | ||||||
|  |             "memory.resident": 0.2 | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "auto_trigger": false, | ||||||
|  |     "uuid": "65a5da84-5819-4aea-8278-a28d2b489028", | ||||||
|  |     "goal_name": "workload_balancing", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-06T07:27:27.820460+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "state": "CANCELLED", | ||||||
|  |     "audit_type": "CONTINUOUS", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audits/65a5da84-5819-4aea-8278-a28d2b489028" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": "workload_stabilization", | ||||||
|  |     "next_run_time": "2018-04-06T11:56:00", | ||||||
|  |     "updated_at": "2018-04-06T11:54:01.266447+00:00" | ||||||
|  | } | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | { | ||||||
|  |     "name": "at2", | ||||||
|  |     "goal": "dummy", | ||||||
|  |     "strategy": "dummy", | ||||||
|  |     "description": "the second audit template", | ||||||
|  |     "scope": [] | ||||||
|  | } | ||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | { | ||||||
|  |     "name": "at2", | ||||||
|  |     "goal": "dummy" | ||||||
|  | } | ||||||
							
								
								
									
										23
									
								
								api-ref/source/samples/audittemplate-create-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								api-ref/source/samples/audittemplate-create-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | { | ||||||
|  |     "description": null, | ||||||
|  |     "strategy_uuid": null, | ||||||
|  |     "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |     "name": "at3", | ||||||
|  |     "uuid": "b4041d8c-85d7-4224-851d-649fe48b7196", | ||||||
|  |     "goal_name": "dummy", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-04T08:38:33.110432+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": null, | ||||||
|  |     "updated_at": null | ||||||
|  | } | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | { | ||||||
|  |     "audit_templates":[ | ||||||
|  |         { | ||||||
|  |             "strategy_uuid": null, | ||||||
|  |             "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |             "name": "at3", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", "href": | ||||||
|  |                     "http://controller:9322/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "strategy_name": null, | ||||||
|  |             "uuid": "b4041d8c-85d7-4224-851d-649fe48b7196", | ||||||
|  |             "goal_name": "dummy", "scope": [], | ||||||
|  |             "description": null | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								api-ref/source/samples/audittemplate-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								api-ref/source/samples/audittemplate-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | { | ||||||
|  |     "audit_templates":[ | ||||||
|  |         { | ||||||
|  |             "strategy_uuid": null, | ||||||
|  |             "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |             "name": "at3", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", "href": | ||||||
|  |                     "http://controller:9322/audit_templates/b4041d8c-85d7-4224-851d-649fe48b7196" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "strategy_name": null, | ||||||
|  |             "uuid": "b4041d8c-85d7-4224-851d-649fe48b7196", | ||||||
|  |             "goal_name": "dummy", "scope": [] | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										23
									
								
								api-ref/source/samples/audittemplate-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								api-ref/source/samples/audittemplate-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | { | ||||||
|  |     "description": "test 1", | ||||||
|  |     "strategy_uuid": null, | ||||||
|  |     "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |     "name": "at1", | ||||||
|  |     "uuid": "0d100c27-14af-4962-86fb-f6079287c9c6", | ||||||
|  |     "goal_name": "dummy", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-04T07:48:36.175472+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audit_templates/0d100c27-14af-4962-86fb-f6079287c9c6" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audit_templates/0d100c27-14af-4962-86fb-f6079287c9c6" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": null, | ||||||
|  |     "updated_at": "2018-04-05T07:57:55.803650+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										7
									
								
								api-ref/source/samples/audittemplate-update-request.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								api-ref/source/samples/audittemplate-update-request.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "op": "replace", | ||||||
|  |         "value": "PENDING", | ||||||
|  |         "path": "/state" | ||||||
|  |     } | ||||||
|  | ] | ||||||
							
								
								
									
										23
									
								
								api-ref/source/samples/audittemplate-update-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								api-ref/source/samples/audittemplate-update-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | { | ||||||
|  |     "description": "test 1", | ||||||
|  |     "strategy_uuid": null, | ||||||
|  |     "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |     "name": "at11", | ||||||
|  |     "uuid": "0d100c27-14af-4962-86fb-f6079287c9c6", | ||||||
|  |     "goal_name": "dummy", | ||||||
|  |     "scope": [], | ||||||
|  |     "created_at": "2018-04-04T07:48:36.175472+00:00", | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/audit_templates/0d100c27-14af-4962-86fb-f6079287c9c6" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/audit_templates/0d100c27-14af-4962-86fb-f6079287c9c6" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "strategy_name": null, | ||||||
|  |     "updated_at": "2018-04-05T07:57:42.139127+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								api-ref/source/samples/goal-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								api-ref/source/samples/goal-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | { | ||||||
|  |     "goals": [ | ||||||
|  |         { | ||||||
|  |             "efficacy_specification": [], | ||||||
|  |             "uuid": "e1a5a45b-f251-47cf-9c5f-fa1e66e1286a", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/goals/e1a5a45b-f251-47cf-9c5f-fa1e66e1286a" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/goals/e1a5a45b-f251-47cf-9c5f-fa1e66e1286a" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "name": "workload_balancing", | ||||||
|  |             "display_name": "Workload Balancing" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "efficacy_specification": [ | ||||||
|  |                 { | ||||||
|  |                     "description": "The total number of enabled compute nodes.", | ||||||
|  |                     "schema": "Range(min=0, max=None, min_included=True, max_included=True, msg=None)", | ||||||
|  |                     "name": "compute_nodes_count", | ||||||
|  |                     "unit": null | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "description": "The number of compute nodes to be released.", | ||||||
|  |                     "schema": "Range(min=0, max=None, min_included=True, max_included=True, msg=None)", | ||||||
|  |                     "name": "released_compute_nodes_count", | ||||||
|  |                     "unit": null | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "description": "The number of VM migrations to be performed.", | ||||||
|  |                     "schema": "Range(min=0, max=None, min_included=True, max_included=True, msg=None)", | ||||||
|  |                     "name": "instance_migrations_count", | ||||||
|  |                     "unit": null | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "uuid": "cb9afa5e-aec7-4a8c-9261-c15c33f2262b", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/goals/cb9afa5e-aec7-4a8c-9261-c15c33f2262b" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/goals/cb9afa5e-aec7-4a8c-9261-c15c33f2262b" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "name": "server_consolidation", | ||||||
|  |             "display_name": "Server Consolidation" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								api-ref/source/samples/goal-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								api-ref/source/samples/goal-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | { | ||||||
|  |     "efficacy_specification": [], | ||||||
|  |     "name": "saving_energy", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/goals/6f52889a-9dd4-4dbb-8e70-39b56c4836cc" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/goals/6f52889a-9dd4-4dbb-8e70-39b56c4836cc" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "uuid": "6f52889a-9dd4-4dbb-8e70-39b56c4836cc", | ||||||
|  |     "updated_at": null, | ||||||
|  |     "display_name": "Saving Energy", | ||||||
|  |     "created_at": "2018-03-26T11:55:24.365584+00:00", | ||||||
|  |     "deleted_at": null | ||||||
|  | } | ||||||
| @@ -0,0 +1,20 @@ | |||||||
|  | { | ||||||
|  |     "scoring_engines": [ | ||||||
|  |         { | ||||||
|  |             "description": "Dummy Scorer calculating the average value", | ||||||
|  |             "uuid": "5a44f007-55b1-423c-809f-6a274a9bd93b", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/scoring_engines/5a44f007-55b1-423c-809f-6a274a9bd93b" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/scoring_engines/5a44f007-55b1-423c-809f-6a274a9bd93b" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "name": "dummy_avg_scorer", | ||||||
|  |             "metainfo": "" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								api-ref/source/samples/scoring_engine-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								api-ref/source/samples/scoring_engine-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | { | ||||||
|  |     "scoring_engines": [ | ||||||
|  |         { | ||||||
|  |             "description": "Dummy Scorer calculating the average value", | ||||||
|  |             "uuid": "5a44f007-55b1-423c-809f-6a274a9bd93b", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/scoring_engines/5a44f007-55b1-423c-809f-6a274a9bd93b" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/scoring_engines/5a44f007-55b1-423c-809f-6a274a9bd93b" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "name": "dummy_avg_scorer" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								api-ref/source/samples/scoring_engine-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								api-ref/source/samples/scoring_engine-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | { | ||||||
|  |     "description": "Dummy Scorer calculating the maximum value", | ||||||
|  |     "uuid": "1ac42282-4e77-473e-898b-62ea007f1deb", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/scoring_engines/1ac42282-4e77-473e-898b-62ea007f1deb" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/scoring_engines/1ac42282-4e77-473e-898b-62ea007f1deb" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "name": "dummy_max_scorer", | ||||||
|  |     "metainfo": "" | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								api-ref/source/samples/service-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								api-ref/source/samples/service-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | { | ||||||
|  |     "services": [ | ||||||
|  |         { | ||||||
|  |             "status": "ACTIVE", | ||||||
|  |             "name": "watcher-applier", | ||||||
|  |             "host": "controller", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/services/1" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/services/1" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "id": 1, | ||||||
|  |             "deleted_at": null, | ||||||
|  |             "updated_at": "2018-04-26T08:52:37.652895+00:00", | ||||||
|  |             "last_seen_up": "2018-04-26T08:52:37.648572", | ||||||
|  |             "created_at": "2018-03-26T11:55:24.075093+00:00" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										36
									
								
								api-ref/source/samples/service-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								api-ref/source/samples/service-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | { | ||||||
|  |     "services": [ | ||||||
|  |         { | ||||||
|  |             "id": 1, | ||||||
|  |             "status": "ACTIVE", | ||||||
|  |             "name": "watcher-applier", | ||||||
|  |             "host": "controller", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/services/1" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/services/1" | ||||||
|  |                 } | ||||||
|  |             ] | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "id": 2, | ||||||
|  |             "status": "ACTIVE", | ||||||
|  |             "name": "watcher-decision-engine", | ||||||
|  |             "host": "controller", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/services/2" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/services/2" | ||||||
|  |                 } | ||||||
|  |             ] | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										20
									
								
								api-ref/source/samples/service-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								api-ref/source/samples/service-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | { | ||||||
|  |     "status": "ACTIVE", | ||||||
|  |     "name": "watcher-applier", | ||||||
|  |     "host": "controller", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/services/1" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/services/1" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "id": 1, | ||||||
|  |     "deleted_at": null, | ||||||
|  |     "updated_at": "2018-04-26T09:45:37.653061+00:00", | ||||||
|  |     "last_seen_up": "2018-04-26T09:45:37.649314", | ||||||
|  |     "created_at": "2018-03-26T11:55:24.075093+00:00" | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								api-ref/source/samples/strategy-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								api-ref/source/samples/strategy-list-detailed-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | { | ||||||
|  |     "strategies": [ | ||||||
|  |         { | ||||||
|  |             "goal_uuid": "cb9afa5e-aec7-4a8c-9261-c15c33f2262b", | ||||||
|  |             "name": "vm_workload_consolidation", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/strategies/6382b2d7-259e-487d-88db-78c852ffea54" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/strategies/6382b2d7-259e-487d-88db-78c852ffea54" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "parameters_spec": { | ||||||
|  |                 "properties": { | ||||||
|  |                     "granularity": { | ||||||
|  |                         "default": 300, | ||||||
|  |                         "type": "number", | ||||||
|  |                         "description": "The time between two measures in an aggregated timeseries of a metric." | ||||||
|  |                     }, | ||||||
|  |                     "period": { | ||||||
|  |                         "default": 3600, | ||||||
|  |                         "type": "number", | ||||||
|  |                         "description": "The time interval in seconds for getting statistic aggregation" | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "uuid": "6382b2d7-259e-487d-88db-78c852ffea54", | ||||||
|  |             "goal_name": "server_consolidation", | ||||||
|  |             "display_name": "VM Workload Consolidation Strategy" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								api-ref/source/samples/strategy-list-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								api-ref/source/samples/strategy-list-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | { | ||||||
|  |     "strategies": [ | ||||||
|  |         { | ||||||
|  |             "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |             "name": "dummy", | ||||||
|  |             "links": [ | ||||||
|  |                 { | ||||||
|  |                     "rel": "self", | ||||||
|  |                     "href": "http://controller:9322/v1/strategies/e311727b-b9b3-43ef-a5f7-8bd7ea80df25" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "rel": "bookmark", | ||||||
|  |                     "href": "http://controller:9322/strategies/e311727b-b9b3-43ef-a5f7-8bd7ea80df25" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "uuid": "e311727b-b9b3-43ef-a5f7-8bd7ea80df25", | ||||||
|  |             "goal_name": "dummy", | ||||||
|  |             "display_name": "Dummy strategy" | ||||||
|  |         } | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										33
									
								
								api-ref/source/samples/strategy-show-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								api-ref/source/samples/strategy-show-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | { | ||||||
|  |     "goal_uuid": "4690f8ba-18ff-45c1-99e9-159556d23810", | ||||||
|  |     "name": "dummy", | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "rel": "self", | ||||||
|  |             "href": "http://controller:9322/v1/strategies/e311727b-b9b3-43ef-a5f7-8bd7ea80df25" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "bookmark", | ||||||
|  |             "href": "http://controller:9322/strategies/e311727b-b9b3-43ef-a5f7-8bd7ea80df25" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "parameters_spec": { | ||||||
|  |         "properties": { | ||||||
|  |             "para2": { | ||||||
|  |                 "default": "hello", | ||||||
|  |                 "type": "string", | ||||||
|  |                 "description": "string parameter example" | ||||||
|  |             }, | ||||||
|  |             "para1": { | ||||||
|  |                 "maximum": 10.2, | ||||||
|  |                 "type": "number", | ||||||
|  |                 "minimum": 1.0, | ||||||
|  |                 "description": "number parameter example", | ||||||
|  |                 "default": 3.2 | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "uuid": "e311727b-b9b3-43ef-a5f7-8bd7ea80df25", | ||||||
|  |     "goal_name": "dummy", | ||||||
|  |     "display_name": "Dummy strategy" | ||||||
|  | } | ||||||
							
								
								
									
										49
									
								
								api-ref/source/samples/strategy-state-response.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								api-ref/source/samples/strategy-state-response.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |         "state": "gnocchi: available", | ||||||
|  |         "comment": "", | ||||||
|  |         "mandatory": true, | ||||||
|  |         "type": "Datasource" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "state": [ | ||||||
|  |             { | ||||||
|  |                 "compute.node.cpu.percent": "available" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "cpu_util": "available" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "memory.resident": "available" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "hardware.memory.used": "available" | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "comment": "", | ||||||
|  |         "mandatory": false, | ||||||
|  |         "type": "Metrics" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "state": [ | ||||||
|  |             { | ||||||
|  |                 "compute_model": "available" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "storage_model": "not available" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "baremetal_model": "not available" | ||||||
|  |             } | ||||||
|  |         ], | ||||||
|  |         "comment": "", | ||||||
|  |         "mandatory": true, | ||||||
|  |         "type": "CDM" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         "state": "workload_stabilization", | ||||||
|  |         "mandatory": "", | ||||||
|  |         "comment": "", | ||||||
|  |         "type": "Name" | ||||||
|  |     } | ||||||
|  | ] | ||||||
							
								
								
									
										209
									
								
								api-ref/source/watcher-api-v1-actionplans.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										209
									
								
								api-ref/source/watcher-api-v1-actionplans.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,209 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ============ | ||||||
|  | Action Plans | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | An ``Action Plan`` specifies a flow of ``Actions`` that should be executed | ||||||
|  | in order to satisfy a given ``Goal``. It also contains an estimated | ||||||
|  | ``global efficacy`` alongside a set of ``efficacy indicators``. | ||||||
|  |  | ||||||
|  | An ``Action Plan`` is generated by Watcher when an ``Audit`` is successful | ||||||
|  | which implies that the ``Strategy`` which was used has found a ``Solution`` | ||||||
|  | to achieve the ``Goal`` of this ``Audit``. | ||||||
|  |  | ||||||
|  | In the default implementation of Watcher, an action plan is composed of | ||||||
|  | a graph of linked ``Actions``. Each action may have parent actions, which | ||||||
|  | should be executed prior to child action. | ||||||
|  |  | ||||||
|  | Start Action Plan | ||||||
|  | ================= | ||||||
|  |  | ||||||
|  | .. rest_method::  POST /v1/action_plans/{actionplan_ident}/start | ||||||
|  |  | ||||||
|  | Starts a created Action Plan resource. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - actionplan_ident: actionplan_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | The list and example below are representative of the response as of API | ||||||
|  | version 1: | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - state: actionplan_state | ||||||
|  |     - audit_uuid: actionplan_audit_uuid | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - efficacy_indicators: actionplan_efficacy_indicators | ||||||
|  |     - global_efficacy: actionplan_global_efficacy | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action Plan:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-start-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Action Plan | ||||||
|  | ================ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/action_plans | ||||||
|  |  | ||||||
|  | Returns a list of Action Plan resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_uuid: r_audit | ||||||
|  |    - strategy: r_strategy | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - state: actionplan_state | ||||||
|  |     - audit_uuid: actionplan_audit_uuid | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - efficacy_indicators: actionplan_efficacy_indicators | ||||||
|  |     - global_efficacy: actionplan_global_efficacy | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action Plan:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Action Plan | ||||||
|  | ================ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/action_plans/{actionplan_ident} | ||||||
|  |  | ||||||
|  | Shows details for an Action Plan. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - actionplan_ident: actionplan_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - state: actionplan_state | ||||||
|  |     - audit_uuid: actionplan_audit_uuid | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - efficacy_indicators: actionplan_efficacy_indicators | ||||||
|  |     - global_efficacy: actionplan_global_efficacy | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-show-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Cancel Action Plan | ||||||
|  | ================== | ||||||
|  |  | ||||||
|  | .. rest_method::  PATCH /v1/action_plans/{actionplan_ident} | ||||||
|  |  | ||||||
|  | Cancels a created Action Plan resource. | ||||||
|  |  | ||||||
|  | .. note: | ||||||
|  |     If Action Plan is in ONGOING state, then ``state`` attribute should be | ||||||
|  |     replaced with ``CANCELLING`` value. Otherwise, ``CANCELLED`` is to be | ||||||
|  |     used. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - actionplan_ident: actionplan_ident | ||||||
|  |  | ||||||
|  | **Example Action Plan ONGOING cancelling request:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-cancel-request-cancelling.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | **Example Action Plan PENDING cancelling request:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-cancel-request-pending.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | The list and example below are representative of the response as of API | ||||||
|  | version 1: | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - state: actionplan_state | ||||||
|  |     - audit_uuid: actionplan_audit_uuid | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - efficacy_indicators: actionplan_efficacy_indicators | ||||||
|  |     - global_efficacy: actionplan_global_efficacy | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action Plan:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actionplan-start-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Delete Action Plan | ||||||
|  | ================== | ||||||
|  |  | ||||||
|  | .. rest_method::  DELETE /v1/action_plans/{actionplan_ident} | ||||||
|  |  | ||||||
|  | Deletes an Action Plan. Action Plan can be deleted only from SUCCEEDED, RECOMMENDED, FAILED, SUPERSEDED, CANCELLED states. | ||||||
|  |  | ||||||
|  | Normal response codes: 204 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - actionplan_ident: actionplan_ident | ||||||
							
								
								
									
										155
									
								
								api-ref/source/watcher-api-v1-actions.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										155
									
								
								api-ref/source/watcher-api-v1-actions.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,155 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ======= | ||||||
|  | Actions | ||||||
|  | ======= | ||||||
|  |  | ||||||
|  | An ``Action`` is what enables Watcher to transform the current state of a | ||||||
|  | ``Cluster`` after an ``Audit``. | ||||||
|  |  | ||||||
|  | An ``Action`` is an atomic task which changes the current state of a target | ||||||
|  | Managed resource of the OpenStack ``Cluster`` such as: | ||||||
|  |  | ||||||
|  | -  Live migration of an instance from one compute node to another compute | ||||||
|  |    node with Nova | ||||||
|  | -  Changing the power level of a compute node (ACPI level, ...) | ||||||
|  | -  Changing the current state of a compute node (enable or disable) with Nova | ||||||
|  |  | ||||||
|  | In most cases, an ``Action`` triggers some concrete commands on an existing | ||||||
|  | OpenStack module (Nova, Neutron, Cinder, Ironic, etc.). | ||||||
|  |  | ||||||
|  | An ``Action`` has a life-cycle and its current state may be one of the | ||||||
|  | following: | ||||||
|  |  | ||||||
|  | -  **PENDING** : the ``Action`` has not been executed yet by the | ||||||
|  |    ``Watcher Applier``. | ||||||
|  | -  **ONGOING** : the ``Action`` is currently being processed by the | ||||||
|  |    ``Watcher Applier``. | ||||||
|  | -  **SUCCEEDED** : the ``Action`` has been executed successfully | ||||||
|  | -  **FAILED** : an error occurred while trying to execute the ``Action``. | ||||||
|  | -  **DELETED** : the ``Action`` is still stored in the ``Watcher database`` | ||||||
|  |    but is not returned any more through the Watcher APIs. | ||||||
|  | -  **CANCELLED** : the ``Action`` was in **PENDING** or **ONGOING** state and | ||||||
|  |    was cancelled by the ``Administrator`` | ||||||
|  |  | ||||||
|  | ``Actions`` are created by ``Watcher Planner`` as result of Audit's execution. | ||||||
|  | ``Action`` can't be created, modified or deleted by user. | ||||||
|  |  | ||||||
|  | List Action | ||||||
|  | =========== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/actions | ||||||
|  |  | ||||||
|  | Returns a list of Action resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - action_plan_uuid: r_action_plan | ||||||
|  |    - audit_uuid: r_audit | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - action_type: action_type | ||||||
|  |     - state: action_state | ||||||
|  |     - action_plan_uuid: action_action_plan_uuid | ||||||
|  |     - parents: action_parents | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actions-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Action Detailed | ||||||
|  | ==================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/actions/detail | ||||||
|  |  | ||||||
|  | Returns a list of Action resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - action_plan_uuid: r_action_plan | ||||||
|  |    - audit_uuid: r_audit | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - action_type: action_type | ||||||
|  |     - state: action_state | ||||||
|  |     - action_plan_uuid: action_action_plan_uuid | ||||||
|  |     - parents: action_parents | ||||||
|  |     - description: action_description | ||||||
|  |     - input_parameters: action_input_parameters | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actions-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Action | ||||||
|  | =========== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/actions/{action_ident} | ||||||
|  |  | ||||||
|  | Shows details for an Action. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - action_ident: action_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - action_type: action_type | ||||||
|  |     - state: action_state | ||||||
|  |     - action_plan_uuid: action_action_plan_uuid | ||||||
|  |     - parents: action_parents | ||||||
|  |     - description: action_description | ||||||
|  |     - input_parameters: action_input_parameters | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Action:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/actions-show-response.json | ||||||
|  |    :language: javascript | ||||||
							
								
								
									
										349
									
								
								api-ref/source/watcher-api-v1-audits.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										349
									
								
								api-ref/source/watcher-api-v1-audits.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,349 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ====== | ||||||
|  | Audits | ||||||
|  | ====== | ||||||
|  |  | ||||||
|  | There are creating, listing, updating and deleting methods of Watcher Audit | ||||||
|  | resources which are implemented via the ``/v1/audits`` resource. | ||||||
|  |  | ||||||
|  | In the Watcher system, an ``Audit`` is a request for optimizing a ``Cluster``. | ||||||
|  |  | ||||||
|  | The optimization is done in order to satisfy one ``Goal`` on a given | ||||||
|  | ``Cluster``. | ||||||
|  |  | ||||||
|  | For each ``Audit``, the Watcher system generates an ``Action Plan``. | ||||||
|  |  | ||||||
|  | Create Audit | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  POST /v1/audits | ||||||
|  |  | ||||||
|  | Creates a new Audit resource. | ||||||
|  |  | ||||||
|  | Mandatory attribute to be supplied: ``audit_type``. | ||||||
|  |  | ||||||
|  | ``Audit`` can be created either based on existed ``Audit Template`` or by | ||||||
|  | itself. In the first case, there also should be supplied | ||||||
|  | ``audit_template_uuid``. If ``Audit`` is created without ``Audit Template``, | ||||||
|  | ``goal`` should be provided. | ||||||
|  |  | ||||||
|  | .. warning:: | ||||||
|  |     **Only ``audit_template_uuid`` can be used to create audit so far.** | ||||||
|  |     It should be fixed during the ``Rocky`` cycle. | ||||||
|  |  | ||||||
|  | Normal response codes: 201 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_template_uuid: audittemplate_name | ||||||
|  |    - audit_type: audit_type | ||||||
|  |    - name: audit_name | ||||||
|  |    - goal: audit_goal | ||||||
|  |    - strategy: audit_strategy | ||||||
|  |    - parameters: audit_parameters | ||||||
|  |    - interval: audit_interval | ||||||
|  |    - scope: audittemplate_scope | ||||||
|  |    - auto_trigger: audit_autotrigger | ||||||
|  |  | ||||||
|  | **Example ONESHOT Audit creation request:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-create-request-oneshot.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | **Example CONTINUOUS Audit creation request with a specified strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-create-request-continuous.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | The list and example below are representative of the response as of API | ||||||
|  | version 1: | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - parameters: audit_parameters | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-create-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Audit | ||||||
|  | ========== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audits | ||||||
|  |  | ||||||
|  | Returns a list of Audit resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - strategy: r_strategy | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Audit Detailed | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audits/detail | ||||||
|  |  | ||||||
|  | Returns a list of Audit resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - strategy: r_strategy | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - parameters: audit_parameters | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Audit | ||||||
|  | ========== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audits/{audit_ident} | ||||||
|  |  | ||||||
|  | Shows details for an Audit. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_ident: audit_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - parameters: audit_parameters | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-show-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Cancel Audit | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  PATCH /v1/audits/{audit_ident} | ||||||
|  |  | ||||||
|  | Cancels an ONGOING Audit resource. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_ident: audit_ident | ||||||
|  |  | ||||||
|  | **Example Audit cancelling request:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-cancel-request.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | The list and example below are representative of the response as of API | ||||||
|  | version 1: | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - parameters: audit_parameters | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-cancel-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Update Audit | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  PATCH /v1/audits/{audit_ident} | ||||||
|  |  | ||||||
|  | Updates an Audit with the given information. | ||||||
|  |  | ||||||
|  | .. note: | ||||||
|  |     ``audit_type`` shouldn't be changed by PATCH method. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_ident: audit_ident | ||||||
|  |  | ||||||
|  | **Example PATCH document updating Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-update-request.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audit_name | ||||||
|  |     - audit_type: audit_type | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - interval: audit_interval | ||||||
|  |     - next_run_time: audit_next_run_time | ||||||
|  |     - parameters: audit_parameters | ||||||
|  |     - auto_trigger: audit_autotrigger | ||||||
|  |     - state: audit_state | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audit-update-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Delete Audit | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  DELETE /v1/audits/{audit_ident} | ||||||
|  |  | ||||||
|  | Deletes an Audit. Audit can be deleted only from FAILED, SUCCEEDED, CANCELLED, | ||||||
|  | SUSPENDED states. | ||||||
|  |  | ||||||
|  | Normal response codes: 204 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audit_ident: audit_ident | ||||||
							
								
								
									
										257
									
								
								api-ref/source/watcher-api-v1-audittemplates.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								api-ref/source/watcher-api-v1-audittemplates.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,257 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | =============== | ||||||
|  | Audit Templates | ||||||
|  | =============== | ||||||
|  |  | ||||||
|  | There are creating, listing, updating and deleting methods of Watcher Audit | ||||||
|  | Template resources which are implemented via the ``/v1/audit_templates`` | ||||||
|  | resource. | ||||||
|  |  | ||||||
|  | An Audit may be launched several times with the same settings | ||||||
|  | (Goal, thresholds, ...). Therefore it makes sense to save those settings in | ||||||
|  | some sort of Audit preset object, which is known as an Audit Template. | ||||||
|  |  | ||||||
|  | An Audit Template contains at least the Goal of the Audit. | ||||||
|  |  | ||||||
|  | Create Audit Template | ||||||
|  | ===================== | ||||||
|  |  | ||||||
|  | .. rest_method::  POST /v1/audit_templates | ||||||
|  |  | ||||||
|  | Creates a new Audit Template resource. | ||||||
|  |  | ||||||
|  | It requires ``name`` and ``goal`` attributes to be supplied in the request | ||||||
|  | body. | ||||||
|  |  | ||||||
|  | Normal response codes: 201 | ||||||
|  |  | ||||||
|  | Error codes: 400,404,409 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - name: audittemplate_name | ||||||
|  |    - goal: audittemplate_goal | ||||||
|  |    - strategy: audittemplate_strategy | ||||||
|  |    - description: audittemplate_description | ||||||
|  |    - scope: audittemplate_scope | ||||||
|  |  | ||||||
|  | **Example Audit Template creation request without a specified strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-create-request-minimal.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | **Example Audit Template creation request with a specified strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-create-request-full.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | The list and example below are representative of the response as of API | ||||||
|  | version 1: | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audittemplate_name | ||||||
|  |     - description: audittemplate_description | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-create-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Audit Template | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audit_templates | ||||||
|  |  | ||||||
|  | Returns a list of Audit Template resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - strategy: r_strategy | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audittemplate_name | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Audit Template Detailed | ||||||
|  | ============================ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audit_templates/detail | ||||||
|  |  | ||||||
|  | Returns a list of Audit Template resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - strategy: r_strategy | ||||||
|  |    - limit: limit | ||||||
|  |    - marker: marker | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audittemplate_name | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |     - description: audittemplate_description | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Audit Template | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/audit_templates/{audittemplate_ident} | ||||||
|  |  | ||||||
|  | Shows details for an Audit Template. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audittemplate_ident: audittemplate_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audittemplate_name | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |     - description: audittemplate_description | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-show-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Update Audit Template | ||||||
|  | ===================== | ||||||
|  |  | ||||||
|  | .. rest_method::  PATCH /v1/audit_templates/{audittemplate_ident} | ||||||
|  |  | ||||||
|  | Updates an Audit Template with the given information. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audittemplate_ident: audittemplate_ident | ||||||
|  |  | ||||||
|  | **Example PATCH document updating Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-update-request.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: audittemplate_name | ||||||
|  |     - strategy_uuid: strategy_uuid | ||||||
|  |     - strategy_name: strategy_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - scope: audittemplate_scope | ||||||
|  |     - links: links | ||||||
|  |     - description: audittemplate_description | ||||||
|  |  | ||||||
|  | **Example JSON representation of an Audit Template:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/audittemplate-update-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Delete Audit Template | ||||||
|  | ===================== | ||||||
|  |  | ||||||
|  | .. rest_method::  DELETE /v1/audit_templates/{audittemplate_ident} | ||||||
|  |  | ||||||
|  | Deletes an Audit Template. | ||||||
|  |  | ||||||
|  | Normal response codes: 204 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - audittemplate_ident: audittemplate_ident | ||||||
							
								
								
									
										126
									
								
								api-ref/source/watcher-api-v1-goals.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								api-ref/source/watcher-api-v1-goals.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ===== | ||||||
|  | Goals | ||||||
|  | ===== | ||||||
|  |  | ||||||
|  | A ``Goal`` is a human readable, observable and measurable end result having | ||||||
|  | one objective to be achieved. | ||||||
|  |  | ||||||
|  | Here are some examples of ``Goals``: | ||||||
|  |  | ||||||
|  | -  minimize the energy consumption | ||||||
|  | -  minimize the number of compute nodes (consolidation) | ||||||
|  | -  balance the workload among compute nodes | ||||||
|  | -  minimize the license cost (some softwares have a licensing model which is | ||||||
|  |    based on the number of sockets or cores where the software is deployed) | ||||||
|  | -  find the most appropriate moment for a planned maintenance on a | ||||||
|  |    given group of host (which may be an entire availability zone): | ||||||
|  |    power supply replacement, cooling system replacement, hardware | ||||||
|  |    modification, ... | ||||||
|  |  | ||||||
|  | List Goal | ||||||
|  | ========= | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/goals | ||||||
|  |  | ||||||
|  | Returns a list of Goal resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - efficacy_specification: goal_efficacy_specification | ||||||
|  |     - name: goal_name | ||||||
|  |     - display_name: goal_display_name | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Goal:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/goal-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Goal Detailed | ||||||
|  | ================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/goals/detail | ||||||
|  |  | ||||||
|  | Returns a list of Goal resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - efficacy_specification: goal_efficacy_specification | ||||||
|  |     - name: goal_name | ||||||
|  |     - display_name: goal_display_name | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Goal:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/goal-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Goal | ||||||
|  | ========= | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/goals/{goal_ident} | ||||||
|  |  | ||||||
|  | Shows details for an Goal. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal_ident: goal_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - efficacy_specification: goal_efficacy_specification | ||||||
|  |     - name: goal_name | ||||||
|  |     - display_name: goal_display_name | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Goal:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/goal-show-response.json | ||||||
|  |    :language: javascript | ||||||
							
								
								
									
										120
									
								
								api-ref/source/watcher-api-v1-scoring_engines.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								api-ref/source/watcher-api-v1-scoring_engines.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | =============== | ||||||
|  | Scoring Engines | ||||||
|  | =============== | ||||||
|  |  | ||||||
|  | A ``Scoring Engine`` is an executable that has a well-defined input, a | ||||||
|  | well-defined output, and performs a purely mathematical task. That is, | ||||||
|  | the calculation does not depend on the environment in which it is running - it | ||||||
|  | would produce the same result anywhere. | ||||||
|  |  | ||||||
|  | Because there might be multiple algorithms used to build a particular data | ||||||
|  | model (and therefore a scoring engine), the usage of scoring engine might | ||||||
|  | vary. A metainfo field is supposed to contain any information which might | ||||||
|  | be needed by the user of a given scoring engine. | ||||||
|  |  | ||||||
|  | List Scoring Engine | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/scoring_engines | ||||||
|  |  | ||||||
|  | Returns a list of Scoring Engine resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: scoring_engine_name | ||||||
|  |     - description: scoring_engine_description | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Scoring Engine:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/scoring_engine-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Scoring Engine Detailed | ||||||
|  | ============================ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/scoring_engines/detail | ||||||
|  |  | ||||||
|  | Returns a list of Scoring Engine resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: scoring_engine_name | ||||||
|  |     - description: scoring_engine_description | ||||||
|  |     - metainfo: scoring_engine_metainfo | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Scoring Engine:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/scoring_engine-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Scoring Engine | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/scoring_engines/{scoring_engine_ident} | ||||||
|  |  | ||||||
|  | Shows details for a Scoring Engine resource. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - scoring_engine_ident: scoring_engine_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: scoring_engine_name | ||||||
|  |     - description: scoring_engine_description | ||||||
|  |     - metainfo: scoring_engine_metainfo | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Scoring Engine:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/scoring_engine-show-response.json | ||||||
|  |    :language: javascript | ||||||
							
								
								
									
										116
									
								
								api-ref/source/watcher-api-v1-services.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								api-ref/source/watcher-api-v1-services.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ======== | ||||||
|  | Services | ||||||
|  | ======== | ||||||
|  |  | ||||||
|  | This resource represents Watcher services, their states and hosts they are | ||||||
|  | placed on. | ||||||
|  |  | ||||||
|  | List Service | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/services | ||||||
|  |  | ||||||
|  | Returns a list of Service resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - id: service_id | ||||||
|  |     - name: service_name | ||||||
|  |     - host: service_host | ||||||
|  |     - status: service_status | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Service:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/service-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Service Detailed | ||||||
|  | ===================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/services/detail | ||||||
|  |  | ||||||
|  | Returns a list of Service resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - id: service_id | ||||||
|  |     - name: service_name | ||||||
|  |     - host: service_host | ||||||
|  |     - status: service_status | ||||||
|  |     - last_seen_up: service_last_seen_up | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Service:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/service-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Service | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/services/{service_ident} | ||||||
|  |  | ||||||
|  | Shows details for a Service resource. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - service_ident: service_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - id: service_id | ||||||
|  |     - name: service_name | ||||||
|  |     - host: service_host | ||||||
|  |     - status: service_status | ||||||
|  |     - last_seen_up: service_last_seen_up | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Service:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/service-show-response.json | ||||||
|  |    :language: javascript | ||||||
							
								
								
									
										164
									
								
								api-ref/source/watcher-api-v1-strategies.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								api-ref/source/watcher-api-v1-strategies.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,164 @@ | |||||||
|  | .. -*- rst -*- | ||||||
|  |  | ||||||
|  | ========== | ||||||
|  | Strategies | ||||||
|  | ========== | ||||||
|  |  | ||||||
|  | A ``Strategy`` is an algorithm implementation which is able to find a | ||||||
|  | ``Solution`` for a given ``Goal``. To get more information about strategies | ||||||
|  | that are shipped along with Watcher, visit `strategies page`_. | ||||||
|  |  | ||||||
|  | There may be several potential strategies which are able to achieve the same | ||||||
|  | ``Goal``. This is why it is possible to configure which specific ``Strategy`` | ||||||
|  | should be used for each goal. | ||||||
|  |  | ||||||
|  | Some strategies may provide better optimization results but may take more time | ||||||
|  | to find an optimal ``Solution``. | ||||||
|  |  | ||||||
|  | .. _`strategies page`: https://docs.openstack.org/watcher/latest/strategies/index.html | ||||||
|  |  | ||||||
|  | List Strategy | ||||||
|  | ============= | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/strategies | ||||||
|  |  | ||||||
|  | Returns a list of Strategy resources. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: strategy_name | ||||||
|  |     - display_name: strategy_display_name | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/strategy-list-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | List Strategy Detailed | ||||||
|  | ====================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/strategies/detail | ||||||
|  |  | ||||||
|  | Returns a list of Strategy resources with complete details. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 400,401 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - goal: r_goal | ||||||
|  |    - limit: limit | ||||||
|  |    - sort_dir: sort_dir | ||||||
|  |    - sort_key: sort_key | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: strategy_name | ||||||
|  |     - display_name: strategy_display_name | ||||||
|  |     - parameters_spec: strategy_parameters_spec | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/strategy-list-detailed-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Strategy | ||||||
|  | ============= | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/strategies/{strategy_ident} | ||||||
|  |  | ||||||
|  | Shows details for a Strategy resource. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - strategy_ident: strategy_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - uuid: uuid | ||||||
|  |     - name: strategy_name | ||||||
|  |     - display_name: strategy_display_name | ||||||
|  |     - parameters_spec: strategy_parameters_spec | ||||||
|  |     - goal_name: goal_name | ||||||
|  |     - goal_uuid: goal_uuid | ||||||
|  |     - links: links | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/strategy-show-response.json | ||||||
|  |    :language: javascript | ||||||
|  |  | ||||||
|  | Show Strategy State | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. rest_method::  GET /v1/strategies/{strategy_ident}/state | ||||||
|  |  | ||||||
|  | Retrieve an information about strategy requirements. | ||||||
|  |  | ||||||
|  | Normal response codes: 200 | ||||||
|  |  | ||||||
|  | Error codes: 404 | ||||||
|  |  | ||||||
|  | Request | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |    - strategy_ident: strategy_ident | ||||||
|  |  | ||||||
|  | Response | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | .. rest_parameters:: parameters.yaml | ||||||
|  |  | ||||||
|  |     - state: strategy_check_state | ||||||
|  |     - comment: strategy_check_comment | ||||||
|  |     - mandatory: strategy_check_mandatory | ||||||
|  |     - type: strategy_check_type | ||||||
|  |  | ||||||
|  | **Example JSON representation of a Strategy:** | ||||||
|  |  | ||||||
|  | .. literalinclude:: samples/strategy-state-response.json | ||||||
|  |    :language: javascript | ||||||
| @@ -131,6 +131,16 @@ The actions that may have a rule enforced on them are: | |||||||
|   * ``GET /v1/actions/<ACTION_UUID>`` |   * ``GET /v1/actions/<ACTION_UUID>`` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | * ``service:get_all``, ``service:detail`` - List available Watcher services | ||||||
|  |  | ||||||
|  |   * ``GET /v1/services`` | ||||||
|  |   * ``GET /v1/services/detail`` | ||||||
|  |  | ||||||
|  | * ``service:get`` - Retrieve a specific Watcher service entity | ||||||
|  |  | ||||||
|  |   * ``GET /v1/services/<SERVICE_ID>`` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| To limit an action to a particular role or roles, you list the roles like so :: | To limit an action to a particular role or roles, you list the roles like so :: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,11 +19,17 @@ optimize your IaaS platform. The Watcher service may, depending upon | |||||||
| configuration, interact with several other OpenStack services. This includes: | configuration, interact with several other OpenStack services. This includes: | ||||||
|  |  | ||||||
| - the OpenStack Identity service (`keystone`_) for request authentication and | - the OpenStack Identity service (`keystone`_) for request authentication and | ||||||
|   to locate other OpenStack services |   to locate other OpenStack services. | ||||||
| - the OpenStack Telemetry service (`ceilometer`_) for consuming the resources | - the OpenStack Telemetry service (`ceilometer`_) for collecting the resources | ||||||
|   metrics |   metrics. | ||||||
|  | - the time series database (`gnocchi`_) for consuming the resources | ||||||
|  |   metrics. | ||||||
| - the OpenStack Compute service (`nova`_) works with the Watcher service and | - the OpenStack Compute service (`nova`_) works with the Watcher service and | ||||||
|   acts as a user-facing API for instance migration. |   acts as a user-facing API for instance migration. | ||||||
|  | - the OpenStack Bare Metal service (`ironic`_) works with the Watcher service | ||||||
|  |   and allows to manage power state of nodes. | ||||||
|  | - the OpenStack Block Storage service (`cinder`_) works with the Watcher | ||||||
|  |   service and as an API for volume node migration. | ||||||
|  |  | ||||||
| The Watcher service includes the following components: | The Watcher service includes the following components: | ||||||
|  |  | ||||||
| @@ -53,6 +59,9 @@ additional functionality: | |||||||
| .. _`keystone`: https://github.com/openstack/keystone | .. _`keystone`: https://github.com/openstack/keystone | ||||||
| .. _`ceilometer`: https://github.com/openstack/ceilometer | .. _`ceilometer`: https://github.com/openstack/ceilometer | ||||||
| .. _`nova`: https://github.com/openstack/nova | .. _`nova`: https://github.com/openstack/nova | ||||||
|  | .. _`gnocchi`: https://github.com/gnocchixyz/gnocchi | ||||||
|  | .. _`ironic`: https://github.com/openstack/ironic | ||||||
|  | .. _`cinder`: https://github.com/openstack/cinder | ||||||
| .. _`python-watcherclient`: https://github.com/openstack/python-watcherclient | .. _`python-watcherclient`: https://github.com/openstack/python-watcherclient | ||||||
| .. _`watcher-dashboard`: https://github.com/openstack/watcher-dashboard | .. _`watcher-dashboard`: https://github.com/openstack/watcher-dashboard | ||||||
| .. _`watcher metering`: https://github.com/b-com/watcher-metering | .. _`watcher metering`: https://github.com/b-com/watcher-metering | ||||||
|   | |||||||
| @@ -193,6 +193,8 @@ still need to configure the following sections: | |||||||
|   :ref:`Identity service <identity-service_configuration>` i.e. Keystone |   :ref:`Identity service <identity-service_configuration>` i.e. Keystone | ||||||
| - The ``[watcher_messaging]`` section to configure the OpenStack AMQP-based | - The ``[watcher_messaging]`` section to configure the OpenStack AMQP-based | ||||||
|   message bus |   message bus | ||||||
|  | - The ``watcher_clients_auth`` section to configure Keystone client to access | ||||||
|  |   related OpenStack projects | ||||||
|  |  | ||||||
| So if you need some more details on how to configure one or more of these | So if you need some more details on how to configure one or more of these | ||||||
| sections, please do have a look at :doc:`../configuration/configuring` before | sections, please do have a look at :doc:`../configuration/configuring` before | ||||||
|   | |||||||
| @@ -54,22 +54,6 @@ Getting Started | |||||||
|  |  | ||||||
|   contributor/index |   contributor/index | ||||||
|  |  | ||||||
| API References |  | ||||||
| -------------- |  | ||||||
|  |  | ||||||
| .. toctree:: |  | ||||||
|   :maxdepth: 1 |  | ||||||
|  |  | ||||||
|   api/index |  | ||||||
|  |  | ||||||
| Plugins |  | ||||||
| ------- |  | ||||||
|  |  | ||||||
| .. toctree:: |  | ||||||
|   :maxdepth: 1 |  | ||||||
|  |  | ||||||
|   contributor/plugin/index |  | ||||||
|  |  | ||||||
| Installation | Installation | ||||||
| ============ | ============ | ||||||
| .. toctree:: | .. toctree:: | ||||||
| @@ -77,14 +61,6 @@ Installation | |||||||
|  |  | ||||||
|   install/index |   install/index | ||||||
|  |  | ||||||
| Watcher Configuration Options |  | ||||||
| ============================= |  | ||||||
|  |  | ||||||
| .. toctree:: |  | ||||||
|   :maxdepth: 2 |  | ||||||
|  |  | ||||||
|   configuration/index |  | ||||||
|  |  | ||||||
| Admin Guide | Admin Guide | ||||||
| =========== | =========== | ||||||
|  |  | ||||||
| @@ -101,6 +77,30 @@ User Guide | |||||||
|  |  | ||||||
|   user/index |   user/index | ||||||
|  |  | ||||||
|  | API References | ||||||
|  | -------------- | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |   :maxdepth: 1 | ||||||
|  |  | ||||||
|  |   api/index | ||||||
|  |  | ||||||
|  | Plugins | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |   :maxdepth: 1 | ||||||
|  |  | ||||||
|  |   contributor/plugin/index | ||||||
|  |  | ||||||
|  | Watcher Configuration Options | ||||||
|  | ============================= | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |   :maxdepth: 2 | ||||||
|  |  | ||||||
|  |   configuration/index | ||||||
|  |  | ||||||
| Watcher Manual Pages | Watcher Manual Pages | ||||||
| ==================== | ==================== | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								tox.ini
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								tox.ini
									
									
									
									
									
								
							| @@ -38,6 +38,14 @@ commands = | |||||||
|     doc8 doc/source/ CONTRIBUTING.rst HACKING.rst README.rst |     doc8 doc/source/ CONTRIBUTING.rst HACKING.rst README.rst | ||||||
|     python setup.py build_sphinx |     python setup.py build_sphinx | ||||||
|  |  | ||||||
|  | [testenv:api-ref] | ||||||
|  | # This environment is called from CI scripts to test and publish | ||||||
|  | # the API Ref to developer.openstack.org. | ||||||
|  | whitelist_externals = bash | ||||||
|  | commands = | ||||||
|  |   bash -c 'rm -rf api-ref/build' | ||||||
|  |   sphinx-build -W -b html -d api-ref/build/doctrees api-ref/source api-ref/build/html | ||||||
|  |  | ||||||
| [testenv:debug] | [testenv:debug] | ||||||
| commands = oslo_debug_helper -t watcher/tests {posargs} | commands = oslo_debug_helper -t watcher/tests {posargs} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -83,7 +83,7 @@ class ScoringEngine(base.APIBase): | |||||||
|     def _convert_with_links(se, url, expand=True): |     def _convert_with_links(se, url, expand=True): | ||||||
|         if not expand: |         if not expand: | ||||||
|             se.unset_fields_except( |             se.unset_fields_except( | ||||||
|                 ['uuid', 'name', 'description', 'metainfo']) |                 ['uuid', 'name', 'description']) | ||||||
|  |  | ||||||
|         se.links = [link.Link.make_link('self', url, |         se.links = [link.Link.make_link('self', url, | ||||||
|                                         'scoring_engines', se.uuid), |                                         'scoring_engines', se.uuid), | ||||||
|   | |||||||
| @@ -292,7 +292,7 @@ class StrategiesController(rest.RestController): | |||||||
|  |  | ||||||
|     @wsme_pecan.wsexpose(wtypes.text, wtypes.text) |     @wsme_pecan.wsexpose(wtypes.text, wtypes.text) | ||||||
|     def state(self, strategy): |     def state(self, strategy): | ||||||
|         """Retrieve a inforamation about strategy requirements. |         """Retrieve an information about strategy requirements. | ||||||
|  |  | ||||||
|         :param strategy: name of the strategy. |         :param strategy: name of the strategy. | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ from watcher.tests.objects import utils as obj_utils | |||||||
| class TestListScoringEngine(api_base.FunctionalTest): | class TestListScoringEngine(api_base.FunctionalTest): | ||||||
|  |  | ||||||
|     def _assert_scoring_engine_fields(self, scoring_engine): |     def _assert_scoring_engine_fields(self, scoring_engine): | ||||||
|         scoring_engine_fields = ['uuid', 'name', 'description', 'metainfo'] |         scoring_engine_fields = ['uuid', 'name', 'description'] | ||||||
|         for field in scoring_engine_fields: |         for field in scoring_engine_fields: | ||||||
|             self.assertIn(field, scoring_engine) |             self.assertIn(field, scoring_engine) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zuul
					Zuul