Skip to main content

Python SDK for the IONOS Cloud Data Platform API

Project description

CI Data Platform Python Gitter Quality Gate Status Bugs Maintainability Rating Reliability Rating Security Rating Vulnerabilities Release Release Date PyPI version

Alt text

Python API client for ionoscloud_dataplatform

Managed Stackable Data Platform by IONOS Cloud provides a preconfigured Kubernetes cluster with pre-installed and managed Stackable operators. After the provision of these Stackable operators, the customer can interact with them directly and build his desired application on top of the Stackable Platform.

Managed Stackable Data Platform by IONOS Cloud can be configured through the IONOS Cloud API in addition or as an alternative to the "Data Center Designer" (DCD).

Getting Started

To get your DataPlatformCluster up and running, the following steps needs to be performed.

IONOS Cloud Account

The first step is the creation of a IONOS Cloud account if not already existing.

To register a new account visit cloud.ionos.com.

Virtual Datacenter (VDC)

The Managed Data Stack needs a virtual datacenter (VDC) hosting the cluster. This could either be a VDC that already exists, especially if you want to connect the managed DataPlatform to other services already running within your VDC. Otherwise, if you want to place the Managed Data Stack in a new VDC or you have not yet created a VDC, you need to do so.

A new VDC can be created via the IONOS Cloud API, the IONOS-CLI or the DCD Web interface. For more information, see the official documentation

Get a authentication token

To interact with this API a user specific authentication token is needed. This token can be generated using the IONOS-CLI the following way:

ionosctl token generate

For more information see

Create a new DataPlatformCluster

Before using Managed Stackable Data Platform, a new DataPlatformCluster must be created.

To create a cluster, use the Create DataPlatformCluster API endpoint.

The provisioning of the cluster might take some time. To check the current provisioning status, you can query the cluster by calling the Get Endpoint with the cluster ID that was presented to you in the response of the create cluster call.

Add a DataPlatformNodePool

To deploy and run a Stackable service, the cluster must have enough computational resources. The node pool that is provisioned along with the cluster is reserved for the Stackable operators. You may create further node pools with resources tailored to your use-case.

To create a new node pool use the Create DataPlatformNodepool endpoint.

Receive Kubeconfig

Once the DataPlatformCluster is created, the kubeconfig can be accessed by the API. The kubeconfig allows the interaction with the provided cluster as with any regular Kubernetes cluster.

The kubeconfig can be downloaded with the Get Kubeconfig endpoint using the cluster ID of the created DataPlatformCluster.

Create Stackable Service

To create the desired application, the Stackable service needs to be provided, using the received kubeconfig and deploy a Stackable service

Authorization

All endpoints are secured, so only an authenticated user can access them. As Authentication mechanism the default IONOS Cloud authentication mechanism is used. A detailed description can be found here.

Basic-Auth

The basic auth scheme uses the IONOS Cloud user credentials in form of a Basic Authentication Header accordingly to RFC7617

API-Key as Bearer Token

The Bearer auth token used at the API-Gateway is a user related token created with the IONOS-CLI. (See the documentation for details) For every request to be authenticated, the token is passed as 'Authorization Bearer' header along with the request.

Permissions and access roles

Currently, an admin can see and manipulate all resources in a contract. A normal authenticated user can only see and manipulate resources he created.

Components

The Managed Stackable Data Platform by IONOS Cloud consists of two components. The concept of a DataPlatformClusters and the backing DataPlatformNodePools the cluster is build on.

DataPlatformCluster

A DataPlatformCluster is the virtual instance of the customer services and operations running the managed Services like Stackable operators. A DataPlatformCluster is a Kubernetes Cluster in the VDC of the customer. Therefore, it's possible to integrate the cluster with other resources as vLANs e.G. to shape the datacenter in the customer's need and integrate the cluster within the topology the customer wants to build.

In addition to the Kubernetes cluster a small node pool is provided which is exclusively used to run the Stackable operators.

DataPlatformNodePool

A DataPlatformNodePool represents the physical machines a DataPlatformCluster is build on top. All nodes within a node pool are identical in setup. The nodes of a pool are provisioned into virtual data centers at a location of your choice and you can freely specify the properties of all the nodes at once before creation.

Nodes in node pools provisioned by the Managed Stackable Data Platform Cloud API are readonly in the customer's VDC and can only be modified or deleted via the API.

References

Overview

The IONOS Cloud SDK for Python provides you with access to the IONOS Cloud Managed Stackable Data Platform API. The client library supports both simple and complex requests. It is designed for developers who are building applications in Python. 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.

Installation & Usage

Requirements:

  • Python >= 3.5

pip install

Since this package is hosted on Pypi you can install it by using:

pip install ionoscloud-dataplatform

If the python package is hosted on a repository, you can install directly using:

pip install git+https://github.com/ionos-cloud/sdk-python-dataplatform.git

Note: you may need to run pip with root permission: sudo pip install git+https://github.com/ionos-cloud/sdk-python-dataplatform.git

Then import the package:

import ionoscloud_dataplatform

Setuptools

Install via Setuptools.

python setup.py install --user

or sudo python setup.py install to install the package for all users

Then import the package:

import ionoscloud_dataplatform

NOTE: The Python SDK does not support Python 2. It only supports Python >= 3.5.

Authentication

The username and password or the authentication token can be manually specified when initializing the SDK client:

configuration = ionoscloud_dataplatform.Configuration(
                username='YOUR_USERNAME',
                password='YOUR_PASSWORD',
                token='YOUR_TOKEN'
                )
client = ionoscloud_dataplatform.ApiClient(configuration)

Environment variables can also be used. This is an example of how one would do that:

import os

configuration = ionoscloud_dataplatform.Configuration(
                username=os.environ.get('IONOS_USERNAME'),
                password=os.environ.get('IONOS_PASSWORD'),
                token=os.environ.get('IONOS_TOKEN')
                )
client = ionoscloud_dataplatform.ApiClient(configuration)

Warning: Make sure to follow the Information Security Best Practices when using credentials within your code or storing them in a file.

HTTP proxies

You can use http proxies by setting the following environment variables:

  • IONOS_HTTP_PROXY - proxy URL
  • IONOS_HTTP_PROXY_HEADERS - proxy headers

Changing the base URL

Base URL for the HTTP operation can be changed in the following way:

import os

configuration = ionoscloud_dataplatform.Configuration(
                username=os.environ.get('IONOS_USERNAME'),
                password=os.environ.get('IONOS_PASSWORD'),
                host=os.environ.get('IONOS_API_URL'),
                server_index=None,
                )
client = ionoscloud_dataplatform.ApiClient(configuration)

Certificate pinning:

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.

Documentation for API Endpoints

All URIs are relative to https://api.ionos.com/dataplatform

API Endpoints table
Class Method HTTP request Description
DataPlatformClusterApi create_cluster POST /clusters Create a DataPlatformCluster
DataPlatformClusterApi delete_cluster DELETE /clusters/{clusterId} Delete DataPlatformCluster
DataPlatformClusterApi get_cluster GET /clusters/{clusterId} Retrieve a DataPlatformCluster
DataPlatformClusterApi get_cluster_kubeconfig GET /clusters/{clusterId}/kubeconfig Read the kubeconfig
DataPlatformClusterApi get_clusters GET /clusters List DataPlatformCluster
DataPlatformClusterApi patch_cluster PATCH /clusters/{clusterId} Partially modify a DataPlatformCluster
DataPlatformMetaDataApi versions_get GET /versions Managed Data Stack API version
DataPlatformNodePoolApi create_cluster_nodepool POST /clusters/{clusterId}/nodepools Create a DataPlatformNodePool for a distinct DataPlatformCluster
DataPlatformNodePoolApi delete_cluster_nodepool DELETE /clusters/{clusterId}/nodepools/{nodepoolId} Remove node pool from DataPlatformCluster.
DataPlatformNodePoolApi get_cluster_nodepool GET /clusters/{clusterId}/nodepools/{nodepoolId} Retrieve a DataPlatformNodePool
DataPlatformNodePoolApi get_cluster_nodepools GET /clusters/{clusterId}/nodepools List the DataPlatformNodePools of a DataPlatformCluster
DataPlatformNodePoolApi patch_cluster_nodepool PATCH /clusters/{clusterId}/nodepools/{nodepoolId} Partially modify a DataPlatformNodePool

Documentation For Models

All URIs are relative to https://api.ionos.com/dataplatform

API models list

[Back to API list] [Back to Model list]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ionoscloud-dataplatform-1.0.0.tar.gz (53.6 kB view details)

Uploaded Source

Built Distribution

ionoscloud_dataplatform-1.0.0-py3-none-any.whl (125.4 kB view details)

Uploaded Python 3

File details

Details for the file ionoscloud-dataplatform-1.0.0.tar.gz.

File metadata

File hashes

Hashes for ionoscloud-dataplatform-1.0.0.tar.gz
Algorithm Hash digest
SHA256 ce00261bea8fcd567c9222b9968dc68170d56a53925ee48f945a334143bdb42c
MD5 aafff2927238e05cfd41d9af72e8d746
BLAKE2b-256 1aaa2089ed06220ce52a9334f03339cc763cc3b527ef5273944ea845c2a5d180

See more details on using hashes here.

File details

Details for the file ionoscloud_dataplatform-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ionoscloud_dataplatform-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 55ba3344aa4838e45a42c202ce1818a0edfaec2e1ce969b65cec4b7c8fcfb375
MD5 64e6eed6372fcce8357a8759c248e465
BLAKE2b-256 fe265c4032cad10cf3503a37349aacc50e106b7024849e1e3058ecaa34624656

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page