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}