🤔Choosing How to Implement Gating

Civic Pass offers robust and flexible integration options for both frontend and backend applications, as well as on-chain smart contracts. This guide provides a high-level overview of the available integration methods, focusing on the key concepts and benefits of each approach.

Comparison of Integration Methods

Integration Method

Key Benefits

Use Cases

Frontend and Backend (Recommended)

Secure token verification, customizable UI, end-to-end security

Secure server-side token validation, customizable gating process, end-to-end security solutions

Smart Contract

Compliance, security, flexibility

Solana-based applications, EVM-based applications, regulatory compliance, secure user environments

Choosing the Right Integration Method

When deciding between frontend, backend, and smart contract integrations, consider:

  • Security requirements: If your application requires robust server-side token validation, frontend and backend integration may be the best choice.

  • Customization needs: If you need a customizable user interface for the gating process, frontend and backend integration is suitable.

  • Blockchain platform: If your application is built on Solana or EVM, smart contract integration using the respective libraries (e.g., `solana_gateway` or `@identity.com/gateway-protocol-eth`) is necessary.

  • Regulatory compliance: If your application must comply with specific regulations, smart contract integration can ensure that only authorized users can interact with your dApp.

App Permissioning is a powerful gating option that combines a user-friendly frontend interface with robust backend verification. This method is ideal for applications that require secure, server-side token validation while maintaining a seamless user experience.

Frontend and Backend Libraries

This integration option provides a comprehensive solution for implementing Civic Pass in your application. It combines a React component for the frontend with a Node.js library for backend verification.

When to Use This Method

Consider using the Frontend and Backend Library approach when:

  • You need to ensure the integrity of token verification on the server side

  • Your application requires a customizable user interface for the gating process

  • You want to implement a secure, end-to-end solution for user-permissioning

Frontend Integration

The frontend integration uses the Civic Pass React component, which provides a pre-built UI for managing the user's Civic Pass status. This component handles the user flow, from requesting a new pass to displaying the current status.

To integrate the React component, go to the appropriate Integration Guide for your chain of choice.

Backend Integration

The backend integration uses a Node.js library to verify the Civic Pass token on the server-side. This ensures that users cannot bypass the gating mechanism by manipulating the frontend. Builders can also verify pass state via an API call. For more details on this method, go to the appropriate Integration Guide for your chain of choice.

We recommend you use both frontend and backend for verification before granting access to gated content or features, so that bad actors cannot circumvent your frontend restrictions.

Frontend and Smart Contract Gating

For a detailed view of the Frontend integration, go to the appropriate Integration Guide for your chain of choice.

The smart contract integration process involves verifying the presence of a valid Civic Pass for users attempting to interact with your dApp. This verification ensures that only compliant users, those with an active Civic Pass, can execute transactions.

On-Chain Civic Pass Structure

The gatewayToken represents the on-chain structure of the Civic Pass. This will only be defined if the Civic Pass is active.

Property

Description

Type

gatekeeperNetwork

The key of the Gatekeeper Network for which the token was issued.

PublicKey

issuingGatekeeper

The key of the issuing Gatekeeper.

PublicKey

state

The on-chain token status.

State { "ACTIVE", "REVOKED", "FROZEN" }

expiryTime

The timestamp at which the on-chain token expires.

number

Last updated