defindex-strategy-core

Crates.iodefindex-strategy-core
lib.rsdefindex-strategy-core
version0.2.0
created_at2024-11-18 18:34:35.887994+00
updated_at2024-12-18 15:17:57.477868+00
descriptionA foundational library for developing and integrating strategies into the DeFindex ecosystem, providing reusable abstractions, events, and custom error handling.
homepagehttps://defindex.io
repositoryhttps://github.com/paltalabs/defindex
max_upload_size
id1452543
size12,905
coderipper (joaquinsoza)

documentation

README

DeFindex Strategy Core

The defindex-strategy-core package is a foundational library designed to facilitate the development of strategies for DeFindex. It provides reusable abstractions and utilities that streamline the creation, management, and integration of strategies into the DeFindex ecosystem.

Features

  • Reusable Events: Predefined events to log actions such as deposits, withdrawals, and harvests.
  • Custom Errors: A unified error handling system to ensure consistent and informative feedback across strategies.
  • Core Abstractions: Base traits and utilities to define and implement strategies with minimal boilerplate.

Structure

This package includes the following modules:

  1. Error: Provides custom error types to handle various edge cases and ensure smooth execution.
  2. Event: Includes predefined events for logging and monitoring strategy activity.
  3. Core Traits: Defines the DeFindexStrategyTrait, which serves as the contract for developing new strategies.

Installation

Add the defindex-strategy-core package to your Cargo.toml dependencies:

[dependencies]
defindex-strategy-core = "0.2.0"

Usage

Here is a simple example of how to use this package to build a custom strategy:

  1. Import the Core Library
use defindex_strategy_core::{DeFindexStrategyTrait, StrategyError, event};
  1. Implement the Strategy Trait

Define your custom strategy by implementing the DeFindexStrategyTrait:

#[contract]
struct MyCustomStrategy;

#[contractimpl]
impl DeFindexStrategyTrait for MyCustomStrategy {
    fn __constructor(e: Env, asset: Address, init_args: Vec<Val>) {
        // Initialization logic
    }

    fn deposit(e: Env, amount: i128, from: Address) -> Result<i128, StrategyError> {
        // Deposit logic
        Ok(0) // it must return the vault balance, same response as balance() 
    }

    fn withdraw(e: Env, amount: i128, from: Address, to: Address) -> Result<i128, StrategyError> {
        // Withdrawal logic
        Ok(amount) // it must return the vault balance, same response as balance() 
    }

    fn balance(e: Env, from: Address) -> Result<i128, StrategyError> {
        // Balance check logic
        Ok(0)
    }

    fn harvest(e: Env, from: Address) -> Result<(), StrategyError> {
        // Harvest logic
        Ok(())
    }
}
  1. Emit Events

Use the event module to log actions:

event::emit_deposit(&e, String::from("MyCustomStrategy"), amount, from.clone());
Commit count: 1866

cargo fmt