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.1.0.tar.gz
(8.3 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.1.0-py3-none-any.whl
(11.6 kB
view details)
File details
Details for the file mailtd-1.1.0.tar.gz.
File metadata
- Download URL: mailtd-1.1.0.tar.gz
- Upload date:
- Size: 8.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bbba314979f2878d1d4972597f713f6b5c6cd0fadea7c5d284584153253bea5c
|
|
| MD5 |
405c19323b0906f4fff947be1c26984a
|
|
| BLAKE2b-256 |
b0e27cc9755748cec69375f116cfedcb569a3f89f027dbd881e127066ff8fa2d
|
File details
Details for the file mailtd-1.1.0-py3-none-any.whl.
File metadata
- Download URL: mailtd-1.1.0-py3-none-any.whl
- Upload date:
- Size: 11.6 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 |
84f53a0db4fb82dda832015e7ba25285b097bf954153f994b0fa9aada15f5ad0
|
|
| MD5 |
114d097a6933cd7369eb11a207578e54
|
|
| BLAKE2b-256 |
c9c73b368e7c5972f8238c0218cc1072cdaac8df5a46f53b18505a2bdc176772
|