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.
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.
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.
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.
Parameters for setAppCallbackUrl
:
URL
: The URL of the API endpoint where proofs will be sent.jsonProofResponse
(Optional): By default, it is set tofalse
. When set tofalse
, the proof is returned as a url encoded message in the response. When set totrue
, 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.
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.
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:
log
: When set totrue
, 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:
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
-
Security: Always prioritize security when configuring callbacks and parameters. Use HTTPS for all URLs and avoid passing sensitive data in parameters.
-
Error Handling: Implement robust error handling for all advanced configurations, especially when dealing with callbacks and redirects.
-
Testing: Thoroughly test your advanced configurations in a staging environment before deploying to production.
-
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!