Skip to main content

Networks API

Project description

pnap-network-api

Create, list, edit and delete public/private networks with the Network API. Use public networks to place multiple servers on the same network or VLAN. Assign new servers with IP addresses from the same CIDR range. Use private networks to avoid unnecessary egress data charges. Model your networks according to your business needs.

Helpful knowledge base articles are available for multi-private backend networks, public networks and border gateway protocol peer groups.

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

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

  • API version: 1.0
  • Package version: 3.1.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_network_api

Then import the package:

import pnap_network_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_network_api

Tests

Execute pytest to run the tests.

Getting Started

Please follow the installation procedure and then run the following:

import pnap_network_api
from pnap_network_api.rest import ApiException
from pprint import pprint

# Defining the host is optional and defaults to https://api.phoenixnap.com/networks/v1
# See configuration.py for a list of all supported configuration parameters.
configuration = pnap_network_api.Configuration(
    host = "https://api.phoenixnap.com/networks/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_network_api.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    api_instance = pnap_network_api.BGPPeerGroupsApi(api_client)
    location = 'PHX' # str | If present will filter the result by the given location of the BGP Peer Group. (optional)

    try:
        # List BGP Peer Groups.
        api_response = api_instance.bgp_peer_groups_get(location=location)
        print("The response of BGPPeerGroupsApi->bgp_peer_groups_get:\n")
        pprint(api_response)
    except ApiException as e:
        print("Exception when calling BGPPeerGroupsApi->bgp_peer_groups_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/networks/v1

Class Method HTTP request Description
BGPPeerGroupsApi bgp_peer_groups_get GET /bgp-peer-groups List BGP Peer Groups.
BGPPeerGroupsApi bgp_peer_groups_peer_group_id_delete DELETE /bgp-peer-groups/{bgpPeerGroupId} Delete a BGP Peer Group.
BGPPeerGroupsApi bgp_peer_groups_peer_group_id_get GET /bgp-peer-groups/{bgpPeerGroupId} Get a BGP Peer Group.
BGPPeerGroupsApi bgp_peer_groups_peer_group_id_patch PATCH /bgp-peer-groups/{bgpPeerGroupId} Modify a BGP Peer Group.
BGPPeerGroupsApi bgp_peer_groups_post POST /bgp-peer-groups Create a BGP Peer Group.
PrivateNetworksApi private_networks_get GET /private-networks List Private Networks.
PrivateNetworksApi private_networks_network_id_delete DELETE /private-networks/{privateNetworkId} Delete a Private Network.
PrivateNetworksApi private_networks_network_id_get GET /private-networks/{privateNetworkId} Get a Private Network.
PrivateNetworksApi private_networks_network_id_put PUT /private-networks/{privateNetworkId} Update a Private Network.
PrivateNetworksApi private_networks_post POST /private-networks Create a Private Network.
PublicNetworksApi public_networks_get GET /public-networks List Public Networks.
PublicNetworksApi public_networks_network_id_delete DELETE /public-networks/{publicNetworkId} Delete a Public Network.
PublicNetworksApi public_networks_network_id_get GET /public-networks/{publicNetworkId} Get a Public Network.
PublicNetworksApi public_networks_network_id_ip_blocks_ip_block_id_delete DELETE /public-networks/{publicNetworkId}/ip-blocks/{ipBlockId} Removes the IP Block from the Public Network.
PublicNetworksApi public_networks_network_id_ip_blocks_post POST /public-networks/{publicNetworkId}/ip-blocks Adds an IP block to this public network.
PublicNetworksApi public_networks_network_id_patch PATCH /public-networks/{publicNetworkId} Update Public Network's Details.
PublicNetworksApi public_networks_post POST /public-networks Create a public network.

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_network_api-3.1.0.tar.gz (38.1 kB view details)

Uploaded Source

Built Distribution

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

pnap_network_api-3.1.0-py3-none-any.whl (73.4 kB view details)

Uploaded Python 3

File details

Details for the file pnap_network_api-3.1.0.tar.gz.

File metadata

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

File hashes

Hashes for pnap_network_api-3.1.0.tar.gz
Algorithm Hash digest
SHA256 947da6ab98a672721a6227d7ce89718db3eb0789df925bdc69f0ccd919e13686
MD5 471926dd34e3d394a3f1b0bfe53aea13
BLAKE2b-256 986ae0daf45b796b40ceba1563662269909beb7d16cd1400367ac598be92911e

See more details on using hashes here.

File details

Details for the file pnap_network_api-3.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pnap_network_api-3.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 236b7da746efdf0f6a91e47a197afd997d5cd6c7675308c3d6d7952ff21fe491
MD5 1eea95c359c26217171d7d5d3703ca32
BLAKE2b-256 9589dad0de0a3d9f4465da54361b4e1d0e0bd1a3fb69816e16d49a1af4e29cef

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