dimafe6 / bank-id
Library for Swedish BankID
Installs: 40 666
Dependents: 2
Suggesters: 0
Security: 0
Stars: 30
Watchers: 10
Forks: 26
Open Issues: 3
Requires
- php: >=7.2.0 | 8.0.*
- guzzlehttp/guzzle: ^7.0.1
Requires (Dev)
- phpunit/phpunit: 5.7.* || 6.3.* || 9.5.*
README
Library for connect Swedish BankID to your application. This library implements BankID API V5. If your needed library for a BankID API V4 please use version 1.*
Requirements
- PHP 7.4+
- curl
Install
Via Composer
$ composer require dimafe6/bank-id
Usage
Either you let the user enter their personal number and pass to BankID or you only pass the order ref and receive the personal number from the response from BankID.
<?php // Create BankIDService $bankIDService = new BankIDService( 'https://appapi2.test.bankid.com/rp/v5.1/', $_SERVER["REMOTE_ADDR"], [ 'verify' => false, 'cert' => 'PATH_TO_TEST_CERT.pem', ] ); // OR Create BankIDService with ssl verification $bankIDService = new BankIDService( 'https://appapi2.test.bankid.com/rp/v5.1/', $_SERVER["REMOTE_ADDR"], [ 'verify' => 'PATH_TO_TEST_CERT.ca', 'cert' => 'PATH_TO_TEST_CERT.crt', 'ssl_key' => 'PATH_TO_TEST_CERT.key', ] );
Example with personal number
// Signing. Step 1 - Get orderRef /** @var OrderResponse $response */ $response = $bankIDService->getSignResponse('PERSONAL_NUMBER', 'User visible data', "user non visible data", "user visible data format"); // Signing. Step 2 - Collect orderRef. // Repeat until $collectResponse->status !== CollectResponse::STATUS_COMPLETED $collectResponse = $bankIDService->collectResponse($response->orderRef); if($collectResponse->status === CollectResponse::STATUS_COMPLETED) { return true; //Signed successfully } // Authorize. Step 1 - Get orderRef $response = $bankIDService->getAuthResponse('PERSONAL_NUMBER'); // Authorize. Step 2 - Collect orderRef. // Repeat until $authResponse->status !== CollectResponse::STATUS_COMPLETED $authResponse = $bankIDService->collectResponse($response->orderRef); if($authResponse->status == CollectResponse::STATUS_COMPLETED) { return true; //Authorized } // Cancel auth or collect order // Authorize. Step 1 - Get orderRef $response = $bankIDService->getAuthResponse('PERSONAL_NUMBER'); // Cancel authorize order if($bankIDService->cancelOrder($response->orderRef)) { return 'Authorization canceled'; }
Example without personal number
// Authorize. Step 1 - Get orderRef $response = $bankIDService->getAuthResponse(); // Authorize. Step 2 - Collect orderRef. // Repeat until $authResponse->status !== CollectResponse::STATUS_COMPLETED $authResponse = $bankIDService->collectResponse($response->orderRef); if($authResponse->status == CollectResponse::STATUS_COMPLETED) { echo $authResponse->completionData->user->personalNumber; return true; //Authorized }
Testing
- Copy phpunit.xml.dist to phpunit.xml
$ cp phpunit.xml.dist phpunit.xml
- Execute
$ ./vendor/bin/phpunit
License
The MIT License (MIT). Please see License File for more information.