|
| 1 | +import logging.handlers |
| 2 | +from asyncio import run |
| 3 | + |
| 4 | +from examples.init_env import init_env |
| 5 | +from examples.utils import find_order_and_cancel, get_adjust_price_by_pct |
| 6 | +from x10.config import ETH_USD_MARKET |
| 7 | +from x10.perpetual.accounts import StarkPerpetualAccount |
| 8 | +from x10.perpetual.configuration import MAINNET_CONFIG |
| 9 | +from x10.perpetual.order_object import create_order_object |
| 10 | +from x10.perpetual.orders import OrderSide, TimeInForce |
| 11 | +from x10.perpetual.trading_client import PerpetualTradingClient |
| 12 | + |
| 13 | +LOGGER = logging.getLogger() |
| 14 | +MARKET_NAME = ETH_USD_MARKET |
| 15 | +ENDPOINT_CONFIG = MAINNET_CONFIG |
| 16 | + |
| 17 | + |
| 18 | +async def run_example(): |
| 19 | + env_config = init_env() |
| 20 | + |
| 21 | + assert env_config.builder_id, "X10_BUILDER_ID is not set" |
| 22 | + |
| 23 | + stark_account = StarkPerpetualAccount( |
| 24 | + api_key=env_config.api_key, |
| 25 | + public_key=env_config.public_key, |
| 26 | + private_key=env_config.private_key, |
| 27 | + vault=env_config.vault_id, |
| 28 | + ) |
| 29 | + trading_client = PerpetualTradingClient(ENDPOINT_CONFIG, stark_account) |
| 30 | + markets_dict = await trading_client.markets_info.get_markets_dict() |
| 31 | + fees = await trading_client.account.get_fees(market_names=[MARKET_NAME], builder_id=env_config.builder_id) |
| 32 | + builder_fee = fees.data[0].builder_fee_rate |
| 33 | + |
| 34 | + market = markets_dict[ETH_USD_MARKET] |
| 35 | + adjust_price_by_pct = get_adjust_price_by_pct(market.trading_config) |
| 36 | + |
| 37 | + order_size = market.trading_config.min_order_size |
| 38 | + order_price = adjust_price_by_pct(market.market_stats.bid_price, -10.0) |
| 39 | + |
| 40 | + LOGGER.info("Builder: id=%s, fee=%s", env_config.builder_id, builder_fee) |
| 41 | + LOGGER.info("Creating LIMIT order object for market: %s", market.name) |
| 42 | + |
| 43 | + new_order = create_order_object( |
| 44 | + account=stark_account, |
| 45 | + starknet_domain=ENDPOINT_CONFIG.starknet_domain, |
| 46 | + market=market, |
| 47 | + side=OrderSide.BUY, |
| 48 | + amount_of_synthetic=order_size, |
| 49 | + price=market.trading_config.round_price(order_price), |
| 50 | + time_in_force=TimeInForce.GTT, |
| 51 | + reduce_only=False, |
| 52 | + post_only=True, |
| 53 | + builder_id=env_config.builder_id, |
| 54 | + builder_fee=builder_fee, |
| 55 | + ) |
| 56 | + |
| 57 | + LOGGER.info("Placing order...") |
| 58 | + |
| 59 | + placed_order = await trading_client.orders.place_order(order=new_order) |
| 60 | + |
| 61 | + LOGGER.info("Order is placed: %s", placed_order.to_pretty_json()) |
| 62 | + |
| 63 | + await find_order_and_cancel(trading_client=trading_client, logger=LOGGER, order_id=placed_order.data.id) |
| 64 | + |
| 65 | + |
| 66 | +if __name__ == "__main__": |
| 67 | + run(main=run_example()) |
0 commit comments