Skip to main content

Bare Metal Cloud API

Project description

pnap-bmc-api

Create, power off, power on, reset, reboot, or shut down your server with the Bare Metal Cloud API. Deprovision servers, get or edit SSH key details, assign public IPs, assign servers to networks and a lot more. Manage your infrastructure more efficiently using just a few simple API calls.

Knowledge base articles to help you can be found here

All URLs are relative to (https://api.phoenixnap.com/bmc/v1/)

This Python package is automatically generated by the OpenAPI Generator project:

  • API version: 0.1
  • Package version: 2.3.0
  • Build package: org.openapitools.codegen.languages.PythonClientCodegen For more information, please visit https://phoenixnap.com/

Requirements.

Python 3.9+

Installation & Usage

pip install

You can install this package directly from the Python Package Index using:

$ pip install pnap_bmc_api

Then import the package:

import pnap_bmc_api

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 pnap_bmc_api

Tests

Execute pytest to run the tests.

Getting Started

Please follow the installation procedure and then run the following:

import pnap_bmc_api
from pnap_bmc_api.rest import ApiException
from pprint import pprint

# Defining the host is optional and defaults to https://api.phoenixnap.com/bmc/v1
# See configuration.py for a list of all supported configuration parameters.
configuration = pnap_bmc_api.Configuration(
    host = "https://api.phoenixnap.com/bmc/v1"
)

# The client must configure the authentication and authorization parameters
# in accordance with the API server security policy.
# Examples for each auth method are provided below, use the example that
# satisfies your auth use case.

configuration.access_token = os.environ["ACCESS_TOKEN"]


# Enter a context with an instance of the API client
with pnap_bmc_api.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    api_instance = pnap_bmc_api.QuotasApi(api_client)

    try:
        # List quotas
        api_response = api_instance.quotas_get()
        print("The response of QuotasApi->quotas_get:\n")
        pprint(api_response)
    except ApiException as e:
        print("Exception when calling QuotasApi->quotas_get: %s\n" % e)

To generate a token using the python-keycloak library:

from keycloak import KeycloakOpenID

clientId = "YOUR_CLIENT_ID"
clientSecret = "YOUR_CLIENT_SECRET"
serverUrl = "https://auth.phoenixnap.com/auth/"
realmName = "BMC"
grantType = "client_credentials"

keycloakOpenId =  KeycloakOpenID(server_url=serverUrl,
                        realm_name=realmName,
                        client_id=clientId,
                        client_secret_key=clientSecret)

ACCESS_TOKEN = keycloakOpenId.token(grant_type=grantType)['access_token']

Documentation for API Endpoints

All URIs are relative to https://api.phoenixnap.com/bmc/v1

Class Method HTTP request Description
QuotasApi quotas_get GET /quotas List quotas
QuotasApi quotas_quota_id_actions_request_edit_post POST /quotas/{quotaId}/actions/request-edit Request quota limit change.
QuotasApi quotas_quota_id_get GET /quotas/{quotaId} Get a quota.
SSHKeysApi ssh_keys_get GET /ssh-keys List SSH Keys.
SSHKeysApi ssh_keys_post POST /ssh-keys Create SSH Key.
SSHKeysApi ssh_keys_ssh_key_id_delete DELETE /ssh-keys/{sshKeyId} Delete SSH Key.
SSHKeysApi ssh_keys_ssh_key_id_get GET /ssh-keys/{sshKeyId} Get SSH Key.
SSHKeysApi ssh_keys_ssh_key_id_put PUT /ssh-keys/{sshKeyId} Edit SSH Key.
ServersApi delete_private_network DELETE /servers/{serverId}/network-configuration/private-network-configuration/private-networks/{privateNetworkId} Removes the server from private network.
ServersApi servers_get GET /servers List servers.
ServersApi servers_post POST /servers Create new server.
ServersApi servers_server_id_actions_deprovision_post POST /servers/{serverId}/actions/deprovision Deprovision a server.
ServersApi servers_server_id_actions_power_off_post POST /servers/{serverId}/actions/power-off Power off server.
ServersApi servers_server_id_actions_power_on_post POST /servers/{serverId}/actions/power-on Power on server.
ServersApi servers_server_id_actions_provision_post POST /servers/{serverId}/actions/provision Provision server.
ServersApi servers_server_id_actions_reboot_post POST /servers/{serverId}/actions/reboot Reboot server.
ServersApi servers_server_id_actions_reserve_post POST /servers/{serverId}/actions/reserve Reserve server.
ServersApi servers_server_id_actions_reset_post POST /servers/{serverId}/actions/reset Reset server.
ServersApi servers_server_id_actions_shutdown_post POST /servers/{serverId}/actions/shutdown Shutdown server.
ServersApi servers_server_id_actions_transfer_reservation POST /servers/{serverId}/actions/transfer-reservation Transfer server reservation.
ServersApi servers_server_id_delete DELETE /servers/{serverId} Delete server.
ServersApi servers_server_id_get GET /servers/{serverId} Get server.
ServersApi servers_server_id_ip_blocks_ip_block_id_delete DELETE /servers/{serverId}/network-configuration/ip-block-configurations/ip-blocks/{ipBlockId} Unassign IP Block from Server.
ServersApi servers_server_id_ip_blocks_post POST /servers/{serverId}/network-configuration/ip-block-configurations/ip-blocks Assign IP Block to Server.
ServersApi servers_server_id_patch PATCH /servers/{serverId} Patch a Server.
ServersApi servers_server_id_private_networks_patch PATCH /servers/{serverId}/network-configuration/private-network-configuration/private-networks/{privateNetworkId} Updates the server's private network's IP addresses
ServersApi servers_server_id_private_networks_post POST /servers/{serverId}/network-configuration/private-network-configuration/private-networks Adds the server to a private network.
ServersApi servers_server_id_public_networks_delete DELETE /servers/{serverId}/network-configuration/public-network-configuration/public-networks/{publicNetworkId} Removes the server from the Public Network
ServersApi servers_server_id_public_networks_patch PATCH /servers/{serverId}/network-configuration/public-network-configuration/public-networks/{publicNetworkId} Updates the server's public network's IP addresses.
ServersApi servers_server_id_public_networks_post POST /servers/{serverId}/network-configuration/public-network-configuration/public-networks Adds the server to a Public Network.
ServersApi servers_server_id_tags_put PUT /servers/{serverId}/tags Overwrite tags assigned for Server.

Documentation For Models

Documentation For Authorization

Authentication schemes defined for the API:

OAuth2

  • Type: OAuth
  • Flow: application
  • Authorization URL:
  • Scopes:
  • bmc: Grants full access to bmc-api.
  • bmc.read: Grants read only access to bmc-api.

Author

support@phoenixnap.com

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

pnap_bmc_api-2.3.0.tar.gz (55.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pnap_bmc_api-2.3.0-py3-none-any.whl (130.5 kB view details)

Uploaded Python 3

File details

Details for the file pnap_bmc_api-2.3.0.tar.gz.

File metadata

  • Download URL: pnap_bmc_api-2.3.0.tar.gz
  • Upload date:
  • Size: 55.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for pnap_bmc_api-2.3.0.tar.gz
Algorithm Hash digest
SHA256 6c2127ed87aeb76b27761222073dc930b2d6043cda9b177bc77d369e3d3d1a57
MD5 88b86f626342af57bdb4961e02462043
BLAKE2b-256 c3010d63d0fed25df4cd9b6da958cce2a2e7426c11849815d8564c800dbcd036

See more details on using hashes here.

File details

Details for the file pnap_bmc_api-2.3.0-py3-none-any.whl.

File metadata

  • Download URL: pnap_bmc_api-2.3.0-py3-none-any.whl
  • Upload date:
  • Size: 130.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for pnap_bmc_api-2.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 50741332f78e00a6c1dab8c6e5aed3be35f9462057b00ec14686fb6e76bc7b45
MD5 42faefb5ace2f056fd6829a7dae065a4
BLAKE2b-256 8c5b3b65db30d14ad8c6b513d2bbf894832155403ad6f3422c08a03d61502e2e

See more details on using hashes here.

Supported by

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