yanyanhu 42d141db9f Add min_size and max_size properties to Cluster
Two new properties are added to cluster: min_size and max_size.
This patch provides related support from client side. Now user
can specify the min and max size of cluster when creating it.

Change-Id: I72869259993ec8a8697eba45c12bf6ba9d408292
Implements: blueprint add-size-limitation-properties-to-cluster
2015-04-30 04:42:55 -04:00

656 lines
19 KiB
Python

# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from openstack import utils
from senlinclient.common import sdk as resource
from senlinclient.openstack.clustering import clustering_service
class Version(resource.Resource):
resource_key = 'version'
resources_key = 'versions'
base_path = '/'
service = clustering_service.ClusteringService(
version=clustering_service.ClusteringService.UNVERSIONED
)
# capabilities
allow_list = True
# Properties
links = resource.prop('links')
status = resource.prop('status')
class BuildInfo(resource.Resource):
base_path = '/build_info'
service = clustering_service.ClusteringService()
# Capabilities
allow_retrieve = True
# Properties
api = resource.prop('api')
engine = resource.prop('engine')
class ProfileType(resource.Resource):
resource_key = None
resources_key = 'profile_types'
base_path = '/profile_types'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
# Properties
name = resource.prop('name')
class ProfileTypeSchema(resource.Resource):
base_path = '/profile_types/%(profile_type)s'
service = clustering_service.ClusteringService()
# Capabilities
allow_retrieve = True
# Properties
schema = resource.prop('schema', type=dict)
class ProfileTypeTemplate(resource.Resource):
resource_key = 'template'
base_path = '/profile_types/%(profile_type)s/template'
service = clustering_service.ClusteringService()
# Capabilities
allow_retrieve = True
# Properties
template = resource.prop('template', type=dict)
class Profile(resource.Resource):
resource_key = 'profile'
resources_key = 'profiles'
base_path = '/profiles'
service = clustering_service.ClusteringService()
# capabilities
allow_create = True
allow_retrieve = True
allow_update = True
allow_delete = True
allow_list = True
# properties
id = resource.prop('id')
name = resource.prop('name')
type = resource.prop('type')
spec = resource.prop('spec', type=dict)
permission = resource.prop('permission')
tags = resource.prop('tags', type=dict)
created_time = resource.prop('created_time')
deleted_time = resource.prop('deleted_time')
def to_dict(self):
pb_dict = {
'id': self.id,
'name': self.name,
'type': self.type,
'permission': self.permission,
'spec': self.spec,
'tags': self.tags,
'created_time': self.created_time,
'deleted_time': self.deleted_time,
}
return pb_dict
class PolicyType(resource.Resource):
resources_key = 'policy_types'
base_path = '/policy_types'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
# Properties
name = resource.prop('name')
class PolicyTypeSchema(resource.Resource):
base_path = '/policy_types/%(policy_type)s'
service = clustering_service.ClusteringService()
# Capabilities
allow_retrieve = True
# Properties
schema = resource.prop('schema', type=dict)
class PolicyTypeTemplate(resource.Resource):
resource_key = 'template'
base_path = '/policy_types/%(policy_type)s/template'
service = clustering_service.ClusteringService()
# Capabilities
allow_retrieve = True
# Properties
template = resource.prop('template', type=dict)
class Policy(resource.Resource):
resource_key = 'policy'
resources_key = 'policies'
base_path = '/policies'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
allow_create = True
allow_delete = True
allow_update = True
# Properties
id = resource.prop('id')
name = resource.prop('name')
type = resource.prop('type')
cooldown = resource.prop('cooldown')
level = resource.prop('level', type=int)
created_time = resource.prop('created_time')
updated_time = resource.prop('updated_time')
deleted_time = resource.prop('deleted_time')
spec = resource.prop('spec', type=dict)
data = resource.prop('data', type=dict)
def to_dict(self):
pb_dict = {
'id': self.id,
'name': self.name,
'type': self.type,
'spec': self.spec,
'level': self.level,
'cooldown': self.cooldown,
'created_time': self.created_time,
'updated_time': self.updated_time,
'deleted_time': self.deleted_time,
}
return pb_dict
class Webhook(resource.Resource):
resource_key = 'webhook'
resources_key = 'webhooks'
base_path = '/webhooks'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
allow_create = True
allow_delete = True
# Properties
id = resource.prop('id')
user = resource.prop('user')
domain = resource.prop('domain')
project = resource.prop('project')
name = resource.prop('name')
obj_type = resource.prop('obj_type')
obj_id = resource.prop('obj_id')
action = resource.prop('action')
created_time = resource.prop('created_time')
deleted_time = resource.prop('deleted_time')
credential = resource.prop('credential', type=dict)
params = resource.prop('params', type=dict)
url = resource.prop('url')
def to_dict(self):
webhook_dict = {
'id': self.id,
'user': self.user,
'domain': self.domain,
'project': self.project,
'name': self.name,
'obj_type': self.obj_type,
'obj_id': self.obj_id,
'action': self.action,
'credential': self.credential,
'params': self.params,
'created_time': self.created_time,
'deleted_time': self.deleted_time,
'url': self.url,
}
return webhook_dict
class Cluster(resource.Resource):
resource_key = 'cluster'
resources_key = 'clusters'
base_path = '/clusters'
service = clustering_service.ClusteringService()
# capabilities
allow_create = True
allow_retrieve = True
allow_update = True
allow_delete = True
allow_list = True
# Properties
id = resource.prop('id')
name = resource.prop('name')
profile_id = resource.prop('profile_id')
user = resource.prop('user')
project = resource.prop('project')
domain = resource.prop('domain')
parent = resource.prop('parent')
created_time = resource.prop('created_time')
updated_time = resource.prop('updated_time')
deleted_time = resource.prop('deleted_time')
min_size = resource.prop('min_size', type=int)
max_size = resource.prop('max_size', type=int)
desired_capacity = resource.prop('desired_capacity', type=int)
timeout = resource.prop('timeout')
status = resource.prop('status')
status_reason = resource.prop('status_reason')
tags = resource.prop('tags', type=dict)
data = resource.prop('data', type=dict)
nodes = resource.prop('nodes')
profile_name = resource.prop('profile_name')
# action = resource.prop('action')
def action(self, session, body):
url = utils.urljoin(self.base_path, self.id, 'action')
resp = session.put(url, service=self.service, json=body).body
return resp
def add_nodes(self, session, nodes):
body = {
'add_nodes': {
'nodes': nodes,
}
}
return self.action(session, body)
def del_nodes(self, session, nodes):
body = {
'del_nodes': {
'nodes': nodes,
}
}
return self.action(session, body)
def attach_policy(self, session, policy_id, priority, level, enabled,
cooldown):
body = {
'attach_policy': {
'policy_id': policy_id,
'priority': priority,
'level': level,
'enabled': enabled,
'cooldown': cooldown,
}
}
return self.action(session, body)
def detach_policy(self, session, policy_id):
body = {
'detach_policy': {
'policy_id': policy_id,
}
}
return self.action(session, body)
def enable_policy(self, session, policy_id, priority, level, cooldown):
body = {
'attach_policy': {
'policy_id': policy_id,
'priority': priority,
'level': level,
'cooldown': cooldown,
}
}
return self.action(session, body)
def disable_policy(self, session, policy_id):
body = {
'disable_policy': {
'policy_id': policy_id,
}
}
return self.action(session, body)
def scale_out(self, session, count=None):
body = {'scale_out': {}}
if count is not None:
body['scale_out'] = {'count': count}
return self.action(session, body)
def scale_in(self, session, count):
body = {
'scale_in': {
'count': count,
}
}
return self.action(session, body)
def policy_attach(self, session, policy_id, priority, level, cooldown,
enabled):
body = {
'policy_attach': {
'policy_id': policy_id,
'priority': priority,
'level': level,
'cooldown': cooldown,
'enabled': enabled,
}
}
return self.action(session, body)
def policy_detach(self, session, policy_id):
body = {
'policy_detach': {
'policy_id': policy_id,
}
}
return self.action(session, body)
def policy_update(self, session, policy_id, priority, level, cooldown,
enabled):
body = {
'policy_update': {
'policy_id': policy_id,
}
}
if priority is not None:
body['policy_update']['priority'] = priority
if level is not None:
body['policy_update']['level'] = level
if cooldown is not None:
body['policy_update']['cooldown'] = cooldown
if enabled is not None:
body['policy_update']['enabled'] = enabled
return self.action(session, body)
def policy_enable(self, session, policy_id):
body = {
'policy_update': {
'policy_id': policy_id,
'enabled': True,
}
}
return self.action(session, body)
def policy_disable(self, session, policy_id):
body = {
'policy_update': {
'policy_id': policy_id,
'enabled': False,
}
}
return self.action(session, body)
def to_dict(self):
info = {
'id': self.id,
'name': self.name,
'profile_id': self.profile_id,
'user': self.user,
'project': self.project,
'domain': self.domain,
'parent': self.parent,
'created_time': self.created_time,
'updated_time': self.updated_time,
'deleted_time': self.deleted_time,
'min_size': self.min_size,
'max_size': self.max_size,
'desired_capacity': self.desired_capacity,
'timeout': self.timeout,
'status': self.status,
'status_reason': self.status_reason,
'tags': self.tags or {},
'data': self.data or {},
'nodes': self.nodes or [],
'profile_name': self.profile_name,
}
return info
class ClusterPolicy(resource.Resource):
id_attribute = 'policy_id'
resource_key = 'cluster_policy'
resources_key = 'cluster_policies'
base_path = '/clusters/%(cluster_id)s/policies'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
# Properties
policy_id = resource.prop('policy_id')
cluster_id = resource.prop('cluster_id')
cluster_name = resource.prop('cluster_name')
policy = resource.prop('policy_name')
type = resource.prop('policy_type')
priority = resource.prop('priority')
level = resource.prop('level', type=int)
cooldown = resource.prop('cooldown')
enabled = resource.prop('enabled')
def to_dict(self):
info = {
'cluster_id': self.cluster_id,
'cluster_name': self.cluster_name,
'policy_id': self.policy_id,
'policy': self.policy,
'type': self.type,
'priority': self.priority,
'level': self.level,
'cooldown': self.cooldown,
'enabled': self.enabled,
}
return info
class ClusterNode(resource.Resource):
resources_key = 'nodes'
base_path = '/clusters/%(cluster_id)s/nodes'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_create = True
allow_delete = True
# Properties
id = resource.prop('id')
cluster_id = resource.prop('cluster_id')
policy_id = resource.prop('node_id')
class Node(resource.Resource):
resource_key = 'node'
resources_key = 'nodes'
base_path = '/nodes'
service = clustering_service.ClusteringService()
# capabilities
allow_create = True
allow_retrieve = True
allow_update = True
allow_delete = True
allow_list = True
# Properties
id = resource.prop('id')
name = resource.prop('name')
physical_id = resource.prop('physical_id')
cluster_id = resource.prop('cluster_id')
profile_id = resource.prop('profile_id')
project = resource.prop('project')
profile_name = resource.prop('profile_name')
index = resource.prop('index', type=int)
role = resource.prop('role')
init_time = resource.prop('init_time')
created_time = resource.prop('created_time')
updated_time = resource.prop('updated_time')
deleted_time = resource.prop('deleted_time')
status = resource.prop('status')
status_reason = resource.prop('status_reason')
tags = resource.prop('tags', type=dict)
data = resource.prop('data', type=dict)
details = resource.prop('details', type=dict)
def action(self, session, body):
url = utils.urljoin(self.base_path, self.id, 'action')
resp = session.put(url, service=self.service, json=body).body
return resp
def join(self, session, cluster_id):
body = {
'join': {
'cluster_id': cluster_id,
}
}
return self.action(session, body)
def leave(self, session):
body = {
'leave': {}
}
return self.action(session, body)
def to_dict(self):
return {
'id': self.id,
'name': self.name,
'physical_id': self.physical_id,
'cluster_id': self.cluster_id,
'profile_id': self.profile_id,
'profile_name': self.profile_name,
'project': self.project,
'index': self.index,
'role': self.role,
'init_time': self.init_time,
'created_time': self.created_time,
'updated_time': self.updated_time,
'deleted_time': self.deleted_time,
'status': self.status,
'status_reason': self.status_reason,
'tags': self.tags,
'data': self.data,
'details': self.details,
}
class Action(resource.Resource):
resources_key = 'actions'
base_path = '/actions'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
# Properties
id = resource.prop('id')
name = resource.prop('name')
target = resource.prop('target')
action = resource.prop('action')
cause = resource.prop('cause')
owner = resource.prop('owner')
interval = resource.prop('interval')
start_time = resource.prop('start_time')
end_time = resource.prop('end_time')
timeout = resource.prop('timeout')
status = resource.prop('status')
status_reason = resource.prop('status_reason')
inputs = resource.prop('inputs', type=dict)
outputs = resource.prop('outputs', type=dict)
depends_on = resource.prop('depends_on', type=list)
depended_by = resource.prop('depended_by', type=list)
def to_dict(self):
action_dict = {
'id': self.id,
'name': self.name,
'action': self.action,
'target': self.target,
'cause': self.cause,
'interval': self.interval,
'start_time': self.start_time,
'end_time': self.end_time,
'interval': self.interval,
'timeout': self.timeout,
'status': self.status,
'status_reason': self.status_reason,
'inputs': self.inputs,
'outputs': self.outputs,
'depends_on': self.depends_on,
'depended_by': self.depended_by,
}
return action_dict
class Event(resource.Resource):
resources_key = 'events'
base_path = '/events'
service = clustering_service.ClusteringService()
# Capabilities
allow_list = True
allow_retrieve = True
# Properties
id = resource.prop('id')
timestamp = resource.prop('timestamp')
obj_id = resource.prop('obj_id')
obj_name = resource.prop('obj_name')
obj_type = resource.prop('obj_type')
cluster_id = resource.prop('cluster_id')
level = resource.prop('level')
user = resource.prop('user')
project = resource.prop('project')
action = resource.prop('action')
status = resource.prop('status')
status_reason = resource.prop('status_reason')
def to_dict(self):
event_dict = {
'id': self.id,
'timestamp': self.timestamp,
'obj_id': self.obj_id,
'obj_type': self.obj_type,
'obj_name': self.obj_name,
'cluster_id': self.cluster_id,
'level': self.level,
'user': self.user,
'project': self.project,
'action': self.action,
'status': self.status,
'status_reason': self.status_reason,
}
return event_dict