-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathtrigger_orders.rs
More file actions
122 lines (104 loc) · 3.79 KB
/
trigger_orders.rs
File metadata and controls
122 lines (104 loc) · 3.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
//! Trigger Orders Example
//!
//! Place stop-loss and take-profit orders.
//!
//! # Usage
//! ```bash
//! export ENDPOINT="https://your-endpoint.hype-mainnet.quiknode.pro/TOKEN"
//! export PRIVATE_KEY="0x..."
//! cargo run --example trigger_orders
//! ```
use hyperliquid_sdk::{HyperliquidSDK, TriggerOrder};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let endpoint = std::env::var("ENDPOINT").ok();
let private_key = std::env::var("PRIVATE_KEY").ok();
if endpoint.is_none() || private_key.is_none() {
eprintln!("Usage:");
eprintln!(" export ENDPOINT='https://your-endpoint.hype-mainnet.quiknode.pro/TOKEN'");
eprintln!(" export PRIVATE_KEY='0x...'");
eprintln!(" cargo run --example trigger_orders");
std::process::exit(1);
}
println!("Trigger Orders Example");
println!("{}", "=".repeat(50));
let mut builder = HyperliquidSDK::new();
if let Some(ep) = &endpoint {
builder = builder.endpoint(ep);
}
if let Some(pk) = &private_key {
builder = builder.private_key(pk);
}
let sdk = builder.build().await?;
if let Some(addr) = sdk.address() {
println!("Address: {}", addr);
}
// Get current price
let mid = sdk.get_mid("BTC").await?;
println!("\nBTC mid price: ${:.2}", mid);
// Stop Loss - triggers sell when price drops below trigger
println!("\n1. Stop Loss Order:");
let stop_loss = TriggerOrder::stop_loss("BTC")
.size(0.001)
.trigger_price(mid * 0.95); // 5% below current price
match sdk.trigger_order(stop_loss).await {
Ok(order) => {
println!(" Status: {}", order.status);
println!(" OID: {:?}", order.oid);
println!(" Trigger: ${:.2}", mid * 0.95);
}
Err(e) => println!(" Error: {}", e),
}
// Take Profit - triggers sell when price rises above trigger
println!("\n2. Take Profit Order:");
let take_profit = TriggerOrder::take_profit("BTC")
.size(0.001)
.trigger_price(mid * 1.10); // 10% above current price
match sdk.trigger_order(take_profit).await {
Ok(order) => {
println!(" Status: {}", order.status);
println!(" OID: {:?}", order.oid);
println!(" Trigger: ${:.2}", mid * 1.10);
}
Err(e) => println!(" Error: {}", e),
}
// Stop Loss with limit price
println!("\n3. Stop Loss with Limit:");
let stop_loss_limit = TriggerOrder::stop_loss("BTC")
.size(0.001)
.trigger_price(mid * 0.95)
.limit(mid * 0.94); // Limit price below trigger
match sdk.trigger_order(stop_loss_limit).await {
Ok(order) => {
println!(" Status: {}", order.status);
println!(" OID: {:?}", order.oid);
}
Err(e) => println!(" Error: {}", e),
}
// Using sdk convenience methods
println!("\n4. Stop Loss (convenience method):");
match sdk.stop_loss("BTC", 0.001, mid * 0.93).await {
Ok(order) => {
println!(" Status: {}", order.status);
println!(" OID: {:?}", order.oid);
}
Err(e) => println!(" Error: {}", e),
}
println!("\n5. Take Profit (convenience method):");
match sdk.take_profit("BTC", 0.001, mid * 1.15).await {
Ok(order) => {
println!(" Status: {}", order.status);
println!(" OID: {:?}", order.oid);
}
Err(e) => println!(" Error: {}", e),
}
// Clean up - cancel all trigger orders
println!("\n6. Cleaning up orders...");
match sdk.cancel_all(Some("BTC")).await {
Ok(_) => println!(" Cancelled all BTC orders"),
Err(e) => println!(" Error: {}", e),
}
println!("\n{}", "=".repeat(50));
println!("Done!");
Ok(())
}