lnm-sdk 0.4.2

Rust SDK for interacting with LN Markets.
Documentation
pub(in crate::api_v2) mod trade_side {
    use serde::{Deserialize, Deserializer, Serializer};

    use crate::shared::models::trade::TradeSide;

    pub fn serialize<S>(value: &TradeSide, serializer: S) -> Result<S::Ok, S::Error>
    where
        S: Serializer,
    {
        serializer.serialize_str(match value {
            TradeSide::Buy => "b",
            TradeSide::Sell => "s",
        })
    }

    // FIXME: As of Nov 11 2025, the LN Markets API returns "buy" / "sell" when fetching recently
    // opened trades via API v2 . It returned only "b" / "s" until recently. Not clear if this
    // behavior is temporary.
    // Handling all cases for now.
    pub fn deserialize<'de, D>(deserializer: D) -> Result<TradeSide, D::Error>
    where
        D: Deserializer<'de>,
    {
        let s = String::deserialize(deserializer)?;
        match s.as_str() {
            "b" | "buy" => Ok(TradeSide::Buy),
            "s" | "sell" => Ok(TradeSide::Sell),
            _ => Err(serde::de::Error::custom(
                format!("unknown trade side: {s}",),
            )),
        }
    }
}

pub(in crate::api_v2) mod trade_execution_type {
    use serde::{Deserialize, Deserializer, Serializer};

    use crate::shared::models::trade::TradeExecutionType;

    pub fn serialize<S>(value: &TradeExecutionType, serializer: S) -> Result<S::Ok, S::Error>
    where
        S: Serializer,
    {
        serializer.serialize_str(match value {
            TradeExecutionType::Market => "m",
            TradeExecutionType::Limit => "l",
        })
    }

    pub fn deserialize<'de, D>(deserializer: D) -> Result<TradeExecutionType, D::Error>
    where
        D: Deserializer<'de>,
    {
        let s = String::deserialize(deserializer)?;
        match s.as_str() {
            "m" => Ok(TradeExecutionType::Market),
            "l" => Ok(TradeExecutionType::Limit),
            _ => Err(serde::de::Error::custom(format!(
                "unknown trade execution type: {s}",
            ))),
        }
    }
}