Official Python SDK for the Mail.td developer email platform
Project description
mailtd
Official Python SDK for the Mail.td developer email platform.
Install
pip install mailtd
Requires Python 3.9+.
Quick Start
from mailtd import MailTD
client = MailTD("tm_pro_...")
# Create a mailbox
account = client.accounts.create("test@mail.td", password="mypassword")
# List messages
messages, page = client.messages.list(account.id)
# Get a message
msg = client.messages.get(account.id, messages[0].id)
print(msg.subject, msg.text_body)
Authentication
# With a Pro API token
client = MailTD("tm_pro_...")
# With custom base URL
client = MailTD("tm_pro_...", base_url="https://api.mail.td")
# As context manager
with MailTD("tm_pro_...") as client:
messages, _ = client.messages.list(account_id)
Resources
Accounts
domains = client.accounts.list_domains()
account = client.accounts.create("user@mail.td", password="pass123")
result = client.accounts.login("user@mail.td", password="pass123")
info = client.accounts.get(account_id)
client.accounts.delete(account_id)
Messages
messages, page = client.messages.list(account_id)
msg = client.messages.get(account_id, message_id)
eml = client.messages.get_source(account_id, message_id)
attachment = client.messages.get_attachment(account_id, message_id, 0)
client.messages.mark_as_read(account_id, message_id)
count = client.messages.batch_mark_as_read(account_id, all=True)
client.messages.delete(account_id, message_id)
Domains (Pro)
domains = client.domains.list()
result = client.domains.create("example.com")
status = client.domains.verify(domain_id)
client.domains.delete(domain_id)
Webhooks (Pro)
webhook = client.webhooks.create("https://example.com/hook", events=["email.received"])
deliveries = client.webhooks.list_deliveries(webhook.id)
secret = client.webhooks.rotate_secret(webhook.id)
client.webhooks.delete(webhook.id)
Sandbox (Pro)
info = client.sandbox.get_info()
messages, page = client.sandbox.list_messages()
msg = client.sandbox.get_message(message_id)
deleted = client.sandbox.purge_messages()
Tokens (Pro)
result = client.tokens.create("CI Token")
tokens = client.tokens.list()
client.tokens.revoke(token_id)
Billing (Pro)
status = client.billing.get_status()
client.billing.cancel()
client.billing.resume()
url = client.billing.get_portal_url()
Error Handling
from mailtd import MailTD, APIError
try:
client.accounts.create("taken@mail.td", password="...")
except APIError as e:
print(e.status) # 409
print(e.code) # "address_already_exists"
License
MIT
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
mailtd-1.2.0.tar.gz
(7.4 kB
view details)
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
mailtd-1.2.0-py3-none-any.whl
(10.5 kB
view details)
File details
Details for the file mailtd-1.2.0.tar.gz.
File metadata
- Download URL: mailtd-1.2.0.tar.gz
- Upload date:
- Size: 7.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9aae730196e9dea67fde0483d813d4558165ee7b4e5c57ea91cbef4fdcab9c48
|
|
| MD5 |
368b18dd115249959507c9479863201a
|
|
| BLAKE2b-256 |
ebff06553924b0d1c6183177f7f05fcf2ec9ba0ea624104700b723a6ccb1cf65
|
File details
Details for the file mailtd-1.2.0-py3-none-any.whl.
File metadata
- Download URL: mailtd-1.2.0-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5d42836467f6c8d36d5059257d26ca2edd159c82ba603192c2f386de3a6637e9
|
|
| MD5 |
a7f0d0ce8fee53139195b2afbff95f6e
|
|
| BLAKE2b-256 |
1824b87b1d2c1e31e69c341a1ee52a806a40c82e4504c37598e904db9328b446
|