Skip to main content

A Python library for sending SMS, email and WhatsApp messages

Project description

TextTalk Communication Library

A Python library for sending SMS, email and WhatsApp messages. This package provides a simple and efficient interface for sending both individual and bulk messages across multiple communication channels.

Features

  • Send individual and bulk SMS messages
  • Send individual and bulk email messages
  • Send individual and bulk WhatsApp messages
  • Configurable through environment variables or direct configuration
  • Comprehensive error handling
  • Type hints for better IDE support
  • Simple and intuitive API

Installation

  1. Clone the repository:
git clone <repository-url>
cd chat
  1. Install the required dependencies:
pip install -r requirements.txt

Configuration

You can configure the SMS client in two ways:

1. Using Environment Variables

Set the following environment variables:

export SMS_API_KEY='your_api_key'
export SMS_PARTNER_ID='your_partner_id'
export SMS_SHORTCODE='your_shortcode'

2. Using Direct Configuration

from sms import SMSConfig

config = SMSConfig(
    api_key='your_api_key',
    partner_id='your_partner_id',
    shortcode='your_shortcode'
)

Usage

Basic Usage

from sms import SMSClient

# Using environment variables
client = SMSClient()

# Send a single SMS
success = client.send_sms(
    to_number='+254713164545',
    message='Hello from TextTalk!'
)

# Send bulk SMS
success = client.send_bulk_sms(
    message='Hello from TextTalk!',
    to_numbers=['+254713164545', '+254713164546']
)

With Custom Configuration

from sms import SMSClient, SMSConfig

config = SMSConfig(
    api_key='your_api_key',
    partner_id='your_partner_id',
    shortcode='your_shortcode'
)

client = SMSClient(config)

Error Handling

The library provides custom exceptions for better error handling:

from sms import SMSClient, SMSException, ConfigurationError, MessageError

try:
    client = SMSClient()
    client.send_sms(to_number='+254713164545', message='Hello!')
except ConfigurationError as e:
    print(f"Configuration error: {e}")
except MessageError as e:
    print(f"Message error: {e}")
except SMSException as e:
    print(f"General SMS error: {e}")

API Reference

SMSClient

__init__(config: Optional[SMSConfig] = None)

Initialize the SMS client with configuration.

send_sms(to_number: str, message: str) -> bool

Send a single SMS message.

Parameters:

  • to_number (str): The recipient's phone number
  • message (str): The message content

Returns:

  • bool: True if the message was sent successfully

send_bulk_sms(message: str, to_numbers: List[str]) -> bool

Send SMS messages to multiple recipients.

Parameters:

  • message (str): The message content
  • to_numbers (List[str]): List of recipient phone numbers

Returns:

  • bool: True if the messages were sent successfully

SMSConfig

Configuration class for managing API credentials and settings.

Parameters:

  • api_key (Optional[str]): API key for authentication
  • partner_id (Optional[str]): Partner ID for the service
  • shortcode (Optional[str]): Shortcode for sending messages

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

texttalk-0.0.8.tar.gz (4.8 kB view details)

Uploaded Source

Built Distribution

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

texttalk-0.0.8-py3-none-any.whl (6.7 kB view details)

Uploaded Python 3

File details

Details for the file texttalk-0.0.8.tar.gz.

File metadata

  • Download URL: texttalk-0.0.8.tar.gz
  • Upload date:
  • Size: 4.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for texttalk-0.0.8.tar.gz
Algorithm Hash digest
SHA256 21091d8f30a73679b39a04924b7e7bc90e432bcd99ea3d4ffab6a12759318f08
MD5 de5fe96417254c948c38bdd1c1e9e8ca
BLAKE2b-256 1e3948542c072738cc87b49833249bd3963b89179500d2d767c4d31262d00e93

See more details on using hashes here.

Provenance

The following attestation bundles were made for texttalk-0.0.8.tar.gz:

Publisher: release.yaml on thaka-creations/chat

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file texttalk-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: texttalk-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 6.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for texttalk-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1b07161ae121c89f69a6138f75e6f219a0f4a2db3b1c75b3c4a080a8815a2e27
MD5 092ad7bcace2ee2b2c478c4dcec63295
BLAKE2b-256 729ea7c9ca9752d2ccc639920546da045d20f4105e4ff0012d8e585cfc9c7f0e

See more details on using hashes here.

Provenance

The following attestation bundles were made for texttalk-0.0.8-py3-none-any.whl:

Publisher: release.yaml on thaka-creations/chat

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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