Skip to main content

Python client for Syriatel API

Project description

PySyriatel

Python client for Syriatel API.

Installation

pip install PySyriatel

Usage

Async

from syriatel import SyriatelAPI

async with SyriatelAPI(api_token="your_token") as api:
    # Get registered numbers
    numbers = await api.get_numbers()
    codes = await api.get_codes()
    numbers_codes = await api.get_numbers_codes()
    
    # Syriatel Cash - accepts phone number or secret code (auto-detected)
    balance = await api.syrcash.balance("0991234567")  # Phone number
    balance = await api.syrcash.balance("65288500")    # Secret code as string
    balance = await api.syrcash.balance(65288500)      # Secret code as int
    
    # Get transaction history (only successful transactions by default)
    incoming = await api.syrcash.get_incoming_history("0991234567")
    
    # Get all transactions including failed ones
    all_tx = await api.syrcash.get_incoming_history("0991234567", status="all")
    
    # Get only failed transactions
    failed = await api.syrcash.get_incoming_history("0991234567", status="failed")
    
    # Date filtering
    incoming = await api.syrcash.get_incoming_history(
        "0991234567",
        start_at="2024-01-01",
        end_at="2024-12-31"
    )
    
    outgoing = await api.syrcash.get_outgoing_history("0991234567")
    
    tx = await api.syrcash.find_incoming_transaction(
        "TXN123456",
        query="0991234567"
    )

Sync

from syriatel import SyriatelAPISync

with SyriatelAPISync(api_token="your_token") as api:
    numbers = api.get_numbers()
    balance = api.syrcash.balance("0991234567")
    balance = api.syrcash.balance(65288500)  # Secret code as int works too
    incoming = api.syrcash.get_incoming_history("0991234567")

API

SyriatelAPI / SyriatelAPISync

Method Returns Description
get_numbers() List[str] Active phone numbers
get_codes() List[str] Secret codes
get_numbers_codes() List[Tuple[str, str]] Number and code pairs

api.syrcash

Method Returns Description
balance(query) float Balance in SYP. Accepts phone number or secret code (auto-detected)
get_incoming_history(query, page, status, start_at, end_at) List[Transaction] Incoming transfers
get_outgoing_history(query, page, status, start_at, end_at) List[Transaction] Outgoing transfers
find_incoming_transaction(transaction_no, query) Transaction Find by transaction number

Notes:

  • query parameter auto-detects: if 10 digits starting with 09, it's a phone number, otherwise it's a secret code
  • status parameter: "success" (default), "failed", or "all"
  • Phone numbers and secret codes can be passed as strings or integers

Transaction

@dataclass
class Transaction:
    transaction_no: str
    date: str
    from_gsm: str
    to_gsm: str
    amount: float
    fee: float
    net: float
    channel: str
    status: str

Error Handling

from syriatel import (
    SyriatelAPIError,
    InvalidTokenError,
    SubscriptionExpiredError,
    FetchFailedError,
    NetworkError,
)

try:
    balance = await api.syrcash.balance("0991234567")
except SubscriptionExpiredError:
    print("Subscription expired")
except InvalidTokenError:
    print("Invalid token")
except NetworkError as e:
    print(f"Network error: {e}")

Rate Limits

  • Balance: 5 requests per minute per number
  • History: 5 requests per minute per number

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

pysyriatel-2.1.0.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

pysyriatel-2.1.0-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file pysyriatel-2.1.0.tar.gz.

File metadata

  • Download URL: pysyriatel-2.1.0.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for pysyriatel-2.1.0.tar.gz
Algorithm Hash digest
SHA256 18be488839de2872dac6a15580b66e6416a3acee3b2f43fab5187cf114c6fe70
MD5 7662429ff74e47364e548b1a41374e21
BLAKE2b-256 0190f4afc2da922b32c328b3e7bc3c097a4c93714945a3b08593dae22637a665

See more details on using hashes here.

File details

Details for the file pysyriatel-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: pysyriatel-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for pysyriatel-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3f258c7e2393b03fb8a8eced1975c01bd76531b23442316d6b056ca47e8dc5b9
MD5 681e59c535bd9ba33be37b6858303097
BLAKE2b-256 ffe0cca4d2df72cb5c5ac0d0a97c3b42dffe1cd0924bec3b62c7a2191a3379c1

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