A CakePHP plugin to handle authentication and user authorization the easy way.
This branch is for CakePHP 5.1+. For details see version map.
TinyAuth now acts as a powerful wrapper around CakePHP's official Authentication and Authorization plugins, providing significant advantages:
- INI-based setup: Define all your authentication and authorization rules in simple INI files
- No controller modifications: Unlike vanilla plugins that require code in every controller
- Plugin-friendly: Automatically works with third-party plugins without modifications
- 5-minute integration: Get authentication and authorization working in minutes, not hours
- Sensible defaults: Pre-configured settings that work for 90% of use cases
- Quick setups: Built-in configurations for common scenarios (public non-prefixed, admin areas, etc.)
- Centralized management: All auth rules in one place, not scattered across controllers
- Easy maintenance: Change access rules without touching code
- Cache optimized: Built-in caching for maximum performance
- DebugKit panel: Visualize auth status, identity, and permissions in real-time
- Adapter pattern: Use INI files, database, or custom adapters for rule storage
- Progressive enhancement: Start simple, add complexity only when needed
- Stand-alone components: Use AuthUser component/helper independently if needed
Choose TinyAuth when you want:
- ✅ Simple role-based access control (RBAC)
- ✅ Quick setup without extensive configuration
- ✅ Controller-action level permissions
- ✅ Easy-to-manage access rules
- ✅ Minimal code changes
Since this plugin just further extends the official ones, you can skip the plugin's authentication and authorization components, and use the original plugins' functionality if you want:
- ❌ Complex policy-based authorization
- ❌ Resource-level permissions (per-entity authorization)
- ❌ Middleware/routing level authentication
- ❌ Custom authentication flows
You can still use the other helpers of this plugin, however.
Default CakePHP authentication and authorization depends on code changes in at least each controller, maybe more classes. This plugin hooks in with a single line of change and manages all that using config files and there is no need to touch all those controllers, including plugin controllers.
It is also possible to manage the config files without the need to code. And it can with adapters also be moved completely to the DB and managed by CRUD backend.
Ask yourself: Do you need the overhead and complexity involved with a full blown (RBAC DB) ACL or very specific Policy approaches? See also my post acl-access-control-lists-revised/. If not, then this plugin could very well be your answer and a super quick solution to your auth problem :)
But even if you don't leverage the full authentication or authorization potential, the available AuthUserComponent and AuthUserHelper can be very useful when dealing with role based decisions in your controller or view level. They also work stand-alone.
See https://sandbox.dereuromark.de/auth-sandbox
Define the public actions (accessible by anyone) per controller:
Users = index,view
Admin/Maintenance = pingCheck
PluginName.SomeController = *
MyPlugin.Api/V1 = *
Define what actions may be accessed by what logged-in user role:
[Users]
index = *
add,edit = user,super-user
[Admin/Users]
* = admin
[Translate.Admin/Languages]
* = *
$currentId = $this->AuthUser->id();
$isMe = $this->AuthUser->isMe($userEntity->id);
if ($this->AuthUser->hasRole('mod')) {
}
if ($this->AuthUser->hasAccess(['action' => 'secretArea'])) {
}
// Helper only
echo $this->AuthUser->link('Admin Backend', ['prefix' => 'Admin', 'action' => 'index']);
echo $this->AuthUser->postLink('Delete', ['action' => 'delete', $id], ['confirm' => 'Sure?']);
Including the plugin is pretty much as with every other CakePHP plugin:
composer require dereuromark/cakephp-tinyauth
Then, to load the plugin:
bin/cake plugin load TinyAuth
That's it. It should be up and running.
For setup and usage see Docs.
Also note the original blog post and how it all started.