stop.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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 tasks
  15. import (
  16. "context"
  17. "time"
  18. "yunion.io/x/jsonutils"
  19. "yunion.io/x/log"
  20. "yunion.io/x/pkg/errors"
  21. "yunion.io/x/onecloud/pkg/cloudcommon/types"
  22. "yunion.io/x/onecloud/pkg/mcclient"
  23. )
  24. type SBaremetalServerStopTask struct {
  25. SBaremetalTaskBase
  26. startTime time.Time
  27. }
  28. func NewBaremetalServerStopTask(
  29. userCred mcclient.TokenCredential,
  30. baremetal IBaremetal,
  31. taskId string,
  32. data jsonutils.JSONObject,
  33. ) ITask {
  34. task := &SBaremetalServerStopTask{
  35. SBaremetalTaskBase: newBaremetalTaskBase(userCred, baremetal, taskId, data),
  36. }
  37. task.SetVirtualObject(task)
  38. task.SetStage(task.DoStop)
  39. return task
  40. }
  41. func (task *SBaremetalServerStopTask) DoStop(ctx context.Context, args interface{}) error {
  42. if task.Baremetal.HasBMC() {
  43. task.SetStage(task.WaitForStop)
  44. if err := task.Baremetal.DoPowerShutdown(true); err != nil {
  45. log.Errorf("Do power shutdown error: %s", err)
  46. }
  47. } else {
  48. if err := task.Baremetal.SSHShutdown(); err != nil {
  49. return errors.Wrap(err, "Try ssh shutdown")
  50. }
  51. task.SetStage(task.OnStopComplete)
  52. }
  53. task.startTime = time.Now()
  54. ExecuteTask(task, nil)
  55. return nil
  56. }
  57. func (self *SBaremetalServerStopTask) GetName() string {
  58. return "BaremetalServerStopTask"
  59. }
  60. func (self *SBaremetalServerStopTask) WaitForStop(ctx context.Context, args interface{}) error {
  61. status, err := self.Baremetal.GetPowerStatus()
  62. if err != nil {
  63. return errors.Wrap(err, "GetPowerStatus")
  64. }
  65. if status == types.POWER_STATUS_OFF {
  66. self.SetStage(self.OnStopComplete)
  67. ExecuteTask(self, nil)
  68. return nil
  69. }
  70. isSoft := true
  71. if time.Since(self.startTime) >= 90*time.Second {
  72. isSoft = false
  73. }
  74. if err := self.Baremetal.DoPowerShutdown(isSoft); err != nil {
  75. log.Errorf("DoPowerShutdown soft=%v error: %s", isSoft, err)
  76. }
  77. time.Sleep(10 * time.Second)
  78. ExecuteTask(self, nil)
  79. return nil
  80. }
  81. func (self *SBaremetalServerStopTask) OnStopComplete(ctx context.Context, args interface{}) error {
  82. SetTaskComplete(self, nil)
  83. return nil
  84. }