Automated publisher for the Interactive Brokers TWS API Python client on PyPI.
Two packages available on PyPI:
pip install ibapi-latestpip install ibapi-stableYou can also install a specific version:
pip install ibapi-latest==10.40.01
pip install ibapi-stable==10.37.02from ibapi.client import EClient
from ibapi.wrapper import EWrapper
from ibapi.contract import Contract
class IBApp(EWrapper, EClient):
def __init__(self):
EClient.__init__(self, self)
app = IBApp()
app.connect("127.0.0.1", 7497, clientId=1)
app.run()For complete examples and documentation, visit the official IB API documentation.
This is an unofficial automated publisher for the Interactive Brokers TWS API Python client. The source code is from Interactive Brokers' official TWS API distribution, packaged and published to PyPI for easy installation.
⚠️ DISCLAIMERThis package is NOT officially affiliated with, endorsed by, or supported by Interactive Brokers LLC. It is an independent community project that automates the packaging and distribution of the official IB API source code.
- The IB API source code is proprietary to Interactive Brokers and is licensed under the TWS API Non-Commercial License
- This automation tool is provided "as is" without any warranties
- For official support, please contact Interactive Brokers
- Trading involves risk. Use at your own discretion.
ibapi-latest: The newest IB API version (frommainbranch)ibapi-stable: Previous IB API versions (fromstablebranch)
Both packages are automatically updated weekly when new IB API versions are released.
ibapi/
├── .github/
│ └── workflows/ # GitHub Actions for automation
│ ├── update-ibapi-latest.yml # Latest version publisher
│ └── update-ibapi-stable.yml # Stable version publisher
├── scripts/ # Automation scripts
│ ├── get_download_url.py # Fetch IB API download URLs
│ ├── update_ibapi.py # Download and commit IB API
│ └── check_and_update.py # Orchestrator (legacy)
├── ibapi/ # IB API Python client (auto-updated)
│ └── ibapi/
│ ├── client.py
│ ├── wrapper.py
│ └── ...
├── pyproject.toml # Package configuration
└── README.md
- Weekly Check: GitHub Actions runs every Monday at 9:00 AM UTC
- Version Detection: Scrapes https://interactivebrokers.github.io/ for new versions
- Download & Extract: Downloads the TWS API zip and extracts the Python client
- Auto-Fix: Automatically fixes version strings and package configuration
- Build & Publish: Builds the package and publishes to PyPI
- Tag & Release: Creates git tags and GitHub releases
- Versions follow IB's format:
10.40.01,10.37.02, etc. - Git tags:
v10.40.01,v10.37.02, etc. - PyPI packages:
- Latest:
ibapi-latest==10.40.01 - Stable:
ibapi-stable==10.37.02
- Latest:
This project has a dual license structure:
The Interactive Brokers TWS API source code is proprietary software owned by Interactive Brokers LLC and is licensed under the TWS API Non-Commercial License.
Key restrictions:
- ✅ Use for personal trading and account management
- ✅ Develop internal proprietary tools for your own IB account
- ❌ NOT permitted: Selling software to third parties
- ❌ NOT permitted: Distributing software to generate indirect financial benefit (e.g., commissions)
⚠️ Requires: Active Interactive Brokers account
For commercial use, contact Interactive Brokers at: opensource@interactivebrokers.com
Full license text: See LICENSE file
The automation tooling that packages and publishes the IB API is licensed under the MIT License.
See the LICENSE file for complete details.
- PyPI Packages:
- Official IB API: https://interactivebrokers.github.io/tws-api
- Documentation: https://ibkrcampus.com/ibkr-api-page/
- GitHub Repository: https://github.com/yourusername/ibapi
For issues with:
- The IB API itself: Contact Interactive Brokers
- This package/automation: Open an issue on GitHub
The package configuration is in pyproject.toml:
[project]
name = "ibapi"
dynamic = ["version"] # Version from ibapi.__version__
dependencies = ["protobuf==5.29.3"]
[tool.setuptools]
packages = ["ibapi", "ibapi.protobuf"]
package-dir = {"" = "ibapi"} # Maps ibapi/ibapi/* to ibapi/*This ensures imports work as expected:
from ibapi.client import EClient # Not from ibapi.ibapi.client