Jincor ICO dashboard backend

Almost all operations require 2-factor Authentication. To fulfill this requirement most of them are split to 2 endpoints: first (e.g. /user/login/initiate) initiates login and generates JWT token. Next this token must be verified using endpoint /user/login/verify.

Resource Group

Register user

User’s email must be verified after registration. Next step after calling this endpoint is POST /user/activate using verification.id from response.

POST http://ico-dashboard:3000//user
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "email": "ortgma@gmail.com",
  "name": "ICO investor",
  "password": "test12A6!@#$%^&*()_-=+|/",
  "referral": "dGVzdEB0ZXN0LmNvbQ",
  "agreeTos": true,
  "source": {
    "utm": "utm",
    "gtm": "gtm"
  }
}
Responses200422
Headers
Content-Type: application/json
Body
{
  "id": "fb10d98f-2a5e-430d-bf2a-c76b42259b74",
  "email": "ortgma@gmail.com",
  "name": "ICO investor",
  "agreeTos": true,
  "verification": {
    "id": "3ed09e0a-72e1-417b-a05c-f0f08a5e1ffa",
    "method": "email"
  },
  "isVerified": false,
  "defaultVerificationMethod": "email",
  "referralCode": "b3J0Z21hQGdtYWlsLmNvbQ",
  "referral": "test@test.com",
  "source": {
    "utm": "utm",
    "gtm": "gtm"
  }
}
Headers
Content-Type: application/json
Body
{
  "error": {
    "isJoi": true,
    "name": "ValidationError",
    "details": [
      {
        "message": "Not valid referral code",
        "path": "referral",
        "type": "string.email",
        "context": {
          "value": "�m�",
          "key": " "
        }
      }
    ],
    "_object": {
      "email": "ortgma111@gmail.com",
      "name": "ICO investor",
      "password": "PasswordA1",
      "agreeTos": true,
      "referral": "�m�"
    }
  },
  "value": {
    "email": "ortgma111@gmail.com",
    "name": "ICO investor",
    "password": "PasswordA1",
    "agreeTos": true,
    "referral": "�m�"
  }
}

Register new user
POST/user

  • email test@test.com (string, required, email)

  • password passwordA6 (string, required, min: 6, regex: ^(?=.[a-z])(?=.[A-Z])(?=.*\d)[a-zA-Z\d]{6,}$)

  • name ICO investor (string, required, min: 3)

  • agreeTos true (boolean, equals: true)

  • referral referral@test.com (optional, string, base64 encoded email)


Activate a user

This endpoint response with JWT token so user can be immediately redirected to dashboard. JWT token received by /activate DOES NOT require verification. This endpoint’s response also contains VERY important information: mnemonic phrase and private key of user’s ethereum address. This information should be saved by user. If user loses this he will also LOSE access to his wallet of ICO dashboard.

POST http://ico-dashboard:3000//user/activate
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "email": "test@test.com",
  "verificationId": "5bb38971-1f22-4f99-a904-62fb44430ab4",
  "code": "327845"
}
Responses200
Headers
Content-Type: application/json
Body
{
  "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImY5NzM5MmVjLTBlYzItNGI3Mi04NmFiLTExMmYxM2ViOWYxNSIsImxvZ2luIjoib3J0Z21hQGdtYWlsLmNvbSIsImRldmljZUlkIjoiZGV2aWNlIiwianRpIjoiZjk3MzkyZWMtMGVjMi00YjcyLTg2YWItMTEyZjEzZWI5ZjE1ZGV2aWNlMTUwNzgxNjcyOTk2MCIsImlhdCI6MTUwNzgxNjcyOTk2MCwic3ViIjoiYWU3YzViNzYtNTgyMS00ZGUyLWE2OGYtZGQ0YzAwN2VkODM0IiwiYXVkIjoiamluY29yLmNvbSIsImV4cCI6MTUwNzgxNzMzNDc2MH0.Va8aBa_kDY2sqz2iZRnRWcOCF6cAGU5T69Y3-Ijg9KI",
  "wallets": [
    {
      "ticker": "ETH",
      "address": "0xdb369b56BA7b07cF287f611Fbf0DAA4A8a4C2751",
      "balance": "0",
      "mnemonic": "skull rain doctor wine stand pigeon roof half laundry tank hero behave",
      "privateKey": "0xda2b3f0590d9f0a8e310203e1c7136693d0954420a82ab2cbcfa88eca07b4b31"
    }
  ]
}

Activate a user
POST/user/activate

  • email test@test.com (string, required, email)

  • verificationId bb38971-1f22-4f99-a904-62fb44430ab4 (string, required)

  • code 123456 (string, required)


Initiate login

The accessToken got from this endpoint response MUST BE ALWAYS verified via /user/login/verify. Authentication attempts with not verified token will result in 401 response.

POST http://ico-dashboard:3000//user/login/initiate
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "email": "test@test.com",
  "password": "test12A6!@#$%^&*()_-=+|/"
}
Responses200
Headers
Content-Type: application/json
Body
{
  "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjNhYTQzMzA0LTNhMTEtNDNkNy05NjNhLTRmNDA0OTY2MDVmMyIsImxvZ2luIjoidGVzdEB0ZXN0LmNvbSIsImRldmljZUlkIjoiZGV2aWNlIiwianRpIjoiM2FhNDMzMDQtM2ExMS00M2Q3LTk2M2EtNGY0MDQ5NjYwNWYzZGV2aWNlMTUwNzcxOTg1MzcwNiIsImlhdCI6MTUwNzcxOTg1MzcwNiwic3ViIjoiNWJiMzg5NzEtMWYyMi00Zjk5LWE5MDQtNjJmYjQ0NDMwYWI0IiwiYXVkIjoiamluY29yLmNvbSIsImV4cCI6MTUwNzcyMDQ1ODUwNn0.vaZtMpPlPZDSLCVpMMC2dpCvbSram9mXNBPAaxSupKc",
  "isVerified": false,
  "verification": {
    "verificationId": "7fa96769-7bcc-4705-b544-02a83707cfc8",
    "consumer": "test@test.com",
    "expiredOn": 1507720153,
    "status": 200,
    "method": "email"
  }
}

Initiate login
POST/user/login/initiate

  • email test@test.com (string, required, email)

  • password passwordA6 (string, required)


Verify login

  • accessToken token (required, string)

  • verification

    • id (string, required)
    • code (string, required)
    • method (string, required)
POST http://ico-dashboard:3000//user/login/verify
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjNhYTQzMzA0LTNhMTEtNDNkNy05NjNhLTRmNDA0OTY2MDVmMyIsImxvZ2luIjoidGVzdEB0ZXN0LmNvbSIsImRldmljZUlkIjoiZGV2aWNlIiwianRpIjoiM2FhNDMzMDQtM2ExMS00M2Q3LTk2M2EtNGY0MDQ5NjYwNWYzZGV2aWNlMTUwNzcxOTg1MzcwNiIsImlhdCI6MTUwNzcxOTg1MzcwNiwic3ViIjoiNWJiMzg5NzEtMWYyMi00Zjk5LWE5MDQtNjJmYjQ0NDMwYWI0IiwiYXVkIjoiamluY29yLmNvbSIsImV4cCI6MTUwNzcyMDQ1ODUwNn0.vaZtMpPlPZDSLCVpMMC2dpCvbSram9mXNBPAaxSupKc",
  "verification": {
    "id": "7fa96769-7bcc-4705-b544-02a83707cfc8",
    "code": "544188",
    "method": "email"
  }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjNhYTQzMzA0LTNhMTEtNDNkNy05NjNhLTRmNDA0OTY2MDVmMyIsImxvZ2luIjoidGVzdEB0ZXN0LmNvbSIsImRldmljZUlkIjoiZGV2aWNlIiwianRpIjoiM2FhNDMzMDQtM2ExMS00M2Q3LTk2M2EtNGY0MDQ5NjYwNWYzZGV2aWNlMTUwNzcxOTg1MzcwNiIsImlhdCI6MTUwNzcxOTg1MzcwNiwic3ViIjoiNWJiMzg5NzEtMWYyMi00Zjk5LWE5MDQtNjJmYjQ0NDMwYWI0IiwiYXVkIjoiamluY29yLmNvbSIsImV4cCI6MTUwNzcyMDQ1ODUwNn0.vaZtMpPlPZDSLCVpMMC2dpCvbSram9mXNBPAaxSupKc",
  "isVerified": true,
  "verification": {
    "verificationId": "7fa96769-7bcc-4705-b544-02a83707cfc8",
    "consumer": "test@test.com",
    "expiredOn": 1507720153,
    "status": 200,
    "method": "email"
  }
}

Verify login
POST/user/login/verify


Initiate password change

POST http://ico-dashboard:3000//user/me/changePassword/initiate
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "oldPassword": "test12A6!@#$%^&*()_-=+|/",
  "newPassword": "passwordA1"
}
Responses200
Headers
Content-Type: application/json
Body
{
  "verification": {
    "verificationId": "8f9ba03c-e903-459c-adb9-7594865a03a4",
    "consumer": "ortgma@gmail.com",
    "expiredOn": 1508268673,
    "status": 200,
    "method": "email"
  }
}

Initiate password change
POST/user/me/changePassword/initiate

  • oldPassword passwordA1 (string, required)

  • newPassword passwordA6 (string, required, regex: /^(?=.[a-z])(?=.[A-Z])(?=.\d)[a-zA-Z0\d!"#$%&’()+,-./:;<=>?@[]^_`{|}~]{8,}$/)


Verify password change

  • oldPassword (required, string)

  • newPassword (required, string, regex: /^(?=.[a-z])(?=.[A-Z])(?=.\d)[a-zA-Z0\d!"#$%&’()+,-./:;<=>?@[]^_`{|}~]{8,}$/)

  • verification

    • verificationId (string, required)
    • code (string, required)
POST http://ico-dashboard:3000//user/me/changePassword/verify
Requestsexample 1
Headers
Content-Type: application/json
Authorization: Bearer token
Accept: application/json
Body
{
  "oldPassword": "test12A6!@#$%^&*()_-=+|/",
  "newPassword": "passwordA1",
  "verification": {
    "verificationId": "d65aa8f7-3b8a-4764-a003-1ecd06dda7fd",
    "method": "email",
    "code": "186198"
  }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImJiNWRjOTBjLTM1NTktNDZhNS04MGNhLTA3Mjg0OTczMjdlYiIsImxvZ2luIjoib3J0Z21hQGdtYWlsLmNvbSIsImRldmljZUlkIjoiZGV2aWNlIiwianRpIjoiYmI1ZGM5MGMtMzU1OS00NmE1LTgwY2EtMDcyODQ5NzMyN2ViZGV2aWNlMTUwODI2NTEwMjQ1NSIsImlhdCI6MTUwODI2NTEwMjQ1NSwic3ViIjoiOGY5YmEwM2MtZTkwMy00NTljLWFkYjktNzU5NDg2NWEwM2E0IiwiYXVkIjoiamluY29yLmNvbSIsImV4cCI6MTUwODI2NTcwNzI1NX0.9HDUMmamSIZX7T0qTKId6oN4XYU7ni7Wx8lQSiIz1S0"
}

Verify password change
POST/user/me/changePassword/verify


Initiate password reset

POST http://ico-dashboard:3000//user/resetPassword/initiate
Requestsexample 1
Headers
Content-Type: application/json
Body
{
  "email": "test@test.com"
}
Responses200
Headers
Content-Type: application/json
Body
{
  "verification": {
    "verificationId": "8f9ba03c-e903-459c-adb9-7594865a03a4",
    "consumer": "test@test.com",
    "expiredOn": 1508268673,
    "status": 200,
    "method": "email"
  }
}

Initiate password change
POST/user/resetPassword/initiate

  • email test@test.com (string, email, required)

Verify password reset

  • email (required, email, string)

  • newPassword (required, string, regex: /^(?=.[a-z])(?=.[A-Z])(?=.\d)[a-zA-Z0\d!"#$%&’()+,-./:;<=>?@[]^_`{|}~]{8,}$/)

  • verification

    • verificationId (string, required)
    • code (string, required)
    • method (string, required, in [“email”, “google_auth”])
POST http://ico-dashboard:3000//user/resetPassword/verify
Requestsexample 1
Headers
Content-Type: application/json
Accept: application/json
Body
{
  "email": "test@test.com",
  "password": "PasswordA1",
  "verification": {
    "verificationId": "b41498d8-a9db-4bb5-b338-0e8f47582066",
    "code": "813365",
    "method": "email"
  }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "status": 200,
  "data": {
    "verificationId": "631dbfce-c5cb-4892-baa8-25e618e224a1",
    "consumer": "test@test.com",
    "attempts": 1,
    "expiredOn": 1511981452
  }
}

Verify password change
POST/user/resetPassword/verify


Initiate enable 2FA

  • Request
    • Headers

      Authorization: Bearer token
        Accept: application/json
GET http://ico-dashboard:3000//user/enable2fa/initiate
Responses200
Headers
Content-Type: application/json
Body
{
  "verification": {
    "verificationId": "61fa7fab-6abd-469c-9196-85680bab577a",
    "consumer": "ortgma@gmail.com",
    "expiredOn": 1508856803,
    "totpUri": "otpauth://totp/Jincor:ortgma@gmail.com?secret=PWQGHWHUIXN6RDINTO4XUSFURXMKWWJO&issuer=Jincor&algorithm=SHA1&digits=6&period=30",
    "status": 200,
    "method": "google_auth",
    "qrPngDataUri": ""
  }
}

Initiate enable 2fa
GET/user/enable2fa/initiate


Verify enable 2fa

  • verification
    • verificationId (string, required)
    • code (string, required)
    • method (string, required, in [“email”, “google_auth”])
POST http://ico-dashboard:3000//user/enable2fa/verify
Requestsexample 1
Headers
Content-Type: application/json
Authorization: Bearer token
Accept: application/json
Body
{
  "verification": {
    "verificationId": "b41498d8-a9db-4bb5-b338-0e8f47582066",
    "code": "813365",
    "method": "google_auth"
  }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "enabled": false
}

Verify enable 2fa
POST/user/enable2fa/verify


Initiate disable 2FA

  • Request
    • Headers

      Authorization: Bearer token
        Accept: application/json
GET http://ico-dashboard:3000//user/disable2fa/initiate
Responses200
Headers
Content-Type: application/json
Body
{
  "verification": {
    "verificationId": "0e47a5fd-d7f7-43af-b080-3918e49bf211",
    "consumer": "ortgma@gmail.com",
    "expiredOn": 1508850911,
    "status": 200,
    "method": "google_auth"
  }
}

Initiate disable 2fa
GET/user/disable2fa/initiate


Verify disable 2fa

  • verification
    • verificationId (string, required)
    • code (string, required)
    • method (string, required, in [“email”, “google_auth”])
POST http://ico-dashboard:3000//user/disable2fa/verify
Requestsexample 1
Headers
Content-Type: application/json
Authorization: Bearer token
Accept: application/json
Body
{
  "verification": {
    "verificationId": "b41498d8-a9db-4bb5-b338-0e8f47582066",
    "code": "813365",
    "method": "google_auth"
  }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "enabled": false
}

Verify disable 2fa
POST/user/disable2fa/verify


Get user info

GET http://ico-dashboard:3000//user/me
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "ethAddress": "0xdb369b56BA7b07cF287f611Fbf0DAA4A8a4C2751",
  "email": "existing@test.com",
  "name": "ICO investor",
  "kycStatus": "Not verified",
  "defaultVerificationMethod": "email"
}

Get user info
GET/user/me


Invite users

POST http://ico-dashboard:3000//user/invite
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Body
{
  "emails": [
    "ortgma@gmail.com",
    "a_pikulin@mail.ru"
  ]
}
Responses200
Headers
Content-Type: application/json
Body
{
  "emails": [
    {
      "email": "ortgma@gmail.com",
      "invited": true
    },
    {
      "email": "a_pikulin@mail.ru",
      "invited": true
    }
  ]
}

Invite users by email
POST/user/invite


Get dashboard info

GET http://ico-dashboard:3000//dashboard
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "ethBalance": "1.0001",
  "jcrTokensSold": "5000",
  "jcrTokenBalance": "500.00012345678912345",
  "jcrTokenPrice": {
    "ETH": "0.005",
    "USD": "1"
  },
  "raised": {
    "ETH": "2000",
    "USD": "1000000",
    "BTC": "100"
  },
  "daysLeft": 10
}

Get dashboard info
GET/dashboard


Get public dashboard info

GET http://ico-dashboard:3000//dashboard/public
Requestsexample 1
Headers
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "jcrTokensSold": "0",
  "ethCollected": "0",
  "contributionsCount": 0,
  "daysLeft": 64
}

Get public dashboard info
GET/dashboard/public


Get expected token purchase fee

GET http://ico-dashboard:3000//dashboard/investTxFee
Requestsexample 1
Headers
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "gasPrice": "47",
  "gas": "130000",
  "expectedTxFee": "0.00611"
}

Get expected token purchase fee
GET/dashboard/investTxFee


Get transaction history

GET http://ico-dashboard:3000//dashboard/transactions
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
[
  {
    "id": "5a003866ee3a9d0ad93aeba3",
    "transactionHash": "0xe423dd7d40b039e4e30ad7b5520f5905c6ec8c11122c94e3858c70e7983b5d7e",
    "timestamp": 1509963894,
    "blockNumber": 2016136,
    "from": "0xBd0cb067A75C23EFB290B4e223059Af8E4AF4fd8",
    "to": "0x446cd17EE68bD5A567d43b696543615a94b01760",
    "ethAmount": "0",
    "jcrAmount": "1",
    "status": "confirmed",
    "type": "jcr_transfer",
    "direction": "out"
  },
  {
    "id": "5a004158b8442c0e1400fc4f",
    "transactionHash": "0xcdf4a9dc086bcb3308475ced42b772879fd052822693aee509f81493412d460f",
    "timestamp": 1509966175,
    "blockNumber": 2016339,
    "from": "0xBd0cb067A75C23EFB290B4e223059Af8E4AF4fd8",
    "to": "0x446cd17EE68bD5A567d43b696543615a94b01760",
    "ethAmount": "0",
    "jcrAmount": "1",
    "status": "confirmed",
    "type": "jcr_transfer",
    "direction": "out"
  },
  {
    "id": "5a004dee3663160140d19291",
    "transactionHash": "0xe5d5ed39bf9eb64d3e56bf4a9d89b7f2bb026fc02c0d149027757936a1e7b6c7",
    "timestamp": 1509969394,
    "blockNumber": 2016578,
    "from": "0xBd0cb067A75C23EFB290B4e223059Af8E4AF4fd8",
    "to": "0x446cd17EE68bD5A567d43b696543615a94b01760",
    "ethAmount": "2",
    "status": "confirmed",
    "type": "eth_transfer",
    "direction": "out"
  },
  {
    "id": "5a004e003663160140d19292",
    "transactionHash": "0x057c0846b7b7fa54c10544c595ec2e476c830220f0ea1fbb52215a3a44deade1",
    "timestamp": 1509969394,
    "blockNumber": 2016578,
    "from": "0xBd0cb067A75C23EFB290B4e223059Af8E4AF4fd8",
    "to": "0x446cd17EE68bD5A567d43b696543615a94b01760",
    "ethAmount": "2",
    "status": "confirmed",
    "type": "eth_transfer",
    "direction": "out"
  },
  {
    "id": "5a00669ab21e84067aac8bf6",
    "transactionHash": "0xb87ef88fe75724ed067413de7c48f4c745cfafa709f42884308663cb53a8e2a0",
    "timestamp": 1509975754,
    "from": "0x54c0B824d575c60F3B80ba1ea3A0cCb5EE3F56eA",
    "to": "0xBd0cb067A75C23EFB290B4e223059Af8E4AF4fd8",
    "ethAmount": "5",
    "status": "pending",
    "type": "eth_transfer",
    "direction": "in"
  }
]

Get transaction history
GET/dashboard/transactions


Get referral info

GET http://ico-dashboard:3000//dashboard/referral
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "data": "dGVzdEB0ZXN0LmNvbQ",
  "referralCount": 5,
  "users": [
    {
      "date": 1508241475,
      "name": "Investor 1",
      "walletAddress": "0x54c0B824d575c60F3B80ba1ea3A0cCb5EE3F56eA",
      "tokens": "105"
    },
    {
      "date": 1508241475,
      "name": "Investor 2",
      "walletAddress": "0x54c0B824d575c60F3B80ba1ea3A0cCb5EE3F56eB",
      "tokens": "1.01"
    }
  ]
}

Get referral info
GET/dashboard/referral


Initiate investment

  • ethAmount 1 (required, number, min(1))

  • mnemonic mnemonic (required, string)

POST http://ico-dashboard:3000//dashboard/invest/initiate
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Body
{
  "ethAmount": 1,
  "mnemonic": "mnemonic"
}
Responses200
Headers
Content-Type: application/json
Body
{
  "verification": {
    "verificationId": "a4d642d6-8c96-4435-94b8-9a2bbd501552",
    "consumer": "test@gmail.com",
    "expiredOn": 1509387586,
    "status": 200,
    "method": "email"
  }
}

Initiate investment
POST/dashboard/invest/initiate


Verify investment

  • ethAmount 1 (required, number, min(1))

  • mnemonic mnemonic (required, string)

  • verification

    • verificationId (string, required)
    • code (string, required)
    • method (string, required, in [“email”, “google_auth”])
POST http://ico-dashboard:3000//dashboard/invest/verify
Requestsexample 1
Headers
Content-Type: application/json
Authorization: Bearer token
Accept: application/json
Body
{
    "ethAmount": 1,
    "mnemonic": "mnemonic"
    "verification": {
        "verificationId": "b41498d8-a9db-4bb5-b338-0e8f47582066",
        "code": "813365",
        "method": "google_auth"
    }
}
Responses200
Headers
Content-Type: application/json
Body
{
  "transactionHash": "0xf33afe0b5b56dfb6584d308d7b5e4c0412041045f3f728708eb90ac6f48e0956",
  "status": "pending",
  "type": "token_purchase"
}

Verify investment
POST/dashboard/invest/verify


Init KYC process

GET http://ico-dashboard:3000//kyc/init
Requestsexample 1
Headers
Authorization: Bearer token
Accept: application/json
Responses200
Headers
Content-Type: application/json
Body
{
  "timestamp": "2017-11-09T06:47:31.467Z",
  "authorizationToken": "c87447f8-fa43-4f98-a933-3c88be4e86ea",
  "clientRedirectUrl": "https://lon.netverify.com/widget/jumio-verify/2.0/form?authorizationToken=c87447f8-fa43-4f98-a933-3c88be4e86ea",
  "jumioIdScanReference": "7b58a08e-19cf-4d28-a828-4bb577c6f69a"
}

Init KYC process
GET/kyc/init


Generated by aglio on 26 Dec 2017