This plugin ships with both
- Authentication: Always comes first - "who is it"?
- Authorization: Afterwards - "What can this person see"?
For the first one usually declares as a whitelist of actions per controller that will not require any authentication. If an action is not whitelisted, it will trigger the login process.
The second only gets invoked once the person is already logged in. In that case the role of this logged in user decides if that action is allowed to be accessed.
You can activate an "Auth" DebugKit panel to have useful insights per URL.
See AuthPanel docs.
This is done via TinyAuth AuthComponent.
The component plays well together with the authorization part (see below). If you do not have any roles and either all are logged in or not logged in you can also use this stand-alone to make certain pages public.
See Authentication docs.
The TinyAuthorize adapter takes care of authorization.
The adapter plays well together with the component above.
But if you prefer to control the action whitelisting for authentication via code and $this->Auth->allow()
calls, you can
also just use this adapter stand-alone for the ACL part of your application.
There is also an AuthUserComponent and AuthUserHelper to assist you in making role based decisions or displaying role based links in your templates.
See Authorization docs.
Those classes most likely share quite a few configs, in that case you definitely should use Configure to define those centrally:
// in your app.php
'TinyAuth' => [
'multiRole' => true,
...
],
This way you keep it DRY.
In general, it is advised to clear the cache after each deploy, e.g. using
bin/cake clear cache
In debug mode this happens automatically for each request.
By default, the cache engine used is _cake_core_
, the prefix is tiny_auth_
.
You can also clear the cache from code using TinyAuth\Utility\Cache::clear()
method for specifically this.
You can easily switch out the INI file adapters for both using allowAdapter
and aclAdapter
config.
This way you can also read from DB or provide any other API driven backend to read the data from for your authentication or authorization.
Current customizations:
- TinyAuthBackend plugin as backend GUI for "allow" and "ACL".
First of all: Isolate the issue. Never mix authentication and authorization (read the top part again).
If you want to use both, first attach authentication and make sure you can log in and you can log out. By default all actions are now protected unless you make them "public". So make sure the non-public actions are not accessible without being logged in and they are afterwards. You just verified: authentication is working now fine - it doesn't matter who logged in as long as someone did.
Only if that is working, attach an Auth adapter (which now means authorization comes into play), in this case probably Tiny
.
By default it will now deny all logged in users any access to any protected action. Only by specifically whitelisting actions/controllers now in the ACL definition, a specific user can access a specific action again.
Make sure that the session contains the correct data structure, also make sure the roles are configured or in the database and can be found as expected. The user with the right role should get access now to the corresponding action (make also sure cache is cleared).
You then verified: authorization is working fine, as well - only with the correct role a user can now access protected actions.
If you are using Authentication or Authorization plugin, you will need to use the Authentication/Authorization components of this plugin instead for them to work with TinyAuth.
See the docs for details:
They are super powerful, but they also require a load of config to get them to run. If you need authentication/authorization on middleware/routing level however, you need to use them.
If you only need the basic request policy provided by this plugin, and no further ORM or other policies, then it is best to stick to the Auth component as simple wrapper. It is then limited to controller scope (no middleware/routing support) as it always has been so far.
Coming from CakePHP 3.x the following major changes will affect your app in CakePHP 4.x:
- Prefixes are now
CamelCase
to follow core conventions (and to be in sync with plugin and controller names). - Roles continue to be
dashed-case
(slugs), actions remaincamelBacked
and thus equal to the method name casing usually. - If you use custom adapters, make sure the paths now contain the correct prefix casing, as well.
Feel free to fork and pull request.
There are a few guidelines:
- Coding standards passing:
composer cs-check
to check andcomposer cs-fix
to fix. - Tests passing:
php phpunit.phar
to run them.