mirror of
https://github.com/opentffoundation/opentf.git
synced 2026-03-13 10:01:08 -04:00
Here is an example that will setup the following:
+ An SSH key resource.
+ A virtual server resource that uses an existing SSH key.
+ A virtual server resource using an existing SSH key and a Terraform managed SSH key (created as "test_key_1" in the example below).
(create this as sl.tf and run terraform commands from this directory):
```hcl
provider "softlayer" {
username = ""
api_key = ""
}
resource "softlayer_ssh_key" "test_key_1" {
name = "test_key_1"
public_key = "${file(\"~/.ssh/id_rsa_test_key_1.pub\")}"
# Windows Example:
# public_key = "${file(\"C:\ssh\keys\path\id_rsa_test_key_1.pub\")}"
}
resource "softlayer_virtual_guest" "my_server_1" {
name = "my_server_1"
domain = "example.com"
ssh_keys = ["123456"]
image = "DEBIAN_7_64"
region = "ams01"
public_network_speed = 10
cpu = 1
ram = 1024
}
resource "softlayer_virtual_guest" "my_server_2" {
name = "my_server_2"
domain = "example.com"
ssh_keys = ["123456", "${softlayer_ssh_key.test_key_1.id}"]
image = "CENTOS_6_64"
region = "ams01"
public_network_speed = 10
cpu = 1
ram = 1024
}
```
You'll need to provide your SoftLayer username and API key,
so that Terraform can connect. If you don't want to put
credentials in your configuration file, you can leave them
out:
```
provider "softlayer" {}
```
...and instead set these environment variables:
- **SOFTLAYER_USERNAME**: Your SoftLayer username
- **SOFTLAYER_API_KEY**: Your API key
40 lines
883 B
Go
40 lines
883 B
Go
package softlayer
|
|
|
|
import (
|
|
"log"
|
|
|
|
slclient "github.com/maximilien/softlayer-go/client"
|
|
softlayer "github.com/maximilien/softlayer-go/softlayer"
|
|
)
|
|
|
|
type Config struct {
|
|
Username string
|
|
ApiKey string
|
|
}
|
|
|
|
type Client struct {
|
|
virtualGuestService softlayer.SoftLayer_Virtual_Guest_Service
|
|
sshKeyService softlayer.SoftLayer_Security_Ssh_Key_Service
|
|
productOrderService softlayer.SoftLayer_Product_Order_Service
|
|
}
|
|
|
|
func (c *Config) Client() (*Client, error) {
|
|
slc := slclient.NewSoftLayerClient(c.Username, c.ApiKey)
|
|
virtualGuestService, err := slc.GetSoftLayer_Virtual_Guest_Service()
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sshKeyService, err := slc.GetSoftLayer_Security_Ssh_Key_Service()
|
|
|
|
client := &Client{
|
|
virtualGuestService: virtualGuestService,
|
|
sshKeyService: sshKeyService,
|
|
}
|
|
|
|
log.Println("[INFO] Created SoftLayer client")
|
|
|
|
return client, nil
|
|
}
|