Python package for API requests to the Pax8 partner API
Project description
Pax8 Partner API Library
This is a python implementation of the Pax8 Partner API. It is still somewhat a work in progress, but is usable. Please report any errors you come along under Issues, or submit a pull request, and I'll get it fixed.
Functionality
The following section gives an overview of the implemented functionality up to this point, and a roadmap of what's still to be implemented. There are some differences between the API implementation and the official documentation, see the section Pax8 API Errors for more information.
General
- Get Access Token
- Access Token Caching (To Disk)
- Access Token Caching (To Redis/Memcache) (To Do)
- Encrypted Access Token Caching (To Do)
- Automatic rate limiting (To Do)
API Token Caching
The API token received from Pax8 in exchange for the client_id and secret is a relatively long-lived token, so the option for caching it to disk exists (and in the future also to redis and memcache). This is not done by default for security reasons, but can be enabled by setting the cache_token parameter to true and setting the cache_location parameter to where you want the file to be saved. The token is currently not encrypted, so it is recommended to only use this option if you are the only user of the machine. The default save location is in the users home folder.
API Resources
Struck resources are not yet implemented. Resources marked Experimental are a part of the undocumented Pax8 API, see more information below.
-
client.Company
.list(filter=filters.CompanyFilter)
.get(id: uuid)
.create(company: types.Company)
.get_ms_tenant_id(id: uuid)
EXPERIMENTAL.list_contacts(id: uuid)
.get_contact(id: uuid, contact_id: uuid)
.create_contact(contact: types.Contact)
.update_contact(contact: types.Contact)
.delete_contact(id: uuid, contact_id: uuid)
-
client.Product
.list(filter: filters.ProductFilter)
.get(id: uuid)
.list_provisioning_details(id: uuid)
.list_dependencies(id: uuid)
.list_pricing(id: uuid)
-
client.Order
.list(filter: filters.OrderFilter)
.get(id: uuid)
.create(order: types.Order)
-
client.Subscription
.list(filter: filters.SubscriptionFilter)
.get(id: uuid)
.get_history(id: uuid)
.update(subscription: types.Subscription)
.delete(id: uuid)
.list_usage_summaries(id: uuid, filter: filters.UsageSummaryFilter)
-
client.Invoice
.list(filter: filters.InvoiceFilter)
.get(id: uuid)
.list_items(id: uuid, filter: filters.InvoiceItemFilter)
-
client.UsageSummary
.list_for_subscription(id: uuid, filter: filters.UsageSummaryFilter)
.get(id: uuid)
.list_usage_lines(id: uuid, filter: filters.UsageSummaryLineFilter)
V3 API Resources (Undocumented APIs)
There are several undocumented APIs used to implement the functionality of the Pax8 Partner Portal (https://app.pax8.com) that have been implemented into this library, marked Experimental above due to their undocumented nature. These APIs are not guaranteed to be stable, and may change at any time. Use at your own risk.
If there are any undocumented APIs you would like to see implemented, please open an issue and I'll get to it as soon as I can. You can find the full list of available endpoints here: https://app.pax8.com/p8p/api/v3/
Installation
From PyPi
pip3 install pax8
From Source
git clone https://github.com/scheibling/py-pax8.git
cd py-pax8
python3 setup.py install
Usage
Creating an API token
To be able to use the API, you must first create a token in the Pax8 Partner Application (https://app.pax8.com). to be able to see the option for doing this, you must first register a partner shell under Tools -> Partner Shells -> Pax8 Partner API Partner Shell. Once this is done, you can create a new client ID and secret under Profile Picture -> Edit Profile -> Developer Apps -> Create.
Usage Examples
Importing the library and retrieving resources
from pax8 import Pax8Client
from pax8 import filters
from pax8 import enums
client = Pax8Client(
client_id='your_client_id',
client_secret='your_client_secret',
cache_token=True,
cache_location='~/pax8_token.json'
)
# List all customers (companies)
client.Company.list()
# List all customers (companies) with pagination and the following options
# First Page
# Page Size 10
# Sort by Name (Ascending)
# Filter by city = 'New York'
companies = client.Company.list(
filters.CompanyFilter(
page=0,
size=10,
sort=enums.CompanySortBy.NAME,
sort_direction=enums.SortDirection.ASCENDING,
city='New York'
)
)
# Recursively get all contacts and the MS Partner ID for the companies retrieved above
for company in companies:
print(f'Company: {company.name}')
print(f'MS Partner ID: {client.Company.get_ms_tenant_id(company.id)}')
print('Contacts:')
for contact in client.Company.list_contacts(company.id):
print(f'\t{contact.first_name} {contact.last_name} ({contact.phoneNumber})')
Pax8 API Errors
Subscriptions
- Subscriptions does not contain a "commitmentTerm" field as stated in the documentation, but instead contains a "commitment" field
Orders
- When an order retrieved from the API and order is placed by the partner, the API returns "Pax8Partner" instead of "Pax8 Partner". When creating a new order, the required value is "Pax8 Partner".
Contacts
- Contacts contains an undocumented field "phoneNumber" in addition to the field called "phone".
- Contacts contains an undocumented field "phoneCountryCode"
- Contacts contains an undocumented field "phoneCountryCallingcode"
Invoice
- InvoiceItem.rateType values are documented as lowercase, but are first-letter-uppercase in the API (at least for Flat, not been able to verify the others)
Usage Summaries
- List Usage Summary Lines does not specify any pagination options for the API call, but the API does support pagination.
Acknowledgements
- dkschruteBeets for the Powershell implementation of the API, which was a great reference for this (especially for the undocumented APIs)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pax8-0.5.tar.gz
.
File metadata
- Download URL: pax8-0.5.tar.gz
- Upload date:
- Size: 25.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | df555375ae4ab16d14a1aca68248c40d1ef73f9a2170f2b4d21cca24c22a6043 |
|
MD5 | 7f4328516210e5c68fe253d0262249d1 |
|
BLAKE2b-256 | dd741b5f707a745c25abdec3c204994e07c166b8bc5f677d30c0303a4d3b7eba |
File details
Details for the file pax8-0.5-py3-none-any.whl
.
File metadata
- Download URL: pax8-0.5-py3-none-any.whl
- Upload date:
- Size: 24.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | beefd1b92ed5d9c99345d835fd51d57d26e071c9328ffb9df70b89bad172987e |
|
MD5 | 7f2b67663ec61e1e03288e2a8aec21f3 |
|
BLAKE2b-256 | a3b3ba5d83d9c52cd39b5bf854655fc2f762c1e3ef2c2c6c57181df7284f3340 |