instance_backup_unpack_task.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. // Copyright 2019 Yunion
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package backup
  15. import (
  16. "context"
  17. "yunion.io/x/jsonutils"
  18. "yunion.io/x/onecloud/pkg/apis/compute"
  19. "yunion.io/x/onecloud/pkg/cloudcommon/db"
  20. "yunion.io/x/onecloud/pkg/cloudcommon/db/taskman"
  21. "yunion.io/x/onecloud/pkg/compute/models"
  22. "yunion.io/x/onecloud/pkg/util/logclient"
  23. )
  24. type InstanceBackupUnpackTask struct {
  25. taskman.STask
  26. }
  27. func init() {
  28. taskman.RegisterTask(InstanceBackupUnpackTask{})
  29. }
  30. func (self *InstanceBackupUnpackTask) taskFailed(ctx context.Context, ib *models.SInstanceBackup, reason jsonutils.JSONObject) {
  31. reasonStr, _ := reason.GetString()
  32. ib.SetStatus(ctx, self.UserCred, compute.INSTANCE_BACKUP_STATUS_CREATE_FROM_PACKAGE_FAILED, reasonStr)
  33. logclient.AddActionLogWithStartable(self, ib, logclient.ACT_UNPACK, reason, self.UserCred, false)
  34. db.OpsLog.LogEvent(ib, db.ACT_UNPACK_FAIL, ib.GetShortDesc(ctx), self.GetUserCred())
  35. self.SetStageFailed(ctx, reason)
  36. }
  37. func (self *InstanceBackupUnpackTask) taskSuccess(ctx context.Context, ib *models.SInstanceBackup) {
  38. ib.SetStatus(ctx, self.UserCred, compute.INSTANCE_BACKUP_STATUS_READY, "")
  39. logclient.AddActionLogWithStartable(self, ib, logclient.ACT_UNPACK, nil, self.UserCred, true)
  40. db.OpsLog.LogEvent(ib, db.ACT_UNPACK, ib.GetShortDesc(ctx), self.GetUserCred())
  41. self.SetStageComplete(ctx, nil)
  42. }
  43. func (self *InstanceBackupUnpackTask) OnInit(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  44. ib := obj.(*models.SInstanceBackup)
  45. ib.SetStatus(ctx, self.UserCred, compute.INSTANCE_BACKUP_STATUS_CREATING_FROM_PACKAGE, "")
  46. packageName, _ := self.GetParams().GetString("package_name")
  47. // fetch metadata first
  48. self.SetStage("OnUnpackMetadata", nil)
  49. err := ib.GetRegionDriver().RequestUnpackInstanceBackup(ctx, ib, self, packageName, true)
  50. if err != nil {
  51. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  52. return
  53. }
  54. }
  55. func (self *InstanceBackupUnpackTask) OnUnpackMetadata(ctx context.Context, ib *models.SInstanceBackup, data jsonutils.JSONObject) {
  56. metadata := &compute.InstanceBackupPackMetadata{}
  57. err := data.Unmarshal(metadata, "metadata")
  58. if err != nil {
  59. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  60. return
  61. }
  62. _, err = ib.FillFromPackMetadata(ctx, self.GetUserCred(), nil, metadata)
  63. if err != nil {
  64. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  65. return
  66. }
  67. packageName, _ := self.GetParams().GetString("package_name")
  68. // fetch full backup info, including disks
  69. self.SetStage("OnUnpackComplete", nil)
  70. err = ib.GetRegionDriver().RequestUnpackInstanceBackup(ctx, ib, self, packageName, false)
  71. if err != nil {
  72. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  73. return
  74. }
  75. }
  76. func (self *InstanceBackupUnpackTask) OnUnpackMetadataFailed(ctx context.Context, ib *models.SInstanceBackup, data jsonutils.JSONObject) {
  77. self.taskFailed(ctx, ib, data)
  78. }
  79. func (self *InstanceBackupUnpackTask) OnUnpackComplete(ctx context.Context, ib *models.SInstanceBackup, data jsonutils.JSONObject) {
  80. diskBackupIds := make([]string, 0)
  81. err := data.Unmarshal(&diskBackupIds, "disk_backup_ids")
  82. if err != nil {
  83. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  84. return
  85. }
  86. metadata := &compute.InstanceBackupPackMetadata{}
  87. err = data.Unmarshal(metadata, "metadata")
  88. if err != nil {
  89. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  90. return
  91. }
  92. _, err = ib.FillFromPackMetadata(ctx, self.GetUserCred(), diskBackupIds, metadata)
  93. if err != nil {
  94. self.taskFailed(ctx, ib, jsonutils.NewString(err.Error()))
  95. return
  96. }
  97. self.taskSuccess(ctx, ib)
  98. }
  99. func (self *InstanceBackupUnpackTask) OnUnpackCompleteFailed(ctx context.Context, ib *models.SInstanceBackup, data jsonutils.JSONObject) {
  100. self.taskFailed(ctx, ib, data)
  101. }