b1cloud / paysera-wallet-php-client
There is no license information available for the latest version (v1.0.2) of this package.
PHP client for Paysera.com Wallet API.
v1.0.2
2024-09-10 09:44 UTC
Requires
- php: >=7.2
- ext-json: *
- paysera/lib-wallet-transfer-rest-client: ^0.2.0
Requires (Dev)
- phpunit/phpunit: ^4.7
This package is auto-updated.
Last update: 2025-03-10 11:16:45 UTC
README
This is repository for PHP client, used with Paysera.com Wallet API.
OAuth example
<?php // setup autoloader for Paysera Wallet API library require_once '../../lib-wallet-php-client/src/Paysera/WalletApi/Autoloader.php'; Paysera_WalletApi_Autoloader::register(); // credentials for API $clientId = 'CLIENT_ID'; // $secret - shared secret to use in MAC auth $secret = 'SECRET'; // or information about certificate to use in SSL auth //$secret = Paysera_WalletApi_Http_ClientCertificate::create() // ->setCertificatePath('/path/to/cert.crt') // ->setPrivateKeyPath('/path/to/private.key'); // create main object to use for all functionality $api = new Paysera_WalletApi($clientId, $secret); // for sandbox environment, use the following code instead: // $api = new Paysera_WalletApi($clientId, $secret, Paysera_WalletApi_Util_Router::createForSandbox()); // get service, responsible for OAuth code grant type integration $oauth = $api->oauthConsumer(); // example how to get ask and get information about paysera.com user session_start(); try { if (!isset($_SESSION['token'])) { // no token in session - let's get the token $token = $oauth->getOAuthAccessToken(); // this gets code query parameter if available and exchanges for token if ($token === null) { // no code parameter - redirect user to authentication endpoint $redirectUri = null; // URL of this file; it's optional parameter header('Location: ' . $oauth->getAuthorizationUri(array( // scopes are optional, no scope allows to get user ID/wallet ID Paysera_WalletApi_OAuth_Consumer::SCOPE_EMAIL, // to get user's main email address // Paysera_WalletApi_OAuth_Consumer::SCOPE_IDENTITY, // this scope allows to get personal code, name and surname // Paysera_WalletApi_OAuth_Consumer::SCOPE_FULL_NAME, // use this scope if only name and surname is needed // Paysera_WalletApi_OAuth_Consumer::SCOPE_IDENTITY_OFFLINE, // this allows to get identity by user ID, after token has expired, using API, not related to token ), $redirectUri)); } else { $_SESSION['token'] = $token; } } if (isset($_SESSION['token'])) { $tokenRelatedClient = $api->walletClientWithToken($_SESSION['token']); echo '<pre>'; $user = $tokenRelatedClient->getUser(); var_dump($user); // $user->getId(); // you can save user ID (on paysera.com), user's email etc. // var_dump($api->walletClient()->getUserIdentity($userId)); // if you have offline scope, you can get info by user ID later echo '</pre>'; $_SESSION['token'] = $tokenRelatedClient->getCurrentAccessToken(); // this could be refreshed, re-save } } catch (Exception $e) { echo '<pre>', $e, '</pre>'; }
Contacts
If you have any further questions feel free to contact us:
„Paysera LT“, UAB
Pilaitės pr. 16
LT-04352 Vilnius
Email: info@paysera.lt
Tel. +37052071558