ib-flex
Type-safe Rust parser for Interactive Brokers FLEX XML statements with comprehensive coverage and financial precision.
Features
- High performance - Fast XML parsing with quick-xml and serde
- Financial precision - rust_decimal for all monetary values (no floating point errors)
- Type-safe - 15 enums with 100+ variants for comprehensive coverage
- Comprehensive - Supports all major FLEX sections and 20 asset categories
- Well-tested - Integration tests, property-based tests, edge case coverage
- Edge case handling - Warrants, T-Bills, CFDs, fractional shares, cancelled trades
- Optional API client - Fetch FLEX statements programmatically from IB
Installation
Add this to your Cargo.toml:
[]
= "0.1"
Quick Start
use ;
FLEX Query Setup
Interactive Brokers FLEX queries must be configured in the IB Client Portal:
- Navigate to: Reports โ Flex Queries โ Create Activity Flex Query
- Select required sections (Trades, Positions, Cash Transactions, etc.)
- Choose date format: ISO-8601 (
yyyy-MM-dd) or compact (yyyyMMdd) - Set output format to XML
- Save query and note the Query ID
Important: European date formats (dd/MM/yyyy) are NOT supported by the IB FLEX API.
๐ For comprehensive setup instructions, see FLEX_SETUP.md which covers all 21 recommended sections, field selections, and configuration options.
FLEX Web Service API Client (Optional)
The api-client feature provides programmatic access to fetch FLEX statements directly from Interactive Brokers without manual downloads.
Installation with API Client
[]
= { = "0.1", = ["api-client"] }
API Setup
- Log in to IB Account Management
- Navigate to: Reports โ Settings โ FlexWeb Service
- Generate a FLEX Web Service token (keep it secure!)
- Note your FLEX Query ID from the Flex Queries page
Usage Example
use FlexApiClient;
use Duration;
async
API Examples
Run the API examples (requires IB credentials):
Supported FLEX Sections
Activity FLEX - Core Types
- โ Trades - Executions with 40+ fields including P&L, commissions, dates, security details
- โ Open Positions - Current holdings with 30+ fields
- โ Cash Transactions - Deposits, withdrawals, interest, fees, dividends
- โ Corporate Actions - Splits, mergers, spinoffs, dividends (36 action types)
- โ Securities Info - Reference data for all traded instruments
- โ FX Conversion Rates - Currency conversion rates for multi-currency accounts
Extended FLEX Sections
- โ Account Information - Account metadata and configuration
- โ Change in NAV - Net asset value changes with transfers and P&L breakdown
- โ Equity Summary - Asset allocation by category (cash, stocks, options, bonds)
- โ Cash Report - Detailed cash flow by currency
- โ Trade Confirmations - Real-time trade execution confirmations
- โ Option EAE - Option exercises, assignments, and expirations
- โ FX Transactions - Foreign exchange conversions
- โ Dividend Accruals - Accrued and open dividend tracking
- โ Interest Accruals - Interest accrual tracking by currency
- โ Transfers - Security transfers (ACATS, ATON, FOP, etc.)
Asset Classes Supported
- โ Stocks (STK) - Including fractional shares
- โ Options (OPT) - Calls, puts, assignments, expirations
- โ Futures (FUT) - All major contracts (ES, NQ, CL, GC, etc.)
- โ Forex (CASH) - FX trades and positions
- โ Bonds (BOND) - Treasuries, corporate, municipal
- โ Treasury Bills (BILL) - With maturity handling
- โ Warrants (WAR) - Equity warrants
- โ CFDs - Contract for difference
- โ Funds, Commodities, and more - 20 asset categories total
Trade Confirmation FLEX
- โ Trade Confirmations - Real-time trade execution data
- โ All trade fields - Full support for all trade attributes
- โ Automatic detection - Detect statement type from XML
Performance
Benchmarked on M1 MacBook Pro:
| Statement Type | Transactions | Parse Time |
|---|---|---|
| Minimal | 1 trade | ~6.5 ยตs |
| Options | 4 trades | ~65 ยตs |
| Cash | 15 transactions | ~71 ยตs |
Memory efficient with approximately 200 bytes per trade. Parsing 10,000 trades uses ~2MB of memory.
Type Safety
All financial values use rust_decimal::Decimal for precise calculations without floating-point errors. The library includes comprehensive enums with 100+ variants covering:
- AssetCategory (20 variants) - STK, OPT, FUT, CASH, BOND, BILL, WAR, CFD, etc.
- CorporateActionType (36 variants) - All corporate action types (formerly Reorg)
- TransactionCode (50+ variants) - Transaction classification codes (formerly Code)
- CashTransactionType (13 variants) - Cash transaction types (formerly CashAction)
- DerivativeInfo - Consolidated derivative metadata for options, futures, and warrants
- OrderType (13 variants) - Market, limit, stop, etc.
- SecurityIdType - CUSIP, ISIN, FIGI, SEDOL identifier types
- SubCategory - ETF, ADR, REIT, Preferred, Common, and more
- LevelOfDetail - Summary, Detail, Execution, Lot reporting granularity
- BuySell, OpenClose, PutCall, LongShort, TradeType, OptionAction, and more
Examples
The repository includes several complete example programs:
Parsing Examples
- parse_activity_statement.rs - Basic Activity FLEX parsing and display
- filter_trades.rs - Filter by asset class, side, symbol, quantity, P&L, date range
- calculate_commissions.rs - Analyze commission costs by category
- parse_trade_confirmation.rs - Trade Confirmation FLEX parsing
Run parsing examples:
Historical Backfill Example
- backfill_summary.rs - Parse multi-statement FLEX XML and display comprehensive summary
To use this example:
- Create a FLEX query with Period: Last 180 Calendar Days (or similar) in IBKR Client Portal - see FLEX_SETUP.md
- Download the XML file manually or via API
- Run the summary:
Output includes:
- NAV over time with returns, high/low, drawdown
- Trading activity by symbol with P&L attribution
- Cash transaction breakdown (dividends, interest, fees)
- Current positions from latest statement
- Monthly returns table
API Client Examples (requires api-client feature)
- fetch_flex_statement.rs - Complete API workflow with detailed output
- api_simple_usage.rs - Minimal API client usage
- api_with_retry.rs - API client with automatic retry logic
Run API examples:
Development
Build
Test
Benchmark
Format
Lint
Testing
The library has comprehensive test coverage including:
- Integration tests covering all asset classes and edge cases
- Extended types tests for FLEX sections
- Error tests for malformed XML and invalid data
- Unit tests for custom deserializers
- Doc tests in inline documentation
- XML fixtures including extended types, warrants, T-Bills, CFDs, fractional shares, cancelled trades
Reliability Testing
The library includes comprehensive reliability tests using:
- Property-based testing with proptest for random inputs
- Stress tests for large XML files
- Concurrency tests for thread safety
- Memory efficiency tests for repeated parsing
- Edge case fuzzing for malformed inputs
Run tests with:
Contributing
Contributions welcome! This is an open-source project designed to benefit the Rust trading community.
Before submitting a PR:
- Ensure all tests pass:
cargo test - Run clippy:
cargo clippy -- -D warnings - Format code:
cargo fmt - Add tests for new features
- Update CHANGELOG.md
Bug reports and feature requests are appreciated. When reporting bugs, please include:
- Anonymized XML sample demonstrating the issue
- Expected vs actual behavior
- Rust version and platform
Documentation
- API Documentation
- Implementation Plan - Full implementation details and statistics
- Project Guide for Claude Code - Development guide
- Edge Cases Summary - Comprehensive edge case analysis
- Types Analysis - Type system breakdown
Resources
License
Licensed under either of:
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Acknowledgments
- Inspired by csingley/ibflex (Python) - Comprehensive enum research
- Built with quick-xml - Fast XML parsing with serde
- rust_decimal - Financial precision
- chrono - Date/time handling
See PLAN.md for detailed implementation statistics and EDGE_CASES_SUMMARY.md for edge case coverage.