#trading #quik #system-api #cargo-toml #moex

trans2quik

Library for importing transactions, entering orders into the QUIK ARQA Technologies trading system via the API

4 releases (2 stable)

1.0.1 Nov 15, 2024
1.0.0 Nov 13, 2024
0.1.1 Nov 13, 2024
0.1.0 Nov 12, 2024

#69 in Finance

MIT/Apache

54KB
793 lines

trans2quik

Library for importing transactions, entering orders into the QUIK ARQA Technologies trading system via the API.

Example of use

Cargo.toml

trans2quik = "1.0.0"
tracing = "0.1.40"
tracing-subscriber = "0.3.18"
lazy_static = "1.5.0"

main.rs

use lazy_static::lazy_static;
use std::error::Error;
use std::sync::{Arc, Condvar, Mutex};
use std::time::Duration;
use tracing::info;
use tracing_subscriber;
use trans2quik;

lazy_static! {
    static ref ORDER_CALLBACK_RECEIVED: Arc<(Mutex<bool>, Condvar)> =
        Arc::new((Mutex::new(false), Condvar::new()));
    static ref TRADE_CALLBACK_RECEIVED: Arc<(Mutex<bool>, Condvar)> =
        Arc::new((Mutex::new(false), Condvar::new()));
    static ref TRANSACTION_CALLBACK_RECEIVED: Arc<(Mutex<bool>, Condvar)> =
        Arc::new((Mutex::new(false), Condvar::new()));
}

fn main() -> Result<(), Box<dyn Error>> {
    tracing_subscriber::fmt::init();

    let path = r"c:\QUIK Junior\trans2quik.dll";
    let terminal = quik::Terminal::new(path)?;
    terminal.connect()?;
    terminal.is_dll_connected()?;
    terminal.is_quik_connected()?;
    terminal.set_connection_status_callback()?;
    terminal.set_transactions_reply_callback()?;
    let class_code = "QJSIM";
    let sec_code = "LKOH";
    terminal.subscribe_orders(class_code, sec_code)?;
    terminal.subscribe_trades(class_code, sec_code)?;
    terminal.start_orders();
    terminal.start_trades();
    let transaction_str = "ACCOUNT=NL0011100043; CLIENT_CODE=10677; TYPE=L; TRANS_ID=1; CLASSCODE=QJSIM; SECCODE=LKOH; ACTION=NEW_ORDER; OPERATION=B; PRICE=7103,5; QUANTITY=1;";
    terminal.send_async_transaction(transaction_str)?;

    // Waiting for callback or timeout
    {
        let order_received = {
            let (lock, cvar) = ORDER_CALLBACK_RECEIVED.as_ref();
            let received = lock.lock().unwrap();
            let timeout = Duration::from_secs(10);

            let (received, timeout_result) = cvar
                .wait_timeout_while(received, timeout, |received| !*received)
                .unwrap();

            if timeout_result.timed_out() {
                info!("Timed out waiting for order_status_callback");
            }

            *received
        };

        let trade_received = {
            let (lock, cvar) = TRADE_CALLBACK_RECEIVED.as_ref();
            let received = lock.lock().unwrap();
            let timeout = Duration::from_secs(10);

            let (received, timeout_result) = cvar
                .wait_timeout_while(received, timeout, |received| !*received)
                .unwrap();

            if timeout_result.timed_out() {
                info!("Timed out waiting for trade_status_callback");
            }

            *received
        };

        let transaction_received = {
            let (lock, cvar) = TRANSACTION_CALLBACK_RECEIVED.as_ref();
            let received = lock.lock().unwrap();
            let timeout = Duration::from_secs(10);

            let (received, timeout_result) = cvar
                .wait_timeout_while(received, timeout, |received| !*received)
                .unwrap();

            if timeout_result.timed_out() {
                info!("Timed out waiting for transaction_reply_callback");
            }

            *received
        };

        if !order_received && !trade_received && !transaction_received {
            info!("Did not receive all expected callbacks");
        }
    }

    terminal.unsubscribe_orders()?;
    terminal.unsubscribe_trades()?;
    terminal.disconnect()?;

    Ok(())
}

Dependencies

~3.5–8MB
~127K SLoC