Files
cloudpods/pkg/compute/tasks/dbinstance_database_create_task.go
2019-11-01 10:42:12 +08:00

92 lines
3.0 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/compute"
"yunion.io/x/onecloud/pkg/cloudcommon/db"
"yunion.io/x/onecloud/pkg/cloudcommon/db/taskman"
"yunion.io/x/onecloud/pkg/cloudprovider"
"yunion.io/x/onecloud/pkg/compute/models"
"yunion.io/x/onecloud/pkg/util/logclient"
)
type DBInstanceDatabaseCreateTask struct {
taskman.STask
}
func init() {
taskman.RegisterTask(DBInstanceDatabaseCreateTask{})
}
func (self *DBInstanceDatabaseCreateTask) taskFailed(ctx context.Context, database *models.SDBInstanceDatabase, err error) {
database.SetStatus(self.UserCred, api.DBINSTANCE_DATABASE_CREATE_FAILE, err.Error())
db.OpsLog.LogEvent(database, db.ACT_CREATE, err.Error(), self.GetUserCred())
logclient.AddActionLogWithStartable(self, database, logclient.ACT_CREATE, err.Error(), self.UserCred, false)
self.SetStageFailed(ctx, err.Error())
}
func (self *DBInstanceDatabaseCreateTask) OnInit(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
database := obj.(*models.SDBInstanceDatabase)
self.CreateDBInstanceDatabase(ctx, database)
}
func (self *DBInstanceDatabaseCreateTask) CreateDBInstanceDatabase(ctx context.Context, database *models.SDBInstanceDatabase) {
instance, err := database.GetDBInstance()
if err != nil {
self.taskFailed(ctx, database, errors.Wrap(err, "database.GetDBInstance"))
return
}
iRds, err := instance.GetIDBInstance()
if err != nil {
self.taskFailed(ctx, database, errors.Wrap(err, "instance.GetIDBInstance"))
return
}
desc := &cloudprovider.SDBInstanceDatabaseCreateConfig{
CharacterSet: database.CharacterSet,
Name: database.Name,
Description: database.Description,
}
err = iRds.CreateDatabase(desc)
if err != nil {
self.taskFailed(ctx, database, errors.Wrap(err, "iRds.CreateDatabase"))
return
}
database.SetStatus(self.UserCred, api.DBINSTANCE_DATABASE_RUNNING, "")
input := api.SDBInstanceDatabaseCreateInput{}
self.GetParams().Unmarshal(&input)
for _, _account := range input.Accounts {
account, err := instance.GetDBInstanceAccount(_account.DBInstancedccountId)
if err != nil {
log.Errorf("failed to found account %s(%s) for instance %s(%s) error: %v", _account.Account, _account.DBInstancedccountId, instance.Name, instance.Id, err)
} else {
account.StartGrantPrivilegeTask(ctx, self.UserCred, database.Name, _account.Privilege, "")
}
}
self.SetStageComplete(ctx, nil)
}