ruhafzazahedi / shield
Auth for CodeIgniter 4
Requires
- php: ^7.4.3 || ^8.0
Requires (Dev)
- codeigniter/phpstan-codeigniter: ^1.3
- codeigniter4/devkit: ^1.0
- codeigniter4/framework: >=4.3.5 <4.5.0 || ^4.5.1
- firebase/php-jwt: ^6.4
- mikey179/vfsstream: ^1.6.7
- mockery/mockery: ^1.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-strict-rules: ^1.5
- phpunit/phpunit: ^9.6
- rector/rector: 1.1.0
Suggests
- ext-curl: Required to use the password validation rule via PwnedValidator class.
- ext-openssl: Required to use the JWT Authenticator.
Provides
README
Shield is the official authentication and authorization framework for CodeIgniter 4. While it does provide a base set of tools that are commonly used in websites, it is designed to be flexible and easily customizable.
The primary goals for Shield are:
- It must be very flexible and allow developers to extend/override almost any part of it.
- It must have security at its core. It is an auth lib after all.
- To cover many auth needs right out of the box, but be simple to add additional functionality to.
Authentication Methods
Shield provides two primary methods Session-based and Access Token authentication out of the box.
It also provides HMAC SHA256 Token and JSON Web Token authentication.
Session-based
This is your typical phone/username/password system you see everywhere. It includes a secure "remember-me" functionality. This can be used for standard web applications, as well as for single page applications. Includes full controllers and basic views for all standard functionality, like registration, login, forgot password, etc.
Access Token
These are much like the access tokens that GitHub uses, where they are unique to a single user, and a single user can have more than one. This can be used for API authentication of third-party users, and even for allowing access for a mobile application that you build.
HMAC SHA256 Token
This is a slightly more complicated improvement on Access Token authentication. The main advantage with HMAC is the shared Secret Key is not passed in the request, but is instead used to create a hash signature of the request body.
JSON Web Token
JWT or JSON Web Token is a compact and self-contained way of securely transmitting information between parties as a JSON object. It is commonly used for authentication and authorization purposes in web applications.
Important Features
- Session-based authentication (traditional ID/Password with Remember-me)
- Stateless authentication using Personal Access Tokens
- Optional Phone verification on account registration
- Optional SMS-based Two-Factor Authentication after login
- Magic Link Login when a user forgets their password
- Flexible Groups-based access control (think Roles, but more flexible)
- Users can be granted additional Permissions
See the An Official Auth Library for more Info.
Getting Started
Prerequisites
Usage of Shield requires the following:
- A CodeIgniter 4.3.5+ based project
- Composer for package management
- PHP 7.4.3+
Installation
Installation is done through Composer.
composer require ruhafzazahedi/shield