Skip to content

Latest commit

 

History

History
169 lines (161 loc) · 6.44 KB

README.md

File metadata and controls

169 lines (161 loc) · 6.44 KB

AshSwap Aggregator Smart Contract

This repository contains the Aggregator smart contract in AshSwap.

Overview

An aggregator service on the MultiversX blockchain, which facilitates the exchange of tokens across different liquidity pools. It handles the collection of fees for the protocol and a swap service (Ashswap), and allows users to claim these fees. The contract also supports the aggregation of ESDT tokens and EGLD, the native cryptocurrency.

State Variables

  • protocol_fee: A map storing the fees accumulated per protocol.
  • ashswap_fee: A map storing the fees accumulated for Ashswap.
  • protocol_fee_percent: The fee percentage for a given protocol.
  • ashswap_fee_percent: The fee percentage for Ashswap.
  • ashswap_fee_address: The address to which Ashswap fees are sent.

Flow Diagrams

sequenceDiagram
    participant U as User
    participant SC as Smart Contract
    participant P as Protocol
    participant A as Ashswap
    U->>SC: aggregateEgld(steps, limits, protocol)
    alt EGLD aggregation
        SC->>SC: Wrap EGLD
    end
    U->>SC: aggregateEsdt(steps, limits, protocol)
    alt ESDT aggregation
        SC->>SC: Receive ESDT
    end
    SC->>SC: Calculate fees
    SC->>P: Deduct protocol fees
    SC->>A: Deduct Ashswap fees
    SC->>SC: Execute token exchanges
    SC->>U: Send out token payments
    SC->>SC: Emit aggregate_event
Loading

Functions Description

  • init: Initializes the contract with the EGLD wrapper address and wrapped token identifier.
    sequenceDiagram
      participant User
      participant Contract
      User->>Contract: init(egld_wrapper_address, egld_wrapped_token_id)
      Contract->>Contract: Store EGLD wrapper address
      Contract->>Contract: Store EGLD wrapped token ID
    
    
    Loading
  • _find_token_in_vault: Searches for a token in the vault and returns its index.
    sequenceDiagram
      participant Contract
      Contract->>Contract: _find_token_in_vault(tokens, token_id)
      loop Each Token in Vault
          Contract->>Contract: Check if token_id matches
      end
      Contract->>Contract: Return index or None
    
    Loading
  • _upsert_vaults: Updates or inserts a token amount in the vault.
      sequenceDiagram
      participant Contract
      Contract->>Contract: _upsert_vaults(vaults, token_id, amount)
      alt Token Found in Vault
          Contract->>Contract: Update existing token amount
      else Token Not Found
          Contract->>Contract: Add new token with amount
      end
    
    Loading
  • _exchange: Handles the exchange of tokens using a provided liquidity pool and updates the vaults accordingly.
    sequenceDiagram
      participant Contract
      participant Pool as Liquidity Pool
      Contract->>Contract: _exchange(vaults, step)
      Contract->>Contract: Validate token and amount
      Contract->>Pool: Send token_in, execute exchange
      Pool-->>Contract: Return token_out
      Contract->>Contract: Update vaults with token_out
    
    Loading
  • _aggregate: Aggregates multiple token exchanges and fee deductions, returns the final token payments.
      sequenceDiagram
      participant Contract
      Contract->>Contract: _aggregate(payments, steps, limits, protocol)
      Contract->>Contract: Process incoming payments
      Contract->>Contract: Deduct fees (if protocol provided)
      loop Each Step
          Contract->>Contract: Execute _exchange
      end
      Contract->>Contract: Enforce limits, prepare results
    
    Loading
  • aggregate_egld: Handles the aggregation operation when EGLD is involved.
      sequenceDiagram
          participant User
          participant Contract
          User->>Contract: aggregateEgld(steps, limits, protocol)
          Contract->>Contract: Wrap received EGLD
          Contract->>Contract: Call _aggregate
          Contract->>User: Send result tokens
          Contract->>Contract: Emit aggregate_event
    
    Loading
  • aggregate_esdt: Handles the aggregation operation for ESDT tokens, with the option to return EGLD.
      sequenceDiagram
          participant User
          participant Contract
          User->>Contract: aggregateEsdt(steps, limits, egld_return, protocol)
          Contract->>Contract: Receive ESDT tokens
          Contract->>Contract: Call _aggregate
          alt egld_return is true
              Contract->>Contract: Convert to EGLD if needed
          end
          Contract->>User: Send result tokens
          Contract->>Contract: Emit aggregate_event
    
    Loading
  • aggregate: General aggregation endpoint for ESDT tokens.
    sequenceDiagram
      participant User
      participant Contract
      User->>Contract: aggregate(steps, limits)
      Contract->>Contract: Receive ESDT tokens
      Contract->>Contract: Call _aggregate
      Contract->>User: Send result tokens
      Contract->>Contract: Emit aggregate_event
    
    Loading
  • aggregate_event: Emits an event after an aggregation operation.
  • get_claimable_protocol_fee: Retrieves claimable fees for a protocol in batches to avoid memory overflow.
    sequenceDiagram
      participant Owner
      participant Contract
      Owner->>Contract: claimProtocolFee(protocol) / claimAshswapFee()
      Contract->>Contract: Retrieve fee amounts in batches
      Contract->>Owner: Send claimed fees
    
    Loading
  • register_protocol_fee: Registers the fee percentage and address for a protocol.
    sequenceDiagram
      participant Owner
      participant Contract
      Owner->>Contract: registerProtocolFee(fee_percent, whitelist_address) / registerAshswapFee(fee_percent, whitelist_address)
      Contract->>Contract: Store fee percent and whitelist address
    
    Loading
  • get_claimable_ashswap_fee: Retrieves claimable Ashswap fees in batches.
    sequenceDiagram
      participant Owner
      participant Contract
      Owner->>Contract: claimProtocolFee(protocol) / claimAshswapFee()
      Contract->>Contract: Retrieve fee amounts in batches
      Contract->>Owner: Send claimed fees
    
    Loading
  • register_ashswap_fee: Registers the fee percentage and address for Ashswap.
    sequenceDiagram
      participant Owner
      participant Contract
      Owner->>Contract: registerProtocolFee(fee_percent, whitelist_address) / registerAshswapFee(fee_percent, whitelist_address)
      Contract->>Contract: Store fee percent and whitelist address
    
    Loading
  • claim_protocol_fee: Allows the protocol to claim their accumulated fees.
  • claim_protocol_fee_by_tokens: Allows the protocol to claim fees for specific tokens.
  • claim_ashswap_fee: Allows Ashswap to claim their accumulated fees.
  • claim_ashswap_fee_by_tokens: Allows Ashswap to claim fees for specific tokens.