tycho-execution 0.171.0

Provides tools for encoding and executing swaps against Tycho router and protocol executors.
Documentation
use std::{io, str::Utf8Error};

use thiserror::Error;
use tycho_common::simulation::errors::SimulationError;

/// Represents the outer-level, user-facing errors of the tycho-execution encoding package.
///
/// `EncodingError` encompasses all possible errors that can occur in the package,
/// wrapping lower-level errors in a user-friendly way for easier handling and display.
/// Variants:
/// - `InvalidInput`: Indicates that the encoding has failed due to bad input parameters.
/// - `FatalError`: There is problem with the application setup.
/// - `RecoverableError`: Indicates that the encoding has failed with a recoverable error. Retrying
///   at a later time may succeed. It may have failed due to a temporary issue, such as a network
///   problem.
#[derive(Error, Debug, PartialEq)]
pub enum EncodingError {
    #[error("Invalid input: {0}")]
    InvalidInput(String),
    #[error("Fatal error: {0}")]
    FatalError(String),
    #[error("Recoverable error: {0}")]
    RecoverableError(String),
    #[error("Not implemented: {0}")]
    NotImplementedError(String),
}

impl From<io::Error> for EncodingError {
    fn from(err: io::Error) -> Self {
        EncodingError::FatalError(err.to_string())
    }
}

impl From<serde_json::Error> for EncodingError {
    fn from(err: serde_json::Error) -> Self {
        EncodingError::FatalError(err.to_string())
    }
}

impl From<Utf8Error> for EncodingError {
    fn from(err: Utf8Error) -> Self {
        EncodingError::FatalError(err.to_string())
    }
}

impl From<SimulationError> for EncodingError {
    fn from(err: SimulationError) -> Self {
        match err {
            SimulationError::FatalError(err_msg) => EncodingError::FatalError(err_msg),
            SimulationError::InvalidInput(err_msg, ..) => EncodingError::InvalidInput(err_msg),
            SimulationError::RecoverableError(error_msg) => {
                EncodingError::RecoverableError(error_msg)
            }
        }
    }
}