Skip to content

adapters for awarding Ethena points to users of integrating protocols

Notifications You must be signed in to change notification settings

VenusProtocol/ethena_sats_adapters

 
 

Repository files navigation

Overview

This repo offers a self service approach to Ethena Points Campaign integrations.

Instructions

For your protocol to be included and your users to receive points, you should submit a PR to this repo. Here some guidelines to follow:

  1. Make a copy of .env.example and name it .env.
  2. Run pip install -r requirements.txt to install the required packages.
    • If using TypeScript scripts (recommended for L2 delegated integrations), also run pnpm install or npm install in the root directory.
  3. Add your integration metadata to integrations/integration_ids.py.
  4. Create a new summary column in constants/summary_columns.py.
  5. Choose your integration type:
  6. Name your file [protocol name]_integration.py and place it in the integrations directory.
  7. Your integration must inherit from either:
    • CachedBalancesIntegration and implement the get_block_balances method
    • L2DelegationIntegration and implement the get_l2_block_balances and get_participants_data methods
  8. The integration should return user balances:
    • For CachedBalances: Return a dict of {block_number: {checksum_address: balance}}
    • For L2Delegation: Return a dict of {block_number: {address: balance}}
  9. Write some basic tests at the bottom of the file to ensure your integration is working correctly.
  10. Submit a PR to this repo with your integration and ping the Ethena team in Telegram.

Guidelines

  • Integrations must follow this architecture and be written in python.
  • The get_block_balances method should be as efficient as possible. So the use of the cached data from previous blocks if possible is highly encouraged.
  • We prefer that on chain RPC calls are used to get information as much as possible due to reliability and trustlessness. Off chain calls to apis or subgraphs are acceptable if necessary. If usage is not reasonable or the external service is not reliable, users may not receive their points.

L2 Delegation Setup Requirements

For non-EVM chain integrations (like Solana) or users that don't control the same addresses in the L2 and Ethereum, your users must complete an additional delegation step to receive points. This process links their L2 wallet to their Ethereum address:

  1. Visit the Ethena UI and connect your Ethereum wallet
  2. Navigate to Ethena Delegation Section
  3. Click "Select Chain" and select.

Select Chain

  1. Click "Signing With" and select your wallet type.

Select Wallet Type

  1. Connect your wallet and sign a message to prove ownership
  2. Once delegated, your L2 balances will be attributed to your Ethereum address for points calculation

Important Notes:

  • Users can delegate at any moment and they won't miss any past points.

Examples

Cached Balances Integrations (Default)

  • ClaimedEnaIntegration: This integration demonstrates how to track ENA token claims using cached balance snapshots for improved performance. It reads from previous balance snapshots to efficiently track user claim history.
  • BeefyCachedBalanceExampleIntegration: This integration is an example of a cached balance integration that is based on API calls.

L2 Delegation Examples (For non-EVM chains)

Legacy Integrations (Don't use, just for reference)

  • PendleLPTIntegration: (Legacy Example) A basic integration showing Pendle LPT staking tracking. Note: This is a non-cached implementation included only for reference - new integrations should use the cached approach for better efficiency.
  • PendleYTIntegration: (Legacy Example) A basic integration showing Pendle YT staking tracking. Note: This is a non-cached implementation included only for reference - new integrations should use the cached approach for better efficiency.

About

adapters for awarding Ethena points to users of integrating protocols

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.5%
  • TypeScript 0.5%