README.md
Go SDK
The ProfitBricks Client Library for Go provides you with access to the ProfitBricks REST API. It is designed for developers who are building applications in Go.
This guide will walk you through getting setup with the library and performing various actions against the API.
Table of Contents
- Concepts
- Getting Started
- Installation
- How to: Create Data Center
- How to: Delete Data Center
- How to: Create Server
- How to: List Available Images
- How to: Create Storage Volume
- How to: Update Cores and Memory
- How to: Attach or Detach Storage Volume
- How to: List Servers, Volumes, and Data Centers
- Example
- Return Types
- Support
Concepts
The Go SDK wraps the latest version of the ProfitBricks REST API. All API operations are performed over SSL and authenticated using your ProfitBricks portal credentials. The API can be accessed within an instance running in ProfitBricks or directly over the Internet from any application that can send an HTTPS request and receive an HTTPS response.
Getting Started
Before you begin you will need to have signed-up for a ProfitBricks account. The credentials you setup during sign-up will be used to authenticate against the API.
Install the Go language from: Go Installation
The GOPATH
environment variable specifies the location of your Go workspace. It is likely the only environment variable you'll need to set when developing Go code. This is an example of pointing to a workspace configured underneath your home directory:
mkdir -p ~/go/bin
export GOPATH=~/go
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOBIN
Installation
The following go command will download profitbricks-sdk-go
to your configured GOPATH
:
go get "github.com/profitbricks/profitbricks-sdk-go"
The source code of the package will be located at:
$GOBIN\src\profitbricks-sdk-go
Create main package file example.go:
package main
import (
"fmt"
)
func main() {
}
Import GO SDK:
import(
"github.com/profitbricks/profitbricks-sdk-go"
)
Add your credentials for connecting to ProfitBricks:
profitbricks.SetAuth("username", "password")
Set depth:
profitbricks.SetDepth("5")
Depth controls the amount of data returned from the REST server ( range 1-5 ). The larger the number the more information is returned from the server. This is especially useful if you are looking for the information in the nested objects.
Caution: You will want to ensure you follow security best practices when using credentials within your code or stored in a file.
How To's
How To: Create Data Center
ProfitBricks introduces the concept of Data Centers. These are logically separated from one another and allow you to have a self-contained environment for all servers, volumes, networking, snapshots, and so forth. The goal is to give you the same experience as you would have if you were running your own physical data center.
The following code example shows you how to programmatically create a data center:
dcrequest := profitbricks.Datacenter{
Properties: profitbricks.DatacenterProperties{
Name: "example.go3",
Description: "description",
Location: "us/lasdev",
},
}
datacenter := profitbricks.CreateDatacenter(dcrequest)
How To: Create Data Center with Multiple Resources
To create a complex Data Center you would do this. As you can see, you can create quite a few of the objects you will need later all in one request.:
datacenter := model.Datacenter{
Properties: model.DatacenterProperties{
Name: "composite test",
Location:location,
},
Entities:model.DatacenterEntities{
Servers: &model.Servers{
Items:[]model.Server{
model.Server{
Properties: model.ServerProperties{
Name : "server1",
Ram: 2048,
Cores: 1,
},
Entities:model.ServerEntities{
Volumes: &model.AttachedVolumes{
Items:[]model.Volume{
model.Volume{
Properties: model.VolumeProperties{
Type_:"HDD",
Size:10,
Name:"volume1",
Image:"1f46a4a3-3f47-11e6-91c6-52540005ab80",
Bus:"VIRTIO",
ImagePassword:"test1234",
SshKeys: []string{"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCoLVLHON4BSK3D8L4H79aFo..."},
},
},
},
},
Nics: &model.Nics{
Items: []model.Nic{
model.Nic{
Properties: model.NicProperties{
Name : "nic",
Lan : "1",
},
},
},
},
},
},
},
},
},
}
dc := CompositeCreateDatacenter(datacenter)
How To: Delete Data Center
You will want to exercise a bit of caution here. Removing a data center will destroy all objects contained within that data center -- servers, volumes, snapshots, and so on.
The code to remove a data center is as follows. This example assumes you want to remove previously data center:
profitbricks.DeleteDatacenter(response.Id)
How To: Create Server
The server create method has a list of required parameters followed by a hash of optional parameters. The optional parameters are specified within the "options" hash and the variable names match the REST API parameters.
The following example shows you how to create a new server in the data center created above:
req := profitbricks.Server{
Properties: profitbricks.ServerProperties{
Name: "go01",
Ram: 1024,
Cores: 2,
},
}
server := CreateServer(datacenter.Id, req)
How To: List Available Images
A list of disk and ISO images are available from ProfitBricks for immediate use. These can be easily viewed and selected. The following shows you how to get a list of images. This list represents both CDROM images and HDD images.
images := profitbricks.ListImages()
This will return a collection object
How To: Create Storage Volume
ProfitBricks allows for the creation of multiple storage volumes that can be attached and detached as needed. It is useful to attach an image when creating a storage volume. The storage size is in gigabytes.
volumerequest := profitbricks.Volume{
Properties: profitbricks.VolumeProperties{
Size: 1,
Name: "Volume Test",
LicenceType: "LINUX",
Type: "HDD",
},
}
storage := CreateVolume(datacenter.Id, volumerequest)
How To: Update Cores and Memory
ProfitBricks allows users to dynamically update cores, memory, and disk independently of each other. This removes the restriction of needing to upgrade to the next size available size to receive an increase in memory. You can now simply increase the instances memory keeping your costs in-line with your resource needs.
Note: The memory parameter value must be a multiple of 256, e.g. 256, 512, 768, 1024, and so forth.
The following code illustrates how you can update cores and memory:
serverupdaterequest := profitbricks.ServerProperties{
Cores: 1,
Ram: 256,
}
resp := PatchServer(datacenter.Id, server.Id, serverupdaterequest)
How To: Attach or Detach Storage Volume
ProfitBricks allows for the creation of multiple storage volumes. You can detach and reattach these on the fly. This allows for various scenarios such as re-attaching a failed OS disk to another server for possible recovery or moving a volume to another location and spinning it up.
The following illustrates how you would attach and detach a volume and CDROM to/from a server:
profitbricks.AttachVolume(datacenter.Id, server.Id, volume.Id)
profitbricks.AttachCdrom(datacenter.Id, server.Id, images.Items[0].Id)
profitbricks.DetachVolume(datacenter.Id, server.Id, volume.Id)
profitbricks.DetachCdrom(datacenter.Id, server.Id, images.Items[0].Id)
How To: List Servers, Volumes, and Data Centers
Go SDK provides standard functions for retrieving a list of volumes, servers, and datacenters.
The following code illustrates how to pull these three list types:
volumes := profitbricks.ListVolumes(datacenter.Id)
servers := profitbricks.ListServers(datacenter.Id)
datacenters := profitbricks.ListDatacenters()
Example
package main
import (
"fmt"
"time"
"github.com/profitbricks/profitbricks-sdk-go"
)
func main() {
//Sets username and password
profitbricks.SetAuth("username", "password")
//Sets depth.
profitbricks.SetDepth("5")
dcrequest := profitbricks.Datacenter{
Properties: profitbricks.DatacenterProperties{
Name: "example.go3",
Description: "description",
Location: "us/lasdev",
},
}
datacenter := profitbricks.CreateDatacenter(dcrequest)
serverrequest := profitbricks.Server{
Properties: profitbricks.ServerProperties{
Name: "go01",
Ram: 1024,
Cores: 2,
},
}
server := profitbricks.CreateServer(datacenter.Id, serverrequest)
volumerequest := profitbricks.Volume{
Properties: profitbricks.VolumeProperties{
Size: 1,
Name: "Volume Test",
LicenceType: "LINUX",
Type: "HDD",
},
}
storage := profitbricks.CreateVolume(datacenter.Id, volumerequest)
serverupdaterequest := profitbricks.ServerProperties{
Name: "go01renamed",
Cores: 1,
Ram: 256,
}
profitbricks.PatchServer(datacenter.Id, server.Id, serverupdaterequest)
//It takes a moment for a volume to be provisioned so we wait.
time.Sleep(60 * time.Second)
profitbricks.AttachVolume(datacenter.Id, server.Id, storage.Id)
volumes := profitbricks.ListVolumes(datacenter.Id)
fmt.Println(volumes.Items)
servers := profitbricks.ListServers(datacenter.Id)
fmt.Println(servers.Items)
datacenters := profitbricks.ListDatacenters()
fmt.Println(datacenters.Items)
profitbricks.DeleteServer(datacenter.Id, server.Id)
profitbricks.DeleteDatacenter(datacenter.Id)
}
Support
You are welcome to contact us with questions or comments at ProfitBricks DevOps Central. Please report any issues via GitHub's issue tracker.