gradiwapp / gradiwapp-php-sdk
Official PHP SDK for GradiWapp External API - Multi-tenant WhatsApp SaaS Messaging Platform
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/gradiwapp/gradiwapp-php-sdk
Requires
- php: >=7.4
- guzzlehttp/guzzle: ^7.0
Suggests
- laravel/framework: ^7.0 || ^8.0 || ^9.0 || ^10.0 || ^11.0 || ^12.0
README
π Overview
The GradiWapp PHP SDK provides a clean, developer-friendly wrapper around the GradiWapp External API, powering multi-tenant WhatsApp messaging at scale.
It supports:
- All message types (text, image, media, file, locationβ¦)
- Webhooks
- Timezone-aware scheduling
- Multi-session messaging
- Laravel 7β12 integration
- Full HMAC authentication
This SDK is production-ready and built with Stripe/Twilio-level documentation quality.
π Table of Contents
- Overview
- Features
- Requirements
- Installation
- Configuration
- Quick Start
- Messaging
- Scheduling
- Message Status
- Webhooks
- Error Handling
- Advanced Usage
- Response Format
- Versioning
- Contributing
- License
π Features
- β Framework-agnostic (PHP 7.4+)
- β First-class Laravel 7β12 integration
- β Fully typed methods + PHPDoc
- β Timezone-aware scheduling (ISO8601 + IANA)
- β Webhook creation + signature verification
- β All message types supported
- β Clean exceptions & error classes
- β Internal base URL (cannot be changed)
- β Production-ready architecture
π§© Requirements
| Component | Version |
|---|---|
| PHP | >= 7.4 |
| Laravel | 7 β 12 |
| Extensions | cURL + JSON |
π₯ Installation
Non-Laravel Installation
composer require gradiwapp/gradiwapp-php-sdk
Before publishing on Packagist:
{
"repositories": [
{
"type": "vcs",
"url": "https://github.com/ahmednaserdev/gradiwapp-php-sdk.git"
}
],
"require": {
"gradiwapp/gradiwapp-php-sdk": "dev-main"
}
}
Laravel Installation
composer require gradiwapp/gradiwapp-php-sdk
Publish config:
php artisan vendor:publish --provider="GradiWapp\Sdk\Laravel\GradiWappServiceProvider" --tag=config
This generates:
config/gradiwapp.php
Add environment variables:
GRADIWAPP_API_KEY=your_key GRADIWAPP_API_SECRET=your_secret GRADIWAPP_TIMEOUT=30 GRADIWAPP_MAX_RETRIES=1 GRADIWAPP_VERIFY_SSL=true
Note: Base URL is internal and cannot be changed.
β‘ Quick Start
Plain PHP Example
use GradiWapp\Sdk\Client; use GradiWapp\Sdk\Config; $config = new Config( apiKey: 'your_key', apiSecret: 'your_secret' ); $client = new Client($config); $response = $client->messages()->sendText( to: '+123456', body: 'Hello from GradiWapp!' );
Laravel β Dependency Injection
public function send(GradiWapp\Sdk\Client $client) { return $client->messages()->sendText( to: '+123456', body: 'Hello!' ); }
Laravel β Facade
use GradiWapp\Sdk\Laravel\Facades\GradiWapp; GradiWapp::messages()->sendText('+123456', 'Hello!');
π¬ Messaging
Text Messages
$client->messages()->sendText('+123', 'Hello!');
Image Messages
$client->messages()->sendImage( '+123', 'https://example.com/image.jpg', caption: 'Check this out!' );
Media Messages
$client->messages()->sendMedia('+123', 'https://example.com/video.mp4');
Location Messages
$client->messages()->sendLocation( '+123', 40.7128, -74.0060, name: 'NYC', address: 'New York' );
File Messages
$client->messages()->sendFile( '+123', fileUrl: 'https://example.com/doc.pdf', filename: 'Invoice.pdf' );
Contact (vCard)
$client->messages()->sendContact( '+123', contactsId: 'whatsapp_contact_id' );
Reply Messages
$client->messages()->sendReply( '+123', 'This is a reply', replyToMessageId: '01ABC...' );
Text + Media Combination
$client->messages()->sendBoth( '+123', 'Hello!', mediaUrl: 'https://example.com/pic.jpg', caption: 'Nice image' );
β° Timezone-Aware Scheduling
ISO8601 Example
ScheduleOptions::fromIso8601('2025-11-15T08:02:00+03:00');
IANA Timezone
ScheduleOptions::at( new DateTimeImmutable('2025-11-15 08:00'), 'Africa/Cairo' );
π‘ Message Status
$client->messages()->getStatus('01ABC...');
π§© Webhooks
Create Webhook
$client->webhooks()->create( 'delivery', 'https://yourdomain.com/webhooks', secret: 'secret' );
Verify Signature
Webhooks::verifySignature($payload, $signature, $secret);
β Error Handling
Built-in typed exceptions:
AuthenticationExceptionValidationExceptionHttpExceptionGradiWappException
Example:
try { $client->messages()->sendText('+123', 'Hi'); } catch (ValidationException $e) { print_r($e->getErrors()); }
π§ Advanced Usage
Multiple Sessions
$client->messages()->sendText( '+123', 'Hi', sessionId: 'session_01' );
Priority
$client->messages()->sendText('+123', 'Hi', priority: 'high');
π¦ Response Format
Your backend returns:
{
"success": true,
"message": "Message queued successfully",
"data": {
"id": "01ARZ3N...",
"status": "queued"
}
}
π§ Versioning & SDK Stability
This SDK follows Semantic Versioning (SemVer):
- MAJOR β Breaking changes
- MINOR β New features
- PATCH β Bug fixes
π€ Contributing
Pull Requests are welcome!
π License
MIT License.