PushAI – Self-Hosted Web Push Notifications
PushAI turns your WordPress site into a re-engagement channel. Visitors subscribe with a single click, and you reach them directly in their browser — even when your site is closed — using the native Web Push standard. There is no third-party SDK, no per-subscriber pricing, and no external delivery service: notifications are sent straight from your own server using your own VAPID credentials, which PushAI generates automatically.
Everything lives on your site. Subscribers are stored in your own database, delivery runs through a background queue so large sends never block your site, and every push link is automatically tagged with UTM parameters so the traffic shows up correctly in Google Analytics and your other reporting tools. The free plugin already covers the full lifecycle — subscribe button, automatic new-post notifications, a manual composer, per-user targeting, delivery history, and GDPR export/erasure.
PushAI is device-aware. When a logged-in visitor subscribes, PushAI keeps one active subscription per device type — one for mobile and one for desktop — so the same person can opt in independently on their phone and on their computer and receive each notification on whichever devices they enabled. Stale and duplicate subscriptions are pruned automatically.
PushAI Pro builds on this foundation with the three features self-hosted push plugins almost never offer out of the box: AI-summarized post digests (powered by OpenAI, Google Gemini, xAI Grok, DeepSeek, or any OpenRouter model — with a template fallback so digests always work), deep WooCommerce automation (order and stock alerts, order-status updates, abandoned-cart reminders, cross-sell follow-ups, and trending-product pushes), and a built-in Progressive Web App (PWA) that adds an installable web-app manifest and service worker so visitors can install your site to their home screen.
Actively developed. PushAI is under continuous, active development. New automations, AI providers, and WooCommerce flows ship regularly, and every release is documented in the changelog below. Feature requests and feedback directly shape the roadmap — this is a living plugin, not a frozen one.
Why choose PushAI?
PushAI keeps your push notifications self-hosted, so the parts that usually cost you money and control stay on your side:
- You own your subscriber list. Subscriptions live in your WordPress database, never on a third-party platform.
- Unlimited subscribers and notifications — on Free and Pro. No per-subscriber pricing, no monthly send caps.
- No third-party SDK or external delivery service. Native Web Push + your own VAPID keys, straight from your server.
- Transparent, flat pricing. The free plugin stays free forever; Pro is one flat price no matter how big your audience gets.
- AI digests built in (Pro). Automatically summarize your latest posts and send them on a schedule — across multiple AI providers, with a template fallback.
- WooCommerce automation (Pro). Order, stock, status, abandoned-cart, cross-sell, and trending-product pushes — from your own store.
- Built-in PWA (Pro). Make your site installable with a managed manifest and service worker — no separate PWA plugin required.
Standout features
- AI post digests (Pro) — collect your recent posts and send a summarized push digest on a schedule, written by OpenAI, Gemini, Grok, DeepSeek, or OpenRouter, with a built-in template fallback.
- WooCommerce automation (Pro) — admin alerts for new/cancelled/refunded orders and low/out-of-stock products; customer order-status and order-note updates; abandoned-cart reminders; post-purchase cross-sell follow-ups; and “Trending Now” product pushes.
- Built-in PWA (Pro) — an installable web-app manifest and service worker, with configurable app name, icon, and theme color, so visitors can add your site to their home screen.
- Separate mobile & desktop subscriptions — one active subscription per device type per account, so a user can opt in independently on phone and desktop.
- Automatic UTM tagging — every push link is tagged with
utm_source,utm_medium, and a source-awareutm_campaignso clicks are attributed in your analytics. Filterable, and can be disabled.
Free vs Pro
Both plans include unlimited subscribers and unlimited notifications, the self-hosted setup, and the developer API. Pro adds automation, AI digests, WooCommerce, the built-in PWA, and analytics on top of the free feature set. The full breakdown is below; you only pay for the automation and AI features.
Free Features
- ✅ One-click subscribe button (shortcode)
- ✅ Automatic new-post notifications
- ✅ Manual notification composer
- ✅ Per-user / specific-subscriber targeting
- ✅ Separate mobile & desktop subscriptions
- ✅ Guest subscriptions
- ✅ Automatic VAPID key generation
- ✅ Background delivery queue with retries
- ✅ Automatic UTM link tagging
- ✅ Delivery history & status
- ✅ Privacy / GDPR export & erasure
- ✅ Developer API (function + action hooks)
- ✅ Unlimited subscribers & notifications
- ✅ Self-hosted — you own your data
- Pricing: $0 forever
Pro Features
- 🚀 Everything in Free, plus:
- ✅ Scheduled AI digests (OpenAI, Gemini, Grok, DeepSeek, OpenRouter + template fallback)
- ✅ WooCommerce order & stock alerts
- ✅ WooCommerce order-status & customer notes
- ✅ Abandoned-cart reminders
- ✅ Cross-sell follow-ups
- ✅ Trending Today (post & product daily-view alerts)
- ✅ Built-in PWA (installable manifest + service worker)
- ✅ Statistics & analytics (7/30/90-day, CTR, conversion)
- ✅ Signed click tracking
- ✅ Custom post type automation
- ✅ Comment notifications (authors & replies)
- ✅ On-site permission prompt (customizable opt-in popup)
- Pricing: $39/yearly
PushAI is developed and maintained by PushAI.
Shortcode
Place a subscribe button anywhere with:
[pushai_button]
Optional attributes:
label— default button text.on— text shown after notifications are enabled.blocked— text shown when the visitor has blocked notifications.align—left,center, orright.class— extra CSS classes.
Example:
[pushai_button label="Enable browser notifications" align="center"]
In PHP templates:
<?php echo do_shortcode( '[pushai_button]' ); ?>
The shortcode is also shown on the PushAI → Settings screen with a copy button.
Developer API
Queue a notification from a theme or plugin:
pushai_trigger_notification( array(
'title' => 'Title',
'body' => 'Message',
'url' => home_url( '/' ),
'image' => '',
) );
The same notification can be triggered with a WordPress action:
do_action( 'pushai_send_notification', array(
'title' => 'Title',
'body' => 'Message',
'url' => home_url( '/' ),
) );
Targeting specific users
By default a notification is delivered to every active subscription. To send it to specific WordPress users instead, pass target_user_id (a single user) or target_user_ids (an array of users). Only subscriptions tied to those user accounts receive the message.
Send to one user:
pushai_trigger_notification( array(
'title' => 'Your order shipped',
'body' => 'Track it from your account.',
'url' => home_url( '/my-account/' ),
'target_user_id' => 123,
) );
Send to several users:
pushai_trigger_notification( array(
'title' => 'Members-only update',
'body' => 'A new perk is available.',
'target_user_ids' => array( 12, 45, 78 ),
) );
Notes on targeting:
- Only users who subscribed while logged in can be targeted; guest subscriptions are stored without a user account and are never matched.
- A user with several browsers or devices receives the notification on each of their active subscriptions (mobile and desktop are tracked separately).
- If targeting arguments are supplied but none resolve to a valid user, the notification is rejected with a
WP_Errorinstead of being broadcast to everyone.
Supported arguments
title(required) — notification heading.body(required) — notification message.url— link opened when the notification is clicked. Defaults to the site home URL. UTM parameters are appended automatically.image— image URL shown in the notification.target_user_id— a single WordPress user ID to deliver to.target_user_ids— an array of WordPress user IDs to deliver to.source_type— a short label describing what triggered the notification (for examplepost,manual, ordeveloper). Metadata only: it is stored with the record, shown in the admin history, used by thesourceindex, and used to build theutm_campaignvalue — it does not affect who receives the message. Defaults todeveloper.source_id— the ID of the object that triggered the notification, paired withsource_type(for example the post ID for apostsource). Also metadata only and not a recipient — usetarget_user_id/target_user_idsto choose recipients. Defaults to0.
Available hooks:
pushai_should_create_post_notification— filter whether a published post creates a notification.pushai_should_send_to_subscription— filter, per subscription, whether it should receive a given notification.pushai_notification_payload— filter the payload sent to the browser.pushai_utm_parameters— filter (or disable) the UTM parameters appended to push links.pushai_notification_queued— fires after a notification is queued.pushai_notification_failed— fires when a notification fails to send.pushai_notification_delivery_completed— fires after a delivery batch finishes, with success/failed/expired counts.pushai_loaded— fires once PushAI has initialized its services.
Bundled Libraries
PushAI bundles the following open-source libraries in its vendor/ directory. All are MIT-licensed and GPL-compatible.
- minishlink/web-push — Web Push delivery (MIT)
- guzzlehttp/guzzle — HTTP client used by web-push (MIT)
- web-token/jwt-library — JWT signing for VAPID (MIT)
- spomky-labs/base64url — Base64url encoding (MIT)
- spomky-labs/pki-framework — PKI utilities (MIT)
- brick/math — Arbitrary-precision math (MIT)
- Various PSR interfaces and Symfony polyfills (MIT)
Third-Party Services
PushAI communicates with two categories of external services. No personal data is sent without user action.
Browser push services
When a visitor subscribes and a notification is delivered, the encrypted push payload is sent directly from your server to the browser’s native push service:
- Google Chrome / Edge — Google’s Firebase Cloud Messaging (FCM): Privacy Policy
- Mozilla Firefox — Mozilla’s Autopush service: Privacy Policy
- Apple Safari — Apple Push Notification service (APNs): Privacy Policy
This is the Web Push standard (RFC 8030). Only the encrypted notification payload (title, body, URL, optional image) is transmitted; the subscriber’s email address or identity is never sent. You control the VAPID keys used to sign each push.
PushAI license API (Pro only)
Sites with a PushAI Pro license send license key verification requests to the PushAI license server at wpushai.com. This happens:
- When the license is first activated.
- On a periodic background check (at most once per day) to confirm the license remains valid.
- When the admin manually refreshes the license status.
- When WordPress checks for Pro plugin updates.
The request includes your site URL (so the license can be validated against the registered domain) and the license key. No personal data beyond these two values is transmitted. PushAI Privacy Policy
