TWS API Users Group /g/twsapi This Group's purpose is to exchange information and ideas about the Trader Workstation API provided by Interactive Brokers. All users of Interactive Brokers' Trader Workstation (TWS) API are welcome. This covers the following API variants: ActiveX Java C++ C# Python Excel DDE, VBA and RTD Client Portal API FIX API Note: if you have a question about IBC, don't post it here: use the IBC User Group at /g/ibcalpha. Note: If you have a question about the ib_insync or new ib_async Python frameworks, which are not provided or supported by Interactive Brokers, don't post it here: use the ib_ansync Python framework User Group at /g/ib-async New members please note that your posts will be moderated until we know that you are genuine. This means it may take a while for them to appear, because a moderator may not be immediately available (especially outside US office hours). So please be patient, and don't repeat a post because it hasn't appeared yet. This Group is not intended for advertising products or services, for recruiting staff, or any other commercial purpose. Members who are in some way affiliated with a product or service that has a direct relationship to TWS API may include a simple link to it in their signature when they make a genuine post that conforms to the Group’s purpose, but this should not contain any marketing slogans, logos, pictures, diagrams, etc. Where a product or service exists that could directly provide a solution to a member’s problem, it is acceptable to mention and link to the product or service in the body of a post, but do not include logos, slogans, etc. If you are affiliated with the product in any way, please state the nature of that affiliation. Individual members who want to use the TWS API but who do not have the necessary programming skills, and are willing to pay a group member to do the work for them, may ask for assistance from other Group members: please provide as much information about your requirements as you can, include your email address explicitly in the post, and ask members to reply directly to you rather than via the Group. Any IBKR API related question and post is welcome, but when you consider a new post or reply to an existing one: First check whether the TWS API Documentation on IBKR Campus (or the TWS API Guide on github), the Client Portal API Documentation, or the FIX Implementation Manual can answer your question Search our group archive for a post that already provides the information you are looking for State your question or problem in terms of the API so that it and the resulting discussion is helpful to members using any of the many supported programming languages Tell us what you have already tried, what worked, and what did not Limit the amount of code you include to the absolute minimum. Our group is not a "fix my code" service When you add a reply to an existing post, stay on the topic of the post and make sure your reply does advance the discussion Remember your submission is sent to more than 6,000 members: please don't waste their time! Users who infringe these rules will be considered to be spamming and may be banned without notice. We are not affiliated in any way with Interactive Brokers Sat, 08 Jun 2002 12:32:38 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54078 <div>It will take a while to convert over to this new API design.   I think its a mistake to be doing this to a mature product that essentially has no new or important trading method additions pending any time soon.</div> <div> </div> <div>But it does give me an opportunity to erase so much old code.  By making the next release a 10.35++ only and forcing a cutoff point, I can eliminate hundreds of  &#34;if ServerVer &gt; x&#34; tests and plenty of &#34;if ServerVer &lt; 201&#34; code too.</div> <div> </div> <div>It would be nice to know how much of this API this ProtoBuf will eventually be applied too.  Obviously this first version is just the starting point.</div> rossh@... (rossh_yh) Thu, 03 Apr 2025 22:43:59 -0700 Re: TWS Time zone /g/twsapi/message/54077 <div>My problem is TWS is showing CDT after logon, even though it&#39;s configured to EDT in the &#34;more options&#34; screen available at logon.  I have another Window&#39;s 11 computer that doesn&#39;t have this problem.</div> fbell50@... (Frank Bell) Thu, 03 Apr 2025 20:27:27 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54076 <html><head><meta http-equiv="Content-Type"/><meta name="Generator"/></head><body lang="EN-US"><div class="WordSection1"><p>Hi Jürgen,</p><p> </p><p>Many thanks. So, it appears we have some time but perhaps not to get third party frameworks up to date.</p><p class="MsoNormal"> </p><p class="MsoNormal"> </p><p class="MsoNormal">Pranav<span style="color: white"></span></p></div> pranav@... (Pranav Lal) Thu, 03 Apr 2025 18:46:06 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54075 <p>Yes, Pranav. All TWS API clients that want to communicate with the capabilities of API 10.35.01 (server version 201) and higher will have to be able to send and receive protobuf formatted messages. IBKR has made those changes for all languages they support (including the IBKR Python API), but independently developed APIs including ib_async will have to add those capabilities eventually as well, or they are limited to requests, responses, and classes available in 10.34.02.</p> <p>For the foreseeable future, clients that implement API 10.34.02 or below will still be able to communicate with TWS/IBGW 10.35 and above. That may be sufficient for many users for quite some time.</p> <p>In API 10.35.01, IBKR has added protobuf formatted messages for the following items (though the original messages are still supported for clients with APs below 10.35):</p> <ul> <li>one request: reqExecutions()</li> <li>two responses: execDetails() and execDetailsEnd()</li> <li>five classes: ComboLeg, Contract, DeltaNeutralContract, Execution, and ExecutionFilter</li> </ul> <p>The classes and functionality of the request and the responses are identical to those in 10.34.02, except that ExecutionFilter in 10.35 has two new fields: the interger field &#34;lastNDays&#34; and the list &#34;specificDates&#34;. </p> <p>Jürgen</p> <p> </p> <div> </div> <div>On Thu, Apr 3, 2025 at 07:20 PM, Pranav Lal wrote:</div> <div> </div> TwsApiOnGroupsIo@... (Jürgen Reinold) Thu, 03 Apr 2025 18:25:46 -0700 Re: TWS Time zone /g/twsapi/message/54074 <div><span style="color: #333333; font-family: system-ui, Roboto, Arial, sans-serif; font-size: 16px; font-style: normal; font-weight: 400; letter-spacing: normal; text-align: start; text-transform: none; word-spacing: 0px; background-color: #ffffff; display: inline">TWS switched <span style="color: #333333; font-family: system-ui, Roboto, Arial, sans-serif; font-size: 16px; font-style: normal; font-weight: 400; letter-spacing: normal; text-align: start; text-transform: none; word-spacing: 0px; background-color: #ffffff; display: inline">mostly </span>to canonical tz-database designations some time ago. America/New_York is in EDT, together with a few other US and non-US canonical regions from Canada and the Caribbean, so a any of these are equivalent to EDT.</span></div> <div>--</div> <div>Best,<br/>DS</div> dimsal.public@... (ds-avatar) Thu, 03 Apr 2025 17:56:13 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54073 Hi Richard,<br /><br />I see from the documentation that python is supported by protocol buffers. Does this mean that third party APIs like ib_async are impacted by this change? <br /><br />Pranav pranav@... (Pranav Lal) Thu, 03 Apr 2025 17:20:47 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54072 <html><head><meta http-equiv="Content-Type"/><meta name="Generator"/></head><body lang="EN-GB"><div class="WordSection1"><p class="MsoNormal"><span style="font-family: sans-serif">No, the ActiveX API is a wrapper around the C-Sharp API, and this change is internal to the C-Sharp API so it won’t look any different to the ActiveX code.</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif">Richard</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><div style="border: none; border-top: solid #E1E1E1 1.0pt"><p class="MsoNormal"></p></div></div> rlking@... (Richard L King) Thu, 03 Apr 2025 14:57:53 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54071 <div dir="ltr">What about the API implementations for Excel &amp; vba? Are those affected?<br/><div><br/></div><div>Thank you</div></div><br/><div class="gmail_quote gmail_quote_container"><div dir="ltr" class="gmail_attr">El jue, 3 abr 2025 a las 22:09, noreply.section+dev via <a href="http://groups.io" rel="nofollow noopener" target="_blank">groups.io</a> (&lt;noreply.section+dev=<a href="mailto:[email protected]" rel="nofollow noopener" target="_blank">[email protected]</a>&gt;) escribió:<br/></div></div> joanmarcel@... (joanmarcel119) Thu, 03 Apr 2025 14:31:22 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54070 <p>On this topic, I also enquired with IB about some mechanism to opt-in/opt-out protobuf, possibly via a connection option or a TWS configuration setting, but they said no.</p> <p>So, even though your client can still decide whether or not to use protobuf when sending a request, TWS responses will automatically use protobuf regardless, if API version â‰� MIN_SERVER_VER_PROTOBUF.</p> noreply.section+dev@... (lbilli) Thu, 03 Apr 2025 13:09:34 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54069 <html><head><meta http-equiv="Content-Type"/><meta name="Generator"/></head><body lang="EN-GB"><div class="WordSection1"><p class="MsoNormal"><span style="font-family: sans-serif">Ross</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif">You’re absolutely right!</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif"> I was too lenient in my earlier post, because after a cursory glance a couple of weeks back I had mistakenly thought that the EClient.useProtoBuf() function was a settable attribute of EClient. But of course it’s notâ€�</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif">So it looks like I’m pretty much shafted by this. One of my API implementations is actually written in Visual Basic 6 (believe it or not, lots of history there) and is still a vital component in my trading platform, but there’s seems to be no chance of using protobuf in that. My other API implementation is .Net based, so there is a way forward there.</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif">Oh well, life is full of surprisesâ€�</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif">Richard</span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><p class="MsoNormal"><span style="font-family: sans-serif"> </span></p><div style="border: none; border-top: solid #E1E1E1 1.0pt"><p class="MsoNormal"></p></div></div> rlking@... (Richard L King) Thu, 03 Apr 2025 12:22:08 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54068 <div>I see in 10.35 in the C++, there is no option to ignore this ProtoBuf.  10.35 is version 201 (MIN_SERVER_VER_PROTOBUF), and its all coded into the source.  It does not seem there is way to avoid this mistake.  Looks like 10.34 will be the max build version for some time for many of us.</div> rossh@... (rossh_yh) Thu, 03 Apr 2025 09:55:46 -0700 TWS Time zone /g/twsapi/message/54067 <div> <p class="western" style="line-height: 100%"><span style="">I’m in the central time zone but I have my computers on EDT. When I run TWS on my new computer it displays CDT, not EDT. When I run it on any of my other computers it uses EDT. My new computer is setup for EDT and that’s what it shows in the task bar. Selecting “more optionsâ€� on the TWS login screen shows the time zone as â€�(UTC-05:00) America/New Yorkâ€� on the new and old computers.</span></p> <p class="western" style="line-height: 100%"> </p> <p class="western" style="line-height: 100%"><span style="">Any ideas?</span></p> <p class="western" style="line-height: 100%"> </p> <p class="western" style="line-height: 100%"><span style="">Frank</span></p> </div> fbell50@... (Frank Bell) Thu, 03 Apr 2025 07:34:28 -0700 Re: Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54066 When use of Protocol Buffers was first suggested back in 2015, I posted<br />some comments on IBKR&#39;s GitHub repository that were fairly critical of<br />the idea. If you have access to the API repository, you can see these at:<br /><br /><a href="https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-141953319" target="_blank">https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-141953319</a><br /><a href="https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-340619917" target="_blank">https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-340619917</a><br /><a href="https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-340735285" target="_blank">https://github.com/InteractiveBrokers/tws-api/issues/2#issuecomment-340735285</a><br /><br />(For those who don&#39;t have access, the attached file contains the text <br />from these posts.)<br /><br />Most of what I wrote then is still true, but one thing that has changed<br />is that protobuf compilers now exist for many common languages: for<br />example WikiPedia says this:<br /><br /> &#34;Protobuf 3.0 provides a code generator for C++, Java (including<br /> JavaNano, a dialect intended for low-resource environments),<br /> Kotlin, Python, Go, Ruby, Objective-C, C#, PHP, Dart.[14] It<br /> also supports JavaScript since 3.0.0-beta-2.[15]<br /><br /> Third-party implementations are also available for Ballerina,<br /> [16] C,[17][18] C++,[19] Dart, Elixir,[20][21] Erlang,[22] <br /> Haskell,[23] JavaScript,[24] Julia,[25] Nim,[26] Perl, PHP, Prolog,<br /> [27][28] R,[29] Rust,[30][31][32] Scala,[33] and Swift.[34]&#34;<br /><br />So those who develop their own API implementations using such <br />languages should have no trouble making use of IBKR&#39;s protobuf work.<br /><br />Those who use other languages will be in serious trouble, unless IBKR <br />commits long-term to allowing use of either the old protocol or the <br />protobuf implementation. At present, the protobuf implementation<br />is very limited in scope, and use is optional. But presumably the long-term<br />goal is to extend the protobuf implementation to all API message types, <br />and who knows what IBKR will insist on then?<br /><br />So my overall position is that this is all a big waste of IBKR&#39;s time and<br />effort, for no real benefit. If they were starting to develop the API now,<br />use of protobuf throughout would be a no-brainer, but after decades<br />of development using the current protocol I&#39;d say: it ain&#39;t broke, so <br />don&#39;t fix it!<br /><br />Richard rlking@... (Richard L King) Thu, 03 Apr 2025 03:03:03 -0700 Google Protocol Buffers usage in the latest Java API /g/twsapi/message/54065 Would anyone like to comment on the introduction of Google Protocol Buffers in the Latest Java TWS API version 10.35 ?<br /><br />-- <br /><a href="https://www.tradingsoftwarelab.com" target="_blank">https://www.tradingsoftwarelab.com</a> paulopersonal@... (Orionn) Thu, 03 Apr 2025 00:58:48 -0700 Re: Anyone has code to show all option chain names for a symbol? /g/twsapi/message/54064 <div>I think IB needs a callback to get OI. This is very slow and time consuming wow. IT should have been more of a spread sheet return.</div> marluv@... (Marluv) Mon, 31 Mar 2025 13:37:48 -0700 Re: Late Prints don't show up when I call reqHistoricalTicks() /g/twsapi/message/54063 <div>WORKED!! THANK YOU SIRRR!!</div> marluv@... (Marluv) Mon, 31 Mar 2025 13:24:50 -0700 Re: reqContractDetails() does not get a callback if secType = "OPT" /g/twsapi/message/54062 <div>Yep, you need to specify the option multiplier (&#34;100&#34;).</div> <div> </div> <div>You don&#39;t need to set conId = 0 unless you&#39;re reusing the same contract for the option as for the underlying; otherwise, I&#39;ve noticed TWS will simply retrieve the contract associated to the conId if not 0.</div> Alex@... Mon, 31 Mar 2025 08:41:09 -0700 Re: Improvements to Intraday Momentum Strategies Using Parameter Optimization and Different Exit Strategies /g/twsapi/message/54061 <div>Thanks for sharing your research! I&#39;ll very interested to read it!</div> Alex@... Mon, 31 Mar 2025 08:30:48 -0700 Re: Anyone has code to show all option chain names for a symbol? /g/twsapi/message/54060 <div>Also, here&#39;s a list of the generic tick types in case you want to retrieve more data:<br/>https://interactivebrokers.github.io/tws-api/tick_types.html</div> Alex@... Mon, 31 Mar 2025 08:26:40 -0700 Re: Anyone has code to show all option chain names for a symbol? /g/twsapi/message/54059 <div>You&#39;re welcome :)</div> <div> </div> <div>Regarding Open Interest, I don&#39;t use it but found this (very old) thread that mentions the tick types you could set in your reqMktData() call:</div> <div><a href="/g/twsapi/topic/how_to_get_open_interest_in/4047032" target="_blank" rel="nofollow noopener">/g/twsapi/topic/how_to_get_open_interest_in/4047032</a></div> <div> </div> <div>Basically, it says that you should add generic tick 101 to the reqMktData() function:</div> <blockquote>m_pClient-&gt;reqMktData( ++m_requestId , retContract, &#34;101&#34; , false , false , NULL );</blockquote> <div> </div> <div>This should return a value in the tickSize() callback.</div> <blockquote> <div>//! [ticksize]<br/>void TraderClient::tickSize( TickerId tickerId, TickType field, Decimal size) {<br/>    //printf( &#34;Tick Size. Ticker Id: %ld, Field: %d, Size: %s\n&#34;, tickerId, (int)field, decimalStringToDisplay(size).c_str());<br/>}<br/>//! [ticksize]</div> </blockquote> <div> </div> <div>In the callback, just check the value of the <strong>field </strong>parameter and if it&#39;s field =<strong> </strong>27, then the <strong>size</strong> parameter will be the call open interest, and if field =<strong> </strong>28 then it will be the put open interest.</div> Alex@... Mon, 31 Mar 2025 08:14:39 -0700