PHP
Send SMS or MMS with PHP
Learn how to send your first SMS using the CCAI PHP SDK
Prerequisites
To get the most out of this guide, you'll need to:
- Sign up for a CCAI Trial Account here
- Get your Client ID from Account\Settings
- Create\Copy an API Key from Account Settings
1. Install
Get the CCAI PHP SDK
composer require cloudcontactai/ccai-php
Configuration
You can configure the client using environmental variables:
# Set your CCAI credentials as environment variables
export CCAI_CLIENT_ID="your-client-id"
export CCAI_API_KEY="your-api-key"
Or provide the code directly:
$ccai = new CCAI([
'clientId' => 'YOUR-CLIENT-ID',
'apiKey' => 'YOUR-API-KEY'
]);
2. Send SMS message
<?php
require 'vendor/autoload.php';
use CloudContactAI\CCAI\CCAI;
use CloudContactAI\CCAI\SMS\Account;
// Initialize the client
$ccai = new CCAI([
'clientId' => 'YOUR-CLIENT-ID',
'apiKey' => 'YOUR-API-KEY'
]);
// Send a single SMS
$response = $ccai->sms->sendSingle(
firstName: 'John',
lastName: 'Doe',
phone: '+15551234567',
message: 'Hello ${firstName}, this is a test message!',
title: 'Test Campaign'
);
echo "Message sent with ID: " . $response->id . "\n";
// Send to multiple recipients
$accounts = [
new Account('John', 'Doe', '+15551234567'),
new Account('Jane', 'Smith', '+15559876543')
];
$campaignResponse = $ccai->sms->send(
accounts: $accounts,
message: 'Hello ${firstName} ${lastName}, this is a test message!',
title: 'Bulk Test Campaign'
);
echo "Campaign sent with ID: " . $campaignResponse->campaignId . "\n";
3. Send MMS Message
<?php
/**
* Simple example of sending an MMS message using the CCAI PHP library
*/
require_once __DIR__ . '/../vendor/autoload.php';
use CloudContactAI\CCAI\CCAI;
// Replace with your actual credentials
$ccai = new CCAI([
'clientId' => getenv('CCAI_CLIENT_ID') ?: 'YOUR_CLIENT_ID',
'apiKey' => getenv('CCAI_API_KEY') ?: 'YOUR_API_KEY'
]);
// Path to the image file you want to send
$filename = 'AllCode.png';
$imagePath = __DIR__ . '/AllCode.png';
$contentType = 'image/png';
try {
// Send an MMS to a single recipient
$response = $ccai->mms->sendWithImage(
$imagePath,
$contentType,
[
[
'firstName' => 'Jane',
'lastName' => 'Doe',
'phone' => '+15555555555'
]
],
'Hi ${firstName} ${lastName}, testing a new campaign',
'MMS Content Test Message'
);
echo "MMS sent successfully! ID: " . $response->id . "\n";
} catch (\Exception $e) {
echo "Error: " . $e->getMessage() . "\n";
}
4. Sending Email
<?php
require 'vendor/autoload.php';
use CloudContactAI\CCAI\CCAI;
use CloudContactAI\CCAI\Email\Account;
use CloudContactAI\CCAI\Email\EmailCampaign;
use CloudContactAI\CCAI\Email\EmailOptions;
// Initialize the client
$ccai = new CCAI([
'clientId' => 'YOUR-CLIENT-ID',
'apiKey' => 'YOUR-API-KEY'
]);
// Send a single email
$response = $ccai->email->sendSingle(
firstName: 'John',
lastName: 'Doe',
email: '[email protected]',
subject: 'Welcome to Our Service',
message: '<p>Hello John,</p><p>Thank you for signing up!</p>',
senderEmail: '[email protected]',
replyEmail: '[email protected]',
senderName: 'Your Company',
title: 'Welcome Email'
);
echo "Email sent successfully!\n";
// Send email campaign to multiple recipients
$accounts = [
new Account('John', 'Doe', '[email protected]'),
new Account('Jane', 'Smith', '[email protected]')
];
$campaign = new EmailCampaign(
subject: 'Monthly Newsletter',
title: 'July 2025 Newsletter',
message: '<h1>Hello ${firstName}!</h1><p>Monthly updates...</p>',
senderEmail: '[email protected]',
replyEmail: '[email protected]',
senderName: 'Your Company Newsletter',
accounts: $accounts
);
// Schedule for future delivery
$tomorrow = new DateTime('tomorrow 10:00:00');
$campaign->scheduledTimestamp = $tomorrow->format('c');
$campaign->scheduledTimezone = 'America/New_York';
// Add progress tracking
$options = new EmailOptions(
timeout: 60,
onProgress: function($status) {
echo "Progress: $status\n";
}
);
$response = $ccai->email->sendCampaign($campaign, $options);
echo "Campaign sent successfully!\n";
5. Webhooks
<?php
require 'vendor/autoload.php';
use CloudContactAI\CCAI\CCAI;
use CloudContactAI\CCAI\WebhookConfig;
use CloudContactAI\CCAI\WebhookEventType;
use CloudContactAI\CCAI\Webhook;
// Initialize the client
$ccai = new CCAI([
'clientId' => 'YOUR-CLIENT-ID',
'apiKey' => 'YOUR-API-KEY'
]);
// Register a webhook
$config = new WebhookConfig(
url: 'https://your-domain.com/api/ccai-webhook',
events: [WebhookEventType::MESSAGE_SENT, WebhookEventType::MESSAGE_RECEIVED],
secret: 'your-webhook-secret'
);
$webhook = $ccai->webhook->register($config);
echo "Webhook registered with ID: {$webhook->id}\n";
// List all webhooks
$webhooks = $ccai->webhook->list();
echo "Found " . count($webhooks) . " webhooks\n";
// Create webhook handler
$handlers = [
'onMessageSent' => function($event) {
echo "Message sent: {$event->message} to {$event->to}\n";
},
'onMessageReceived' => function($event) {
echo "Message received: {$event->message} from {$event->from}\n";
}
];
$webhookHandler = Webhook::createHandler($handlers);
// Use in your web application
// $payload = json_decode(file_get_contents('php://input'), true);
// $result = $webhookHandler($payload);
Example Files
Run the example files:
# Basic email sending
php send_email.php
# Advanced email campaigns with HTML templates and scheduling
php email_campaign_examples.php
# Webhook management and handling
php webhook_example.php
Features
- Send SMS messages to single or multiple recipients
- Send MMS messages with images
- Send Email campaigns with HTML content
- Schedule emails for future delivery
- Webhook management (register, update, list, delete)
- Webhook event handling for web frameworks
- Variable substitution in messages (
${firstName}
,${lastName}
) - Progress tracking callbacks
- Type hints for better IDE integration
- Comprehensive error handling
- PSR-7 and PSR-18 compliant
Try it yourself
See the full source code here.
Updated 8 days ago