ibapi 2.11.2

A Rust implementation of the Interactive Brokers TWS API, providing a reliable and user friendly interface for TWS and IB Gateway. Designed with a focus on simplicity and performance.
Documentation
# Architecture Overview

The rust-ibapi crate is a Rust implementation of the Interactive Brokers TWS API. The architecture supports both synchronous (thread-based) and asynchronous (tokio-based) operation modes; the async client is enabled by default, and the blocking client can be added alongside it.

## System Architecture

```mermaid
graph TB
    User[User Application]
    Client[Client API]
    MessageBus[MessageBus]
    Connection[Connection Manager]
    TWS[TWS/IB Gateway]
    
    User -->|API Calls| Client
    Client -->|Requests| MessageBus
    MessageBus -->|Messages| Connection
    Connection <-->|TCP Socket| TWS
    TWS -->|Responses| Connection
    Connection -->|Messages| MessageBus
    MessageBus -->|Responses| Client
    Client -->|Results| User
    
    style User fill:#e1f5fe
    style Client fill:#b3e5fc
    style MessageBus fill:#81d4fa
    style Connection fill:#4fc3f7
    style TWS fill:#29b6f6
```

## Core Components

### 1. Client
Main interface for user interactions:
- **Sync mode**: Uses threads and crossbeam channels
- **Async mode**: Uses tokio tasks and mpsc channels
- Encodes user requests
- Sends requests to the MessageBus
- Receives responses via channels
- Decodes responses for the user

### 2. MessageBus
Handles connection and message routing:
- **Sync mode**: Runs on a dedicated thread
- **Async mode**: Runs as a tokio task
- Establishes and maintains connection to TWS/Gateway
- Sends messages from client to TWS
- Listens for messages from TWS
- Routes incoming messages to appropriate client channels
- Implements automatic reconnection with Fibonacci backoff

### 3. Connection
Low-level connection management:
- Handles TWS protocol handshake
- Manages socket I/O operations
- Implements reconnection logic
- Maintains connection metadata

## Request/Response Flow

```mermaid
sequenceDiagram
    participant U as User App
    participant C as Client
    participant MB as MessageBus
    participant CM as Connection
    participant TWS as TWS/Gateway
    
    U->>C: API Call (e.g., req_contract_details)
    C->>C: Generate Request ID
    C->>C: Encode Request
    C->>MB: Send Request Message
    MB->>MB: Create Response Channel
    MB->>CM: Forward Request
    CM->>TWS: Send via TCP Socket
    TWS-->>CM: Response Message(s)
    CM-->>MB: Parse Response
    MB-->>MB: Route by Request ID
    MB-->>C: Send to Response Channel
    C-->>C: Decode Response
    C-->>U: Return Result
```

### Message Routing Patterns

1. **Requests with IDs**: MessageBus creates dedicated channels for responses
2. **Requests without IDs**: MessageBus uses shared channels for responses
3. **Order-based requests**: Special handling for order tracking

## Module Structure

```mermaid
graph TD
    ModRoot[module/mod.rs<br/>Public Types & Exports]
    Common[module/common/<br/>Shared Logic]
    SyncImpl[module/sync.rs<br/>Sync Implementation]
    AsyncImpl[module/async.rs<br/>Async Implementation]
    
    ModRoot -->|Types| Common
    ModRoot -->|#cfg feature=sync| SyncImpl
    ModRoot -->|#cfg feature=async| AsyncImpl
    
    Common --> Encoders[encoders.rs<br/>Message Encoding]
    Common --> Decoders[decoders.rs<br/>Message Decoding]
    Common --> TestData[test_data.rs<br/>Test Fixtures]
    
    SyncImpl -->|uses| Common
    AsyncImpl -->|uses| Common
    
    style ModRoot fill:#fff9c4
    style Common fill:#f0f4c3
    style SyncImpl fill:#dcedc8
    style AsyncImpl fill:#c5e1a5
```

Each API module follows a consistent structure:

```
src/<module>/
├── mod.rs         # Public types and module exports
├── common/        # Shared implementation details
│   ├── mod.rs     # Export encoders/decoders
│   ├── encoders.rs # Message encoding functions
│   └── decoders.rs # Message decoding functions
├── sync.rs        # Synchronous implementation
└── async.rs       # Asynchronous implementation
```

### Example Module Implementation

```rust
// src/accounts/mod.rs - Public types (always available)
#[derive(Debug)]
pub struct AccountSummary {
    pub account: String,
    pub tag: String,
    pub value: String,
    pub currency: String,
}

// Feature-specific implementations
#[cfg(feature = "sync")]
mod sync;

#[cfg(feature = "async")]
mod r#async;

// Re-export API functions based on active feature
#[cfg(feature = "sync")]
pub use sync::{account_summary, positions};

#[cfg(feature = "async")]
pub use r#async::{account_summary, positions};
```

This structure ensures:
- Public types are always available regardless of feature flags
- Shared business logic in common/encoders and common/decoders
- Clear separation between public API (types) and implementation
- No code duplication for encoding/decoding
- Easy debugging and maintenance

## Key Modules

- **`accounts`**: Account management and portfolio information
- **`contracts`**: Contract definitions and search
- **`market_data`**: Real-time and historical market data
- **`orders`**: Order placement and management
- **`news`**: News bulletins and articles
- **`wsh`**: Wall Street Horizon event data
- **`transport`**: Connection and message handling (internal)
- **`messages`**: Message definitions and routing (internal)
- **`protocol`**: Protocol version constants and feature checking

## Multi-Threading Model

The `Client` can be shared between threads for concurrent operations:

1. **Thread-Safe Design**: Use `Arc<Client>` when sharing across threads
2. **Channel Isolation**: Each subscription gets its own channel
3. **Subscription Model**: Subscriptions can be converted to iterators (sync) or streams (async)

## Connection Management

### Connection States
- **Connected**: Active connection to TWS/Gateway
- **Reconnecting**: Attempting to restore connection
- **Shutdown**: Connection closed, no reconnection attempts

### Reconnection Strategy
- Automatic reconnection on connection loss
- Fibonacci backoff (1, 2, 3, 5, 8... seconds)
- Maximum 20 reconnection attempts
- Configurable via `MAX_RECONNECT_ATTEMPTS`

### Connection Monitoring
Use `client.is_connected()` to check connection status:
```rust
if client.is_connected() {
    // Safe to make API calls
}
```

## Important Design Considerations

1. **Shared Channels**: Some TWS API calls don't have unique request IDs and use shared channels. Avoid concurrent requests of the same type.

2. **Message Ordering**: TWS doesn't guarantee message ordering for different request types.

3. **Rate Limiting**: TWS has rate limits. The library doesn't enforce these - applications must manage their request rates.

4. **Error Recovery**: Connection errors trigger automatic reconnection. Application errors must be handled by the caller.