You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
193 lines
7.5 KiB
193 lines
7.5 KiB
# Copyright 2014 Rackspace
|
|
#
|
|
# 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 wsme import types as wtypes
|
|
|
|
from octavia.api.common import types
|
|
from octavia.api.v2.types import listener
|
|
from octavia.api.v2.types import pool
|
|
|
|
|
|
class BaseLoadBalancerType(types.BaseType):
|
|
_type_to_model_map = {'vip_address': 'vip.ip_address',
|
|
'vip_subnet_id': 'vip.subnet_id',
|
|
'vip_port_id': 'vip.port_id',
|
|
'vip_network_id': 'vip.network_id',
|
|
'vip_qos_policy_id': 'vip.qos_policy_id',
|
|
'admin_state_up': 'enabled'}
|
|
_child_map = {'vip': {
|
|
'ip_address': 'vip_address',
|
|
'subnet_id': 'vip_subnet_id',
|
|
'port_id': 'vip_port_id',
|
|
'network_id': 'vip_network_id',
|
|
'qos_policy_id': 'vip_qos_policy_id'}}
|
|
|
|
|
|
class LoadBalancerResponse(BaseLoadBalancerType):
|
|
"""Defines which attributes are to be shown on any response."""
|
|
id = wtypes.wsattr(wtypes.UuidType())
|
|
name = wtypes.wsattr(wtypes.StringType())
|
|
description = wtypes.wsattr(wtypes.StringType())
|
|
provisioning_status = wtypes.wsattr(wtypes.StringType())
|
|
operating_status = wtypes.wsattr(wtypes.StringType())
|
|
admin_state_up = wtypes.wsattr(bool)
|
|
project_id = wtypes.wsattr(wtypes.StringType())
|
|
created_at = wtypes.wsattr(wtypes.datetime.datetime)
|
|
updated_at = wtypes.wsattr(wtypes.datetime.datetime)
|
|
vip_address = wtypes.wsattr(types.IPAddressType())
|
|
vip_port_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_subnet_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_network_id = wtypes.wsattr(wtypes.UuidType())
|
|
listeners = wtypes.wsattr([types.IdOnlyType])
|
|
pools = wtypes.wsattr([types.IdOnlyType])
|
|
provider = wtypes.wsattr(wtypes.StringType())
|
|
flavor_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_qos_policy_id = wtypes.wsattr(wtypes.UuidType())
|
|
tags = wtypes.wsattr(wtypes.ArrayType(wtypes.StringType()))
|
|
availability_zone = wtypes.wsattr(wtypes.StringType())
|
|
|
|
@classmethod
|
|
def from_data_model(cls, data_model, children=False):
|
|
result = super(LoadBalancerResponse, cls).from_data_model(
|
|
data_model, children=children)
|
|
if data_model.vip:
|
|
result.vip_subnet_id = data_model.vip.subnet_id
|
|
result.vip_port_id = data_model.vip.port_id
|
|
result.vip_address = data_model.vip.ip_address
|
|
result.vip_network_id = data_model.vip.network_id
|
|
result.vip_qos_policy_id = data_model.vip.qos_policy_id
|
|
if cls._full_response():
|
|
listener_model = listener.ListenerFullResponse
|
|
pool_model = pool.PoolFullResponse
|
|
else:
|
|
listener_model = types.IdOnlyType
|
|
pool_model = types.IdOnlyType
|
|
result.listeners = [
|
|
listener_model.from_data_model(i) for i in data_model.listeners]
|
|
result.pools = [
|
|
pool_model.from_data_model(i) for i in data_model.pools]
|
|
|
|
if not result.provider:
|
|
result.provider = "octavia"
|
|
|
|
return result
|
|
|
|
|
|
class LoadBalancerFullResponse(LoadBalancerResponse):
|
|
@classmethod
|
|
def _full_response(cls):
|
|
return True
|
|
|
|
listeners = wtypes.wsattr([listener.ListenerFullResponse])
|
|
pools = wtypes.wsattr([pool.PoolFullResponse])
|
|
|
|
|
|
class LoadBalancerRootResponse(types.BaseType):
|
|
loadbalancer = wtypes.wsattr(LoadBalancerResponse)
|
|
|
|
|
|
class LoadBalancerFullRootResponse(LoadBalancerRootResponse):
|
|
loadbalancer = wtypes.wsattr(LoadBalancerFullResponse)
|
|
|
|
|
|
class LoadBalancersRootResponse(types.BaseType):
|
|
loadbalancers = wtypes.wsattr([LoadBalancerResponse])
|
|
loadbalancers_links = wtypes.wsattr([types.PageType])
|
|
|
|
|
|
class LoadBalancerPOST(BaseLoadBalancerType):
|
|
"""Defines mandatory and optional attributes of a POST request."""
|
|
|
|
name = wtypes.wsattr(wtypes.StringType(max_length=255))
|
|
description = wtypes.wsattr(wtypes.StringType(max_length=255))
|
|
admin_state_up = wtypes.wsattr(bool, default=True)
|
|
vip_address = wtypes.wsattr(types.IPAddressType())
|
|
vip_port_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_subnet_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_network_id = wtypes.wsattr(wtypes.UuidType())
|
|
vip_qos_policy_id = wtypes.wsattr(wtypes.UuidType())
|
|
project_id = wtypes.wsattr(wtypes.StringType(max_length=36))
|
|
listeners = wtypes.wsattr([listener.ListenerSingleCreate], default=[])
|
|
pools = wtypes.wsattr([pool.PoolSingleCreate], default=[])
|
|
provider = wtypes.wsattr(wtypes.StringType(max_length=64))
|
|
tags = wtypes.wsattr(wtypes.ArrayType(wtypes.StringType(max_length=255)))
|
|
flavor_id = wtypes.wsattr(wtypes.UuidType())
|
|
availability_zone = wtypes.wsattr(wtypes.StringType(max_length=255))
|
|
|
|
|
|
class LoadBalancerRootPOST(types.BaseType):
|
|
loadbalancer = wtypes.wsattr(LoadBalancerPOST)
|
|
|
|
|
|
class LoadBalancerPUT(BaseLoadBalancerType):
|
|
"""Defines attributes that are acceptable of a PUT request."""
|
|
|
|
name = wtypes.wsattr(wtypes.StringType(max_length=255))
|
|
description = wtypes.wsattr(wtypes.StringType(max_length=255))
|
|
vip_qos_policy_id = wtypes.wsattr(wtypes.UuidType())
|
|
admin_state_up = wtypes.wsattr(bool)
|
|
tags = wtypes.wsattr(wtypes.ArrayType(wtypes.StringType(max_length=255)))
|
|
|
|
|
|
class LoadBalancerRootPUT(types.BaseType):
|
|
loadbalancer = wtypes.wsattr(LoadBalancerPUT)
|
|
|
|
|
|
class LoadBalancerStatusResponse(BaseLoadBalancerType):
|
|
"""Defines which attributes are to be shown on status response."""
|
|
id = wtypes.wsattr(wtypes.UuidType())
|
|
name = wtypes.wsattr(wtypes.StringType())
|
|
operating_status = wtypes.wsattr(wtypes.StringType())
|
|
provisioning_status = wtypes.wsattr(wtypes.StringType())
|
|
listeners = wtypes.wsattr([listener.ListenerStatusResponse])
|
|
|
|
@classmethod
|
|
def from_data_model(cls, data_model, children=False):
|
|
result = super(LoadBalancerStatusResponse, cls).from_data_model(
|
|
data_model, children=children)
|
|
listener_model = listener.ListenerStatusResponse
|
|
result.listeners = [
|
|
listener_model.from_data_model(i) for i in data_model.listeners]
|
|
if not result.name:
|
|
result.name = ""
|
|
|
|
return result
|
|
|
|
|
|
class StatusResponse(wtypes.Base):
|
|
loadbalancer = wtypes.wsattr(LoadBalancerStatusResponse)
|
|
|
|
|
|
class StatusRootResponse(types.BaseType):
|
|
statuses = wtypes.wsattr(StatusResponse)
|
|
|
|
|
|
class LoadBalancerStatisticsResponse(BaseLoadBalancerType):
|
|
"""Defines which attributes are to show on stats response."""
|
|
bytes_in = wtypes.wsattr(wtypes.IntegerType())
|
|
bytes_out = wtypes.wsattr(wtypes.IntegerType())
|
|
active_connections = wtypes.wsattr(wtypes.IntegerType())
|
|
total_connections = wtypes.wsattr(wtypes.IntegerType())
|
|
request_errors = wtypes.wsattr(wtypes.IntegerType())
|
|
|
|
@classmethod
|
|
def from_data_model(cls, data_model, children=False):
|
|
result = super(LoadBalancerStatisticsResponse, cls).from_data_model(
|
|
data_model, children=children)
|
|
return result
|
|
|
|
|
|
class StatisticsRootResponse(types.BaseType):
|
|
stats = wtypes.wsattr(LoadBalancerStatisticsResponse)
|