Carbon

Documentation

Welcome to Carbon's docs!

Get Started    
const axios = require("axios");
const ROOT = process.env.NODE_ENV === "PRODUCTION" ? "https://api.carbon.money" : "https://sandbox.carbon.money";

Google 2FA is required once a user passes KYC.

We believe Google 2FA is very important because it prevent unauthorized access to your accounts. Google 2FA is also more secure than SMS-2FA because of recent sim-swapping hacks. Sim-swapping can reset your iCloud, your email and all of your cryptocurrency accounts.

2FA can also be enabled at any time to protect a user's account. The steps to enabling 2FA is to first:

  1. Create a 2FA
    Once the user has linked the 2FA with his/her Google Authentication (iOS or Android), they need to send in the real time 6 digit token in to step 2.

  2. Enabled 2FA
    If the token checks true, 2FA has successfully been added.

  3. Disable 2FA (optional)
    A user may also disabled 2FA if they pass in their token. Remember, all KYC-ed users are required to have 2FA for account safety purposes.

Super JWT Required

2FA Requirement Exception

To work through removing the 2FA requirement for your integration, please reach out to [email protected] Unless your KYC/AML and anti-fraud are already very stringent, it is very unlikely we will approve waiving this requirement.

1: Create 2FA

GET
Parameters
Access
Description

twoFactorIssuer

optional

When you create a google 2FA, your users will see a name corresponding to the 6 digit code. The default value is Carbon2FA but you can set this to something more relevant

let url = `${ROOT}/v1/auth/create2fa?contactId=ab5bb41b-5979-4a54-b734-23eb9076188e&twoFactorIssuer=CompanyName`;

axios.get(url).then(result => console.log).catch(err => console.log);
{
  "message":"successfully created 2fa!",
   "code": 200,
  "details":{
    "qrCode":"",
    "manual":"KA7F4SJTKYSUSL2RHZXSGUCMKVDSK6RYJFTSQMBVONGVONKCJIUA"
  }
}
// 401
{
  'message': 'you must disable 2fa before you can create a new 2fa',
  'code': 401
}

// 409
{
  'message': 'already existing 2fa',
  'code': 409
}

(Responses)

Response
Description

qrCode

If you add this as the source for a tag on the front end, you can generate a qrCode users can scan.

manual

Your users can also add this auth using a manual entry for Google 2FA.

Video Overview of Google 2FA

2: Enable 2FA

POST
let url = `${ROOT}/v1/auth/enable2fa`;

let data = {
  token: '1234565',
  contactId: 'ab5bb41b-5979-4a54-b734-23eb9076188e'
}

axios.post(url, data).then(result => console.log).catch(err => console.log);
{
  'message': 'successfully enabled 2fa!',
  "code": 200
}
{
  'message': 'error enabling 2fa', 
  'details': error,
  'code': 401
}

3: Disable 2FA

POST
let url = `${ROOT}/v1/auth/disable2fa`;

let data = {
  token: '1234565',
  contactId: 'ab5bb41b-5979-4a54-b734-23eb9076188e'
}


axios.post(url, data).then(result => console.log).catch(err => console.log);
{
  "message": "Successfully disbled 2fa!",
   "code": 200
}
{ 
  "message": "2fa failed",
  "code": 401 
}

Get Current 2FA Status

GET
let url = `${ROOT}/v1/auth/2fa?contactId=ab5bb41b-5979-4a54-b734-23eb9076188e`;

axios.get(url).then(result => console.log).catch(err => console.log);
{
  "message": "2FA is true",
   "code": 200,
  "status": true
}
Thank you for your feedback

2FA


Suggested Edits are limited on API Reference Pages

You can only suggest edits to Markdown body content, but not to the API spec.