https://github.com/ionos-cloud/sdk-python-dataplatform
https://github.com/ionos-cloud/sdk-python-dataplatform
Last synced: 8 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/ionos-cloud/sdk-python-dataplatform
- Owner: ionos-cloud
- License: apache-2.0
- Created: 2022-08-16T12:22:41.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-01-19T14:31:18.000Z (almost 2 years ago)
- Last Synced: 2025-04-22T13:48:21.765Z (9 months ago)
- Language: Python
- Size: 98.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[](https://github.com/ionos-cloud/sdk-resources/actions/workflows/ci-dataplatform-python.yml)
[](https://gitter.im/ionos-cloud/sdk-general)
[](https://sonarcloud.io/summary?id=sdk-python-dataplatform)
[](https://sonarcloud.io/summary/new_code?id=sdk-python-dataplatform)
[](https://sonarcloud.io/summary/new_code?id=sdk-python-dataplatform)
[](https://sonarcloud.io/summary/new_code?id=sdk-python-dataplatform)
[](https://sonarcloud.io/summary/new_code?id=sdk-python-dataplatform)
[](https://sonarcloud.io/summary/new_code?id=sdk-python-dataplatform)
[](https://github.com/ionos-cloud/sdk-python-dataplatform/releases/latest)
[](https://github.com/ionos-cloud/sdk-python-dataplatform/releases/latest)
[](https://pypi.org/project/ionoscloud-dataplatform/)

# 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.
The 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](https://cloud.ionos.com/compute/signup).
### Virtual Data Center (VDC)
The Managed Stackable Data Platform needs a virtual data center (VDC) hosting the cluster.
This could either be a VDC that already exists, especially if you want to connect the managed data platform
to other services already running within your VDC.
Otherwise, if you want to place the Managed Stackable Data Platform 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 Cloud CLI (ionosctl), or the DCD Web interface.
For more information, see the [official documentation](https://docs.ionos.com/cloud/getting-started/tutorials/data-center-basics)
### Get a authentication token
To interact with this API a user specific authentication token is needed.
This token can be generated using the IONOS Cloud CLI the following way:
```
ionosctl token generate
```
For more information [see](https://docs.ionos.com/cli-ionosctl/subcommands/authentication/token-generate)
### Create a new DataPlatformCluster
Before using the Managed Stackable Data Platform, a new DataPlatformCluster must be created.
To create a cluster, use the [Create DataPlatformCluster](paths./clusters.post) 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](#/DataPlatformCluster/getCluster) 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](paths./clusters/{clusterId}/nodepools.post)
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](paths./clusters/{clusterId}/kubeconfig.get) 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](https://docs.stackable.tech/home/getting_started.html#_deploying_stackable_services)
## 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](https://api.ionos.com/docs/authentication/).
### Basic Auth
The basic auth scheme uses the IONOS Cloud user credentials in form of a Basic Authentication Header
accordingly to [RFC7617](https://datatracker.ietf.org/doc/html/rfc7617)
### API Key as Bearer Token
The Bearer auth token used at the API Gateway is a user-related token created with the IONOS Cloud CLI.
(See the [documentation](https://docs.ionos.com/cli-ionosctl/subcommands/authentication/token-generate) 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 data center 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 read-only 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](https://pypi.org/) you can install it by using:
```bash
pip install ionoscloud-dataplatform
```
If the python package is hosted on a repository, you can install directly using:
```bash
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:
```python
import ionoscloud_dataplatform
```
### Setuptools
Install via [Setuptools](http://pypi.python.org/pypi/setuptools).
```bash
python setup.py install --user
```
or `sudo python setup.py install` to install the package for all users
Then import the package:
```python
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:
```python
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:
```python
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:
```python
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=
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 | [**clusters_delete**](docs/api/DataPlatformClusterApi.md#clusters_delete) | **DELETE** /clusters/{clusterId} | Delete a DataPlatformCluster |
| DataPlatformClusterApi | [**clusters_find_by_id**](docs/api/DataPlatformClusterApi.md#clusters_find_by_id) | **GET** /clusters/{clusterId} | Retrieve a DataPlatformCluster |
| DataPlatformClusterApi | [**clusters_get**](docs/api/DataPlatformClusterApi.md#clusters_get) | **GET** /clusters | List the DataPlatformClusters |
| DataPlatformClusterApi | [**clusters_kubeconfig_find_by_cluster_id**](docs/api/DataPlatformClusterApi.md#clusters_kubeconfig_find_by_cluster_id) | **GET** /clusters/{clusterId}/kubeconfig | Read the Kubeconfig |
| DataPlatformClusterApi | [**clusters_patch**](docs/api/DataPlatformClusterApi.md#clusters_patch) | **PATCH** /clusters/{clusterId} | Partially Modify a DataPlatformCluster |
| DataPlatformClusterApi | [**clusters_post**](docs/api/DataPlatformClusterApi.md#clusters_post) | **POST** /clusters | Create a DataPlatformCluster |
| DataPlatformMetaDataApi | [**versions_get**](docs/api/DataPlatformMetaDataApi.md#versions_get) | **GET** /versions | Managed Stackable Data Platform API Versions |
| DataPlatformNodePoolApi | [**clusters_nodepools_delete**](docs/api/DataPlatformNodePoolApi.md#clusters_nodepools_delete) | **DELETE** /clusters/{clusterId}/nodepools/{nodepoolId} | Remove a DataPlatformNodePool from a DataPlatformCluster |
| DataPlatformNodePoolApi | [**clusters_nodepools_find_by_id**](docs/api/DataPlatformNodePoolApi.md#clusters_nodepools_find_by_id) | **GET** /clusters/{clusterId}/nodepools/{nodepoolId} | Retrieve a DataPlatformNodePool |
| DataPlatformNodePoolApi | [**clusters_nodepools_get**](docs/api/DataPlatformNodePoolApi.md#clusters_nodepools_get) | **GET** /clusters/{clusterId}/nodepools | List the DataPlatformNodePools of a DataPlatformCluster |
| DataPlatformNodePoolApi | [**clusters_nodepools_patch**](docs/api/DataPlatformNodePoolApi.md#clusters_nodepools_patch) | **PATCH** /clusters/{clusterId}/nodepools/{nodepoolId} | Partially Modify a DataPlatformNodePool |
| DataPlatformNodePoolApi | [**clusters_nodepools_post**](docs/api/DataPlatformNodePoolApi.md#clusters_nodepools_post) | **POST** /clusters/{clusterId}/nodepools | Create a DataPlatformNodePool for a distinct DataPlatformCluster |
## Documentation For Models
All URIs are relative to *https://api.ionos.com/dataplatform*
API models list
- [AvailabilityZone](docs/models/AvailabilityZone)
- [Cluster](docs/models/Cluster)
- [ClusterListResponseData](docs/models/ClusterListResponseData)
- [ClusterResponseData](docs/models/ClusterResponseData)
- [CreateClusterProperties](docs/models/CreateClusterProperties)
- [CreateClusterRequest](docs/models/CreateClusterRequest)
- [CreateNodePoolProperties](docs/models/CreateNodePoolProperties)
- [CreateNodePoolRequest](docs/models/CreateNodePoolRequest)
- [ErrorMessage](docs/models/ErrorMessage)
- [ErrorResponse](docs/models/ErrorResponse)
- [MaintenanceWindow](docs/models/MaintenanceWindow)
- [Metadata](docs/models/Metadata)
- [NodePool](docs/models/NodePool)
- [NodePoolListResponseData](docs/models/NodePoolListResponseData)
- [NodePoolResponseData](docs/models/NodePoolResponseData)
- [PatchClusterProperties](docs/models/PatchClusterProperties)
- [PatchClusterRequest](docs/models/PatchClusterRequest)
- [PatchNodePoolProperties](docs/models/PatchNodePoolProperties)
- [PatchNodePoolRequest](docs/models/PatchNodePoolRequest)
- [StorageType](docs/models/StorageType)
[[Back to API list]](#documentation-for-api-endpoints) [[Back to Model list]](#documentation-for-models)