NAV Navbar
shell javascript json
  • Introduction
  • Authentication
  • API Interaction
  • Versioning
  • Endpoints - Account
  • Endpoints - Wallet
  • Endpoints - General
  • Introduction

    Xinfin provides a simple and powerful wallet REST API. You can use our API to access wallet API endpoints and integrate into your application.

    This API reference provides information on available endpoints and how to interact with it.

    Authentication

    Wallet uses API key to allow access to the API. You can request a new API key at our developer portal.

    The API Key and Merchant ID needs to be included in the request body for all API requests.

    Alternatively you can also do the following ,

    The API key needs to be included for all API requests to the server in a header that looks like the following:

    API-KEY: 04af606c-38a3-11e8-b467-0ed5f89f718b

    along with the Merchant ID.

    API Interaction

    Status codes

    Response format

    Depending on whether the request is successful or not the response format will change.

    Endpoint specific data will exist in data object on successful request.

    Successful repsonse format

    {
      "status" : "success",
      "data" : {}
    }
    

    Failed repsonse format

    {
      "status" : "failed",
      "appErrorCode": "",
      "errMessage": ""
    }
    

    Errors

    List of api errors and their mapping with http status code.

    Error Code Status code Error Message
    1001 400 The request was unacceptable, often due to missing a required parameter
    1002 400 No value provided for mandatory resource
    1003 400 The specified resource type does not match the required type
    1004 403 The specified resource does not exist
    1005 400 The resource exceeds the maximum allowed value of {{MAX}}
    1006 400 The resource does not meet minimum required value of {{MIN}}
    1007 400 The resource does not match required size of {{SIZE}}
    1008 409 Invalid email
    1009 400 Invalid date format
    1010 400 Invalid XDC address
    1011 400 The specified resource is out of range
    1012 409 Invalid value
    1101 401 No valid API key provided
    1102 400 Too many requests hit the API too quickly
    1103 409 The specified account already exists
    1104 403 Server failed to authenticate the request
    1105 500 Internal Error
    1106 500 DB Error
    1107 500 Cannot send activation email to the user
    1108 500 Cannot unlock account
    1109 500 Cannot create new account
    1110 500 Cannot send forgot password/reset email to the user
    1111 404 Given email id does not exist
    1112 404 Reset Link Expired
    1113 400 Cannot change password. Enter correct detail
    1115 500 Something went wrong. Cannot process the request
    1116 400 Failed not enough balance
    1117 400 Account is invalid
    1118 400 Incorrect Password
    1119 400 Invalid OTP (2FA)
    1120 400 Cannot setup new account
    1121 404 Account does not exists
    1122 400 OTP Error
    1123 400 API Key is invalid
    1124 400 OTP Expired

    Versioning

    Inorder to use v1.0 API version, use the following url address :
    https://[host]/api/v1/[endpoint]

    Endpoints - Account

    Most of the endpoint require authentication of some type (user/API Key authentication). Where not required appropriate note will be provided.

    Check Account Existence

    Create new account for user.

    HTTP Request

    GET https://[host]/api/v1/account/check-existence

    curl -X GET \
      'http://localhost:3000/api/v1/account/check-existence?email=test%40email.com&merchantId=00&apiKey=04af606c-38a3-11e8-b467-0ed5f89f718b' \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
    

    The JSON encoded response on successful request

    {
        "status": "success",
        "data": {
            "email": "test@email.com",
            "merchantId": "00",
            "message": "Account already exists."
        }
    }
    

    Parameters

    Argument Type Required
    email String yes
    merchantId String yes
    apiKey String yes

    Create Account

    Create new account for user.

    HTTP Request

    POST https://[host]/api/v1/account

    curl -X POST \
      http://localhost:3000/api/v1/account \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "email":"test@email.com",
        "phone":"1234567890",
        "password":"123",
        "merchantName":"Xinfin",
        "merchantId":"00",
        "apiKey":"04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response on successful account creation

    {
        "status": "success",
        "data": {
            "publicKey": "0xca9c3fc05f3dda885d77c0b4ae2e3a01cf92cec7",
            "message": "Account created successfully. Activation link sent on your email."
        }
    }
    

    Parameters

    Argument Type Required
    email String yes
    phone String yes
    merchantName String yes
    merchantId String yes
    apiKey String yes

    Sign In

    Sign into users account.
    2FA authentication is required for signin.

    Supported 2FA Auth methods :

    If otpNo parameter is kept blank, email containing otp will be sent to user address given email based 2FA is enabled.
    Retry the request with otpNo parameter set as given otp.

    On successful signin the jwt token will be issued.

    HTTP Request

    POST https://[host]/api/v1/signin

    curl -X POST \
      http://localhost:3000/api/v1/signin \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
      "username" : "test@email.com",
      "password" : "123",
      "merchantId" : "00",
      "otpNo" : ""
      "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response when otp is blank

    {
        "status": "success",
        "data": {
            "twofaenabled": false,
            "message": "OTP sent Successfully on your Email."
        }
    }
    

    The JSON encoded response when otp is set

    {
        "status": "success",
        "data": {
            "message": "Successfully logged in.",
            "jwt": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJtZXJjaGFudElkIjoiMDAiLCJhcGlLZXkiOiIzYjQxNGVmMC0zMzMxLTExZTgtODNiYi04MWNhZjU0ZTU1YzMiLCJ2ZXJzaW9uIjoidjEuMCIsImlhdCI6MTUyMjkyNzA5MiwiZXhwIjoxNTIyOTI3NjkyfQ.4U-oYtIftbqrjGLIgfzmEBC_u4hVZaVcFu8znzcS2EI"
        }
    }
    

    Parameters

    Argument Type Required Description
    username String yes user's email
    phone String yes
    merchantName String yes
    otpNo String yes keeping this field blank will result in api server sending otp email to the user.
    apiKey String yes

    Enable TOTP 2FA

    Enable Google Authenticator based 2FA.

    HTTP Request

    POST https://[host]/api/v1/account/enable2FA

    curl -X POST \
      http://localhost:3000/api/v1/account/enable2FA \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "merchantId":"00",
        "username":"test@email.com",
        "apiKey":"04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response

    {
      "status": "success",
      "data": {
        "account": "test@email.com",
        "message": "2FA authentication enabled.",
        "qrcode": "data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAANQAAADUCAYAAADk.....redacted...",
        "secret": "OR5GKNZUJ4YFKWJXKJKVIS2QOJ3EK4SZ"
      }
    }
    

    Parameters

    Argument Type Required Description
    username String yes user's email
    merchantId String yes
    apiKey String yes

    Disable TOTP 2FA

    Disable Google Authenticator based 2FA.

    HTTP Request

    POST `https://[host]/api/v1/account/disable2FA

    curl -X POST \
      http://localhost:3000/api/v1/account/disable2FA \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "merchantId":"00",
        "username":"test@email.com",
        "apiKey":"04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response

    {
        "status": "success",
        "data": {
            "message": "2FA authentication disabled."
        }
    }
    

    Parameters

    Argument Type Required Description
    username String yes user's email
    merchantId String yes
    apiKey String yes

    Verify TOTP 2FA

    Disable Google Authenticator based 2FA.

    HTTP Request

    POST `https://[host]/api/v1/account/verify2FA

    curl -X POST \
      http://localhost:3000/api/v1/account/verify2FA \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "username":"test@email.com",
        "merchantId":"00",
        "otp":"050395",
        "apiKey":"04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response

    {
        "status": "success",
        "data": {
        "message": "Otp is verified",
    }
    

    Parameters

    Argument Type Required Description
    username String yes user's email
    merchantId String yes
    otp String yes
    apiKey String yes

    Change Password

    Change user account password.

    HTTP Request

    POST https://[host]/api/v1/account/password

    curl -X POST \
      http://localhost:3000/api/v1/account/password \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "email" : "test@email.com",
        "newPassword" : "1234",
        "oldPassword" : "123",
        "merchantId" : "00",
        "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response

    {
        "status": "success",
        "data": {
            "message": "Password changed successfully."
        }
    }
    

    Parameters

    Argument Type Required Description
    email String yes user's email
    oldPassword String yes
    newPassword String yes
    merchantId String yes
    apiKey String yes

    Forgot Password

    Initiate forgot password/reset password process.

    Calling this API will result in sending reset link to the user's registered email account.

    HTTP Request

    POST https://[host]/api/v1/account/forgot-password

    curl -X POST \
      http://localhost:3000/api/v1/account/forgot-password \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "email" : "test@email.com",
        "merchantId" : "00",
        "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response

    {
        "status": "success",
        "data": {
            "message": "Reset link has been sent to your registered email."
        }
    }
    

    Parameters

    Argument Type Required Description
    email String yes user's email
    merchantId String yes
    apiKey String yes

    Endpoints - Wallet

    Get Balance

    Get user's balance in tokens.

    HTTP Request

    GET https://[host]/api/v1/wallet/balance

    curl -X GET \
      'http://localhost:3000/api/v1/wallet/balance?address=0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6&apiKey=04af606c-38a3-11e8-b467-0ed5f89f718b&merchantId=00' \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
      "address": "0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6"
    }'
    

    The JSON encoded response on successful request

    {
        "status": "success",
        "data": {
            "address": "0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6",
            "res": "0",
            "message": "Your Account Balance is 0",
            "balance": "0"
        }
    }
    

    Parameters

    Argument Type Required Description
    address String yes Public address
    merchantId String yes
    apiKey String yes

    Verify XDC address

    Verify XDC address.

    HTTP Request

    GET https://[host]/api/v1/wallet/balance

    curl -X GET \
      'http://localhost:3000/api/v1/wallet/verify-xdc-address?address=0xca9c3fc05f3dda885d77c0b4ae2e3a01cf92cec7&apiKey=04af606c-38a3-11e8-b467-0ed5f89f718b&merchantId=00&xdc=1001' \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
      "address": "0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6"
    }'
    

    The JSON encoded response on successful request

    {
        "status": "success",
        "data": {
            "message": "Address is valid"
        }
    }
    

    Parameters

    Argument Type Required Description
    address String yes Public address
    merchantId String yes
    apiKey String yes

    Get QRCode

    Get qrcode for user's public address.

    HTTP Request

    GET https://[host]/api/v1/wallet/qrcode

    curl -X GET \
      'http://localhost:3000/api/v1/wallet/qrcode?address=0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6&apiKey=04af606c-38a3-11e8-b467-0ed5f89f718b&merchantId=00' \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
    

    The JSON encoded response on successful request

    {
        "status": "success",
        "data": {
            "url": "...redacted...."
        }
    }
    

    Parameters

    Argument Type Required Description
    address String yes Public address
    merchantId String yes
    apiKey String yes

    Get Transactions

    Get user account transactions.

    HTTP Request

    POST https://[host]/api/v1/wallet/qrcode

    curl -X POST \
      http://localhost:3000/api/v1/wallet/transactions \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
      "walletNo" : "",
      "address" : "0x3a4c7825695f22b693fc7bd42f3e8d9bc1af8bb6",
      "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b",
      "merchantId" : "00",
      "amount" : 0,
      "fromDate" : "",
      "toDate" : ""
    }'
    

    The JSON encoded response on successful request

    {
        "status": 'success',
        "data": []
    }
    

    Parameters

    Argument Type Required Description
    walletNo String yes
    address String yes Public address
    amount String yes
    fromDate String yes
    toDate String yes
    merchantId String yes
    apiKey String yes

    Send XDC

    Transfers XDC between accounts.

    Keep otp parameter blank during first request - this will result in API server sending email contaning the otp to the users email account. Once you get the otp, resend the request again with otp parameter set.

    HTTP Request

    POST https://[host]/api/v1/wallet/xdc

    curl -X POST \
      http://localhost:3000/api/v1/wallet/xdc \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
        "address" : "0xca9c3fc05f3dda885d77c0b4ae2e3a01cf92cec7",
        "email" : "test@email.com",
        "password" : "123",
        "xdc" : 1001,
        "otp" : "",
        "merchantId" : "00",
        "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b"
    }'
    

    The JSON encoded response on successful request

    {
        "status": 'success',
        "data": []
    }
    

    Parameters

    Argument Type Required Description
    address String yes Public address
    email String yes
    password String yes
    xdc String yes xdc amount
    otp String yes otp
    merchantId String yes
    apiKey String yes

    Endpoints - General

    Get XDC Price

    Get today's xdc price.

    HTTP Request

    POST https://[host]/api/v1/wallet/qrcode

    curl -X GET \
      http://localhost:3000/api/v1/today-xdc-price \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json'
    

    The JSON encoded response on successful request

    {
        "status": "success",
        "data": {
            "todayxdcprice": "0.00277758"
        }
    }
    

    Contact

    Creates support ticket.

    HTTP Request

    POST https://[host]/api/v1/contact

    curl -X POST \
      http://localhost:3000/api/v1/contact \
      -H 'cache-control: no-cache' \
      -H 'content-type: application/json' \
      -d '{
      "apiKey" : "04af606c-38a3-11e8-b467-0ed5f89f718b",
      "merchantId" : "00",
      "email" : "test@email.com",
      "name" : "John Doe",
      "query" : "body text"
    }'
    

    The JSON encoded response on successful request

    {
        status: 'success',
        data: {
            message: 'Query Sent. Someone from Xinfin will contact you shortly.'
        }
    
    }