latest
Models
Introduction

Overview

The IONOS Cloud SDK for GO provides you with access to the IONOS Cloud API. The client library supports both simple and complex requests. It is designed for developers who are building applications in GO . The SDK for GO wraps the IONOS Cloud API. All API operations are performed over SSL and authenticated using your IONOS Cloud portal credentials. The API can be accessed within an instance running in IONOS Cloud or directly over the Internet from any application that can send an HTTPS request and receive an HTTPS response.

Getting Started

An IONOS account is required for access to the Cloud API; credentials from your registration are used to authenticate against the IONOS Cloud API.

Installation

Install the Go language from from the official Go installation guide.
The GOPATH environment variable specifies the location of your Go workspace. It is likely the only environment variable you will have to set when developing Go code. This is an example of pointing to a workspace configured under your home directory:
1
mkdir -p ~/go/bin
2
export GOPATH=~/go
3
export GOBIN=$GOPATH/bin
4
export PATH=$PATH:$GOBIN
Copied!
The following go command will download sdk-go to your configured GOPATH:
1
go get "github.com/ionos-cloud/sdk-go"
Copied!
The source code of the package will be located here:
1
$GOPATH/src/github.com/ionos-cloud/sdk-go
Copied!
Create main package file example.go:
1
package main
2
3
import (
4
"fmt"
5
)
6
7
func main() {
8
}
Copied!
Include the IONOS Cloud SDK for Go under the list of imports.
1
import(
2
"fmt"
3
4
"github.com/ionos-cloud/sdk-go"
5
)
Copied!

Authentication

The username and password or the authentication token can be manually specified when initializing the SDK client:
1
client := ionoscloud.NewAPIClient(ionoscloud.NewConfiguration(username, password, token, apiUrl))
Copied!
Environment variables can also be used; the SDK uses the following variables:
  • IONOS_USERNAME - to specify the username used to login
  • IONOS_PASSWORD - to specify the password
  • IONOS_TOKEN - if an authentication token is being used
  • IONOS_API_URL - to overwrite the API endpoint: api.ionos.com - if it is not set, the default value will be used
In this case, the client configuration must be initialized using NewConfigurationFromEnv()
1
client := ionoscloud.NewAPIClient(ionoscloud.NewConfigurationFromEnv())
Copied!
Warning: Make sure to follow the Information Security Best Practices when using credentials within your code or storing them in a file.

Environment Variables

Environment Variable
Description
IONOS_USERNAME
Specify the username used to login, to authenticate against the IONOS Cloud API
IONOS_PASSWORD
Specify the password used to login, to authenticate against the IONOS Cloud API
IONOS_TOKEN
Specify the token used to login, if a token is being used instead of username and password
IONOS_API_URL
Specify the API URL. It will overwrite the API endpoint default value api.ionos.com. Note: the host URL does not contain the /cloudapi/v5 path, so it should not be included in the IONOS_API_URL environment variable

Depth

Many of the List or Get operations will accept an optional depth argument. Setting this to a value between 0 and 5 affects the amount of data that is returned. The details returned vary depending on the resource being queried, but it generally follows this pattern. By default, the SDK sets the depth argument to the maximum value.
Depth
Description
0
Only direct properties are included. Children are not included.
1
Direct properties and children's references are returned.
2
Direct properties and children's properties are returned.
3
Direct properties, children's properties, and descendants' references are returned.
4
Direct properties, children's properties, and descendants' properties are returned.
5
Returns all available properties.

Pretty

The operations will also accept an optional pretty argument. Setting this to a value of true or false controls whether the response is pretty-printed (with indentation and new lines). By default, the SDK sets the pretty argument to true.

Changing the base URL

Base URL for the HTTP operation can be changed by using the following function:
1
requestProperties.SetURL("https://api.ionos.com/cloudapi/v5")
Copied!

Feature Reference

The IONOS Cloud SDK for GO aims to offer access to all resources in the IONOS Cloud API, and has additional features to make integration easier:
  • Authentication for API calls
  • Asynchronous request handling

FAQ

  1. 1.
    How can I open a bug report/feature request?
Bug reports and feature requests can be opened in the Issues repository: https://github.com/ionos-cloud/sdk-go/issues/new/choose
  1. 1.
    Can I contribute to the GO SDK?
Pure SDKs are automatically generated using OpenAPI Generator and don’t support manual changes. If you require changes, please open an issue and we will try to address it.
Last modified 10d ago