packer-cn/builder/oracle/classic/step_add_keys.go

76 lines
2.0 KiB
Go
Raw Normal View History

2018-01-22 19:54:49 -05:00
package classic
import (
"bytes"
2018-01-25 17:43:55 -05:00
"context"
2018-01-22 19:54:49 -05:00
"fmt"
"github.com/hashicorp/go-oracle-terraform/compute"
2018-01-25 17:45:09 -05:00
"github.com/hashicorp/packer/helper/multistep"
2018-01-22 19:54:49 -05:00
"github.com/hashicorp/packer/packer"
)
type stepAddKeysToAPI struct {
2018-10-26 18:47:49 -04:00
Skip bool
KeyName string
}
2018-01-22 19:54:49 -05:00
2018-01-25 17:42:39 -05:00
func (s *stepAddKeysToAPI) Run(_ context.Context, state multistep.StateBag) multistep.StepAction {
2018-01-22 19:54:49 -05:00
// get variables from state
ui := state.Get("ui").(packer.Ui)
config := state.Get("config").(*Config)
2018-10-24 17:08:11 -04:00
client := state.Get("client").(*compute.Client)
2018-01-22 19:54:49 -05:00
if s.Skip {
ui.Say("Skipping generating SSH keys...")
return multistep.ActionContinue
}
2018-01-22 19:54:49 -05:00
// grab packer-generated key from statebag context.
// Always check configured communicator for keys
sshPublicKey := bytes.TrimSpace(config.Comm.SSHPublicKey)
2018-01-22 19:54:49 -05:00
// form API call to add key to compute cloud
2018-10-26 18:47:49 -04:00
ui.Say(fmt.Sprintf("Creating temporary key: %s", s.KeyName))
2018-01-26 16:12:35 -05:00
2018-01-22 19:54:49 -05:00
sshKeysClient := client.SSHKeys()
sshKeysInput := compute.CreateSSHKeyInput{
2018-10-26 18:47:49 -04:00
Name: s.KeyName,
Key: string(sshPublicKey),
2018-01-22 19:54:49 -05:00
Enabled: true,
}
// Load the packer-generated SSH key into the Oracle Compute cloud.
keyInfo, err := sshKeysClient.CreateSSHKey(&sshKeysInput)
if err != nil {
err = fmt.Errorf("Problem adding Public SSH key through Oracle's API: %s", err)
ui.Error(err.Error())
state.Put("error", err)
return multistep.ActionHalt
2018-01-22 19:54:49 -05:00
}
config.Comm.SSHKeyPairName = keyInfo.Name
2018-01-22 19:54:49 -05:00
return multistep.ActionContinue
}
func (s *stepAddKeysToAPI) Cleanup(state multistep.StateBag) {
if s.Skip {
return
}
config := state.Get("config").(*Config)
// Delete the keys we created during this run
if len(config.Comm.SSHKeyPairName) == 0 {
// No keys were generated; none need to be cleaned up.
return
}
ui := state.Get("ui").(packer.Ui)
ui.Say("Deleting SSH keys...")
deleteInput := compute.DeleteSSHKeyInput{Name: config.Comm.SSHKeyPairName}
2018-10-24 17:08:11 -04:00
client := state.Get("client").(*compute.Client)
deleteClient := client.SSHKeys()
err := deleteClient.DeleteSSHKey(&deleteInput)
if err != nil {
ui.Error(fmt.Sprintf("Error deleting SSH keys: %s", err.Error()))
}
return
2018-01-22 19:54:49 -05:00
}