// 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" "time" "yunion.io/x/jsonutils" "yunion.io/x/log" "yunion.io/x/onecloud/pkg/mcclient" "yunion.io/x/onecloud/pkg/util/ssh" ) var _ IServerBaseDeployTask = new(SBaremetalServerCreateTask) type SBaremetalServerCreateTask struct { SBaremetalServerBaseDeployTask } func NewBaremetalServerCreateTask( userCred mcclient.TokenCredential, baremetal IBaremetal, taskId string, data jsonutils.JSONObject, ) ITask { task := &SBaremetalServerCreateTask{ SBaremetalServerBaseDeployTask: newBaremetalServerBaseDeployTask(userCred, baremetal, taskId, data), } task.SetVirtualObject(task) task.SetStage(task.InitPXEBootTask) return task } func (self *SBaremetalServerCreateTask) GetName() string { return "BaremetalServerCreateTask" } func (self *SBaremetalServerCreateTask) RemoveEFIOSEntry() bool { return true } func (self *SBaremetalServerCreateTask) DoDeploys(ctx context.Context, term *ssh.Client) (jsonutils.JSONObject, error) { if err := self.Baremetal.GetServer().DoEraseDisk(term); err != nil { return nil, self.onError(ctx, term, err) } time.Sleep(2 * time.Second) // Build raid tool, err := self.Baremetal.GetServer().DoDiskConfig(term) if err != nil { return nil, self.onError(ctx, term, err) } time.Sleep(2 * time.Second) rootDisk, parts, err := self.Baremetal.GetServer().DoPartitionDisk(tool, term, self.IsDisableImageCache()) if err != nil { return nil, self.onError(ctx, term, err) } data := jsonutils.NewDict() disks, err := self.Baremetal.GetServer().SyncPartitionSize(term, rootDisk, parts) if err != nil { return nil, self.onError(ctx, term, err) } data.Add(jsonutils.Marshal(disks), "disks") rootImageId := self.Baremetal.GetServer().GetRootTemplateId() if len(rootImageId) > 0 { deployInfo, err := self.Baremetal.GetServer().DoDeploy(tool, term, self.data, true) if err != nil { return nil, self.onError(ctx, term, err) } if deployInfo != nil { data.Update(deployInfo) } } return data, nil } func doPoweroff(term *ssh.Client) error { if _, err := term.Run("/sbin/poweroff"); err != nil { log.Errorf("poweroff error: %s", err) return nil } time.Sleep(2 * time.Second) return nil } func (self *SBaremetalServerCreateTask) PostDeploys(ctx context.Context, term *ssh.Client) error { if self.Baremetal.HasBMC() { return doPoweroff(term) } return nil } func (self *SBaremetalServerCreateTask) onError(ctx context.Context, term *ssh.Client, err error) error { log.Errorf("Create server error: %+v", err) if err1 := self.Baremetal.GetServer().DoEraseDisk(term); err1 != nil { log.Warningf("EraseDisk error: %v", err1) } self.Baremetal.AutoSyncStatus(ctx) return err }