-
Notifications
You must be signed in to change notification settings - Fork 20
IBind Configuration
There are three fundamental configurations of IBind:
-
Constructor parameters for
IbkrClient
andIbkrWsClient
- Environment variables
- Logging
IbkrClient
and IbkrWsClient
have three common settings that can be configured through their constructor parameters:
Many of the IBKR API endpoints require an account ID to be specified.
In most cases this value will be the constant for a particular user, hence both the IbkrClient
and IbkrWsClient
allow to store the account ID by specifying the account_id
parameter upon construction.
IbkrClient(account_id='DU12345678')
Note:
- This value can be set as an environment variable
IBIND_ACCOUNT_ID
, which will be read automatically upon construction. - All API methods that require the account ID to be specified provide an optional
account_id
parameter allowing you to override this class field on case-by-case basis.
The client classes require a URL to the Client Portal Gateway. There are two ways of specifying it:
IbkrClient(url='https://mydomain:6060/v1/api/')
IbkrWsClient(url='wss://mydomain:6060/v1/api/ws')
Note:
- This value can be set as an environment variable
IBIND_REST_URL
, which will be read automatically upon construction.
These then get combined as follows:
-
https://{host}:{port}{base_route}
forIbkrClient
-
wss://{host}:{port}{base_route}
forIbkrWsClient
Eg.:
IbkrClient(port=6060)
The default values are:
host = 'localhost'
port = '5000'
base_route = '/v1/api/' # for IbkrClient
base_route = '/v1/api/ws' # for IbkrWsClient
Note:
- The
host
,port
andbase_route
parameters are ignored if theurl
parameter is provided. - If no parameters are provided, the default
host
,port
, andbase_route
values will be used.
The Client Portal Gateway can be set up to use custom CAcerts. To communicate with it, the API client will need to use the same certificates.
The cacert
parameter allows you to specify a path to the cacert.pem
certificate, eg.:
IbkrClient(cacert='/some/path/to/my/cacert.pem')
Note:
- This value can be set as an environment variable
IBIND_CACERT
, which will be read automatically upon construction. - You can set this value to
False
which will avoid using certificates and verified HTTPS.
A full and most up-to-date list of environment variables can be found in the var.py
file.
Variable name | Default value | Description |
---|---|---|
LOG_TO_CONSOLE |
True | Whether logs should be streamed to the standard output. |
LOG_LEVEL |
'DEBUG' | The global log level for the StreamHandler. |
LOG_FORMAT |
'%(asctime)s|%(levelname)-.1s| %(message)s' | Log format that is used by IBind |
LOGS_DIR |
tempfile.gettempdir() | Directory of file logs produced. |
LOG_TO_FILE |
True | Whether logs should be saved to a file. |
IBIND_REST_URL |
None | IBKR Client Portal Gateway's URL for REST API. |
IBIND_WS_URL |
None | IBKR Client Portal Gateway's URL for WebSocket API. |
IBIND_ACCOUNT_ID |
None | IBKR account ID to use. |
IBIND_CACERT |
False | Path to certificates used to communicate with IBKR Client Portal Gateway. |
IBIND_WS_PING_INTERVAL |
45 | Interval between WebSocket pings. |
IBIND_WS_MAX_PING_INTERVAL |
300 | Max accepted interval between WebSocket pings. |
IBIND_WS_TIMEOUT |
5 | Timeout for WebSocket state change verifications. |
IBIND_WS_SUBSCRIPTION_RETRIES |
5 | Number of attempts to create a WebSocket subscription. |
IBIND_WS_SUBSCRIPTION_TIMEOUT |
2 | Timeout for WebSocket subscription verifications. |
IBIND_WS_LOG_RAW_MESSAGES |
False | Whether raw WebSocket messages should be logged. |
IBind produces a number of logs using the Python standard logging
module.
Off by default, this logging functionality needs to be activated by calling the ibind_logs_initialize()
function.
from ibind import IbkrClient, ibind_logs_initialize
ibind_logs_initialize()
The ibind_logs_initialise
function accepts the following parameters:
-
log_to_console
- whether the logs should be output to the current console,True
by default -
log_to_file
- whether the logs should be written to a daily log file,True
by default. -
log_level
- what is the minimum log level ofibind
logs,INFO
by default. -
log_format
- what is the log format to be used,'%(asctime)s|%(levelname)-.1s| %(message)s'
by default.
Note:
- All of these parameters are read from the environment variables by default.
- Calling
ibind_logs_initialize
withlog_to_console=False
will disable only logs belowWARNING
level. - The daily file logs are saved in the directory specified by the
IBIND_LOGS_DIR
environment variable, the system temp directory by default. - To get more verbose logs, set either the
log_level
parameter or theIBIND_LOG_LEVEL
environment variable to'DEBUG'
See any error on this page? Create an Issue and let us know.