rs / socialite-healthcare-authenticator
Socialite Healthcare Authenticator
Requires
- php: ^8.3
- socialiteproviders/manager: ^4.8
Requires (Dev)
- larastan/larastan: ^3.1
- laravel/pint: ^1.21
- orchestra/testbench: ^10.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- phpunit/phpunit: ^11.5
README
Allows for web portals for HCPs to seamlessly implement and maintain sign-on, authentication, and/or verification through integration with one of the world’s largest and most accurate sources of HCP data.
Installation
You can install the package via composer:
composer require rs/socialite-healthcare-authenticator
Installation & Basic Usage
Please see the Base Installation Guide, then follow the provider specific instructions below.
Add configuration to config/services.php
'hca' => [ 'client_id' => env('HCA_CLIENT_ID'), 'client_secret' => env('HCA_CLIENT_SECRET'), 'redirect' => env('HCA_REDIRECT_URI'), 'profile_extended'=>true // Set this to false if you dont have access to the full profile 'api_key'=>env('HCA_API_KEY') ],
Add the API key for user consents and magic links.
Add provider event listener
Configure the package's listener to listen for SocialiteWasCalled
events.
Add the event to your listen[]
array in app/Providers/EventServiceProvider
. See the Base Installation Guide for detailed instructions.
protected $listen = [ \SocialiteProviders\Manager\SocialiteWasCalled::class => [ // ... other providers \RedSnapper\SocialiteProviders\HealthCareAuthenticator\HealthCareAuthenticatorExtendSocialite::class ], ];
Usage
You should now be able to use the provider like you would regularly use Socialite (assuming you have the facade installed):
return Socialite::driver('hca')->redirect();
Can provide the locale using the with method.
return Socialite::driver('hca')->with(['locale'=>'it-IT'])->redirect();
Available methods for the returned user.
$user = Socialite::driver('hca')->user(); $user->getId(); $user->getEmail(); $user->getName(); $user->getTitle(); $user->getFirstName(); $user->getLastName(); $user->getPhoneNumber(); $user->getWorkplaceAddress(); $user->getCity(); $user->getZipCode(); $user->getSpecialties(); // [Speciality] $user->getProfessionalCode(); // ProfessionalCode $user->getOneKeyId(); $user->getTrustLevel();
Consents
You can also retrieve the user's consents using the consents
method.
$user->consents()->all();
This returns back a Laravel collection.
$user->consents()->ids(); // [1,2,3] $user->consents()->captions(); // ['Consent 1','Consent 2']
Handling errors
When calling the user
method, there are two exceptions that may be thrown.
\RedSnapper\SocialiteProviders\HealthCareAuthenticator\HealthCareAuthenticatorRequestException
This exception is thrown if the user cancels the sign-up process or fails to verify as an HCP.
\Laravel\Socialite\Two\InvalidStateException
This exception is thrown if the state returned by the HCA service does not match the state stored in the session.
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email param@redsnapper.net instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.