Skip to main content

nautilus_hyperliquid/python/
factories.rs

1// -------------------------------------------------------------------------------------------------
2//  Copyright (C) 2015-2026 Nautech Systems Pty Ltd. All rights reserved.
3//  https://nautechsystems.io
4//
5//  Licensed under the GNU Lesser General Public License Version 3.0 (the "License");
6//  You may not use this file except in compliance with the License.
7//  You may obtain a copy of the License at https://www.gnu.org/licenses/lgpl-3.0.en.html
8//
9//  Unless required by applicable law or agreed to in writing, software
10//  distributed under the License is distributed on an "AS IS" BASIS,
11//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//  See the License for the specific language governing permissions and
13//  limitations under the License.
14// -------------------------------------------------------------------------------------------------
15
16//! Python bindings for Hyperliquid factory types.
17
18use nautilus_model::identifiers::{AccountId, TraderId};
19use pyo3::prelude::*;
20
21use crate::{
22    config::HyperliquidExecClientConfig,
23    factories::{
24        HyperliquidDataClientFactory, HyperliquidExecFactoryConfig,
25        HyperliquidExecutionClientFactory,
26    },
27};
28
29#[pymethods]
30#[pyo3_stub_gen::derive::gen_stub_pymethods]
31impl HyperliquidDataClientFactory {
32    /// Factory for creating Hyperliquid data clients.
33    #[new]
34    fn py_new() -> Self {
35        Self
36    }
37
38    #[pyo3(name = "name")]
39    fn py_name(&self) -> &'static str {
40        "HYPERLIQUID"
41    }
42}
43
44#[pymethods]
45#[pyo3_stub_gen::derive::gen_stub_pymethods]
46impl HyperliquidExecutionClientFactory {
47    /// Factory for creating Hyperliquid execution clients.
48    #[new]
49    fn py_new() -> Self {
50        Self
51    }
52
53    #[pyo3(name = "name")]
54    fn py_name(&self) -> &'static str {
55        "HYPERLIQUID"
56    }
57}
58
59#[pymethods]
60#[pyo3_stub_gen::derive::gen_stub_pymethods]
61impl HyperliquidExecFactoryConfig {
62    /// Configuration for creating Hyperliquid execution clients via factory.
63    ///
64    /// This wraps `HyperliquidExecClientConfig` with the additional trader and account
65    /// identifiers required by the `ExecutionClientCore`.
66    #[new]
67    fn py_new(
68        trader_id: TraderId,
69        account_id: AccountId,
70        config: HyperliquidExecClientConfig,
71    ) -> Self {
72        Self {
73            trader_id,
74            account_id,
75            config,
76        }
77    }
78
79    fn __repr__(&self) -> String {
80        format!("{self:?}")
81    }
82}