byjg/sms-client

A lightweight, extensible PHP library for sending SMS messages through multiple providers.

Fund package maintenance!
byjg

Installs: 8 211

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 1

Open Issues: 0

pkg:composer/byjg/sms-client

5.0.1 2025-04-15 19:58 UTC

This package is auto-updated.

Last update: 2025-11-25 14:25:30 UTC


README

Sponsor Build Status Opensource ByJG GitHub source GitHub license GitHub release

A lightweight, extensible PHP library for sending SMS messages through multiple providers.

Features

  • Low code - Simple, intuitive API for sending SMS
  • Provider agnostic - Support for multiple SMS providers
  • Extensible - Easy to implement custom providers
  • Phone formatting - Built-in phone number validation and formatting
  • Multi-provider support - Route messages to different providers based on country codes

Installation

composer require byjg/sms-client

Quick Start

use ByJG\SmsClient\Message;
use ByJG\SmsClient\Provider\ProviderFactory;
use ByJG\SmsClient\Provider\TwilioMessagingProvider;
use ByJG\Uri\Uri;

// Register and create provider
ProviderFactory::registerProvider(TwilioMessagingProvider::class);
$provider = ProviderFactory::create(new Uri("twilio://$accountSid:$authToken@default"));

// Send message
$response = $provider->send(
    "+12221234567",
    (new Message("Hello World!"))->withSender("+12223217654")
);

// Check result
if ($response->isSent()) {
    echo "Message sent successfully!";
}

Documentation

Available Providers

Provider URI Scheme Documentation Region
Twilio Messaging twilio://accountId:authToken@default Twilio SMS Global
Twilio Verify twilio_verify://accountId:authToken@serviceSid Twilio Verify Global
ByJG SMS byjg://username:password@default ByJG Brazil
Fake Sender fakesender:// Testing only Testing

Multi-Provider Setup

Route messages to different providers based on country codes:

use ByJG\SmsClient\Provider\ProviderFactory;
use ByJG\SmsClient\Provider\TwilioMessagingProvider;
use ByJG\SmsClient\Provider\ByJGSmsProvider;
use ByJG\SmsClient\Message;

// Register providers
ProviderFactory::registerProvider(TwilioMessagingProvider::class);
ProviderFactory::registerProvider(ByJGSmsProvider::class);

// Associate with country codes
ProviderFactory::registerServices("twilio://accountId:authToken@default", "+1");
ProviderFactory::registerServices("byjg://username:password@default", "+55");

// Automatically routes to the right provider
ProviderFactory::createAndSend("+12221234567", new Message("Hello USA!"));
ProviderFactory::createAndSend("+5521987654321", new Message("Olá Brasil!"));

Phone Number Formatting

Format and validate phone numbers with country-specific rules:

use ByJG\SmsClient\Phone;
use ByJG\SmsClient\PhoneFormat\USPhoneFormat;

$phone = Phone::phone("2345678900", new USPhoneFormat())
    ->withPlusPrefix()
    ->withCountryCode();

echo $phone->hydrate();  // Output: +12345678900
echo $phone->format();   // Output: +1(234)567-8900

// Validate phone numbers
$isValid = $phone->validate(throwException: false);

Dependencies

flowchart TD
    byjg/sms-client --> byjg/webrequest
Loading

Open source ByJG