✨Works out of the box guarantee. If you face any issue at all, hit us up on Telegram and we will write the integration for you.
logoReclaim Protocol Docs

Advance Options

This guide provides detailed information on advanced configuration options for the Reclaim Protocol SDK across multiple platforms. These options allow you to customize and enhance your integration for specific use cases.

Before exploring advanced options, ensure you're familiar with the Basic Usage guide for your platform. All advanced configurations should be set before calling getRequestUrl(). These options work for both frontend and backend implementations.

Advanced Options

Adding Context

Use the addContext method to include additional information in your proof request. This context helps identify and differentiate between various proof requests in the resulting proof object.

const reclaimProofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID'
)
 
reclaimProofRequest.addContext('0x1234567890abcdef', 'User registration proof')
 
const requestUrl = await reclaimProofRequest.getRequestUrl()
  • contextId: Unique hex address identifier (string)
  • Context message: Descriptive information about the proof request (string)

Context provides valuable metadata about your proof request's purpose or origin. This is particularly helpful when managing multiple proof types. The contextId must be a valid hex address (starting with '0x' and containing only 0-9 and a-f).

Setting Parameters

The setParams method lets you define specific conditions for proof generation, enabling selective triggering and manual verification workflows.

const reclaimProofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID'
)
 
reclaimProofRequest.setParams({ // Params value must be a string
  minConnections: '500', 
  industry: 'Technology'
})
 
const requestUrl = await reclaimProofRequest.getRequestUrl()

Use parameters judiciously. Proof generation will fail if the actual data doesn't meet the specified parameters. Ensure your parameters are both achievable and relevant to your proof request.

Custom Redirect URL

The setRedirectUrl method allows you to specify a custom URL where users will be redirected after the verification process.

const reclaimProofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID'
)
 
reclaimProofRequest.setRedirectUrl('https://your-app.com/verification-complete')
 
const requestUrl = await reclaimProofRequest.getRequestUrl()

This enhances user experience by seamlessly guiding users back to your application after proof generation. Ensure the redirect URL is prepared to handle post-verification logic.

Custom Callback URL

The setAppCallbackUrl method allows you to specify a custom API endpoint where proofs will be sent upon successful generation.

const reclaimProofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID'
)
 
reclaimProofRequest.setAppCallbackUrl('https://your-api.com/receive-proofs')
 
const requestUrl = await reclaimProofRequest.getRequestUrl()

Parameters for setAppCallbackUrl:

  • URL: The URL of the API endpoint where proofs will be sent.
  • jsonProofResponse (Optional): By default, it is set to false. When set to false, the proof is returned as a url encoded message in the response. When set to true, the proof is returned as a JSON object in the response.

This method is particularly useful for backend implementations. It allows you to receive proofs directly without polling the status URL. Ensure your endpoint is secure and can handle incoming proof data. Make sure to proper middleware to parse the proof object in the response. Eg. express.text({ type: '*/*', limit: '50mb' }) in express.js.

Exporting and Importing SDK Configuration

The SDK provides methods to export and import the entire configuration as a JSON string. This allows for flexible usage across different parts of your application.

// Export configuration
const reclaimProofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID'
)
 
const reclaimProofRequestConfig = reclaimProofRequest.toJsonString()
 
// On a different service or application import the configuration
const reclaimProofRequest = await ReclaimProofRequest.fromJsonString(reclaimProofRequestConfig)
const requestUrl = await reclaimProofRequest.getRequestUrl()

This feature is particularly useful when you need to initialize the SDK in one part of your application (e.g., frontend) and use it in another (e.g., backend). It provides a seamless way to transfer the configuration.

Verifying Proof Signatures

The SDK provides a method to verify the cryptographic signatures of proofs to ensure their authenticity. This is particularly useful when receiving proofs from users or application sources.

import { ReclaimProofRequest, verifyProof } from 'reclaim-sdk'
 
// make sure proofObject is of type Proof Object
const isValid = await verifyProof(proofObject)
if (isValid) {
  console.log('Proof is valid!')
} else {
  console.log('Invalid proof - signature verification failed')
}

The verifyProof method checks the cryptographic signatures in the proof against the attestor's public key to ensure the proof hasn't been tampered with. Always verify proofs before accepting them as valid, especially when receiving them from different application sources.

Initialization Options

When initializing the SDK, you can pass additional options to customize its behavior:

const proofRequest = await ReclaimProofRequest.init(
  'YOUR_RECLAIM_APP_ID',
  'YOUR_RECLAIM_APP_SECRET',
  'YOUR_PROVIDER_ID',
  { log: true }
)
  • log: When set to true, enables detailed logging for debugging purposes.

Use this option to enhance debugging capabilities in your application. The logging option is particularly useful during development and testing phases.

Understanding the Proof Structure

When using any Reclaim SDK (JavaScript, React Native, Flutter), a proof is generated and returned upon successful verification. This proof contains several key components that provide detailed information about the verification process. Below is a generic structure of a proof:

{
  "identifier": "unique_identifier_for_proof", // string
  "claimData": {
    "provider": "provider_type", // string
    "parameters": "verified_data_from_website", // stringified JSON object
    "owner": "owner_address", // string
    "timestampS": "timestamp_of_proof_generation", // int
    "context": "additional_context_information", // stringified JSON object
    "epoch": "epoch_number" // int
  },
  "signatures": [
    "signature_of_proof" // string
  ],
  "witnesses": [
    {
      "id": "witness_id", // string
      "url": "witness_url" // string
    }
  ],
  // publicData is optional and only available if provider supports it else it will be empty
  "publicData": {} // stringified JSON object
}

Key Components:

  • identifier: A unique identifier for the proof.
  • claimData: Contains detailed information about the claim, including:
    • provider: The type of provider used for verification.
    • parameters: The parameters used during the verification process.
    • owner: The address of the owner of the proof.
    • timestampS: The timestamp when the proof was generated.
    • context: Any additional context information related to the proof.
    • epoch: The epoch number indicating the version or state of the proof.
  • signatures: A list of signatures that validate the proof.
  • witnesses: Information about witnesses that observed the proof generation, including their ID and URL.
  • publicData: Any public data associated with the proof.

This proof is typically received in the onSuccess callback of startVerificationSession method when using the default callbackUrl. However, if you have set a custom callbackUrl, you will receive this proof at your specified API endpoint.

Best Practices for Advanced Configuration

  1. Security: Always prioritize security when configuring callbacks and parameters. Use HTTPS for all URLs and avoid passing sensitive data in parameters.

  2. Error Handling: Implement robust error handling for all advanced configurations, especially when dealing with callbacks and redirects.

  3. Testing: Thoroughly test your advanced configurations in a staging environment before deploying to production.

  4. Documentation: Maintain clear documentation of your custom configurations, especially when using context or custom parameters.

Remember, while these advanced configurations offer more flexibility, they also require careful implementation to ensure security and reliability.

By leveraging these advanced configuration options, you can create a more tailored and robust integration of the Reclaim Protocol into your application. If you have any questions about these advanced features, don't hesitate to reach out to our support team or community forums.

Happy coding with Reclaim Protocol!

On this page