Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Pollora/ajax

Repository files navigation

Pollora Ajax

A modern PHP package for WordPress AJAX action management with a fluent API and secure defaults.

Installation

composer require pollora/ajax

Quick Start

use Pollora\Ajax\Ajax;
// Logged-in users only (default — secure by design)
Ajax::listen('my_action', function () {
 wp_send_json_success(['message' => 'It works!']);
});
// All users (explicit opt-in required)
Ajax::listen('public_action', function () {
 // ...
})->forAllUsers();
// Guest users only
Ajax::listen('guest_action', function () {
 // ...
})->forGuestUsers();

With the Pollora Framework

When used inside Pollora, you can also use the #[Ajax] PHP attribute for declarative registration:

use Pollora\Attributes\Ajax;
use Pollora\Ajax\Domain\Model\AjaxAccess;
class NewsletterHandler
{
 #[Ajax('subscribe')]
 public function subscribe(): void
 {
 wp_send_json_success(['message' => 'Subscribed!']);
 }
 #[Ajax('load_more', access: AjaxAccess::ALL)]
 public function loadMore(): void
 {
 wp_send_json_success([/* ... */]);
 }
}

Documentation

See docs/ajax.md for full documentation.

Testing

composer test

License

GPL-2.0-or-later

About

A modern PHP package for WordPress AJAX action management with fluent API

Resources

License

Stars

Watchers

Forks

Packages

Contributors

Languages

AltStyle によって変換されたページ (->オリジナル) /