package common import ( "fmt" "log" "github.com/mitchellh/multistep" "github.com/mitchellh/packer/packer" xsclient "github.com/terra-farm/go-xen-api-client" ) type StepAttachVdi struct { VdiUuidKey string VdiType xsclient.VbdType vdi xsclient.VDIRef } func (self *StepAttachVdi) Run(state multistep.StateBag) multistep.StepAction { ui := state.Get("ui").(packer.Ui) c := state.Get("client").(*Connection) log.Printf("Running attach vdi for key %s\n", self.VdiUuidKey) var vdiUuid string if vdiUuidRaw, ok := state.GetOk(self.VdiUuidKey); ok { vdiUuid = vdiUuidRaw.(string) } else { log.Printf("Skipping attach of '%s'", self.VdiUuidKey) return multistep.ActionContinue } var err error self.vdi, err = c.client.VDI.GetByUUID(c.session, vdiUuid) if err != nil { ui.Error(fmt.Sprintf("Unable to get VDI from UUID '%s': %s", vdiUuid, err.Error())) return multistep.ActionHalt } uuid := state.Get("instance_uuid").(string) instance, err := c.client.VM.GetByUUID(c.session, uuid) if err != nil { ui.Error(fmt.Sprintf("Unable to get VM from UUID '%s': %s", uuid, err.Error())) return multistep.ActionHalt } err = ConnectVdi(c, instance, self.vdi, self.VdiType) if err != nil { ui.Error(fmt.Sprintf("Error attaching VDI '%s': '%s'", vdiUuid, err.Error())) return multistep.ActionHalt } log.Printf("Attached VDI '%s'", vdiUuid) return multistep.ActionContinue } func (self *StepAttachVdi) Cleanup(state multistep.StateBag) { config := state.Get("commonconfig").(CommonConfig) c := state.Get("client").(*Connection) if config.ShouldKeepVM(state) { return } // TODO: What the fuck does this mean? if self.vdi == "" { return } uuid := state.Get("instance_uuid").(string) vmRef, err := c.client.VM.GetByUUID(c.session, uuid) if err != nil { log.Printf("Unable to get VM from UUID '%s': %s", uuid, err.Error()) return } vdiUuid := state.Get(self.VdiUuidKey).(string) err = DisconnectVdi(c, vmRef, self.vdi) if err != nil { log.Printf("Unable to disconnect VDI '%s': %s", vdiUuid, err.Error()) return } log.Printf("Detached VDI '%s'", vdiUuid) }