mirror of
https://github.com/yunionio/cloudpods.git
synced 2026-06-23 22:48:06 +08:00
85 lines
2.9 KiB
Go
85 lines
2.9 KiB
Go
// Copyright 2019 Yunion
|
|
//
|
|
// 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.
|
|
|
|
package models
|
|
|
|
import (
|
|
"yunion.io/x/pkg/utils"
|
|
"yunion.io/x/sqlchemy"
|
|
|
|
api "yunion.io/x/onecloud/pkg/apis/compute"
|
|
"yunion.io/x/onecloud/pkg/cloudcommon/db"
|
|
)
|
|
|
|
func AttachUsageQuery(
|
|
q *sqlchemy.SQuery,
|
|
hosts *sqlchemy.SSubQuery,
|
|
hostTypes []string,
|
|
resourceTypes []string,
|
|
providers []string, brands []string, cloudEnv string,
|
|
rangeObj db.IStandaloneModel,
|
|
) *sqlchemy.SQuery {
|
|
if len(hostTypes) > 0 {
|
|
q = q.Filter(sqlchemy.In(hosts.Field("host_type"), hostTypes))
|
|
}
|
|
if len(resourceTypes) > 0 {
|
|
if utils.IsInStringArray(api.HostResourceTypeShared, resourceTypes) {
|
|
q = q.Filter(sqlchemy.OR(
|
|
sqlchemy.IsNullOrEmpty(hosts.Field("resource_type")),
|
|
sqlchemy.In(hosts.Field("resource_type"), resourceTypes),
|
|
))
|
|
} else {
|
|
q = q.Filter(sqlchemy.In(hosts.Field("resource_type"), resourceTypes))
|
|
}
|
|
}
|
|
|
|
q = CloudProviderFilter(q, hosts.Field("manager_id"), providers, brands, cloudEnv)
|
|
|
|
if rangeObj == nil {
|
|
return q
|
|
}
|
|
//rangeObjId := rangeObj.GetId()
|
|
kw := rangeObj.Keyword()
|
|
// log.Debugf("rangeObj keyword: %s", kw)
|
|
switch kw {
|
|
case "zone":
|
|
zone := rangeObj.(*SZone)
|
|
q = q.Filter(sqlchemy.Equals(hosts.Field("zone_id"), zone.Id))
|
|
case "wire":
|
|
wire := rangeObj.(*SWire)
|
|
hostWires := HostwireManager.Query().SubQuery()
|
|
subq := hostWires.Query(hostWires.Field("host_id")).Equals("wire_id", wire.Id).SubQuery()
|
|
q = q.Filter(sqlchemy.In(hosts.Field("id"), subq))
|
|
case "host":
|
|
q = q.Filter(sqlchemy.Equals(hosts.Field("id"), rangeObj.GetId()))
|
|
case "cloudprovider":
|
|
q = q.Filter(sqlchemy.Equals(hosts.Field("manager_id"), rangeObj.GetId()))
|
|
case "cloudaccount":
|
|
cloudproviders := CloudproviderManager.Query().SubQuery()
|
|
subq := cloudproviders.Query(cloudproviders.Field("id")).Equals("cloudaccount_id", rangeObj.GetId()).SubQuery()
|
|
q = q.Filter(sqlchemy.In(hosts.Field("manager_id"), subq))
|
|
case "schedtag":
|
|
aggHosts := HostschedtagManager.Query().SubQuery()
|
|
q = q.Join(aggHosts, sqlchemy.AND(
|
|
sqlchemy.Equals(hosts.Field("id"), aggHosts.Field("host_id")),
|
|
sqlchemy.IsFalse(aggHosts.Field("deleted")))).
|
|
Filter(sqlchemy.Equals(aggHosts.Field("schedtag_id"), rangeObj.GetId()))
|
|
case "cloudregion":
|
|
zones := ZoneManager.Query().SubQuery()
|
|
q = q.Join(zones, sqlchemy.Equals(hosts.Field("zone_id"), zones.Field("id")))
|
|
q = q.Filter(sqlchemy.Equals(zones.Field("cloudregion_id"), rangeObj.GetId()))
|
|
}
|
|
return q
|
|
}
|