Pushpad is a service for sending push notifications from websites and web apps. It uses the Push API, which is supported by all major browsers (Chrome, Firefox, Opera, Edge, Safari).
Notifications are delivered in real time even when the users are not on your website and you can target specific users or send bulk notifications.
This package requires PHP 8.0+ with the curl extension.
Install the SDK via Composer:
composer require pushpad/pushpad-phpThen include Composer's autoloader:
require_once __DIR__ . '/vendor/autoload.php';Clone the repository and require the bootstrap file in your project:
git clone https://github.com/pushpad/pushpad-php.gitrequire_once __DIR__ . '/path/to/pushpad-php/init.php';First sign up to Pushpad and create a project.
Configure the SDK with your credentials before you make any API calls:
Pushpad\Pushpad::$authToken = '5374d7dfeffa2eb49965624ba7596a09';
Pushpad\Pushpad::$projectId = 123; // set a default project (optional)authTokencan be created in the account settings.projectIdis shown in the project settings. If you work with multiple projects you can pass a different project id to individual method calls instead of configuring the global default.
Use the JavaScript SDK to subscribe users to push notifications (see the getting started guide).
When you need to sign a uid, generate the HMAC signature with:
$signature = Pushpad\Pushpad::signatureFor((string) $currentUserId);Use Pushpad\Notification::create() (or the send() alias) to create and send a notification:
$response = Pushpad\Notification::create([
// required content
'body' => 'Hello world!',
// optional fields
'title' => 'Website Name',
'target_url' => 'https://example.com',
'icon_url' => 'https://example.com/assets/icon.png',
'badge_url' => 'https://example.com/assets/badge.png',
'image_url' => 'https://example.com/assets/image.png',
'ttl' => 604800,
'require_interaction' => true,
'silent' => false,
'urgent' => false,
'custom_data' => '123',
'actions' => [
[
'title' => 'My Button 1',
'target_url' => 'https://example.com/button-link',
'icon' => 'https://example.com/assets/button-icon.png',
'action' => 'myActionName',
],
],
'starred' => true,
'send_at' => (new DateTimeImmutable('+1 hour'))->format(DATE_ATOM),
'custom_metrics' => ['examples', 'another_metric'],
// targeting options
'uids' => ['user-1', 'user-2'],
'tags' => ['segment1', 'segment2'],
]);- Omit
uidsandtagsto broadcast to everyone. - If you set
uidsand some users are not subscribed to notifications, Pushpad ignores them. - Use boolean expressions inside
tagsfor complex segments (e.g.'zip_code:28865 && !optout:local_events'). - Scheduled notifications require an ISO 8601 timestamp in
send_at(as produced byDateTimeInterface::format(DATE_ATOM)). - You can set default values for most notification fields in the project settings.
- Refer to the REST API docs for more details about the notification fields and their usage.
The response includes useful information:
// Notification ID
$notificationId = $response['id'];
// Estimated number of devices that will receive the notification
// Not available for notifications that use send_at
$estimatedReach = $response['scheduled'];
// Available only if you specify some user IDs (uids) in the request:
// it indicates which of those users are subscribed to notifications.
// Not available for notifications that use send_at
$reachedUids = $response['uids'];
// The time when the notification will be sent.
// Available for notifications that use send_at
$scheduledAt = $response['send_at'];Fetch a single notification and inspect its attributes:
$notification = Pushpad\Notification::find(42);
echo $notification->title; // "Foo Bar"
echo $notification->target_url; // "https://example.com"
echo $notification->ttl; // 604800
echo $notification->created_at; // ISO 8601 string
echo $notification->successfully_sent_count; // 4
echo $notification->opened_count; // 2
// ... and many other attributes
print_r($notification->toArray());List notifications for a project (pagination supported through the page query parameter):
$notifications = Pushpad\Notification::findAll(['page' => 1]);
foreach ($notifications as $item) {
printf("Notification %d: %s\n", $item->id, $item->title);
}Pass the project id as the second argument when you prefer not to rely on the globally configured Pushpad\Pushpad::$projectId:
Pushpad\Notification::findAll([], projectId: 456);
If you need to refresh a previously loaded notification, call $notification->refresh() to hydrate the latest data from the API.
Create a notification that will be sent later:
Pushpad\Notification::create([
'body' => 'This notification will be sent after 60 seconds',
'send_at' => (new DateTimeImmutable('+60 seconds'))->format(DATE_ATOM),
]);Cancel a scheduled notification when it is still pending:
$notification = Pushpad\Notification::find(5);
$notification->cancel();Retrieve the number of subscriptions associated with a project, optionally filtered by user IDs or tags:
$total = Pushpad\Subscription::count();
$byUser = Pushpad\Subscription::count(['uids' => ['user1']]);
$byTags = Pushpad\Subscription::count(['tags' => ['sports && travel']]);
$combined = Pushpad\Subscription::count(['uids' => ['user1'], 'tags' => ['sports && travel']], 5);The second argument lets you override the project id if you did not configure Pushpad\Pushpad::$projectId or you need to switch project on the fly.
Fetch subscriptions with optional filters and pagination:
$subscriptions = Pushpad\Subscription::findAll(['tags' => ['sports'], 'page' => 2]);
foreach ($subscriptions as $subscription) {
echo $subscription->id . PHP_EOL;
// ...
}Load a specific subscription when you already know its id:
$subscription = Pushpad\Subscription::find(123);
echo $subscription->id;
echo $subscription->project_id;
echo $subscription->endpoint;
echo $subscription->uid;
echo $subscription->tags;
echo $subscription->last_click_at;
echo $subscription->created_at;
// ... and many other attributes
print_r($subscription->toArray());Although tags and user IDs are usually managed from the JavaScript SDK, you can also update them from server:
$subscriptions = Pushpad\Subscription::findAll(['uids' => ['user1']]);
foreach ($subscriptions as $subscription) {
$tags = $subscription->tags ?? [];
$tags[] = 'another_tag';
$subscription->update([
'uid' => 'myuser1',
'tags' => array_values(array_unique($tags)),
]);
}To import existing subscriptions or seed test data use Pushpad\Subscription::create():
$subscription = Pushpad\Subscription::create([
'endpoint' => 'https://example.com/push/f7Q1Eyf7EyfAb1',
'p256dh' => 'BCQVDTlYWdl05lal3lG5SKr3VxTrEWpZErbkxWrzknHrIKFwihDoZpc_2sH6Sh08h-CacUYI-H8gW4jH-uMYZQ4=',
'auth' => 'cdKMlhgVeSPzCXZ3V7FtgQ==',
'uid' => 'exampleUid',
'tags' => ['exampleTag1', 'exampleTag2'],
]);Typically subscriptions are collected from the browser using the JavaScript SDK; server-side creation should be reserved for migrations and special workflows.
Delete subscriptions programmatically (use with care, the operation is irreversible):
$subscription = Pushpad\Subscription::find(123);
$subscription->delete();Projects can also be managed via the API for automation use cases:
$project = Pushpad\Project::create([
'sender_id' => 123,
'name' => 'My project',
'website' => 'https://example.com',
'icon_url' => 'https://example.com/icon.png',
'badge_url' => 'https://example.com/badge.png',
'notifications_ttl' => 604800,
'notifications_require_interaction' => false,
'notifications_silent' => false,
]);
$projects = Pushpad\Project::findAll();
$project = Pushpad\Project::find(123);
$project->update(['name' => 'The New Project Name']);
$project->delete();Senders hold the VAPID credentials used for Web Push:
$sender = Pushpad\Sender::create([
'name' => 'My sender',
// omit the keys below to let Pushpad generate them automatically
// 'vapid_private_key' => '-----BEGIN EC PRIVATE KEY----- ...',
// 'vapid_public_key' => '-----BEGIN PUBLIC KEY----- ...',
]);
$senders = Pushpad\Sender::findAll();
$sender = Pushpad\Sender::find(987);
$sender->update(['name' => 'The New Sender Name']);
$sender->delete();The library is available as open source under the terms of the MIT License.