mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-09 23:54:17 -06:00
9f314a3c29
* provider/scaleway: update api version * provider/scaleway: expose ipv6 support, rename ip attributes since it can be both ipv4 and ipv6, choose a more generic name. * provider/scaleway: allow servers in different SGs * provider/scaleway: update documentation * provider/scaleway: Update docs with security group * provider/scaleway: add testcase for server security groups * provider/scaleway: make deleting of security rules more resilient * provider/scaleway: make deletion of security group more resilient * provider/scaleway: guard against missing server
219 lines
4.7 KiB
Go
219 lines
4.7 KiB
Go
package scaleway
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
"github.com/scaleway/scaleway-cli/pkg/api"
|
|
)
|
|
|
|
func resourceScalewayServer() *schema.Resource {
|
|
return &schema.Resource{
|
|
Create: resourceScalewayServerCreate,
|
|
Read: resourceScalewayServerRead,
|
|
Update: resourceScalewayServerUpdate,
|
|
Delete: resourceScalewayServerDelete,
|
|
Schema: map[string]*schema.Schema{
|
|
"name": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
},
|
|
"image": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
ForceNew: true,
|
|
},
|
|
"type": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
ForceNew: true,
|
|
},
|
|
"bootscript": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"tags": &schema.Schema{
|
|
Type: schema.TypeList,
|
|
Elem: &schema.Schema{
|
|
Type: schema.TypeString,
|
|
},
|
|
Optional: true,
|
|
},
|
|
"enable_ipv6": &schema.Schema{
|
|
Type: schema.TypeBool,
|
|
Optional: true,
|
|
Default: false,
|
|
},
|
|
"dynamic_ip_required": &schema.Schema{
|
|
Type: schema.TypeBool,
|
|
Optional: true,
|
|
},
|
|
"security_group": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
},
|
|
"private_ip": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
"public_ip": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
"state": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Optional: true,
|
|
Computed: true,
|
|
},
|
|
"state_detail": &schema.Schema{
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func resourceScalewayServerCreate(d *schema.ResourceData, m interface{}) error {
|
|
scaleway := m.(*Client).scaleway
|
|
|
|
image := d.Get("image").(string)
|
|
var server = api.ScalewayServerDefinition{
|
|
Name: d.Get("name").(string),
|
|
Image: String(image),
|
|
Organization: scaleway.Organization,
|
|
EnableIPV6: d.Get("enable_ipv6").(bool),
|
|
SecurityGroup: d.Get("security_group").(string),
|
|
}
|
|
|
|
server.DynamicIPRequired = Bool(d.Get("dynamic_ip_required").(bool))
|
|
server.CommercialType = d.Get("type").(string)
|
|
|
|
if bootscript, ok := d.GetOk("bootscript"); ok {
|
|
server.Bootscript = String(bootscript.(string))
|
|
}
|
|
|
|
if raw, ok := d.GetOk("tags"); ok {
|
|
for _, tag := range raw.([]interface{}) {
|
|
server.Tags = append(server.Tags, tag.(string))
|
|
}
|
|
}
|
|
|
|
id, err := scaleway.PostServer(server)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
d.SetId(id)
|
|
if d.Get("state").(string) != "stopped" {
|
|
err = scaleway.PostServerAction(id, "poweron")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
err = waitForServerState(scaleway, id, "running")
|
|
}
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return resourceScalewayServerRead(d, m)
|
|
}
|
|
|
|
func resourceScalewayServerRead(d *schema.ResourceData, m interface{}) error {
|
|
scaleway := m.(*Client).scaleway
|
|
server, err := scaleway.GetServer(d.Id())
|
|
|
|
if err != nil {
|
|
if serr, ok := err.(api.ScalewayAPIError); ok {
|
|
log.Printf("[DEBUG] Error reading server: %q\n", serr.APIMessage)
|
|
|
|
if serr.StatusCode == 404 {
|
|
d.SetId("")
|
|
return nil
|
|
}
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
d.Set("private_ip", server.PrivateIP)
|
|
d.Set("public_ip", server.PublicAddress.IP)
|
|
|
|
d.Set("state", server.State)
|
|
d.Set("state_detail", server.StateDetail)
|
|
d.Set("tags", server.Tags)
|
|
|
|
d.SetConnInfo(map[string]string{
|
|
"type": "ssh",
|
|
"host": server.PublicAddress.IP,
|
|
})
|
|
|
|
return nil
|
|
}
|
|
|
|
func resourceScalewayServerUpdate(d *schema.ResourceData, m interface{}) error {
|
|
scaleway := m.(*Client).scaleway
|
|
|
|
var req api.ScalewayServerPatchDefinition
|
|
|
|
if d.HasChange("name") {
|
|
name := d.Get("name").(string)
|
|
req.Name = &name
|
|
}
|
|
|
|
if d.HasChange("tags") {
|
|
if raw, ok := d.GetOk("tags"); ok {
|
|
var tags []string
|
|
for _, tag := range raw.([]interface{}) {
|
|
tags = append(tags, tag.(string))
|
|
}
|
|
req.Tags = &tags
|
|
}
|
|
}
|
|
|
|
if d.HasChange("enable_ipv6") {
|
|
req.EnableIPV6 = Bool(d.Get("enable_ipv6").(bool))
|
|
}
|
|
|
|
if d.HasChange("dynamic_ip_required") {
|
|
req.DynamicIPRequired = Bool(d.Get("dynamic_ip_required").(bool))
|
|
}
|
|
|
|
if d.HasChange("security_group") {
|
|
req.SecurityGroup = &api.ScalewaySecurityGroup{
|
|
Identifier: d.Get("security_group").(string),
|
|
}
|
|
}
|
|
|
|
if err := scaleway.PatchServer(d.Id(), req); err != nil {
|
|
return fmt.Errorf("Failed patching scaleway server: %q", err)
|
|
}
|
|
|
|
return resourceScalewayServerRead(d, m)
|
|
}
|
|
|
|
func resourceScalewayServerDelete(d *schema.ResourceData, m interface{}) error {
|
|
scaleway := m.(*Client).scaleway
|
|
|
|
def, err := scaleway.GetServer(d.Id())
|
|
if err != nil {
|
|
if serr, ok := err.(api.ScalewayAPIError); ok {
|
|
if serr.StatusCode == 404 {
|
|
d.SetId("")
|
|
return nil
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
err = deleteServerSafe(scaleway, def.Identifier)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
d.SetId("")
|
|
return nil
|
|
}
|