mirror of
https://github.com/yunionio/cloudpods.git
synced 2026-05-13 01:17:42 +08:00
187 lines
5.6 KiB
Go
187 lines
5.6 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 (
|
|
"context"
|
|
"time"
|
|
|
|
"yunion.io/x/jsonutils"
|
|
"yunion.io/x/log"
|
|
"yunion.io/x/pkg/errors"
|
|
"yunion.io/x/sqlchemy"
|
|
|
|
api "yunion.io/x/onecloud/pkg/apis/cloudevent"
|
|
"yunion.io/x/onecloud/pkg/cloudcommon/db"
|
|
"yunion.io/x/onecloud/pkg/cloudprovider"
|
|
"yunion.io/x/onecloud/pkg/mcclient"
|
|
)
|
|
|
|
type SCloudeventManager struct {
|
|
db.SModelBaseManager
|
|
}
|
|
|
|
var CloudeventManager *SCloudeventManager
|
|
|
|
func init() {
|
|
CloudeventManager = &SCloudeventManager{
|
|
SModelBaseManager: db.NewModelBaseManager(
|
|
SCloudevent{},
|
|
"cloudevents_tbl",
|
|
"cloudevent",
|
|
"cloudevents",
|
|
),
|
|
}
|
|
CloudeventManager.SetVirtualObject(CloudeventManager)
|
|
}
|
|
|
|
type SCloudevent struct {
|
|
db.SModelBase
|
|
|
|
EventId int64 `primary:"true" auto_increment:"true" list:"user"`
|
|
Name string `width:"128" charset:"utf8" nullable:"false" index:"true" list:"user"`
|
|
Service string `width:"64" charset:"utf8" nullable:"true" list:"user"`
|
|
ResourceType string `width:"64" charset:"utf8" nullable:"true" list:"user"`
|
|
Action string `width:"64" charset:"utf8" nullable:"true" list:"user"`
|
|
RequestId string `width:"128" charset:"utf8" nullable:"true" list:"user"`
|
|
Request jsonutils.JSONObject `charset:"utf8" nullable:"true" list:"user"`
|
|
Account string `width:"64" charset:"utf8" nullable:"true" list:"user"`
|
|
Success bool `nullable:"false" list:"user"`
|
|
CreatedAt time.Time `nullable:"false" created_at:"true" index:"true" get:"user" list:"user"`
|
|
|
|
CloudproviderId string `width:"64" charset:"utf8" nullable:"true" list:"user"`
|
|
Manager string `width:"128" charset:"utf8" nullable:"false" index:"true" list:"user"`
|
|
Provider string `width:"64" charset:"ascii" nullable:"false" list:"user"`
|
|
Brand string `width:"64" charset:"ascii" list:"domain"`
|
|
}
|
|
|
|
func (self *SCloudeventManager) AllowCreateItem(ctx context.Context, userCred mcclient.TokenCredential, query jsonutils.JSONObject, data jsonutils.JSONObject) bool {
|
|
return false
|
|
}
|
|
|
|
func (self *SCloudevent) AllowDeleteItem(ctx context.Context, userCred mcclient.TokenCredential, query jsonutils.JSONObject, data jsonutils.JSONObject) bool {
|
|
return false
|
|
}
|
|
|
|
func (self *SCloudevent) AllowUpdateItem(ctx context.Context, userCred mcclient.TokenCredential) bool {
|
|
return false
|
|
}
|
|
|
|
// 云平台操作日志列表
|
|
func (manager *SCloudeventManager) ListItemFilter(
|
|
ctx context.Context,
|
|
q *sqlchemy.SQuery,
|
|
userCred mcclient.TokenCredential,
|
|
input api.CloudeventListInput,
|
|
) (*sqlchemy.SQuery, error) {
|
|
q, err := manager.SModelBaseManager.ListItemFilter(ctx, q, userCred, input.ModelBaseListInput)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "SVirtualResourceBaseManager.ListItemFilter")
|
|
}
|
|
|
|
if len(input.Providers) > 0 {
|
|
q = q.In("provider", input.Providers)
|
|
}
|
|
|
|
if len(input.Brands) > 0 {
|
|
q = q.In("brand", input.Brands)
|
|
}
|
|
|
|
if len(input.Service) > 0 {
|
|
q = q.In("service", input.Service)
|
|
}
|
|
|
|
if len(input.Manager) > 0 {
|
|
q = q.In("manager", input.Manager)
|
|
}
|
|
|
|
if len(input.Account) > 0 {
|
|
q = q.In("account", input.Account)
|
|
}
|
|
|
|
if len(input.Action) > 0 {
|
|
q = q.In("action", input.Action)
|
|
}
|
|
|
|
if !input.Since.IsZero() {
|
|
q = q.GT("created_at", input.Since)
|
|
}
|
|
if !input.Until.IsZero() {
|
|
q = q.LE("created_at", input.Until)
|
|
}
|
|
|
|
return q, nil
|
|
}
|
|
|
|
func (manager *SCloudeventManager) SyncCloudevent(ctx context.Context, userCred mcclient.TokenCredential, cloudprovider *SCloudprovider, iEvents []cloudprovider.ICloudEvent) int {
|
|
count := 0
|
|
for _, iEvent := range iEvents {
|
|
event := &SCloudevent{
|
|
Name: iEvent.GetName(),
|
|
Service: iEvent.GetService(),
|
|
ResourceType: iEvent.GetResourceType(),
|
|
Action: iEvent.GetAction(),
|
|
Account: iEvent.GetAccount(),
|
|
RequestId: iEvent.GetRequestId(),
|
|
Request: iEvent.GetRequest(),
|
|
Success: iEvent.IsSuccess(),
|
|
Manager: cloudprovider.Name,
|
|
Provider: cloudprovider.Provider,
|
|
Brand: cloudprovider.Brand,
|
|
CloudproviderId: cloudprovider.Id,
|
|
}
|
|
if len(event.Brand) == 0 {
|
|
event.Brand = event.Provider
|
|
}
|
|
|
|
event.CreatedAt = iEvent.GetCreatedAt()
|
|
event.SetModelManager(manager, event)
|
|
err := manager.TableSpec().Insert(event)
|
|
if err != nil {
|
|
log.Errorf("failed to insert event: %s for cloudprovider: %s(%s) error: %v", jsonutils.Marshal(event).PrettyString(), cloudprovider.Name, cloudprovider.Id, err)
|
|
continue
|
|
}
|
|
count += 1
|
|
}
|
|
return count
|
|
}
|
|
|
|
func (manager *SCloudeventManager) GetPagingConfig() *db.SPagingConfig {
|
|
return &db.SPagingConfig{
|
|
Order: sqlchemy.SQL_ORDER_DESC,
|
|
MarkerFields: []string{"created_at", "event_id"},
|
|
DefaultLimit: 20,
|
|
}
|
|
}
|
|
|
|
func (manager *SCloudeventManager) InitializeData() error {
|
|
events := []SCloudevent{}
|
|
q := manager.Query().IsNullOrEmpty("brand")
|
|
err := db.FetchModelObjects(manager, q, &events)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
for i := range events {
|
|
_, err = db.Update(&events[i], func() error {
|
|
events[i].Brand = events[i].Provider
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|