mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-25 16:06:25 -06:00
a1935a135d
When a Packet provision exceeds our time limit, we move the device to an internal project for Packet staff to investigate. When this happens, the original user no longer has access to the device, and they get a 403. These changes make that and other external state changes more pleasant for users of Terraform.
123 lines
2.5 KiB
Go
123 lines
2.5 KiB
Go
package packet
|
|
|
|
import (
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
"github.com/packethost/packngo"
|
|
)
|
|
|
|
func resourcePacketSSHKey() *schema.Resource {
|
|
return &schema.Resource{
|
|
Create: resourcePacketSSHKeyCreate,
|
|
Read: resourcePacketSSHKeyRead,
|
|
Update: resourcePacketSSHKeyUpdate,
|
|
Delete: resourcePacketSSHKeyDelete,
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
"id": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
|
|
"name": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
},
|
|
|
|
"public_key": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
ForceNew: true,
|
|
},
|
|
|
|
"fingerprint": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
|
|
"created": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
|
|
"updated": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func resourcePacketSSHKeyCreate(d *schema.ResourceData, meta interface{}) error {
|
|
client := meta.(*packngo.Client)
|
|
|
|
createRequest := &packngo.SSHKeyCreateRequest{
|
|
Label: d.Get("name").(string),
|
|
Key: d.Get("public_key").(string),
|
|
}
|
|
|
|
key, _, err := client.SSHKeys.Create(createRequest)
|
|
if err != nil {
|
|
return friendlyError(err)
|
|
}
|
|
|
|
d.SetId(key.ID)
|
|
|
|
return resourcePacketSSHKeyRead(d, meta)
|
|
}
|
|
|
|
func resourcePacketSSHKeyRead(d *schema.ResourceData, meta interface{}) error {
|
|
client := meta.(*packngo.Client)
|
|
|
|
key, _, err := client.SSHKeys.Get(d.Id())
|
|
if err != nil {
|
|
err = friendlyError(err)
|
|
|
|
// If the key is somehow already destroyed, mark as
|
|
// succesfully gone
|
|
if isNotFound(err) {
|
|
d.SetId("")
|
|
return nil
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
d.Set("id", key.ID)
|
|
d.Set("name", key.Label)
|
|
d.Set("public_key", key.Key)
|
|
d.Set("fingerprint", key.FingerPrint)
|
|
d.Set("created", key.Created)
|
|
d.Set("updated", key.Updated)
|
|
|
|
return nil
|
|
}
|
|
|
|
func resourcePacketSSHKeyUpdate(d *schema.ResourceData, meta interface{}) error {
|
|
client := meta.(*packngo.Client)
|
|
|
|
updateRequest := &packngo.SSHKeyUpdateRequest{
|
|
ID: d.Get("id").(string),
|
|
Label: d.Get("name").(string),
|
|
Key: d.Get("public_key").(string),
|
|
}
|
|
|
|
_, _, err := client.SSHKeys.Update(updateRequest)
|
|
if err != nil {
|
|
return friendlyError(err)
|
|
}
|
|
|
|
return resourcePacketSSHKeyRead(d, meta)
|
|
}
|
|
|
|
func resourcePacketSSHKeyDelete(d *schema.ResourceData, meta interface{}) error {
|
|
client := meta.(*packngo.Client)
|
|
|
|
_, err := client.SSHKeys.Delete(d.Id())
|
|
if err != nil {
|
|
return friendlyError(err)
|
|
}
|
|
|
|
d.SetId("")
|
|
return nil
|
|
}
|