A library to access the mailbox.org Business API.
Project description
mailbox-org-api
A library to access the mailbox Business API.
Motivation and purpose
The goal is to provide a comprehensive, easy to use library to integrate the business features of mailbox.
Primarily, the library should mirror all calls and features of the mailbox API.
As a secondary goal, the library should implement helper functions for common tasks.
Installation
Using pip:
pip install mailbox-org-api
Directly from source:
pip install git+https://github.com/heshsum/mailbox-org-api
Usage
Basic usage is fairly straightforward. The naming scheme of the functions is similar to the naming at mailbox.org,
but instead of points, it uses underscores (e.g. instead of mail.add it's mail_add).
Additionally, some helper functions for common or more complicated tasks are included to make life a bit easier,
e.g. for changing plans, password and to retrieve invoices.
from mailbox_org_api import APIClient
username = 'foo'
password = 'bar'
# Initializing
api = APIClient.APIClient()
# Testing with hello.world
api.hello_world()
# Creating a new API session
api.auth(username, password)
# Testing the session with hello.innerworld
api.hello_innerworld()
# Changing account settings
api.account_set('foo', payment_type='invoice')
# Creating an inbox
api.mail_add('foo@bar.com', 's3cr3tp4ssw0rd', 'standard', 'First Name', 'Last Name')
# Here are some examples for helper functions provided by this package
# Changing an inbox password
api.mail_set_password('foo@bar.com', 'an0th3rS3cr3t')
# Changing an inbox plan
api.mail_set_plan('foo@bar.com', 'premium')
# Deactivating an inbox
api.mail_set_state('foo@bar.com', False)
# Changing alias addresses
api.mail_set_aliases('foo@bar.com', ['alias1@bar.com', 'alias2@bar.com'])
# Changing forward addresses
api.mail_set_forwards('foo@bar.com', ['forward1@bar.com', 'forward2@bar.com'])
# Closing the session
api.deauth()
Common tasks
mailbox_org_api includes a number of helper functions to make common tasks simpler. These include:
mail_set_password
This is a function to send a mail.setcommand and set a user's password.
Usage:
api.mail_set_password('user@testmail.tech', 'theNewPassword')
mail_set_password_require_reset
This function sends a mail.set command to set a user's password and require the user to change it upon the next login.
Usage:
api.mail_set_password('user@testmail.tech', 'theNewPassword')
The function will automatically set 'require_reset':True when sending the request.
mail_set_plan
This function sets the plan for an inbox.
Usage:
api.mail_set_plan('user@testmail.tech', 'standard')
mail_set_forwards
This function sets the forwards of an inbox.
Usage:
api.mail_set_forwards('user@testmail.tech', ['forward@testmail.tech', 'forward@testmail.tech'])
mail_set_aliases
This function sets the aliases of an inbox.
Usage:
api.mail_set_forwards('user@testmail.tech', ['alias1@testmail.tech', 'alias2@testmail.tech'])
mail_set_state
With this function an inbox can be (de-)activated. It sends a mail.set command with the active parameter.
Usage:
# Deactivates an inbox
api.mail_set_state('user@testmail.tech', 'False')
# Activates an inbox
api.mail_set_state('user@testmail.tech', 'True')
account_invoice_get_list
This function makes retrieving a list of all invoices easier.
It returns a list of all invoice id's for a given account.
Usage:
api.account_invoice_get_list('account_name')
account_invoice_get_token
In order to retrieve an invoice, a token is needed. Tokens change periodically.
This function helps to get the token for a given invoice ID.
Usage:
api.account_invoice_get_token('BMBO-1234-24')
account_invoice_get_pdf
Invoices are provided as Based64 encoded gz Strings. This function
- takes the invoice ID
- retrieves the token for the invoice
- gets the binary data
- decodes the Base64
- decompresses it
- returns the bytes of the actual PDF
Usage
invoice_id = 'BMBO-1234-24'
account_name = 'some_user'
with open(invoice_id + '.pdf', 'w') as file:
file.write(api.account_invoice_get_pdf(account_name, invoice_id))
Here be dragons
- I'm not a programmer. I'm not very good at this. Be aware of my incompetence.
- Implementation is not complete. Not all functions of the API have been implemented
- Type hinting is available for most functions, but not all of them.
E.g.mail_set()accepts kwargs due to the number of available attributes. In that case type errors will be returned if wrong types are provided.
API documentation
mailbox.org provides API documentation here: https://api.mailbox.org
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mailbox_org_api-2.2.tar.gz.
File metadata
- Download URL: mailbox_org_api-2.2.tar.gz
- Upload date:
- Size: 24.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a87a561df4188f8ce9306386ead6d8747356bbddbe94d0194373afec43e9019
|
|
| MD5 |
f628de13b6594a640507da20053e3eca
|
|
| BLAKE2b-256 |
922c258d59189dacc82a3881a13e76e9a252923f3d65a369033369b3029ddfb6
|
File details
Details for the file mailbox_org_api-2.2-py3-none-any.whl.
File metadata
- Download URL: mailbox_org_api-2.2-py3-none-any.whl
- Upload date:
- Size: 25.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1fe0dca8020530bfbef6d41399f4992d116d62c80dea214a546393bfd8f08ed8
|
|
| MD5 |
f18356f7f4389c72bf55bc14701a1f83
|
|
| BLAKE2b-256 |
0e8c65526c3b1ea7760e7dfd7b2c32e69e65ffdfd74a8b3e3a40a8ee3d29d6ed
|