mirror of
https://github.com/apache/cloudstack.git
synced 2025-11-03 04:12:31 +01:00
Addition of two new resource types i.e. CPU and Memory in the existing pool of
resource types.
Added some methods to set the limits on these resources using updateResourceLimit
API command and to get a count using updateResourceCount. Also added calls in the
Virtual machine life cycle to check these limits and to increment/decrement the new
resource types
Resource Name :: Resource type number
CPU 8
Memory 9
Also added Unit Tests for the same.
1152 lines
44 KiB
SQL
1152 lines
44 KiB
SQL
-- Licensed to the Apache Software Foundation (ASF) under one
|
|
-- or more contributor license agreements. See the NOTICE file
|
|
-- distributed with this work for additional information
|
|
-- regarding copyright ownership. The ASF licenses this file
|
|
-- to you 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.
|
|
|
|
-- DB views for list api
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`user_vm_view`;
|
|
CREATE VIEW `cloud`.`user_vm_view` AS
|
|
select
|
|
vm_instance.id id,
|
|
vm_instance.name name,
|
|
user_vm.display_name display_name,
|
|
user_vm.user_data user_data,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
instance_group.id instance_group_id,
|
|
instance_group.uuid instance_group_uuid,
|
|
instance_group.name instance_group_name,
|
|
vm_instance.uuid uuid,
|
|
vm_instance.last_host_id last_host_id,
|
|
vm_instance.vm_type type,
|
|
vm_instance.vnc_password vnc_password,
|
|
vm_instance.limit_cpu_use limit_cpu_use,
|
|
vm_instance.created created,
|
|
vm_instance.state state,
|
|
vm_instance.removed removed,
|
|
vm_instance.ha_enabled ha_enabled,
|
|
vm_instance.hypervisor_type hypervisor_type,
|
|
vm_instance.instance_name instance_name,
|
|
vm_instance.guest_os_id guest_os_id,
|
|
guest_os.uuid guest_os_uuid,
|
|
vm_instance.pod_id pod_id,
|
|
host_pod_ref.uuid pod_uuid,
|
|
vm_instance.private_ip_address private_ip_address,
|
|
vm_instance.private_mac_address private_mac_address,
|
|
vm_instance.vm_type vm_type,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
data_center.is_security_group_enabled security_group_enabled,
|
|
host.id host_id,
|
|
host.uuid host_uuid,
|
|
host.name host_name,
|
|
vm_template.id template_id,
|
|
vm_template.uuid template_uuid,
|
|
vm_template.name template_name,
|
|
vm_template.display_text template_display_text,
|
|
vm_template.enable_password password_enabled,
|
|
iso.id iso_id,
|
|
iso.uuid iso_uuid,
|
|
iso.name iso_name,
|
|
iso.display_text iso_display_text,
|
|
service_offering.id service_offering_id,
|
|
disk_offering.uuid service_offering_uuid,
|
|
service_offering.cpu cpu,
|
|
service_offering.speed speed,
|
|
service_offering.ram_size ram_size,
|
|
disk_offering.name service_offering_name,
|
|
storage_pool.id pool_id,
|
|
storage_pool.uuid pool_uuid,
|
|
storage_pool.pool_type pool_type,
|
|
volumes.id volume_id,
|
|
volumes.uuid volume_uuid,
|
|
volumes.device_id volume_device_id,
|
|
volumes.volume_type volume_type,
|
|
security_group.id security_group_id,
|
|
security_group.uuid security_group_uuid,
|
|
security_group.name security_group_name,
|
|
security_group.description security_group_description,
|
|
nics.id nic_id,
|
|
nics.uuid nic_uuid,
|
|
nics.network_id network_id,
|
|
nics.ip4_address ip_address,
|
|
nics.default_nic is_default_nic,
|
|
nics.gateway gateway,
|
|
nics.netmask netmask,
|
|
nics.mac_address mac_address,
|
|
nics.broadcast_uri broadcast_uri,
|
|
nics.isolation_uri isolation_uri,
|
|
vpc.id vpc_id,
|
|
vpc.uuid vpc_uuid,
|
|
networks.uuid network_uuid,
|
|
networks.traffic_type traffic_type,
|
|
networks.guest_type guest_type,
|
|
user_ip_address.id public_ip_id,
|
|
user_ip_address.uuid public_ip_uuid,
|
|
user_ip_address.public_ip_address public_ip_address,
|
|
ssh_keypairs.keypair_name keypair_name,
|
|
resource_tags.id tag_id,
|
|
resource_tags.uuid tag_uuid,
|
|
resource_tags.key tag_key,
|
|
resource_tags.value tag_value,
|
|
resource_tags.domain_id tag_domain_id,
|
|
resource_tags.account_id tag_account_id,
|
|
resource_tags.resource_id tag_resource_id,
|
|
resource_tags.resource_uuid tag_resource_uuid,
|
|
resource_tags.resource_type tag_resource_type,
|
|
resource_tags.customer tag_customer,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`user_vm`
|
|
inner join
|
|
`cloud`.`vm_instance` ON vm_instance.id = user_vm.id
|
|
and vm_instance.removed is NULL
|
|
inner join
|
|
`cloud`.`account` ON vm_instance.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON vm_instance.domain_id = domain.id
|
|
left join
|
|
`cloud`.`guest_os` ON vm_instance.guest_os_id = guest_os.id
|
|
left join
|
|
`cloud`.`host_pod_ref` ON vm_instance.pod_id = host_pod_ref.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = account.id
|
|
left join
|
|
`cloud`.`instance_group_vm_map` ON vm_instance.id = instance_group_vm_map.instance_id
|
|
left join
|
|
`cloud`.`instance_group` ON instance_group_vm_map.group_id = instance_group.id
|
|
left join
|
|
`cloud`.`data_center` ON vm_instance.data_center_id = data_center.id
|
|
left join
|
|
`cloud`.`host` ON vm_instance.host_id = host.id
|
|
left join
|
|
`cloud`.`vm_template` ON vm_instance.vm_template_id = vm_template.id
|
|
left join
|
|
`cloud`.`vm_template` iso ON iso.id = user_vm.iso_id
|
|
left join
|
|
`cloud`.`service_offering` ON vm_instance.service_offering_id = service_offering.id
|
|
left join
|
|
`cloud`.`disk_offering` ON vm_instance.service_offering_id = disk_offering.id
|
|
left join
|
|
`cloud`.`volumes` ON vm_instance.id = volumes.instance_id
|
|
left join
|
|
`cloud`.`storage_pool` ON volumes.pool_id = storage_pool.id
|
|
left join
|
|
`cloud`.`security_group_vm_map` ON vm_instance.id = security_group_vm_map.instance_id
|
|
left join
|
|
`cloud`.`security_group` ON security_group_vm_map.security_group_id = security_group.id
|
|
left join
|
|
`cloud`.`nics` ON vm_instance.id = nics.instance_id
|
|
left join
|
|
`cloud`.`networks` ON nics.network_id = networks.id
|
|
left join
|
|
`cloud`.`vpc` ON networks.vpc_id = vpc.id
|
|
left join
|
|
`cloud`.`user_ip_address` ON user_ip_address.vm_id = vm_instance.id
|
|
left join
|
|
`cloud`.`user_vm_details` ON user_vm_details.vm_id = vm_instance.id
|
|
and user_vm_details.name = 'SSH.PublicKey'
|
|
left join
|
|
`cloud`.`ssh_keypairs` ON ssh_keypairs.public_key = user_vm_details.value
|
|
left join
|
|
`cloud`.`resource_tags` ON resource_tags.resource_id = vm_instance.id
|
|
and resource_tags.resource_type = 'UserVm'
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = vm_instance.id
|
|
and async_job.instance_type = 'VirtualMachine'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`domain_router_view`;
|
|
CREATE VIEW `cloud`.`domain_router_view` AS
|
|
select
|
|
vm_instance.id id,
|
|
vm_instance.name name,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
vm_instance.uuid uuid,
|
|
vm_instance.created created,
|
|
vm_instance.state state,
|
|
vm_instance.removed removed,
|
|
vm_instance.pod_id pod_id,
|
|
vm_instance.instance_name instance_name,
|
|
host_pod_ref.uuid pod_uuid,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
data_center.dns1 dns1,
|
|
data_center.dns2 dns2,
|
|
host.id host_id,
|
|
host.uuid host_uuid,
|
|
host.name host_name,
|
|
vm_template.id template_id,
|
|
vm_template.uuid template_uuid,
|
|
service_offering.id service_offering_id,
|
|
disk_offering.uuid service_offering_uuid,
|
|
disk_offering.name service_offering_name,
|
|
nics.id nic_id,
|
|
nics.uuid nic_uuid,
|
|
nics.network_id network_id,
|
|
nics.ip4_address ip_address,
|
|
nics.default_nic is_default_nic,
|
|
nics.gateway gateway,
|
|
nics.netmask netmask,
|
|
nics.mac_address mac_address,
|
|
nics.broadcast_uri broadcast_uri,
|
|
nics.isolation_uri isolation_uri,
|
|
vpc.id vpc_id,
|
|
vpc.uuid vpc_uuid,
|
|
networks.uuid network_uuid,
|
|
networks.name network_name,
|
|
networks.network_domain network_domain,
|
|
networks.traffic_type traffic_type,
|
|
networks.guest_type guest_type,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id,
|
|
domain_router.template_version template_version,
|
|
domain_router.scripts_version scripts_version,
|
|
domain_router.is_redundant_router is_redundant_router,
|
|
domain_router.redundant_state redundant_state,
|
|
domain_router.stop_pending stop_pending
|
|
from
|
|
`cloud`.`domain_router`
|
|
inner join
|
|
`cloud`.`vm_instance` ON vm_instance.id = domain_router.id
|
|
inner join
|
|
`cloud`.`account` ON vm_instance.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON vm_instance.domain_id = domain.id
|
|
left join
|
|
`cloud`.`host_pod_ref` ON vm_instance.pod_id = host_pod_ref.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = account.id
|
|
left join
|
|
`cloud`.`data_center` ON vm_instance.data_center_id = data_center.id
|
|
left join
|
|
`cloud`.`host` ON vm_instance.host_id = host.id
|
|
left join
|
|
`cloud`.`vm_template` ON vm_instance.vm_template_id = vm_template.id
|
|
left join
|
|
`cloud`.`service_offering` ON vm_instance.service_offering_id = service_offering.id
|
|
left join
|
|
`cloud`.`disk_offering` ON vm_instance.service_offering_id = disk_offering.id
|
|
left join
|
|
`cloud`.`volumes` ON vm_instance.id = volumes.instance_id
|
|
left join
|
|
`cloud`.`storage_pool` ON volumes.pool_id = storage_pool.id
|
|
left join
|
|
`cloud`.`nics` ON vm_instance.id = nics.instance_id
|
|
left join
|
|
`cloud`.`networks` ON nics.network_id = networks.id
|
|
left join
|
|
`cloud`.`vpc` ON networks.vpc_id = vpc.id
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = vm_instance.id
|
|
and async_job.instance_type = 'DomainRouter'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`security_group_view`;
|
|
CREATE VIEW `cloud`.`security_group_view` AS
|
|
select
|
|
security_group.id id,
|
|
security_group.name name,
|
|
security_group.description description,
|
|
security_group.uuid uuid,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
security_group_rule.id rule_id,
|
|
security_group_rule.uuid rule_uuid,
|
|
security_group_rule.type rule_type,
|
|
security_group_rule.start_port rule_start_port,
|
|
security_group_rule.end_port rule_end_port,
|
|
security_group_rule.protocol rule_protocol,
|
|
security_group_rule.allowed_network_id rule_allowed_network_id,
|
|
security_group_rule.allowed_ip_cidr rule_allowed_ip_cidr,
|
|
security_group_rule.create_status rule_create_status,
|
|
resource_tags.id tag_id,
|
|
resource_tags.uuid tag_uuid,
|
|
resource_tags.key tag_key,
|
|
resource_tags.value tag_value,
|
|
resource_tags.domain_id tag_domain_id,
|
|
resource_tags.account_id tag_account_id,
|
|
resource_tags.resource_id tag_resource_id,
|
|
resource_tags.resource_uuid tag_resource_uuid,
|
|
resource_tags.resource_type tag_resource_type,
|
|
resource_tags.customer tag_customer,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`security_group`
|
|
left join
|
|
`cloud`.`security_group_rule` ON security_group.id = security_group_rule.security_group_id
|
|
inner join
|
|
`cloud`.`account` ON security_group.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON security_group.domain_id = domain.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = security_group.account_id
|
|
left join
|
|
`cloud`.`resource_tags` ON resource_tags.resource_id = security_group.id
|
|
and resource_tags.resource_type = 'SecurityGroup'
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = security_group.id
|
|
and async_job.instance_type = 'SecurityGroup'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`resource_tag_view`;
|
|
CREATE VIEW `cloud`.`resource_tag_view` AS
|
|
select
|
|
resource_tags.id,
|
|
resource_tags.uuid,
|
|
resource_tags.key,
|
|
resource_tags.value,
|
|
resource_tags.resource_id,
|
|
resource_tags.resource_uuid,
|
|
resource_tags.resource_type,
|
|
resource_tags.customer,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name
|
|
from
|
|
`cloud`.`resource_tags`
|
|
inner join
|
|
`cloud`.`account` ON resource_tags.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON resource_tags.domain_id = domain.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = resource_tags.account_id;
|
|
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`event_view`;
|
|
CREATE VIEW `cloud`.`event_view` AS
|
|
select
|
|
event.id,
|
|
event.uuid,
|
|
event.type,
|
|
event.state,
|
|
event.description,
|
|
event.created,
|
|
event.level,
|
|
event.parameters,
|
|
event.start_id,
|
|
eve.uuid start_uuid,
|
|
event.user_id,
|
|
user.username user_name,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name
|
|
from
|
|
`cloud`.`event`
|
|
inner join
|
|
`cloud`.`account` ON event.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON event.domain_id = domain.id
|
|
inner join
|
|
`cloud`.`user` ON event.user_id = user.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = event.account_id
|
|
left join
|
|
`cloud`.`event` eve ON event.start_id = eve.id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`instance_group_view`;
|
|
CREATE VIEW `cloud`.`instance_group_view` AS
|
|
select
|
|
instance_group.id,
|
|
instance_group.uuid,
|
|
instance_group.name,
|
|
instance_group.removed,
|
|
instance_group.created,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name
|
|
from
|
|
`cloud`.`instance_group`
|
|
inner join
|
|
`cloud`.`account` ON instance_group.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON account.domain_id = domain.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = instance_group.account_id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`user_view`;
|
|
CREATE VIEW `cloud`.`user_view` AS
|
|
select
|
|
user.id,
|
|
user.uuid,
|
|
user.username,
|
|
user.password,
|
|
user.firstname,
|
|
user.lastname,
|
|
user.email,
|
|
user.state,
|
|
user.api_key,
|
|
user.secret_key,
|
|
user.created,
|
|
user.removed,
|
|
user.timezone,
|
|
user.registration_token,
|
|
user.is_registered,
|
|
user.incorrect_login_attempts,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`user`
|
|
inner join
|
|
`cloud`.`account` ON user.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON account.domain_id = domain.id
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = user.id
|
|
and async_job.instance_type = 'User'
|
|
and async_job.job_status = 0;
|
|
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`project_view`;
|
|
CREATE VIEW `cloud`.`project_view` AS
|
|
select
|
|
projects.id,
|
|
projects.uuid,
|
|
projects.name,
|
|
projects.display_text,
|
|
projects.state,
|
|
projects.removed,
|
|
projects.created,
|
|
account.account_name owner,
|
|
pacct.account_id,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
resource_tags.id tag_id,
|
|
resource_tags.uuid tag_uuid,
|
|
resource_tags.key tag_key,
|
|
resource_tags.value tag_value,
|
|
resource_tags.domain_id tag_domain_id,
|
|
resource_tags.account_id tag_account_id,
|
|
resource_tags.resource_id tag_resource_id,
|
|
resource_tags.resource_uuid tag_resource_uuid,
|
|
resource_tags.resource_type tag_resource_type,
|
|
resource_tags.customer tag_customer
|
|
from
|
|
`cloud`.`projects`
|
|
inner join
|
|
`cloud`.`domain` ON projects.domain_id = domain.id
|
|
inner join
|
|
`cloud`.`project_account` ON projects.id = project_account.project_id
|
|
and project_account.account_role = 'Admin'
|
|
inner join
|
|
`cloud`.`account` ON account.id = project_account.account_id
|
|
left join
|
|
`cloud`.`resource_tags` ON resource_tags.resource_id = projects.id
|
|
and resource_tags.resource_type = 'Project'
|
|
left join
|
|
`cloud`.`project_account` pacct ON projects.id = pacct.project_id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`project_account_view`;
|
|
CREATE VIEW `cloud`.`project_account_view` AS
|
|
select
|
|
project_account.id,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name,
|
|
account.type account_type,
|
|
project_account.account_role,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path
|
|
from
|
|
`cloud`.`project_account`
|
|
inner join
|
|
`cloud`.`account` ON project_account.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON account.domain_id = domain.id
|
|
inner join
|
|
`cloud`.`projects` ON projects.id = project_account.project_id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`project_invitation_view`;
|
|
CREATE VIEW `cloud`.`project_invitation_view` AS
|
|
select
|
|
project_invitations.id,
|
|
project_invitations.uuid,
|
|
project_invitations.email,
|
|
project_invitations.created,
|
|
project_invitations.state,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path
|
|
from
|
|
`cloud`.`project_invitations`
|
|
left join
|
|
`cloud`.`account` ON project_invitations.account_id = account.id
|
|
left join
|
|
`cloud`.`domain` ON project_invitations.domain_id = domain.id
|
|
left join
|
|
`cloud`.`projects` ON projects.id = project_invitations.project_id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`host_view`;
|
|
CREATE VIEW `cloud`.`host_view` AS
|
|
select
|
|
host.id,
|
|
host.uuid,
|
|
host.name,
|
|
host.status,
|
|
host.disconnected,
|
|
host.type,
|
|
host.private_ip_address,
|
|
host.version,
|
|
host.hypervisor_type,
|
|
host.hypervisor_version,
|
|
host.capabilities,
|
|
host.last_ping,
|
|
host.created,
|
|
host.removed,
|
|
host.resource_state,
|
|
host.mgmt_server_id,
|
|
host.cpus,
|
|
host.speed,
|
|
host.ram,
|
|
cluster.id cluster_id,
|
|
cluster.uuid cluster_uuid,
|
|
cluster.name cluster_name,
|
|
cluster.cluster_type,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
host_pod_ref.id pod_id,
|
|
host_pod_ref.uuid pod_uuid,
|
|
host_pod_ref.name pod_name,
|
|
host_tags.tag,
|
|
guest_os_category.id guest_os_category_id,
|
|
guest_os_category.uuid guest_os_category_uuid,
|
|
guest_os_category.name guest_os_category_name,
|
|
mem_caps.used_capacity memory_used_capacity,
|
|
mem_caps.reserved_capacity memory_reserved_capacity,
|
|
cpu_caps.used_capacity cpu_used_capacity,
|
|
cpu_caps.reserved_capacity cpu_reserved_capacity,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`host`
|
|
left join
|
|
`cloud`.`cluster` ON host.cluster_id = cluster.id
|
|
left join
|
|
`cloud`.`data_center` ON host.data_center_id = data_center.id
|
|
left join
|
|
`cloud`.`host_pod_ref` ON host.pod_id = host_pod_ref.id
|
|
left join
|
|
`cloud`.`host_details` ON host.id = host_details.id
|
|
and host_details.name = 'guest.os.category.id'
|
|
left join
|
|
`cloud`.`guest_os_category` ON guest_os_category.id = CONVERT( host_details.value , UNSIGNED)
|
|
left join
|
|
`cloud`.`host_tags` ON host_tags.host_id = host.id
|
|
left join
|
|
`cloud`.`op_host_capacity` mem_caps ON host.id = mem_caps.host_id
|
|
and mem_caps.capacity_type = 0
|
|
left join
|
|
`cloud`.`op_host_capacity` cpu_caps ON host.id = cpu_caps.host_id
|
|
and cpu_caps.capacity_type = 1
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = host.id
|
|
and async_job.instance_type = 'Host'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`volume_view`;
|
|
CREATE VIEW `cloud`.`volume_view` AS
|
|
select
|
|
volumes.id,
|
|
volumes.uuid,
|
|
volumes.name,
|
|
volumes.device_id,
|
|
volumes.volume_type,
|
|
volumes.size,
|
|
volumes.created,
|
|
volumes.state,
|
|
volumes.attached,
|
|
volumes.removed,
|
|
volumes.pod_id,
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
projects.id project_id,
|
|
projects.uuid project_uuid,
|
|
projects.name project_name,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
vm_instance.id vm_id,
|
|
vm_instance.uuid vm_uuid,
|
|
vm_instance.name vm_name,
|
|
vm_instance.state vm_state,
|
|
vm_instance.vm_type,
|
|
user_vm.display_name vm_display_name,
|
|
volume_host_ref.size volume_host_size,
|
|
volume_host_ref.created volume_host_created,
|
|
volume_host_ref.format,
|
|
volume_host_ref.download_pct,
|
|
volume_host_ref.download_state,
|
|
volume_host_ref.error_str,
|
|
disk_offering.id disk_offering_id,
|
|
disk_offering.uuid disk_offering_uuid,
|
|
disk_offering.name disk_offering_name,
|
|
disk_offering.display_text disk_offering_display_text,
|
|
disk_offering.use_local_storage,
|
|
disk_offering.system_use,
|
|
storage_pool.id pool_id,
|
|
storage_pool.uuid pool_uuid,
|
|
storage_pool.name pool_name,
|
|
cluster.hypervisor_type,
|
|
vm_template.id template_id,
|
|
vm_template.uuid template_uuid,
|
|
vm_template.extractable,
|
|
vm_template.type template_type,
|
|
resource_tags.id tag_id,
|
|
resource_tags.uuid tag_uuid,
|
|
resource_tags.key tag_key,
|
|
resource_tags.value tag_value,
|
|
resource_tags.domain_id tag_domain_id,
|
|
resource_tags.account_id tag_account_id,
|
|
resource_tags.resource_id tag_resource_id,
|
|
resource_tags.resource_uuid tag_resource_uuid,
|
|
resource_tags.resource_type tag_resource_type,
|
|
resource_tags.customer tag_customer,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`volumes`
|
|
inner join
|
|
`cloud`.`account` ON volumes.account_id = account.id
|
|
inner join
|
|
`cloud`.`domain` ON volumes.domain_id = domain.id
|
|
left join
|
|
`cloud`.`projects` ON projects.project_account_id = account.id
|
|
left join
|
|
`cloud`.`data_center` ON volumes.data_center_id = data_center.id
|
|
left join
|
|
`cloud`.`vm_instance` ON volumes.instance_id = vm_instance.id
|
|
left join
|
|
`cloud`.`user_vm` ON user_vm.id = vm_instance.id
|
|
left join
|
|
`cloud`.`volume_host_ref` ON volumes.id = volume_host_ref.volume_id
|
|
and volumes.data_center_id = volume_host_ref.zone_id
|
|
left join
|
|
`cloud`.`disk_offering` ON volumes.disk_offering_id = disk_offering.id
|
|
left join
|
|
`cloud`.`storage_pool` ON volumes.pool_id = storage_pool.id
|
|
left join
|
|
`cloud`.`cluster` ON storage_pool.cluster_id = cluster.id
|
|
left join
|
|
`cloud`.`vm_template` ON volumes.template_id = vm_template.id
|
|
left join
|
|
`cloud`.`resource_tags` ON resource_tags.resource_id = volumes.id
|
|
and resource_tags.resource_type = 'Volume'
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = volumes.id
|
|
and async_job.instance_type = 'Volume'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`account_netstats_view`;
|
|
CREATE VIEW `cloud`.`account_netstats_view` AS
|
|
SELECT
|
|
account_id,
|
|
sum(net_bytes_received) + sum(current_bytes_received) as bytesReceived,
|
|
sum(net_bytes_sent) + sum(current_bytes_sent) as bytesSent
|
|
FROM
|
|
`cloud`.`user_statistics`
|
|
group by account_id;
|
|
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`account_vmstats_view`;
|
|
CREATE VIEW `cloud`.`account_vmstats_view` AS
|
|
SELECT
|
|
account_id, state, count(*) as vmcount
|
|
from
|
|
`cloud`.`vm_instance`
|
|
group by account_id , state;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`free_ip_view`;
|
|
CREATE VIEW `cloud`.`free_ip_view` AS
|
|
select
|
|
count(user_ip_address.id) free_ip
|
|
from
|
|
`cloud`.`user_ip_address`
|
|
inner join
|
|
`cloud`.`vlan` ON vlan.id = user_ip_address.vlan_db_id
|
|
and vlan.vlan_type = 'VirtualNetwork'
|
|
where
|
|
state = 'Free';
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`account_view`;
|
|
CREATE VIEW `cloud`.`account_view` AS
|
|
select
|
|
account.id,
|
|
account.uuid,
|
|
account.account_name,
|
|
account.type,
|
|
account.state,
|
|
account.removed,
|
|
account.cleanup_needed,
|
|
account.network_domain,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
account_netstats_view.bytesReceived,
|
|
account_netstats_view.bytesSent,
|
|
vmlimit.max vmLimit,
|
|
vmcount.count vmTotal,
|
|
runningvm.vmcount runningVms,
|
|
stoppedvm.vmcount stoppedVms,
|
|
iplimit.max ipLimit,
|
|
ipcount.count ipTotal,
|
|
free_ip_view.free_ip ipFree,
|
|
volumelimit.max volumeLimit,
|
|
volumecount.count volumeTotal,
|
|
snapshotlimit.max snapshotLimit,
|
|
snapshotcount.count snapshotTotal,
|
|
templatelimit.max templateLimit,
|
|
templatecount.count templateTotal,
|
|
vpclimit.max vpcLimit,
|
|
vpccount.count vpcTotal,
|
|
projectlimit.max projectLimit,
|
|
projectcount.count projectTotal,
|
|
networklimit.max networkLimit,
|
|
networkcount.count networkTotal,
|
|
cpulimit.max cpuLimit,
|
|
cpucount.count cpuTotal,
|
|
memorylimit.max memoryLimit,
|
|
memorycount.count memoryTotal,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`free_ip_view`,
|
|
`cloud`.`account`
|
|
inner join
|
|
`cloud`.`domain` ON account.domain_id = domain.id
|
|
left join
|
|
`cloud`.`data_center` ON account.default_zone_id = data_center.id
|
|
left join
|
|
`cloud`.`account_netstats_view` ON account.id = account_netstats_view.account_id
|
|
left join
|
|
`cloud`.`resource_limit` vmlimit ON account.id = vmlimit.account_id
|
|
and vmlimit.type = 'user_vm'
|
|
left join
|
|
`cloud`.`resource_count` vmcount ON account.id = vmcount.account_id
|
|
and vmcount.type = 'user_vm'
|
|
left join
|
|
`cloud`.`account_vmstats_view` runningvm ON account.id = runningvm.account_id
|
|
and runningvm.state = 'Running'
|
|
left join
|
|
`cloud`.`account_vmstats_view` stoppedvm ON account.id = stoppedvm.account_id
|
|
and stoppedvm.state = 'Stopped'
|
|
left join
|
|
`cloud`.`resource_limit` iplimit ON account.id = iplimit.account_id
|
|
and iplimit.type = 'public_ip'
|
|
left join
|
|
`cloud`.`resource_count` ipcount ON account.id = ipcount.account_id
|
|
and ipcount.type = 'public_ip'
|
|
left join
|
|
`cloud`.`resource_limit` volumelimit ON account.id = volumelimit.account_id
|
|
and volumelimit.type = 'volume'
|
|
left join
|
|
`cloud`.`resource_count` volumecount ON account.id = volumecount.account_id
|
|
and volumecount.type = 'volume'
|
|
left join
|
|
`cloud`.`resource_limit` snapshotlimit ON account.id = snapshotlimit.account_id
|
|
and snapshotlimit.type = 'snapshot'
|
|
left join
|
|
`cloud`.`resource_count` snapshotcount ON account.id = snapshotcount.account_id
|
|
and snapshotcount.type = 'snapshot'
|
|
left join
|
|
`cloud`.`resource_limit` templatelimit ON account.id = templatelimit.account_id
|
|
and templatelimit.type = 'template'
|
|
left join
|
|
`cloud`.`resource_count` templatecount ON account.id = templatecount.account_id
|
|
and templatecount.type = 'template'
|
|
left join
|
|
`cloud`.`resource_limit` vpclimit ON account.id = vpclimit.account_id
|
|
and vpclimit.type = 'vpc'
|
|
left join
|
|
`cloud`.`resource_count` vpccount ON account.id = vpccount.account_id
|
|
and vpccount.type = 'vpc'
|
|
left join
|
|
`cloud`.`resource_limit` projectlimit ON account.id = projectlimit.account_id
|
|
and projectlimit.type = 'project'
|
|
left join
|
|
`cloud`.`resource_count` projectcount ON account.id = projectcount.account_id
|
|
and projectcount.type = 'project'
|
|
left join
|
|
`cloud`.`resource_limit` networklimit ON account.id = networklimit.account_id
|
|
and networklimit.type = 'network'
|
|
left join
|
|
`cloud`.`resource_count` networkcount ON account.id = networkcount.account_id
|
|
and networkcount.type = 'network'
|
|
left join
|
|
`cloud`.`resource_limit` cpulimit ON account.id = cpulimit.account_id
|
|
and cpulimit.type = 'cpu'
|
|
left join
|
|
`cloud`.`resource_count` cpucount ON account.id = cpucount.account_id
|
|
and cpucount.type = 'cpu'
|
|
left join
|
|
`cloud`.`resource_limit` memorylimit ON account.id = memorylimit.account_id
|
|
and memorylimit.type = 'memory'
|
|
left join
|
|
`cloud`.`resource_count` memorycount ON account.id = memorycount.account_id
|
|
and memorycount.type = 'memory'
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = account.id
|
|
and async_job.instance_type = 'Account'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`async_job_view`;
|
|
CREATE VIEW `cloud`.`async_job_view` AS
|
|
select
|
|
account.id account_id,
|
|
account.uuid account_uuid,
|
|
account.account_name account_name,
|
|
account.type account_type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path,
|
|
user.id user_id,
|
|
user.uuid user_uuid,
|
|
async_job.id,
|
|
async_job.uuid,
|
|
async_job.job_cmd,
|
|
async_job.job_status,
|
|
async_job.job_process_status,
|
|
async_job.job_result_code,
|
|
async_job.job_result,
|
|
async_job.created,
|
|
async_job.removed,
|
|
async_job.instance_type,
|
|
async_job.instance_id,
|
|
CASE
|
|
WHEN async_job.instance_type = 'Volume' THEN volumes.uuid
|
|
WHEN
|
|
async_job.instance_type = 'Template'
|
|
or async_job.instance_type = 'Iso'
|
|
THEN
|
|
vm_template.uuid
|
|
WHEN
|
|
async_job.instance_type = 'VirtualMachine'
|
|
or async_job.instance_type = 'ConsoleProxy'
|
|
or async_job.instance_type = 'SystemVm'
|
|
or async_job.instance_type = 'DomainRouter'
|
|
THEN
|
|
vm_instance.uuid
|
|
WHEN async_job.instance_type = 'Snapshot' THEN snapshots.uuid
|
|
WHEN async_job.instance_type = 'Host' THEN host.uuid
|
|
WHEN async_job.instance_type = 'StoragePool' THEN storage_pool.uuid
|
|
WHEN async_job.instance_type = 'IpAddress' THEN user_ip_address.uuid
|
|
WHEN async_job.instance_type = 'SecurityGroup' THEN security_group.uuid
|
|
WHEN async_job.instance_type = 'PhysicalNetwork' THEN physical_network.uuid
|
|
WHEN async_job.instance_type = 'TrafficType' THEN physical_network_traffic_types.uuid
|
|
WHEN async_job.instance_type = 'PhysicalNetworkServiceProvider' THEN physical_network_service_providers.uuid
|
|
WHEN async_job.instance_type = 'FirewallRule' THEN firewall_rules.uuid
|
|
WHEN async_job.instance_type = 'Account' THEN acct.uuid
|
|
WHEN async_job.instance_type = 'User' THEN us.uuid
|
|
WHEN async_job.instance_type = 'StaticRoute' THEN static_routes.uuid
|
|
WHEN async_job.instance_type = 'PrivateGateway' THEN vpc_gateways.uuid
|
|
WHEN async_job.instance_type = 'Counter' THEN counter.uuid
|
|
WHEN async_job.instance_type = 'Condition' THEN conditions.uuid
|
|
WHEN async_job.instance_type = 'AutoScalePolicy' THEN autoscale_policies.uuid
|
|
WHEN async_job.instance_type = 'AutoScaleVmProfile' THEN autoscale_vmprofiles.uuid
|
|
WHEN async_job.instance_type = 'AutoScaleVmGroup' THEN autoscale_vmgroups.uuid
|
|
ELSE null
|
|
END instance_uuid
|
|
from
|
|
`cloud`.`async_job`
|
|
left join
|
|
`cloud`.`account` ON async_job.account_id = account.id
|
|
left join
|
|
`cloud`.`domain` ON domain.id = account.domain_id
|
|
left join
|
|
`cloud`.`user` ON async_job.user_id = user.id
|
|
left join
|
|
`cloud`.`volumes` ON async_job.instance_id = volumes.id
|
|
left join
|
|
`cloud`.`vm_template` ON async_job.instance_id = vm_template.id
|
|
left join
|
|
`cloud`.`vm_instance` ON async_job.instance_id = vm_instance.id
|
|
left join
|
|
`cloud`.`snapshots` ON async_job.instance_id = snapshots.id
|
|
left join
|
|
`cloud`.`host` ON async_job.instance_id = host.id
|
|
left join
|
|
`cloud`.`storage_pool` ON async_job.instance_id = storage_pool.id
|
|
left join
|
|
`cloud`.`user_ip_address` ON async_job.instance_id = user_ip_address.id
|
|
left join
|
|
`cloud`.`security_group` ON async_job.instance_id = security_group.id
|
|
left join
|
|
`cloud`.`physical_network` ON async_job.instance_id = physical_network.id
|
|
left join
|
|
`cloud`.`physical_network_traffic_types` ON async_job.instance_id = physical_network_traffic_types.id
|
|
left join
|
|
`cloud`.`physical_network_service_providers` ON async_job.instance_id = physical_network_service_providers.id
|
|
left join
|
|
`cloud`.`firewall_rules` ON async_job.instance_id = firewall_rules.id
|
|
left join
|
|
`cloud`.`account` acct ON async_job.instance_id = acct.id
|
|
left join
|
|
`cloud`.`user` us ON async_job.instance_id = us.id
|
|
left join
|
|
`cloud`.`static_routes` ON async_job.instance_id = static_routes.id
|
|
left join
|
|
`cloud`.`vpc_gateways` ON async_job.instance_id = vpc_gateways.id
|
|
left join
|
|
`cloud`.`counter` ON async_job.instance_id = counter.id
|
|
left join
|
|
`cloud`.`conditions` ON async_job.instance_id = conditions.id
|
|
left join
|
|
`cloud`.`autoscale_policies` ON async_job.instance_id = autoscale_policies.id
|
|
left join
|
|
`cloud`.`autoscale_vmprofiles` ON async_job.instance_id = autoscale_vmprofiles.id
|
|
left join
|
|
`cloud`.`autoscale_vmgroups` ON async_job.instance_id = autoscale_vmgroups.id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`storage_pool_view`;
|
|
CREATE VIEW `cloud`.`storage_pool_view` AS
|
|
select
|
|
storage_pool.id,
|
|
storage_pool.uuid,
|
|
storage_pool.name,
|
|
storage_pool.status,
|
|
storage_pool.path,
|
|
storage_pool.pool_type,
|
|
storage_pool.host_address,
|
|
storage_pool.created,
|
|
storage_pool.removed,
|
|
storage_pool.capacity_bytes,
|
|
cluster.id cluster_id,
|
|
cluster.uuid cluster_uuid,
|
|
cluster.name cluster_name,
|
|
cluster.cluster_type,
|
|
data_center.id data_center_id,
|
|
data_center.uuid data_center_uuid,
|
|
data_center.name data_center_name,
|
|
host_pod_ref.id pod_id,
|
|
host_pod_ref.uuid pod_uuid,
|
|
host_pod_ref.name pod_name,
|
|
storage_pool_details.name tag,
|
|
op_host_capacity.used_capacity disk_used_capacity,
|
|
op_host_capacity.reserved_capacity disk_reserved_capacity,
|
|
async_job.id job_id,
|
|
async_job.uuid job_uuid,
|
|
async_job.job_status job_status,
|
|
async_job.account_id job_account_id
|
|
from
|
|
`cloud`.`storage_pool`
|
|
left join
|
|
`cloud`.`cluster` ON storage_pool.cluster_id = cluster.id
|
|
left join
|
|
`cloud`.`data_center` ON storage_pool.data_center_id = data_center.id
|
|
left join
|
|
`cloud`.`host_pod_ref` ON storage_pool.pod_id = host_pod_ref.id
|
|
left join
|
|
`cloud`.`storage_pool_details` ON storage_pool_details.pool_id = storage_pool.id
|
|
and storage_pool_details.value = 'true'
|
|
left join
|
|
`cloud`.`op_host_capacity` ON storage_pool.id = op_host_capacity.host_id
|
|
and op_host_capacity.capacity_type = 3
|
|
left join
|
|
`cloud`.`async_job` ON async_job.instance_id = storage_pool.id
|
|
and async_job.instance_type = 'StoragePool'
|
|
and async_job.job_status = 0;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`disk_offering_view`;
|
|
CREATE VIEW `cloud`.`disk_offering_view` AS
|
|
select
|
|
disk_offering.id,
|
|
disk_offering.uuid,
|
|
disk_offering.name,
|
|
disk_offering.display_text,
|
|
disk_offering.disk_size,
|
|
disk_offering.created,
|
|
disk_offering.tags,
|
|
disk_offering.customized,
|
|
disk_offering.removed,
|
|
disk_offering.use_local_storage,
|
|
disk_offering.system_use,
|
|
disk_offering.sort_key,
|
|
disk_offering.type,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path
|
|
from
|
|
`cloud`.`disk_offering`
|
|
left join
|
|
`cloud`.`domain` ON disk_offering.domain_id = domain.id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`service_offering_view`;
|
|
CREATE VIEW `cloud`.`service_offering_view` AS
|
|
select
|
|
service_offering.id,
|
|
disk_offering.uuid,
|
|
disk_offering.name,
|
|
disk_offering.display_text,
|
|
disk_offering.created,
|
|
disk_offering.tags,
|
|
disk_offering.removed,
|
|
disk_offering.use_local_storage,
|
|
disk_offering.system_use,
|
|
service_offering.cpu,
|
|
service_offering.speed,
|
|
service_offering.ram_size,
|
|
service_offering.nw_rate,
|
|
service_offering.mc_rate,
|
|
service_offering.ha_enabled,
|
|
service_offering.limit_cpu_use,
|
|
service_offering.host_tag,
|
|
service_offering.default_use,
|
|
service_offering.vm_type,
|
|
service_offering.sort_key,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path
|
|
from
|
|
`cloud`.`service_offering`
|
|
inner join
|
|
`cloud`.`disk_offering` ON service_offering.id = disk_offering.id
|
|
left join
|
|
`cloud`.`domain` ON disk_offering.domain_id = domain.id;
|
|
|
|
DROP VIEW IF EXISTS `cloud`.`data_center_view`;
|
|
CREATE VIEW `cloud`.`data_center_view` AS
|
|
select
|
|
data_center.id,
|
|
data_center.uuid,
|
|
data_center.name,
|
|
data_center.is_security_group_enabled,
|
|
data_center.is_local_storage_enabled,
|
|
data_center.description,
|
|
data_center.dns1,
|
|
data_center.dns2,
|
|
data_center.internal_dns1,
|
|
data_center.internal_dns2,
|
|
data_center.guest_network_cidr,
|
|
data_center.domain,
|
|
data_center.networktype,
|
|
data_center.allocation_state,
|
|
data_center.zone_token,
|
|
data_center.dhcp_provider,
|
|
data_center.removed,
|
|
domain.id domain_id,
|
|
domain.uuid domain_uuid,
|
|
domain.name domain_name,
|
|
domain.path domain_path
|
|
from
|
|
`cloud`.`data_center`
|
|
left join
|
|
`cloud`.`domain` ON data_center.domain_id = domain.id; |