Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@nexeraid/kyc-sdk

Package Overview
Dependencies
Maintainers
1
Versions
41
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@nexeraid/kyc-sdk

Nexera ID KYC Verification SDK

  • 0.2.0
  • npm
  • Socket score

Version published
Weekly downloads
3
increased by50%
Maintainers
1
Weekly downloads
 
Created
Source

NexeraID KYC SDK

  • NexeraID KYC SDK, written in TypeScript.

How to install

$ npm install @nexeraid/kyc-sdk

First steps

  • You need to provide NexeraID Team with the Web App domain and a Webhook
  • You need to provide NexeraID with the required rules
  • NexeraID Team will provide to you with an API_KEY and a RULE_ID

How to use

Server app
  /*
   * Get access token
   * This has to be done from secured server, to avoid leaking API_KEY
   */
  const response = await fetch('https://api.nexera.id/kyc/auth/access-token', {
    body: JSON.stringify({ publicAddress }),
    headers: {
      'Content-Type': 'application/json',
      'Authorization': `Bearer ${API_KEY}`
    },
    method: 'POST'
  })
  const { accessToken } = await response.json()

  /*
   * Handle data from webhook
   * At the defined webhook endpoint, each time an user shares data with you, data with format
   * {
   *   address: '0x0000000000000000000000000000000000000000',
   *   data: {
   *     ...
   *   } 
   *  }
   */

  // Assuming you have this data in some variable named input 
  const response = await fetch('https://api.nexera.id/compliance/rules/execute', {
    body: JSON.stringify({
      inputData: input.data,
      address: input.address,
      policyId: `${POLICY_ID}`,
    }),
    headers: {
      'Content-Type': 'application/json',
      'Authorization': `Bearer ${API_KEY}`
    },
    method: 'POST'
  })
  /*
   * Validation result structure could vary according the required rules defined, but it will
   * have the necessary flags that determine whether or not the user meets the requirements. 
   */
  const validationResult = await response.json()
Web app
  // instantiate KycClient
  // identifier is optional, but if used, it will be considered for dom element id. Id will be conformed as "kyc-btn-myIdentifier"
  const KYC_CLIENT = new KycClient({ identifier: "myIdentifier"})

  // configure kyc flow callbacks

  // mandatory onSignPersonalData callback
  KYC_CLIENT.onSignPersonalData(async (data: string) => {
    // make user sign data with wallet, and return result
    return await signMessageAsync({ message: data })
  })

  // optional onOffChainShareCompletition callback
  KYC_CLIENT.onOffChainShareCompletition((isValid: boolean) => {
    //with this param, you can check if the kyc shared data is valid for the defined rules
    if (isValid)
      console.log(`Success Off chain data sharing`)
    else
      console.error(`Off chain share data was invalid`)
  })

  // optional onZkCallback (mandatory if zk flow will be used)
  KYC_CLIENT.onZkCallback(async (data) => {
    // make wallet user send transaction, using data from kyc app, and returning transaction hash
    const tx = await signer.data.sendTransaction(data);
    return tx.hash;
  });

  // build signing message, needed to safety store kyc in user's browser
  const signingMessage = KycClient.buildSignatureMessage(address)
  const signature = await signMessageAsync({ message: signingMessage })
  // here you need to get access token from your server, which will call our backend as we explained in the Server app section
  const accessToken = getAccessTokenFromYourServer(address)
  <!--define button with id 'kyc-btn-myIdentifier' in frontend page. If no identifier was defined in KycClient constructor, 'kyc-btn' is used-->
  <button id="kyc-btn">Start KYC</button>
  // finally, once accessToken, signingMessage and signature ready, and button defined, KycClient can be initialised
  KYC_CLIENT.init({
    auth: {
      accessToken,
      signingMessage,
      signature,
    },
    initOnFlow: "REQUEST", // flows available: "REQUEST" | "MANAGEMENT"
  })
  // In addition to the KYC request, the sdk also provides a management of your kyc. It can be initialized as follows

  KYC_CLIENT.init({
    auth: {
      accessToken,
      signingMessage,
      signature,
    },
    initOnFlow: "MANAGEMENT", // flows available: "REQUEST" | "MANAGEMENT"
  })

Keep Updated

For the latest changes, see the CHANGELOG.

FAQs

Package last updated on 20 Jun 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc