rwandabuild / murugo_api_auth
Package that will use Murugo auth to all 3rd party laravel projects with only API structure
Installs: 3 540
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 3
Forks: 0
Open Issues: 0
- dev-test
- v2.6.2
- v2.6.1
- v2.6.0
- v2.5.9
- v2.5.8
- v2.5.7
- v2.5.6
- v2.5.1
- v2.5
- v2.4.2
- v2.4.1
- v2.4
- v2.3
- v2.2
- v2.1
- v2.0
- v1.42
- v1.41
- v1.40
- v1.39
- v1.38
- v1.37
- v1.36
- v1.35
- v1.34
- v1.32
- v1.31
- v1.30
- v1.29
- v1.28
- v1.27
- v1.26
- v1.25
- v1.24
- v1.23
- v1.22
- v1.21
- v1.20
- v1.19
- v1.18
- v1.17
- v1.16
- v1.15
- v1.14
- v1.13
- v1.12
- v1.11
- v1.10
- v1.9
- v1.8
- v1.7
- v1.6
- v1.5
- v1.4
- v1.3
- v1.2
- v1.1
- v1.0
- dev-master
- dev-ft-redirection
- dev-ft-error
- dev-ft-murugo-state
- dev-ft-state
- dev-ft-support-dynamic-redirect-urls
- dev-ft-support-custom-password-grant
- dev-ft-support-invite-service
- dev-fix-deprecated-package
This package is auto-updated.
Last update: 2025-01-09 11:23:27 UTC
README
Package that will be used for Murugo auth to all 3rd party laravel projects with only API structure
Follow the following steps to get started:
1. Install package by running the following command
composer require rwandabuild/murugo_api_auth
2. Include the following variables in config services file
'murugo' => [ 'client_id' => env('MURUGO_CLIENT_ID'), 'client_secret' => env('MURUGO_CLIENT_SECRET'), 'redirect' => env('APP_REDIRECT_URL', 'YOUR LOGIN REDIRECT URL'), 'murugo_url' => env('MURUGO_URL', 'MURUGO_URL'), 'murugo_app_key' => env('MURUGO_APP_KEY'), ],
3. Dont forget to publish your migration by running the following command, when you want to upgrade
php artisan vendor:publish
4. Use the following migration
php artisan migrate
5. Add method to redirect user to murugo
use RwandaBuild\MurugoAuth\Facades\MurugoAuth; public function redirectToMurugo() { return MurugoAuth::redirect(); }
6. Add a callback method to be used after the redirection
use RwandaBuild\MurugoAuth\Facades\MurugoAuth; public function murugoCallback() { $murugoUser = MurugoAuth::user() }
7. Package also comes with this following method
/** * This one is used by client(mobile) to authenticate murugo users on their 3rd party servers */ use RwandaBuild\MurugoAuth\Facades\MurugoAuth; $tokens = [ 'access_token' => 'murugo_user_access_token'], 'refresh_token' => 'murugo_user_refresh_token', 'expires_in' => integer ], $murugoUser = MurugoAuth::userFromToken($tokens);
8. Add relationship between User and Murugo User models
- Add a Trait built in the package already that makes relationship between User model and Murugo user model
use RwandaBuild\MurugoAuth\Traits\MurugoAuthHelper; class User extends Authenticatable { use MurugoAuthHelper; }
- To access the murugo user when you already have user model like the following:
$user = User::find(1); // access the relationship $murugoUser = $user->murugoUser;
- When you have a murugo user model and you need to the related user, you can do it in the following way:
$murugoUser = MurugoAuth::user(); // accessing the related user $user = $murugoUser->user;
NOTES: By default package is using App\User model or App\Models|user for making relationship between your user and murugo user model
9. At this step this is how you refresh tokens
First you should know that the Murugo user model keeps the access_token
refresh_token
and the token_expires_at
, now in case you may need to refresh the token of an existing, just do it in the following way:
$user = User::find(2); // refreshing murugo user token $murugoUser = MurugoAuth::refreshToken($user->murugoUser);
By Default package will add the following api routes in your laravel project
- api/murugo-auth >>> This route will be used to get response sent from murugo and save in your laravel project database
- api/authenticate-user >>>This route will authenticate user by checking uuid of user and by checking if token is still valid and if true return user object
- api/logout >>> This route will logout user on murugo server