/laravel-cognito-auth

AWS Cognito Auth driver for Laravel

Primary LanguagePHPMIT LicenseMIT

Laravel Cognito Auth

Packagist

AWS Cognito Auth driver for Laravel

Installation

Add the following line to your composer.json file:

"pod-point/laravel-cognito-auth": "^0.1"

Then add the service provider in config/app.php:

PodPoint\LaravelCognitoAuth\Providers\CognitoAuthServiceProvider::class

Update the driver in auth.php:

'driver' => 'cognito',

Publish the config file:

php artisan vendor:publish --provider="PodPoint\LaravelCognitoAuth\Providers\CognitoAuthServiceProvider"

Add the following to your .env file:

AWS_KEY=
AWS_SECRET=
AWS_REGION=
AWS_COGNITO_CLIENT_ID=
AWS_COGNITO_CLIENT_SECRET=
AWS_COGNITO_USER_POOL_ID=

Usage

You can either use the provided Laravel Auth style traits which provide a boilerplate for a standard Laravel Auth workflow:

  • PodPoint\LaravelCognitoAuth\Auth\AuthenticatesUsers
  • PodPoint\LaravelCognitoAuth\Auth\RegistersUsers
  • PodPoint\LaravelCognitoAuth\Auth\ResetsPasswords
  • PodPoint\LaravelCognitoAuth\Auth\SendsPasswordResetEmails

Or you can use the CognitoClient directly.

Registration Flows

register($username, $password, array $attributes = [])

This will register a user with a given user/password and set their email address as verified. The user will immediatly be able to log in with the supplied credentials.

inviteUser($username, array $attributes = [])

This will register a user with the given email address and mark them as NEW_PASSWORD_REQUIRED. They will also be sent an email asking them to reset their password via the existing password reset workflow. Once this password is set the user will be able to log in.