guest_insert_iso_task.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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 guest
  15. import (
  16. "context"
  17. "yunion.io/x/jsonutils"
  18. "yunion.io/x/pkg/errors"
  19. api "yunion.io/x/onecloud/pkg/apis/compute"
  20. "yunion.io/x/onecloud/pkg/cloudcommon/db"
  21. "yunion.io/x/onecloud/pkg/cloudcommon/db/taskman"
  22. "yunion.io/x/onecloud/pkg/compute/models"
  23. "yunion.io/x/onecloud/pkg/util/logclient"
  24. )
  25. type GuestInsertIsoTask struct {
  26. SGuestBaseTask
  27. }
  28. func init() {
  29. taskman.RegisterTask(GuestInsertIsoTask{})
  30. taskman.RegisterTask(HaGuestInsertIsoTask{})
  31. }
  32. func (self *GuestInsertIsoTask) OnInit(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  33. self.prepareIsoImage(ctx, obj)
  34. }
  35. func (self *GuestInsertIsoTask) prepareIsoImage(ctx context.Context, obj db.IStandaloneModel) {
  36. guest := obj.(*models.SGuest)
  37. imageId, _ := self.Params.GetString("image_id")
  38. cdromOrdinal, _ := self.Params.Int("cdrom_ordinal")
  39. db.OpsLog.LogEvent(obj, db.ACT_ISO_PREPARING, imageId, self.UserCred)
  40. disks, _ := guest.GetGuestDisks()
  41. disk := disks[0].GetDisk()
  42. storage, _ := disk.GetStorage()
  43. storageCache := storage.GetStoragecache()
  44. if storageCache != nil {
  45. self.SetStage("OnIsoPrepareComplete", nil)
  46. input := api.CacheImageInput{
  47. ImageId: imageId,
  48. Format: "iso",
  49. ParentTaskId: self.GetTaskId(),
  50. ServerId: guest.Id,
  51. }
  52. storageCache.StartImageCacheTask(ctx, self.UserCred, input)
  53. } else {
  54. guest.EjectIso(cdromOrdinal, self.UserCred)
  55. db.OpsLog.LogEvent(obj, db.ACT_ISO_PREPARE_FAIL, imageId, self.UserCred)
  56. logclient.AddActionLogWithContext(ctx, guest, logclient.ACT_ISO_ATTACH, nil, self.UserCred, false)
  57. self.SetStageFailed(ctx, jsonutils.NewString("host no local storage cache"))
  58. }
  59. }
  60. func (self *GuestInsertIsoTask) OnIsoPrepareCompleteFailed(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  61. imageId, _ := self.Params.GetString("image_id")
  62. cdromOrdinal, _ := self.Params.Int("cdrom_ordinal")
  63. db.OpsLog.LogEvent(obj, db.ACT_ISO_PREPARE_FAIL, imageId, self.UserCred)
  64. guest := obj.(*models.SGuest)
  65. guest.EjectIso(cdromOrdinal, self.UserCred)
  66. logclient.AddActionLogWithContext(ctx, guest, logclient.ACT_ISO_ATTACH, nil, self.UserCred, false)
  67. self.SetStageFailed(ctx, data)
  68. }
  69. func (self *GuestInsertIsoTask) OnIsoPrepareComplete(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  70. imageId, _ := data.GetString("image_id")
  71. cdromOrdinal, _ := self.Params.Int("cdrom_ordinal")
  72. size, err := data.Int("size")
  73. if err != nil {
  74. self.SetStageFailed(ctx, jsonutils.NewString(errors.Wrapf(err, "get image size").Error()))
  75. return
  76. }
  77. name, _ := data.GetString("name")
  78. path, _ := data.GetString("path")
  79. var bootIndex *int8
  80. if self.Params.Contains("boot_index") {
  81. bd, _ := self.Params.Int("boot_index")
  82. bd8 := int8(bd)
  83. bootIndex = &bd8
  84. }
  85. guest := obj.(*models.SGuest)
  86. if cdrom, ok := guest.InsertIsoSucc(cdromOrdinal, imageId, path, size, name, bootIndex); ok {
  87. db.OpsLog.LogEvent(guest, db.ACT_ISO_ATTACH, cdrom.GetDetails(), self.UserCred)
  88. logclient.AddActionLogWithContext(ctx, guest, logclient.ACT_ISO_ATTACH, cdrom.GetDetails(), self.UserCred, true)
  89. drv, err := guest.GetDriver()
  90. if err != nil {
  91. self.OnIsoPrepareCompleteFailed(ctx, guest, jsonutils.NewString(err.Error()))
  92. return
  93. }
  94. if drv.NeedRequestGuestHotAddIso(ctx, guest) {
  95. self.SetStage("OnConfigSyncComplete", nil)
  96. boot := jsonutils.QueryBoolean(self.Params, "boot", false)
  97. drv.RequestGuestHotAddIso(ctx, guest, path, boot, self)
  98. } else {
  99. self.SetStageComplete(ctx, nil)
  100. }
  101. } else {
  102. self.SetStageComplete(ctx, nil)
  103. }
  104. }
  105. func (self *GuestInsertIsoTask) OnConfigSyncComplete(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  106. self.SetStageComplete(ctx, nil)
  107. }
  108. type HaGuestInsertIsoTask struct {
  109. GuestInsertIsoTask
  110. }
  111. func (self *HaGuestInsertIsoTask) OnInit(ctx context.Context, obj db.IStandaloneModel, data jsonutils.JSONObject) {
  112. self.prepareIsoImage(ctx, obj)
  113. }
  114. func (self *HaGuestInsertIsoTask) prepareIsoImage(ctx context.Context, obj db.IStandaloneModel) {
  115. guest := obj.(*models.SGuest)
  116. imageId, _ := self.Params.GetString("image_id")
  117. cdromOrdinal, _ := self.Params.Int("cdrom_ordinal")
  118. db.OpsLog.LogEvent(obj, db.ACT_ISO_PREPARING, imageId, self.UserCred)
  119. disks, _ := guest.GetGuestDisks()
  120. disk := disks[0].GetDisk()
  121. storage := disk.GetBackupStorage()
  122. storageCache := storage.GetStoragecache()
  123. if storageCache != nil {
  124. self.SetStage("OnBackupIsoPrepareComplete", nil)
  125. input := api.CacheImageInput{
  126. ImageId: imageId,
  127. Format: "iso",
  128. ParentTaskId: self.GetTaskId(),
  129. }
  130. storageCache.StartImageCacheTask(ctx, self.UserCred, input)
  131. } else {
  132. guest.EjectIso(cdromOrdinal, self.UserCred)
  133. db.OpsLog.LogEvent(obj, db.ACT_ISO_PREPARE_FAIL, imageId, self.UserCred)
  134. self.SetStageFailed(ctx, jsonutils.NewString("host no local storage cache"))
  135. }
  136. }
  137. func (self *HaGuestInsertIsoTask) OnBackupIsoPrepareComplete(
  138. ctx context.Context, guest *models.SGuest, data jsonutils.JSONObject,
  139. ) {
  140. self.GuestInsertIsoTask.prepareIsoImage(ctx, guest)
  141. }
  142. func (self *HaGuestInsertIsoTask) OnBackupIsoPrepareCompleteFailed(
  143. ctx context.Context, guest *models.SGuest, data jsonutils.JSONObject,
  144. ) {
  145. self.OnIsoPrepareCompleteFailed(ctx, guest, data)
  146. }