User connect flow
Oauth page
Moneymade server redirects user to your platform website with two query string parameters:
- payload - base64 encoded string, which contains main info (userId, redirect urls)
- signature - request hmac
Example:
https://domain/oauth?payload={PAYLOAD}&signature={SIGNATURE}
You may set the strategy to open your website's oauth page (in the admin console):
- popup - your website will be opened in the new window
- iframe - your website will be located at moneymade page in the iframe
Oauth security
Signature validation should be handled at the server side
To validatie signature, follow this algorithm:
Read payload and signature values.
Concat the SDK public key with payload by formula:
publicKey + payload + publicKey
Create hmac using sha256 alrogithm and privateKey as encription key. Note: hmac digest should be hex.
Compare created hmac and signature.
We reccomend to read payload and signature from oauth url and send it to your backend part with POST query. Don't do it at the frontend side, because private key shouldn't be shared.
You may use expressMiddleware method of node.js moneymade connect sdk to validate signature in POST query body.
info
See examples repository for a complete example
If signature was validated as correct, then you need to generate user accessToken and send it to moneymade server via http request.
To achieve this follow these points:
- Decode request data from payload parameter. (Payload is a base64 encoded JSON string);
- Read from decoded data these variables:
- moneymadeAuthUrl
- userId
- Handle user authorization according to your logic
- Send request to moneymade.io API to finish oauth (See request requriements below);
Finish OAuth request
To finish oauth process, you should make finish oauth request from your backend side. URL is different for production and development modes, you should see API Base url variable in your console.
Body paremeters
Request body should be JSON contains following fields:
Field | Description |
---|---|
userId | userId read from payload received from moneymade side (query string) |
accessToken | accessToken with access rights to read user balances and transactions |
Sample:
{
"userId": "05db7e8c-d4d1-4b54-a09e-5039de2e6269"
"accessToken": "329f7bd421e3a516c5d88ea8e2654735329f7bd421e3a516c5d88ea8e2654735"
}
Request headers
Header | Description |
---|---|
api-key | Public key received from moneymade devs |
request-signature | Request signature received from moneymade side (signature from query string parameter) |
oauth-signature | Oauth signature received from moneymade (read from query string) |
Close oauth popup
Dashboard moneymade.io opens your platform oauth page in popup or iframe. You should send following messages to main window for closing the popup or iframe:
For iframe:
If oauth authorization was sucessull:
window.parent.postMessage({ status: 'OK' }, '*');
If oauth authorization was failed:
window.parent.postMessage({ status: 'FAILED' }, '*');
For popup:
If oauth authorization was sucessull:
window.opener.postMessage({ status: 'OK' }, '*');
If oauth authorization was failed:
window.opener.postMessage({ status: 'FAILED' }, '*');