Skip to main content

Simple Python client for PaichaCloud disposable email API

Project description

PaichaCloud Client 📦

PaichaCloud のメール受信 API を扱う軽量 Python クライアント。 デフォルトはドメイン一覧の取得 → ランダム選択 → 新規メール発行です。必要に応じてドメイン固定、既存アドレスでの閲覧にも対応。


✨ 特徴

  • ドメイン一覧の取得(初回の change_mailbox は一覧取得専用として実行、発行メールは破棄)
  • ランダム/任意ドメインでの 新規メールアドレス発行
  • 既存のメールアドレスでの受信閲覧(発行スキップ)
  • 受信一覧(サマリー)・個別メール(本文含む詳細)の取得
  • 件名/送信者フィルタ、新着待機(ポーリング)
  • ドメイン一覧の整形表示、CLI 付属
  • 例外・タイムアウト・requests.Session 差し替え等の基本拡張

⚡ インストール

pip install mail-paicha-cloud

依存: requests


🚀 クイックスタート

from paichacloud import PaichaCloudClient

# 1) ドメインは自動取得 → ランダム選択 → new_email を発行
client = PaichaCloudClient()

print("Email:", client.email)          # 例: 0918xxxx@paicharm.tokyo
print("Domains (cached):", client.list_domains())

# 2) 受信一覧(サマリー)
inbox = client.inbox()
for m in inbox:
    print("ID:", m["id"], "Subject:", m.get("subject"))

# 3) 個別メールの詳細(本文など)
if inbox:
    detail = client.get_mail(inbox[0]["id"])
    # 本文は API 仕様により 'text' / 'body' / 'html' などのキーに入ることがあります
    print(detail)

📬 メールを見る(全パターン)

A. 自動で新規アドレスを発行して読む(デフォルト)

client = PaichaCloudClient()
print(client.email)
print(client.inbox())

B. 既存のメールアドレスで受信を見る(発行スキップ)

すでに把握している一時アドレスを使いたい場合

from paichacloud import PaichaCloudClient

client = PaichaCloudClient(email="already_known@some-domain.tld")
inbox = client.inbox()            # そのアドレスの受信一覧
if inbox:
    detail = client.get_mail(inbox[0]["id"])
    print(detail)

C. 特定ドメインで新規アドレスを発行して読む

client = PaichaCloudClient(domain="niganiga.link")
print(client.email)
print(client.inbox())

D. ドメイン一覧から好みで選んで発行して読む

client = PaichaCloudClient()         # とりあえず起動(この時点で1つ発行される)
domains = client.fetch_domains()     # 一覧だけを取り直し(この時の new_email は内部で破棄)
# 例: .tokyo 優先、無ければ先頭
choices = [d for d in domains if d.endswith(".tokyo")] or domains
client.change_mailbox(choices[0])    # 本命で発行し直し
print(client.email)
print(client.inbox())

🧭 ドメイン操作

# 最新のドメイン一覧を取得(※この呼び出しで返る new_email は破棄されます)
domains = client.fetch_domains()
print(domains)

# 整形表示
print(client.format_domains(columns=3))

🔎 受信を扱う

受信一覧(サマリー)

inbox = client.inbox()
for mail in inbox:
    print(mail["id"], mail.get("subject"), mail.get("from"))

個別メール(本文・ヘッダ等)

if inbox:
    mail_id = inbox[0]["id"]
    detail = client.get_mail(mail_id)

    # よくある本文の取り出し(環境によりキーが異なります)
    body = detail.get("text") or detail.get("body") or detail.get("html") or ""
    print(body[:500])

件名/送信者フィルタ

filtered = client.filter_inbox(inbox, subject_contains="Verify", sender_contains="noreply@")
print(filtered)

条件に合う新着を待機(ポーリング)

msg = client.wait_for(subject_contains="Verify", timeout=60, interval=2)
if msg:
    print("Found:", msg.get("subject"))

💻 CLI

# ドメイン一覧(最新)を表示
python -m paichacloud --list-domains

# 自動発行 → 受信一覧を表示
python -m paichacloud --print-inbox

# 条件に合う新着を待機(件名に "Verify" を含む)
python -m paichacloud --wait --subject-contains Verify

既存アドレスで受信を見る(発行スキップ)

python -m paichacloud --email already_known@some-domain.tld --print-inbox

主なオプション:

  • --list-domains : ドメイン一覧を最新取得して表示
  • --print-inbox : 受信一覧を JSON 出力
  • --wait : 条件に合う新着を待機
  • --timeout <sec> / --interval <sec> : 待機タイムアウト/間隔
  • --domain <name>: 特定ドメインで 直ちに 新規メールを発行
  • --email <addr> : 既存メールを使用(発行スキップ)
  • --probe-domain <name> : ドメイン一覧の取得に使うプローブ用ドメイン(既定: paicharm.tokyo
  • --seed <int> : ドメインのランダム選択にシード付与(再現性)

⚙️ 拡張・実運用向け Tips

例外ハンドリング

from paichacloud import PaichaCloudClient, PaichaCloudError

try:
    client = PaichaCloudClient(timeout=15.0)
    inbox = client.inbox()
except PaichaCloudError as e:
    print("mail error:", e)

タイムアウト / リダイレクト

client = PaichaCloudClient(timeout=15.0, allow_redirects=True)

requests.Session の差し替え(プロキシ・リトライ等)

import requests
s = requests.Session()
s.proxies = {"https": "http://proxy.local:8080"}
client = PaichaCloudClient(session=s)

ランダム選択の再現性(テスト)

import random
client = PaichaCloudClient(rng=random.Random(42))

with 構文

from paichacloud import PaichaCloudClient
with PaichaCloudClient() as client:
    print(client.email)
    print(client.inbox())

🔍 API リファレンス(抜粋)

class PaichaCloudClient(
    domain: str | None = None, *,
    email: str | None = None,
    session: requests.Session | None = None,
    timeout: float = 30.0,
    allow_redirects: bool = True,
    rng: random.Random | None = None,
    probe_domain: str = "paicharm.tokyo",
)
  • 既定挙動domain=None, email=None

    1. ドメイン一覧のみ取得(この時の new_email は破棄)
    2. 一覧からランダム選択で change_mailbox 実行 → email を確保
  • domain を与えると、そのドメインで 直ちに 新規メールを発行

  • email を与えると、発行スキップで既存メールを即参照

属性

  • email: str | None … 現在のメールアドレス
  • domains: list[str] … 直近に取得したドメイン一覧(キャッシュ)

主要メソッド

  • fetch_domains() -> list[str] … ドメイン一覧の最新取得(発行は破棄)
  • list_domains() -> list[str] … キャッシュ返却(最新が必要なら fetch_domains()
  • format_domains(columns: int = 2, padding: int = 2) -> str … 一覧の整形表示
  • change_mailbox(domain: str) -> MailboxChange … 指定ドメインで新規発行
  • inbox() -> list[dict] … 受信一覧(配列)
  • get_mail(mail_id: str) -> dict … 個別メールの詳細
  • filter_inbox(..., subject_contains=None, sender_contains=None) -> list[dict]
  • wait_for(..., timeout=60.0, interval=2.0, return_detail=True) -> dict | None
  • close() -> None(with 構文対応)

例外

  • PaichaCloudError … クライアント共通の例外

🧩 トラブルシューティング

  • inbox() が空 まだ到着していない可能性。数秒〜数十秒待って再実行、または wait_for() を利用。
  • 本文が見つからない 環境でキー名が異なる可能性(text/body/html 等)。print(detail.keys()) で確認。
  • Email address is not set email 未設定で inbox() 等を呼んだ可能性。PaichaCloudClient() 初期化や change_mailbox() で発行/設定を。
  • ネットワーク/JSON エラー PaichaCloudError が送出。リトライ・タイムアウト調整・requests.Session の利用を検討。

最後に、AIだと思いましたか?

はい!正解です!

すべてのコードはGPT-5を使用して出力されました

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

mail_paicha_cloud-0.3.1.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

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

mail_paicha_cloud-0.3.1-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file mail_paicha_cloud-0.3.1.tar.gz.

File metadata

  • Download URL: mail_paicha_cloud-0.3.1.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for mail_paicha_cloud-0.3.1.tar.gz
Algorithm Hash digest
SHA256 fb9e335c689a205e7f21c96d3cd0ccd2c35baae30cb8845833bad4bd416b40f0
MD5 d9967720456dc5b65e14fd8ea311cabc
BLAKE2b-256 e99f54a3bddc3ea5fe2c345707ad3e71234fd9a719eac3672660e135c53b0511

See more details on using hashes here.

File details

Details for the file mail_paicha_cloud-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mail_paicha_cloud-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f784472c0f7f189502c4431ff6d0c570920519e51fb71e3f13180c01133b8ce7
MD5 a059f7bddd64de82809bf70349ee4014
BLAKE2b-256 b6933a0517d9ad925ec784584109505a62acef9a166146c1953c4c64cfab01b6

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