
Security News
Open Source Maintainers Feeling the Weight of the EU’s Cyber Resilience Act
The EU Cyber Resilience Act is prompting compliance requests that open source maintainers may not be obligated or equipped to handle.
github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql
An enterprise-grade Database is provided as a Service (DBaaS) solution that can be managed through a browser-based "Data Center Designer" (DCD) tool or via an easy to use API.
The API allows you to create additional database clusters or modify existing ones. It is designed to allow users to leverage the same power and flexibility found within the DCD visual tool. Both tools are consistent with their concepts and lend well to making the experience smooth and intuitive.
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.
go get github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql.git
To update the SDK use go get -u to retrieve the latest version of the SDK.
go get -u github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql.git
If you are using Go modules, your go get will default to the latest tagged release version of the SDK. To get a specific release version of the SDK use @ in your go get command.
To get the latest SDK repository, use @latest.
go get github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql@latest
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/v6 path, so it should not be included in the IONOS_API_URL environment variable |
IONOS_LOGLEVEL | Specify the Log Level used to log messages. Possible values: Off, Debug, Trace |
IONOS_PINNED_CERT | Specify the SHA-256 public fingerprint here, enables certificate pinning |
⚠️ Note: To overwrite the api endpoint - api.ionos.com
, the environment variable $IONOS_API_URL
can be set, and used with NewConfigurationFromEnv()
function.
Examples for creating resources using the Go SDK can be found here
Example
import (
"context"
"fmt"
"github.com/ionos-cloud/sdk-go-bundle/shared"
psql "github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql"
"log"
)
func basicAuthExample() error {
cfg := shared.NewConfiguration("username_here", "pwd_here", "", "")
cfg.LogLevel = Trace
apiClient := psql.NewAPIClient(cfg)
return nil
}
There are 2 ways to generate your token:
import (
"context"
"fmt"
"github.com/ionos-cloud/sdk-go-bundle/products/auth"
"github.com/ionos-cloud/sdk-go-bundle/shared"
psql "github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql"
"log"
)
func TokenAuthExample() error {
//note: to use NewConfigurationFromEnv(), you need to previously set IONOS_USERNAME and IONOS_PASSWORD as env variables
authClient := auth.NewAPIClient(authApi.NewConfigurationFromEnv())
jwt, _, err := auth.TokensApi.TokensGenerate(context.Background()).Execute()
if err != nil {
return fmt.Errorf("error occurred while generating token (%w)", err)
}
if !jwt.HasToken() {
return fmt.Errorf("could not generate token")
}
cfg := shared.NewConfiguration("", "", *jwt.GetToken(), "")
cfg.LogLevel = Trace
apiClient := psql.NewAPIClient(cfg)
return nil
}
Install ionosctl as explained here Run commands to login and generate your token.
ionosctl login
ionosctl token generate
export IONOS_TOKEN="insert_here_token_saved_from_generate_command"
Save the generated token and use it to authenticate:
import (
"context"
"fmt"
"github.com/ionos-cloud/sdk-go-bundle/products/auth"
psql "github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql"
"log"
)
func TokenAuthExample() error {
//note: to use NewConfigurationFromEnv(), you need to previously set IONOS_TOKEN as env variables
authClient := auth.NewAPIClient(authApi.NewConfigurationFromEnv())
cfg.LogLevel = Trace
apiClient := psql.NewAPIClient(cfg)
return nil
}
You can enable certificate pinning if you want to bypass the normal certificate checking procedure, by doing the following:
Set env variable IONOS_PINNED_CERT=<insert_sha256_public_fingerprint_here>
You can get the sha256 fingerprint most easily from the browser by inspecting the certificate.
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. |
Base URL for the HTTP operation can be changed by using the following function:
requestProperties.SetURL("https://api.ionos.com/cloudapi/v6")
You can now inject any logger that implements Printf as a logger
instead of using the default sdk logger.
There are now Loglevels that you can set: Off
, Debug
and Trace
.
Off
- does not show any logs
Debug
- regular logs, no sensitive information
Trace
- we recommend you only set this field for debugging purposes. Disable it in your production environments because it can log sensitive data.
It logs the full request and response without encryption, even for an HTTPS call. Verbose request and response logging can also significantly impact your application's performance.
package main
import (
psql "github.com/ionos-cloud/sdk-go-bundle/products/dbaas/psql"
"github.com/ionos-cloud/sdk-go-bundle/shared"
"github.com/sirupsen/logrus"
)
func main() {
// create your configuration. replace username, password, token and url with correct values, or use NewConfigurationFromEnv()
// if you have set your env variables as explained above
cfg := shared.NewConfiguration("username", "password", "token", "hostUrl")
// enable request and response logging. this is the most verbose loglevel
cfg.LogLevel = Trace
// inject your own logger that implements Printf
cfg.Logger = logrus.New()
// create you api client with the configuration
apiClient := psql.NewAPIClient(cfg)
}
All URIs are relative to https://api.ionos.com/databases/postgresql
Class | Method | HTTP request | Description |
---|---|---|---|
BackupsApi | ClusterBackupsGet | Get /clusters/{clusterId}/backups | List backups of cluster |
BackupsApi | ClustersBackupsFindById | Get /clusters/backups/{backupId} | Fetch a cluster backup |
BackupsApi | ClustersBackupsGet | Get /clusters/backups | List cluster backups |
ClustersApi | ClusterPostgresVersionsGet | Get /clusters/{clusterId}/postgresversions | List PostgreSQL versions |
ClustersApi | ClustersDelete | Delete /clusters/{clusterId} | Delete a cluster |
ClustersApi | ClustersFindById | Get /clusters/{clusterId} | Fetch a cluster |
ClustersApi | ClustersGet | Get /clusters | List clusters |
ClustersApi | ClustersPatch | Patch /clusters/{clusterId} | Patch a cluster |
ClustersApi | ClustersPost | Post /clusters | Create a cluster |
ClustersApi | PostgresVersionsGet | Get /clusters/postgresversions | List PostgreSQL versions |
LogsApi | ClusterLogsGet | Get /clusters/{clusterId}/logs | Get logs of your cluster |
MetadataApi | InfosVersionGet | Get /infos/version | Get the current API version |
MetadataApi | InfosVersionsGet | Get /infos/versions | Fetch all API versions |
RestoresApi | ClusterRestorePost | Post /clusters/{clusterId}/restore | In-place restore of a cluster |
All URIs are relative to https://api.ionos.com/databases/postgresql
FAQs
Unknown package
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The EU Cyber Resilience Act is prompting compliance requests that open source maintainers may not be obligated or equipped to handle.
Security News
Crates.io adds Trusted Publishing support, enabling secure GitHub Actions-based crate releases without long-lived API tokens.
Research
/Security News
Undocumented protestware found in 28 npm packages disrupts UI for Russian-language users visiting Russian and Belarusian domains.