Merge "Add API Reference for Watcher"
This commit is contained in:
commit
6ed8fc0c15
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)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user