- Node
v14.X
or higher - Only for NodeJS, i.e. it does't work on the browser side as it's a server-side library for security reasons.
npm i @handcash/handcash-connect
To start, you will need to create an instance of HandCashConnect
. This object allows you to interact with the SDK.
Don't have an app yet? Sign-up for dashboard.handcash.dev and create your first app.
A HandCashConnect
requires a appId
that represents your application, as well as an appSecret
to ensure the SDK is invoked under your domain.
import { HandCashConnect } from '@handcash/handcash-connect';
const handCashConnect = new HandCashConnect({
appId: 'your-app-id',
appSecret: 'your-app-secret',
});
In order to access to user account and trigger payments on their behalf, you need to obtain an authToken
that represents such permissions. You can find more about the user authorization process.
- Get the
redirectionUrl
that redirects to HandCash to obtain theauthToken
- Redirect the user to the
redirectionUrl
.
const redirectionUrl = handCashConnect.getRedirectionUrl();
- Once the user is redirected back to your app with the authToken, you are ready to go!
const account = handCashConnect.getAccountFromAuthToken(authToken);
The following code shows how to make a simple payment:
import { HandCashConnect } from '@handcash/handcash-connect';
const handCashConnect = new HandCashConnect({ appId: 'your-app-id', appSecret: 'your-app-secret' });
const account = handCashConnect.getAccountFromAuthToken(authToken);
const paymentParameters = {
description: 'Hold my beer!🍺',
appAction: 'drink',
payments: [
{ to: 'eyeone', currencyCode: 'USD', amount: 0.25 },
{ to: 'apagut', currencyCode: 'EUR', amount: 0.05 },
{ to: 'satoshi', currencyCode: 'SAT', amount: 50000 },
],
};
const paymentResult = await account.wallet.pay(paymentParameters);
console.log(paymentResult);
{
"transactionId": "0a25cc07953de261e2f7dbc3601a61d4e74f96b99cd55c0755df9b9888cdccbc",
"note": "Hold my beer!🍺",
"appAction": "drink",
"type": "send",
"time": 1599223479,
"satoshiFees": 288,
"satoshiAmount": 5332,
"fiatExchangeRate": 165.4370470109637,
"fiatCurrencyCode": "EUR",
"participants": [
{
"type": "user",
"alias": "eyeone",
"displayName": "Eye One",
"profilePictureUrl": "https://handcash-cloud-production.herokuapp.com/users/profilePicture/eyeone"
},
{
"type": "user",
"alias": "apagut",
"displayName": "Alex",
"profilePictureUrl": "https://handcash-cloud-production.herokuapp.com/users/profilePicture/apagut"
},
{
"type": "user",
"alias": "satoshi",
"displayName": "Satoshi Nakamoto",
"profilePictureUrl": "https://handcash-cloud-production.herokuapp.com/users/profilePicture/satoshi"
}
],
"attachments": []
}