use log::LevelFilter;
use nautilus_common::{enums::Environment, logging::logger::LoggerConfig};
use nautilus_live::node::LiveNode;
use nautilus_model::identifiers::{ClientId, InstrumentId, TraderId};
use nautilus_polymarket::{
config::PolymarketDataClientConfig, factories::PolymarketDataClientFactory,
};
use nautilus_testkit::testers::{DataTester, DataTesterConfig};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
dotenvy::dotenv().ok();
let environment = Environment::Live;
let trader_id = TraderId::from("TESTER-001");
let node_name = "POLYMARKET-DATA-TESTER-001".to_string();
let instrument_ids = vec![
InstrumentId::from(
"0x7ad403c3508f8e3912940fd1a913f227591145ca0614074208e0b962d5fcc422-16040015440196279900485035793550429453516625694844857319147506590755961451627.POLYMARKET",
),
InstrumentId::from(
"0x7ad403c3508f8e3912940fd1a913f227591145ca0614074208e0b962d5fcc422-81694916552422830064199102811909459806011700139178165530145523694780063771756.POLYMARKET",
),
];
let polymarket_config = PolymarketDataClientConfig::default();
let client_factory = PolymarketDataClientFactory;
let client_id = ClientId::new("POLYMARKET");
let log_config = LoggerConfig {
stdout_level: LevelFilter::Info,
..Default::default()
};
let mut node = LiveNode::builder(trader_id, environment)?
.with_name(node_name)
.with_logging(log_config)
.with_delay_post_stop_secs(2)
.add_data_client(None, Box::new(client_factory), Box::new(polymarket_config))?
.build()?;
let tester_config = DataTesterConfig::builder()
.client_id(client_id)
.instrument_ids(instrument_ids)
.subscribe_trades(true)
.subscribe_quotes(true)
.manage_book(true)
.build();
let tester = DataTester::new(tester_config);
node.add_actor(tester)?;
node.run().await?;
Ok(())
}