Files
cloudpods/pkg/cloudid/tasks/cloudgroup_sync_users_task.go
2020-06-21 11:30:01 +08:00

140 lines
4.3 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 tasks
import (
"context"
"yunion.io/x/jsonutils"
"yunion.io/x/log"
"yunion.io/x/pkg/errors"
api "yunion.io/x/onecloud/pkg/apis/cloudid"
"yunion.io/x/onecloud/pkg/cloudcommon/db"
"yunion.io/x/onecloud/pkg/cloudcommon/db/taskman"
"yunion.io/x/onecloud/pkg/cloudid/models"
"yunion.io/x/onecloud/pkg/util/logclient"
)
type CloudgroupSyncUsersTask struct {
taskman.STask
}
func init() {
taskman.RegisterTask(CloudgroupSyncUsersTask{})
}
func (self *CloudgroupSyncUsersTask) taskFailed(ctx context.Context, group *models.SCloudgroup, err error) {
group.SetStatus(self.GetUserCred(), api.CLOUD_GROUP_STATUS_SYNC_POLICIES, err.Error())
logclient.AddActionLogWithStartable(self, group, logclient.ACT_SYNC_POLICIES, err, self.UserCred, false)
self.SetStageFailed(ctx, err.Error())
}
func (self *CloudgroupSyncUsersTask) OnInit(ctx context.Context, obj db.IStandaloneModel, body jsonutils.JSONObject) {
group := obj.(*models.SCloudgroup)
factory, err := group.GetProviderFactory()
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "GetProviderFactory"))
return
}
users, err := group.GetCloudusers()
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "GetCloudusers"))
return
}
if !factory.IsSupportCreateCloudgroup() && factory.IsSupportClouduserPolicy() {
for i := range users {
result, err := users[i].SyncCloudpoliciesForCloud(ctx)
if err != nil {
logclient.AddActionLogWithStartable(self, &users[i], logclient.ACT_SYNC_POLICIES, err, self.UserCred, false)
continue
}
log.Infof("Sync cloudpolicies for user %s(%s) result: %s", users[i].Name, users[i].Id, result.Result())
if result.AddErrCnt+result.DelErrCnt > 0 {
self.taskFailed(ctx, group, result.AllError())
return
}
}
} else {
caches, err := group.GetCloudgroupcaches()
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "GetCloudgroupcaches"))
return
}
accounts := map[string]string{}
for i := range caches {
account, err := caches[i].GetCloudaccount()
if err != nil {
log.Errorf("failed to get cloudaccoutn for cache %s(%s) error: %v", caches[i].Name, caches[i].Id, err)
continue
}
accounts[account.Id] = account.Name
result, err := caches[i].SyncCloudusersForCloud(ctx)
if err != nil {
logclient.AddActionLogWithStartable(self, &caches[i], logclient.ACT_SYNC_POLICIES, err, self.UserCred, false)
continue
}
log.Infof("Sync cloudpolicies for group cache %s(%s) result: %s", caches[i].Name, caches[i].Id, result.Result())
if result.AddErrCnt+result.DelErrCnt > 0 {
self.taskFailed(ctx, group, result.AllError())
return
}
}
for _, user := range users {
if _, ok := accounts[user.CloudaccountId]; !ok {
account, err := user.GetCloudaccount()
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "GetCloudaccount"))
return
}
cache, err := models.CloudgroupcacheManager.Register(group, account)
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "CloudgroupcacheManager.Register"))
return
}
_, err = cache.GetOrCreateICloudgroup(ctx, self.GetUserCred())
if err != nil {
self.taskFailed(ctx, group, errors.Wrap(err, "GetOrCreateICloudgroup"))
return
}
result, err := cache.SyncCloudusersForCloud(ctx)
if err != nil {
logclient.AddActionLogWithStartable(self, cache, logclient.ACT_SYNC_POLICIES, err, self.UserCred, false)
continue
}
log.Infof("Sync cloudpolicies for group cache %s(%s) result: %s", cache.Name, cache.Id, result.Result())
if result.AddErrCnt+result.DelErrCnt > 0 {
self.taskFailed(ctx, group, result.AllError())
return
}
}
}
}
group.SetStatus(self.GetUserCred(), api.CLOUD_GROUP_STATUS_AVAILABLE, "")
self.SetStageComplete(ctx, nil)
}