This patch set adds supervisor mechanism for Watcher services to get ability to track states. Partially-Implements: blueprint watcher-service-list Change-Id: Iab1cefb971c79ed27b22b6a5d1bed8698e35f9a4
198 lines
6.8 KiB
Python
198 lines
6.8 KiB
Python
# -*- encoding: utf-8 -*-
|
|
#
|
|
# 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.
|
|
|
|
|
|
"""
|
|
Version 1 of the Watcher API
|
|
|
|
NOTE: IN PROGRESS AND NOT FULLY IMPLEMENTED.
|
|
"""
|
|
|
|
import datetime
|
|
|
|
import pecan
|
|
from pecan import rest
|
|
import wsme
|
|
from wsme import types as wtypes
|
|
import wsmeext.pecan as wsme_pecan
|
|
|
|
from watcher.api.controllers import link
|
|
from watcher.api.controllers.v1 import action
|
|
from watcher.api.controllers.v1 import action_plan
|
|
from watcher.api.controllers.v1 import audit
|
|
from watcher.api.controllers.v1 import audit_template
|
|
from watcher.api.controllers.v1 import goal
|
|
from watcher.api.controllers.v1 import scoring_engine
|
|
from watcher.api.controllers.v1 import service
|
|
from watcher.api.controllers.v1 import strategy
|
|
|
|
|
|
class APIBase(wtypes.Base):
|
|
|
|
created_at = wsme.wsattr(datetime.datetime, readonly=True)
|
|
"""The time in UTC at which the object is created"""
|
|
|
|
updated_at = wsme.wsattr(datetime.datetime, readonly=True)
|
|
"""The time in UTC at which the object is updated"""
|
|
|
|
deleted_at = wsme.wsattr(datetime.datetime, readonly=True)
|
|
"""The time in UTC at which the object is deleted"""
|
|
|
|
def as_dict(self):
|
|
"""Render this object as a dict of its fields."""
|
|
return dict((k, getattr(self, k))
|
|
for k in self.fields
|
|
if hasattr(self, k) and
|
|
getattr(self, k) != wsme.Unset)
|
|
|
|
def unset_fields_except(self, except_list=None):
|
|
"""Unset fields so they don't appear in the message body.
|
|
|
|
:param except_list: A list of fields that won't be touched.
|
|
|
|
"""
|
|
if except_list is None:
|
|
except_list = []
|
|
|
|
for k in self.as_dict():
|
|
if k not in except_list:
|
|
setattr(self, k, wsme.Unset)
|
|
|
|
|
|
class MediaType(APIBase):
|
|
"""A media type representation."""
|
|
|
|
base = wtypes.text
|
|
type = wtypes.text
|
|
|
|
def __init__(self, base, type):
|
|
self.base = base
|
|
self.type = type
|
|
|
|
|
|
class V1(APIBase):
|
|
"""The representation of the version 1 of the API."""
|
|
|
|
id = wtypes.text
|
|
"""The ID of the version, also acts as the release number"""
|
|
|
|
media_types = [MediaType]
|
|
"""An array of supcontainersed media types for this version"""
|
|
|
|
audit_templates = [link.Link]
|
|
"""Links to the audit templates resource"""
|
|
|
|
audits = [link.Link]
|
|
"""Links to the audits resource"""
|
|
|
|
actions = [link.Link]
|
|
"""Links to the actions resource"""
|
|
|
|
action_plans = [link.Link]
|
|
"""Links to the action plans resource"""
|
|
|
|
scoring_engines = [link.Link]
|
|
"""Links to the Scoring Engines resource"""
|
|
|
|
services = [link.Link]
|
|
"""Links to the services resource"""
|
|
|
|
links = [link.Link]
|
|
"""Links that point to a specific URL for this version and documentation"""
|
|
|
|
@staticmethod
|
|
def convert():
|
|
v1 = V1()
|
|
v1.id = "v1"
|
|
v1.links = [link.Link.make_link('self', pecan.request.host_url,
|
|
'v1', '', bookmark=True),
|
|
link.Link.make_link('describedby',
|
|
'http://docs.openstack.org',
|
|
'developer/watcher/dev',
|
|
'api-spec-v1.html',
|
|
bookmark=True, type='text/html')
|
|
]
|
|
v1.media_types = [MediaType('application/json',
|
|
'application/vnd.openstack.watcher.v1+json')]
|
|
v1.audit_templates = [link.Link.make_link('self',
|
|
pecan.request.host_url,
|
|
'audit_templates', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'audit_templates', '',
|
|
bookmark=True)
|
|
]
|
|
v1.audits = [link.Link.make_link('self', pecan.request.host_url,
|
|
'audits', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'audits', '',
|
|
bookmark=True)
|
|
]
|
|
v1.actions = [link.Link.make_link('self', pecan.request.host_url,
|
|
'actions', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'actions', '',
|
|
bookmark=True)
|
|
]
|
|
v1.action_plans = [link.Link.make_link(
|
|
'self', pecan.request.host_url, 'action_plans', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'action_plans', '',
|
|
bookmark=True)
|
|
]
|
|
|
|
v1.scoring_engines = [link.Link.make_link(
|
|
'self', pecan.request.host_url, 'scoring_engines', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'scoring_engines', '',
|
|
bookmark=True)
|
|
]
|
|
|
|
v1.services = [link.Link.make_link(
|
|
'self', pecan.request.host_url, 'services', ''),
|
|
link.Link.make_link('bookmark',
|
|
pecan.request.host_url,
|
|
'services', '',
|
|
bookmark=True)
|
|
]
|
|
return v1
|
|
|
|
|
|
class Controller(rest.RestController):
|
|
"""Version 1 API controller root."""
|
|
|
|
audits = audit.AuditsController()
|
|
audit_templates = audit_template.AuditTemplatesController()
|
|
actions = action.ActionsController()
|
|
action_plans = action_plan.ActionPlansController()
|
|
goals = goal.GoalsController()
|
|
scoring_engines = scoring_engine.ScoringEngineController()
|
|
services = service.ServicesController()
|
|
strategies = strategy.StrategiesController()
|
|
|
|
@wsme_pecan.wsexpose(V1)
|
|
def get(self):
|
|
# NOTE: The reason why convert() it's being called for every
|
|
# request is because we need to get the host url from
|
|
# the request object to make the links.
|
|
return V1.convert()
|
|
|
|
|
|
__all__ = ("Controller", )
|