dxFeed Graal CXX API v4.2.0
Loading...
Searching...
No Matches
OrderSource.hpp
1// Copyright (c) 2025 Devexperts LLC.
2// SPDX-License-Identifier: MPL-2.0
3
4#pragma once
5
6#include "../../internal/Conf.hpp"
7
9
10#include <cstdint>
11#include <memory>
12#include <mutex>
13#include <string>
14#include <unordered_map>
15
16#include "../EventTypeEnum.hpp"
17#include "../IndexedEventSource.hpp"
18
20
21struct EventSourceWrapper;
22
23/**
24 * Identifies source of Order, AnalyticOrder, OtcMarketsOrder and SpreadOrder events.
25 * There are the following kinds of order sources:
26 * <ul>
27 * <li><em>Synthetic</em> sources OrderSource::COMPOSITE_BID, OrderSource::COMPOSITE_ASK,
28 * OrderSource::REGIONAL_BID, and OrderSource::REGIONAL_ASK are provided for convenience of a consolidated
29 * order book and are automatically generated based on the corresponding Quote events.
30 * <li><em>Aggregate</em> sources OrderSource::AGGREGATE_BID and OrderSource::AGGREGATE_ASK provide
31 * futures depth (aggregated by price level) and NASDAQ Level II (top of book for each market maker).
32 * These source cannot be directly published to via dxFeed API.
33 * <li><em>Publishable</em> sources OrderSource::DEFAULT, OrderSource::NTV, OrderSource::ISE etc
34 * support full range of dxFeed API features.
35 * </ul>
36 */
37class DXFCPP_EXPORT OrderSource final : public IndexedEventSource {
38 friend struct EventSourceWrapper;
39
40 static constexpr std::uint32_t PUB_ORDER = 0x0001U;
41 static constexpr std::uint32_t PUB_ANALYTIC_ORDER = 0x0002U;
42 static constexpr std::uint32_t PUB_OTC_MARKETS_ORDER = 0x0004;
43 static constexpr std::uint32_t PUB_SPREAD_ORDER = 0x0008U;
44 static constexpr std::uint32_t FULL_ORDER_BOOK = 0x0010U;
45
46 static constexpr std::uint32_t FLAGS_SIZE = 5U;
47
48 public:
49 static const std::unordered_map<std::variant<std::int32_t, std::string>, std::reference_wrapper<const OrderSource>>
50 PREDEFINED_SOURCES;
51
52 private:
53 static inline std::mutex MTX_{};
54 static std::unordered_map<std::int32_t, OrderSource> USER_SOURCES_;
55
56 std::uint32_t pubFlags_{};
57 bool builtin_{};
58
59 OrderSource(std::int32_t id, std::string name, std::uint32_t pubFlags) noexcept;
60
61 OrderSource(const std::string &name, std::uint32_t pubFlags);
62
63 OrderSource(std::int32_t id, const std::string &name) noexcept;
64
65 static std::int32_t composeId(const std::string &name);
66
67 static void checkChar(char c);
68
69 static std::string decodeName(std::int32_t id);
70
71 static std::uint32_t getEventTypeMask(const EventTypeEnum &eventType);
72
73 /**
74 * Allocates memory for the dxFeed Graal SDK structure (recursively if necessary).
75 * Fills the dxFeed Graal SDK structure's fields by the data of the current entity (recursively if necessary).
76 * Returns the pointer to the filled structure.
77 *
78 * @return The pointer to the filled dxFeed Graal SDK structure
79 */
80 void *toGraal() const override;
81
82 std::unique_ptr<void, decltype(&IndexedEventSource::freeGraal)> toGraalUnique() const noexcept override;
83
84 public:
85 /**
86 * Bid side of a composite Quote.
87 * It is a <em>synthetic</em> source.
88 * The subscription on composite Quote event is observed when this source is subscribed to.
89 */
90 static const OrderSource COMPOSITE_BID;
91
92 /**
93 * Ask side of a composite Quote.
94 * It is a <em>synthetic</em> source.
95 * The subscription on composite Quote event is observed when this source is subscribed to.
96 */
97 static const OrderSource COMPOSITE_ASK;
98
99 /**
100 * Bid side of a regional Quote.
101 * It is a <em>synthetic</em> source.
102 * The subscription on regional Quote event is observed when this source is subscribed to.
103 */
104 static const OrderSource REGIONAL_BID;
105
106 /**
107 * Ask side of a regional Quote.
108 * It is a <em>synthetic</em> source.
109 * The subscription on regional Quote event is observed when this source is subscribed to.
110 */
111 static const OrderSource REGIONAL_ASK;
112
113 /**
114 * Bid side of an aggregate order book (futures depth and NASDAQ Level II).
115 * This source cannot be directly published via dxFeed API, but otherwise it is fully operational.
116 */
117 static const OrderSource AGGREGATE_BID;
118
119 /**
120 * Ask side of an aggregate order book (futures depth and NASDAQ Level II).
121 * This source cannot be directly published via dxFeed API, but otherwise it is fully operational.
122 */
123 static const OrderSource AGGREGATE_ASK;
124
125 /**
126 * Default source for publishing custom order books.
127 * Order, AnalyticOrder, OtcMarketsOrder and SpreadOrder events are @ref ::isPublishable() "publishable"
128 * on this source and the corresponding subscription can be observed via DXPublisher.
129 */
130 static const OrderSource DEFAULT;
131
132 /**
133 * NASDAQ Total View.
134 *
135 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
136 * observed via DXPublisher.
137 */
138 static const OrderSource NTV;
139
140 /**
141 * NASDAQ Total View. Record for price level book.
142 *
143 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
144 * observed via DXPublisher.
145 */
146 static const OrderSource ntv;
147
148 /**
149 * NASDAQ Futures Exchange.
150 *
151 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
152 * observed via DXPublisher.
153 */
154 static const OrderSource NFX;
155
156 /**
157 * NASDAQ eSpeed.
158 *
159 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
160 * observed via DXPublisher.
161 */
162 static const OrderSource ESPD;
163
164 /**
165 * NASDAQ Fixed Income.
166 *
167 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
168 * observed via DXPublisher.
169 */
170 static const OrderSource XNFI;
171
172 /**
173 * Intercontinental Exchange.
174 *
175 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
176 * observed via DXPublisher.
177 */
178 static const OrderSource ICE;
179
180 /**
181 * International Securities Exchange.
182 *
183 * Order and SpreadOrder events are @ref ::isPublishable() "publishable" on this source and the corresponding
184 * subscription can be observed via DXPublisher.
185 */
186 static const OrderSource ISE;
187
188 /**
189 * Direct-Edge EDGA Exchange.
190 *
191 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
192 * observed via DXPublisher.
193 */
194 static const OrderSource DEA;
195
196 /**
197 * Direct-Edge EDGX Exchange.
198 *
199 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
200 * observed via DXPublisher.
201 */
202 static const OrderSource DEX;
203
204 /**
205 * Direct-Edge EDGX Exchange. Record for price level book.
206 *
207 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
208 * observed via DXPublisher.
209 */
210
211 static const OrderSource dex;
212
213 /**
214 * Bats BYX Exchange.
215 *
216 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
217 * observed via DXPublisher.
218 */
219 static const OrderSource BYX;
220
221 /**
222 * Bats BZX Exchange.
223 *
224 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
225 * observed via DXPublisher.
226 */
227 static const OrderSource BZX;
228
229 /**
230 * Bats BZX Exchange. Record for price level book.
231 *
232 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
233 * observed via DXPublisher.
234 */
235 static const OrderSource bzx;
236
237 /**
238 * Bats Europe BXE Exchange.
239 *
240 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
241 * observed via DXPublisher.
242 */
243 static const OrderSource BATE;
244
245 /**
246 * Bats Europe CXE Exchange.
247 *
248 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
249 * observed via DXPublisher.
250 */
251 static const OrderSource CHIX;
252
253 /**
254 * Bats Europe DXE Exchange.
255 *
256 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
257 * observed via DXPublisher.
258 */
259 static const OrderSource CEUX;
260
261 /**
262 * Bats Europe TRF.
263 *
264 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
265 * observed via DXPublisher.
266 */
267 static const OrderSource BXTR;
268
269 /**
270 * Borsa Istanbul Exchange.
271 *
272 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
273 * observed via DXPublisher.
274 */
275 static const OrderSource IST;
276
277 /**
278 * Borsa Istanbul Exchange. Record for particular top 20 order book.
279 *
280 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
281 * observed via DXPublisher.
282 */
283 static const OrderSource BI20;
284
285 /**
286 * ABE (abe.io) exchange.
287 *
288 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
289 * observed via DXPublisher.
290 */
291 static const OrderSource ABE;
292
293 /**
294 * FAIR (FairX) exchange.
295 *
296 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
297 * observed via DXPublisher.
298 */
299 static const OrderSource FAIR;
300
301 /**
302 * CME Globex.
303 *
304 * Order and AnalyticOrder events are @ref ::isPublishable() "publishable" on this source and the corresponding
305 * subscription can be observed via DXPublisher.
306 */
307 static const OrderSource GLBX;
308
309 /**
310 * CME Globex. Record for price level book.
311 *
312 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
313 * observed via DXPublisher.
314 */
315 static const OrderSource glbx;
316
317 /**
318 * Eris Exchange group of companies.
319 *
320 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
321 * observed via DXPublisher.
322 */
323 static const OrderSource ERIS;
324
325 /**
326 * Eurex Exchange.
327 *
328 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
329 * observed via DXPublisher.
330 */
331 static const OrderSource XEUR;
332
333 /**
334 * Eurex Exchange. Record for price level book.
335 *
336 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
337 * observed via DXPublisher.
338 */
339 static const OrderSource xeur;
340
341 /**
342 * CBOE Futures Exchange.
343 *
344 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
345 * observed via DXPublisher.
346 */
347 static const OrderSource CFE;
348
349 /**
350 * CBOE Options C2 Exchange.
351 *
352 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
353 * observed via DXPublisher.
354 */
355 static const OrderSource C2OX;
356
357 /**
358 * Small Exchange.
359 *
360 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
361 * observed via DXPublisher.
362 */
363 static const OrderSource SMFE;
364
365 /**
366 * Small Exchange. Record for price level book.
367 *
368 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
369 * observed via DXPublisher.
370 */
371 static const OrderSource smfe;
372
373 /**
374 * Investors exchange. Record for price level book.
375 *
376 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
377 * observed via DXPublisher.
378 */
379 static const OrderSource iex;
380
381 /**
382 * Members Exchange.
383 *
384 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
385 * observed via DXPublisher.
386 */
387 static const OrderSource MEMX;
388
389 /**
390 * Members Exchange. Record for price level book.
391 *
392 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
393 * observed via DXPublisher.
394 */
395 static const OrderSource memx;
396
397 /**
398 * Blue Ocean Technologies Alternative Trading System.
399 *
400 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
401 * observed via DXPublisher.
402 */
403 static const OrderSource OCEA;
404
405 /**
406 * Pink Sheets. Record for price level book.
407 * Pink sheets are listings for stocks that trade over-the-counter (OTC).
408 *
409 * Order and OtcMarketsOrder events are @ref ::isPublishable() "publishable" on this source and the corresponding
410 * subscription can be observed via DXPublisher.
411 */
412 static const OrderSource pink;
413
414 /**
415 * NYSE Arca traded securities
416 *
417 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
418 * observed via DXPublisher.
419 */
420 static const OrderSource ARCA;
421
422 /**
423 * NYSE Arca traded securities. Record for price level book.
424 *
425 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
426 * observed via DXPublisher.
427 */
428 static const OrderSource arca;
429
430 /**
431 * Cboe European Derivatives.
432 *
433 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
434 * observed via DXPublisher.
435 */
436 static const OrderSource CEDX;
437
438 /**
439 * Cboe European Derivatives. Record for price level book.
440 *
441 * Order events are @ref ::isPublishable() "publishable" on this source and the corresponding subscription can be
442 * observed via DXPublisher.
443 */
444 static const OrderSource cedx;
445
446 /**
447 * Determines whether specified source identifier refers to special order source.
448 * Special order sources are used for wrapping non-order events into order events.
449 *
450 * @param sourceId the source identifier.
451 * @return `true` if it is a special source identifier
452 */
453 static bool isSpecialSourceId(std::int32_t sourceId) noexcept;
454
455 /**
456 * Returns order source for the specified source identifier.
457 *
458 * @param sourceId the source identifier.
459 * @return order source.
460 */
461 static const OrderSource &valueOf(std::int32_t sourceId);
462
463 /**
464 * Returns order source for the specified source name.
465 * The name must be either predefined, or contain at most 4 alphanumeric characters.
466 *
467 * @param name the name of the source.
468 * @return order source.
469 */
470 static const OrderSource &valueOf(const std::string &name);
471};
472
474
475template <> struct std::hash<dxfcpp::OrderSource> {
476 std::size_t operator()(const dxfcpp::OrderSource &orderSource) const noexcept {
477 return static_cast<std::size_t>(orderSource.id());
478 }
479};
480
#define DXFCXX_DISABLE_MSC_WARNINGS_POP()
Definition Conf.hpp:22
#define DXFCPP_END_NAMESPACE
Definition Conf.hpp:70
#define DXFCPP_BEGIN_NAMESPACE
Definition Conf.hpp:67
#define DXFCXX_DISABLE_GCC_WARNINGS_PUSH(warnings)
Definition Conf.hpp:38
#define DXFCXX_DISABLE_GCC_WARNINGS_POP()
Definition Conf.hpp:40
#define DXFCXX_DISABLE_MSC_WARNINGS_PUSH(warnings)
Definition Conf.hpp:21
#define DXFCPP_TRACE_ISOLATES
Definition Debug.hpp:19
#define DXFCPP_DEBUG
Definition Debug.hpp:15
#define DXFCPP_TRACE_LISTS
Definition Debug.hpp:22
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_with_properties(dxfc_dxendpoint_builder_t builder, const dxfc_dxendpoint_property_t **properties, size_t size)
Sets all supported properties from the provided properties object.
Definition DXEndpoint.cpp:700
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_password(dxfc_dxendpoint_t endpoint, const char *password)
Changes password for this endpoint.
Definition DXEndpoint.cpp:943
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_publisher(dxfc_dxendpoint_t endpoint, DXFC_OUT dxfc_dxpublisher_t *publisher)
Definition DXEndpoint.cpp:1133
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_supports_property(dxfc_dxendpoint_builder_t builder, const char *key, DXFC_OUT int *supports)
Checks if a property is supported.
Definition DXEndpoint.cpp:727
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_add_state_change_listener(dxfc_dxendpoint_t endpoint, dxfc_dxendpoint_state_change_listener listener)
Adds listener that is notified about changes in state property.
Definition DXEndpoint.cpp:1079
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_disconnect(dxfc_dxendpoint_t endpoint)
Terminates all remote network connections.
Definition DXEndpoint.cpp:994
#define DXFCPP_EXPORT
Definition api.h:35
void * dxfc_dxendpoint_builder_t
The dxFeed endpoint's builder handle.
Definition api.h:207
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_close_and_await_termination(dxfc_dxendpoint_t endpoint)
Closes this endpoint and wait until all pending data processing tasks are completed.
Definition DXEndpoint.cpp:892
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_await_not_connected(dxfc_dxendpoint_t endpoint)
Waits while this endpoint state becomes NOT_CONNECTED or CLOSED.
Definition DXEndpoint.cpp:1045
dxfc_dxendpoint_state_t
Represents the current state of endpoint.
Definition api.h:149
@ DXFC_DXENDPOINT_STATE_CLOSED
Endpoint was closed.
Definition api.h:169
@ DXFC_DXENDPOINT_STATE_NOT_CONNECTED
Endpoint was created by is not connected to remote endpoints.
Definition api.h:153
@ DXFC_DXENDPOINT_STATE_CONNECTING
The connect function was called to establish connection to remove endpoint, but connection is not act...
Definition api.h:159
@ DXFC_DXENDPOINT_STATE_CONNECTED
The connection to remote endpoint is established.
Definition api.h:164
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_instance(void *user_data, DXFC_OUT dxfc_dxendpoint_t *endpoint)
Returns a default application-wide singleton instance of dxFeed endpoint with a FEED role.
Definition DXEndpoint.cpp:785
#define DXFC_OUT
Definition api.h:17
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_state(dxfc_dxendpoint_t endpoint, DXFC_OUT dxfc_dxendpoint_state_t *state)
Returns the state of this endpoint.
Definition DXEndpoint.cpp:1062
void * dxfc_dxendpoint_t
The dxFeed endpoint handle.
Definition api.h:198
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_with_property(dxfc_dxendpoint_builder_t builder, const char *key, const char *value)
Sets the specified property.
Definition DXEndpoint.cpp:683
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_free(dxfc_dxendpoint_builder_t builder)
Removes a builder from the registry.
Definition DXEndpoint.cpp:773
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_connect(dxfc_dxendpoint_t endpoint, const char *address)
Connects to the specified remote address.
Definition DXEndpoint.cpp:960
dxfc_error_code_t
List of error codes.
Definition api.h:49
@ DXFC_EC_ERROR
The error returned if the current operation cannot be completed.
Definition api.h:60
@ DXFC_EC_SUCCESS
OK.
Definition api.h:53
@ DXFC_EC_G_ERR
dxFeed Graal Native API error.
Definition api.h:57
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_remove_state_change_listener(dxfc_dxendpoint_t endpoint, dxfc_dxendpoint_state_change_listener listener)
Removes listener that is notified about changes in state property.
Definition DXEndpoint.cpp:1105
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_with_name(dxfc_dxendpoint_builder_t builder, const char *name)
Changes name that is used to distinguish multiple endpoints in the same process (GraalVM Isolate) in ...
Definition DXEndpoint.cpp:667
DXFCPP_EXPORT dxfc_error_code_t dxfc_system_set_property(const char *key, const char *value)
Sets the system property indicated by the specified key.
Definition System.cpp:68
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_build(dxfc_dxendpoint_builder_t builder, void *user_data, DXFC_OUT dxfc_dxendpoint_t *endpoint)
Builds the new dxFeed endpoint instance.
Definition DXEndpoint.cpp:744
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_feed(dxfc_dxendpoint_t endpoint, DXFC_OUT dxfc_dxfeed_t *feed)
Definition DXEndpoint.cpp:1128
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_await_processed(dxfc_dxendpoint_t endpoint)
Waits until this endpoint stops processing data (becomes quiescent).
Definition DXEndpoint.cpp:1028
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_close(dxfc_dxendpoint_t endpoint)
Closes this endpoint.
Definition DXEndpoint.cpp:875
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_new_builder(DXFC_OUT dxfc_dxendpoint_builder_t *builder)
Creates new dxFeed endpoint's builder instance.
Definition DXEndpoint.cpp:634
void(* dxfc_dxendpoint_state_change_listener)(dxfc_dxendpoint_state_t old_state, dxfc_dxendpoint_state_t new_state, void *user_data)
The endpoint current state change listener.
Definition api.h:178
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_reconnect(dxfc_dxendpoint_t endpoint)
Terminates all established network connections and initiates connecting again with the same address.
Definition DXEndpoint.cpp:977
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_role(dxfc_dxendpoint_t endpoint, DXFC_OUT dxfc_dxendpoint_role_t *role)
Returns the role of this endpoint.
Definition DXEndpoint.cpp:909
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_user(dxfc_dxendpoint_t endpoint, const char *user)
Changes username for this endpoint.
Definition DXEndpoint.cpp:926
DXFCPP_EXPORT dxfc_error_code_t dxfc_system_get_property(const char *key, DXFC_OUT char *buffer, size_t buffer_size)
Gets the system property indicated by the specified key.
dxfc_dxendpoint_role_t
Represents the role of endpoint that was specified during its creation.
Definition api.h:89
@ DXFC_DXENDPOINT_ROLE_PUBLISHER
PUBLISHER endpoint connects to the remote publisher hub (also known as multiplexor) or creates a publ...
Definition api.h:127
@ DXFC_DXENDPOINT_ROLE_STREAM_FEED
STREAM_FEED endpoint is similar to DXFC_DXENDPOINT_ROLE_FEED and also connects to the remote data fee...
Definition api.h:116
@ DXFC_DXENDPOINT_ROLE_FEED
FEED endpoint connects to the remote data feed provider and is optimized for real-time or delayed dat...
Definition api.h:99
@ DXFC_DXENDPOINT_ROLE_STREAM_PUBLISHER
STREAM_PUBLISHER endpoint is similar to DXFC_DXENDPOINT_ROLE_PUBLISHER and also connects to the remot...
Definition api.h:136
@ DXFC_DXENDPOINT_ROLE_LOCAL_HUB
LOCAL_HUB endpoint is a local hub without ability to establish network connections.
Definition api.h:143
@ DXFC_DXENDPOINT_ROLE_ON_DEMAND_FEED
ON_DEMAND_FEED endpoint is similar to DXFC_DXENDPOINT_ROLE_FEED, but it is designed to be used with d...
Definition api.h:107
void * dxfc_dxpublisher_t
The dxFeed publisher handle.
Definition api.h:217
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_create(void *user_data, DXFC_OUT dxfc_dxendpoint_t *endpoint)
Creates an endpoint with FEED role.
Definition DXEndpoint.cpp:830
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_get_instance2(dxfc_dxendpoint_role_t role, void *user_data, DXFC_OUT dxfc_dxendpoint_t *endpoint)
Returns a default application-wide singleton instance of DXEndpoint for a specific role.
Definition DXEndpoint.cpp:807
void * dxfc_dxfeed_t
The dxFeed handle.
Definition api.h:212
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_builder_with_role(dxfc_dxendpoint_builder_t builder, dxfc_dxendpoint_role_t role)
Sets role for the created dxFeed endpoint.
Definition DXEndpoint.cpp:650
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_create2(dxfc_dxendpoint_role_t role, void *user_data, DXFC_OUT dxfc_dxendpoint_t *endpoint)
Creates an endpoint with a specified role.
Definition DXEndpoint.cpp:852
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_free(dxfc_dxendpoint_t endpoint)
Removes the dxFeed endpoint from the registry.
Definition DXEndpoint.cpp:1138
DXFCPP_EXPORT dxfc_error_code_t dxfc_dxendpoint_disconnect_and_clear(dxfc_dxendpoint_t endpoint)
Terminates all remote network connections and clears stored data.
Definition DXEndpoint.cpp:1011
The enumeration type that provides additional information about the dxFeed Graal C++-API event type.
Definition EventTypeEnum.hpp:21
bool isTimeSeries() const noexcept
Definition EventTypeEnum.hpp:174
const std::string & getClassName() const &noexcept
Definition EventTypeEnum.hpp:117
bool isLasting() const noexcept
Definition EventTypeEnum.hpp:160
bool isOnlyIndexed() const noexcept
Definition EventTypeEnum.hpp:181
bool isIndexed() const noexcept
Definition EventTypeEnum.hpp:167
std::uint32_t getId() const noexcept
Definition EventTypeEnum.hpp:103
bool isMarket() const noexcept
Definition EventTypeEnum.hpp:188
const std::string & getName() const &noexcept
Definition EventTypeEnum.hpp:110
Source identifier for IndexedEvent.
Definition IndexedEventSource.hpp:22
static void freeGraal(void *graalNative)
Releases the memory occupied by the dxFeed Graal SDK structure (recursively if necessary).
Definition IndexedEventSource.cpp:21
const std::string & name() const noexcept
Returns the string representation of the object.
Definition IndexedEventSource.hpp:90
static IndexedEventSource fromGraal(void *graalNative)
Creates an object of the current type and fills it with data from the the dxFeed Graal SDK structure.
Definition IndexedEventSource.cpp:32
static const IndexedEventSource DEFAULT
The default source with zero identifier for all events that do not support multiple sources.
Definition IndexedEventSource.hpp:13
std::int32_t id() const noexcept
Returns the source identifier.
Definition IndexedEventSource.hpp:81
virtual void * toGraal() const
Allocates memory for the dxFeed Graal SDK structure (recursively if necessary).
Definition IndexedEventSource.cpp:15
std::string toString() const
Returns the string representation of the object.
Definition IndexedEventSource.hpp:99
IndexedEventSource(std::int32_t id, std::string name) noexcept
Creates the new IndexedEvent's source by id and name.
Definition IndexedEventSource.hpp:73
static const OrderSource GLBX
CME Globex.
Definition OrderSource.hpp:307
static const OrderSource smfe
Small Exchange.
Definition OrderSource.hpp:371
static const OrderSource bzx
Bats BZX Exchange.
Definition OrderSource.hpp:235
static const OrderSource DEX
Direct-Edge EDGX Exchange.
Definition OrderSource.hpp:202
static const OrderSource NTV
NASDAQ Total View.
Definition OrderSource.hpp:138
static const OrderSource AGGREGATE_ASK
Ask side of an aggregate order book (futures depth and NASDAQ Level II).
Definition OrderSource.hpp:123
static const OrderSource & valueOf(std::int32_t sourceId)
Returns order source for the specified source identifier.
Definition OrderSource.cpp:178
static const OrderSource ESPD
NASDAQ eSpeed.
Definition OrderSource.hpp:162
static const OrderSource CFE
CBOE Futures Exchange.
Definition OrderSource.hpp:347
static const OrderSource ntv
NASDAQ Total View.
Definition OrderSource.hpp:146
static const OrderSource ICE
Intercontinental Exchange.
Definition OrderSource.hpp:178
static const OrderSource BZX
Bats BZX Exchange.
Definition OrderSource.hpp:227
static const OrderSource C2OX
CBOE Options C2 Exchange.
Definition OrderSource.hpp:355
static const OrderSource REGIONAL_ASK
Ask side of a regional Quote.
Definition OrderSource.hpp:111
static const OrderSource REGIONAL_BID
Bid side of a regional Quote.
Definition OrderSource.hpp:104
static const OrderSource ABE
ABE (abe.io) exchange.
Definition OrderSource.hpp:291
static const OrderSource CEUX
Bats Europe DXE Exchange.
Definition OrderSource.hpp:259
static const OrderSource OCEA
Blue Ocean Technologies Alternative Trading System.
Definition OrderSource.hpp:403
static const OrderSource AGGREGATE_BID
Bid side of an aggregate order book (futures depth and NASDAQ Level II).
Definition OrderSource.hpp:117
static const OrderSource BXTR
Bats Europe TRF.
Definition OrderSource.hpp:267
static const OrderSource dex
Direct-Edge EDGX Exchange.
Definition OrderSource.hpp:211
static const OrderSource cedx
Cboe European Derivatives.
Definition OrderSource.hpp:444
static const OrderSource COMPOSITE_ASK
Ask side of a composite Quote.
Definition OrderSource.hpp:97
static const OrderSource XNFI
NASDAQ Fixed Income.
Definition OrderSource.hpp:170
static const OrderSource iex
Investors exchange.
Definition OrderSource.hpp:379
static const OrderSource xeur
Eurex Exchange.
Definition OrderSource.hpp:339
static const OrderSource CEDX
Cboe European Derivatives.
Definition OrderSource.hpp:436
static const OrderSource ISE
International Securities Exchange.
Definition OrderSource.hpp:186
static const OrderSource DEA
Direct-Edge EDGA Exchange.
Definition OrderSource.hpp:194
static const OrderSource glbx
CME Globex.
Definition OrderSource.hpp:315
static const OrderSource BI20
Borsa Istanbul Exchange.
Definition OrderSource.hpp:283
static const OrderSource BYX
Bats BYX Exchange.
Definition OrderSource.hpp:219
static const OrderSource FAIR
FAIR (FairX) exchange.
Definition OrderSource.hpp:299
static const OrderSource BATE
Bats Europe BXE Exchange.
Definition OrderSource.hpp:243
static const OrderSource pink
Pink Sheets.
Definition OrderSource.hpp:412
static const OrderSource DEFAULT
Default source for publishing custom order books.
Definition OrderSource.hpp:130
static const OrderSource NFX
NASDAQ Futures Exchange.
Definition OrderSource.hpp:154
static const OrderSource memx
Members Exchange.
Definition OrderSource.hpp:395
static bool isSpecialSourceId(std::int32_t sourceId) noexcept
Determines whether specified source identifier refers to special order source.
Definition OrderSource.cpp:174
static const OrderSource IST
Borsa Istanbul Exchange.
Definition OrderSource.hpp:275
static const OrderSource ARCA
NYSE Arca traded securities.
Definition OrderSource.hpp:420
static const OrderSource CHIX
Bats Europe CXE Exchange.
Definition OrderSource.hpp:251
static const OrderSource & valueOf(const std::string &name)
Returns order source for the specified source name.
Definition OrderSource.cpp:192
static const OrderSource ERIS
Eris Exchange group of companies.
Definition OrderSource.hpp:323
static const OrderSource XEUR
Eurex Exchange.
Definition OrderSource.hpp:331
static const OrderSource MEMX
Members Exchange.
Definition OrderSource.hpp:387
static const OrderSource COMPOSITE_BID
Bid side of a composite Quote.
Definition OrderSource.hpp:90
static const OrderSource arca
NYSE Arca traded securities.
Definition OrderSource.hpp:428
static const OrderSource SMFE
Small Exchange.
Definition OrderSource.hpp:363
Base abstract class for all dxFeed C++ API entities.
Definition Entity.hpp:13
virtual ~Entity() noexcept=default
The default virtual d-tor.
bool isOrderSource() const noexcept
Definition EventSourceWrapper.hpp:242
std::unique_ptr< void, decltype(&EventSourceWrapper::freeGraal)> toGraalUnique() const noexcept
Allocates memory for the dxFeed Graal SDK structure (recursively if necessary).
Definition EventSourceWrapper.hpp:200
std::string toStringUnderlying() const
Returns a string representation of the underlying object.
Definition EventSourceWrapper.hpp:224
static void freeGraal(void *graalNative)
Releases the memory occupied by the dxFeed Graal SDK structure (recursively if necessary).
Definition EventSourceWrapper.hpp:163
std::string toString() const
Returns a string representation of the current object.
Definition EventSourceWrapper.hpp:209
void * toGraal() const noexcept
Allocates memory for the dxFeed Graal SDK structure (recursively if necessary).
Definition EventSourceWrapper.hpp:184
static EventSourceWrapper fromGraal(void *graalNative)
Creates an object of the current type and fills it with data from the the dxFeed Graal SDK structure.
Definition EventSourceWrapper.cpp:40
const DataType & getData() const noexcept
Definition EventSourceWrapper.hpp:266
EventSourceWrapper(const IndexedEventSource &data) noexcept
Constructs a wrapper from IndexedEventSource.
Definition EventSourceWrapper.hpp:145
bool isIndexedEventSource() const noexcept
Definition EventSourceWrapper.hpp:235
std::optional< IndexedEventSource > asIndexedEventSource() const noexcept
Definition EventSourceWrapper.hpp:250
std::optional< OrderSource > asOrderSource() const noexcept
Definition EventSourceWrapper.hpp:259
EventSourceWrapper(const OrderSource &data) noexcept
Constructs a wrapper from OrderSource.
Definition EventSourceWrapper.hpp:153
Event type parametrized by a symbol.
Definition EventType.hpp:116
virtual const std::optional< Symbol > & getEventSymbolOpt() const &noexcept=0
Returns event symbol that identifies this event type in subscription.
virtual void setEventSymbol(const Symbol &eventSymbol) noexcept=0
Changes event symbol that identifies this event type in subscription.
virtual const Symbol & getEventSymbol() const &noexcept=0
Returns event symbol that identifies this event type in subscription.
Marks all event types that can be received via dxFeed API.
Definition EventType.hpp:31
std::string toString() const override
Returns a string representation of the current object.
Definition EventType.hpp:89
virtual std::int64_t getEventTime() const noexcept
Returns time when event was created or zero when time is not available.
Definition EventType.hpp:54
virtual void assign(std::shared_ptr< EventType > event)
Replaces the contents of the event.
Definition EventType.hpp:84
virtual void * toGraal() const =0
Allocates memory for the dxFeed Graal SDK structure (recursively if necessary).
virtual void setEventTime(std::int64_t) noexcept
Changes event creation time.
Definition EventType.hpp:66
The wrapper over CEntryPointErrorsEnum, the error code returned by GraalVM.
Definition GraalException.hpp:22
GraalException(CEntryPointErrorsEnum entryPointErrorsEnum)
Constructs an exception.
Definition GraalException.cpp:10
void handle(ArgTypes... args)
Calls the listeners and pass the args to them.
Definition Handler.hpp:123
std::size_t add(ListenerType &&listener)
Adds the listener to "main" group.
Definition Handler.hpp:157
std::size_t operator%=(ListenerType &&listener)
Adds the low priority listener (to the "low priority" group).
Definition Handler.hpp:209
std::size_t operator+=(ListenerType &&listener)
Adds the listener to "main" group.
Definition Handler.hpp:198
void operator()(ArgTypes... args)
Calls the listeners and pass the ars to them.
Definition Handler.hpp:147
Handler(std::size_t mainFuturesSize=MAIN_FUTURES_DEFAULT_SIZE) noexcept
Creates the new handler by specified size of circular buffer of futures.
Definition Handler.hpp:85
void operator-=(std::size_t id)
Removes a listener by the id.
Definition Handler.hpp:237
std::size_t addLowPriority(ListenerType &&listener)
Adds the low priority listener (to the "low priority" group) It will be called after the "main" liste...
Definition Handler.hpp:178
void remove(std::size_t id)
Removes a listener by the id.
Definition Handler.hpp:218
A helper class needed to construct smart pointers to objects, and does not allow explicit constructio...
Definition SharedEntity.hpp:89
static auto createShared(Args &&...args)
Creates smart pointer to object.
Definition SharedEntity.hpp:103
A runtime axception with stacktrace.
Definition RuntimeException.hpp:20
RuntimeException(const StringLikeWrapper &message, const StringLikeWrapper &additionalStackTrace="")
Constructs a runtime exception.
Definition RuntimeException.cpp:71
const std::string & getStackTrace() const &
Definition RuntimeException.cpp:85
Base abstract "shared entity" class. Has some helpers for dynamic polymorphism.
Definition SharedEntity.hpp:21
virtual std::string toString() const
Returns a string representation of the current object.
Definition SharedEntity.hpp:78
std::shared_ptr< T > sharedAs() const noexcept
Returns a pointer to the current object wrapped in a smart pointer to type T.
Definition SharedEntity.hpp:69
std::shared_ptr< T > sharedAs() noexcept
Returns a pointer to the current object wrapped in a smart pointer to type T.
Definition SharedEntity.hpp:56
bool is() const noexcept
Checks that pointer to the current type could be converted to type T* In other words: whether type T ...
Definition SharedEntity.hpp:35
std::size_t operator+=(ListenerType &&listener)
Adds the listener to "main" group.
Definition Handler.hpp:378
void remove(std::size_t id)
Removes a listener by the id.
Definition Handler.hpp:398
void handle(ArgTypes... args)
Calls the listeners and pass the args to them.
Definition Handler.hpp:316
void operator()(ArgTypes... args)
Calls the listeners and pass the ars to them.
Definition Handler.hpp:327
SimpleHandler() noexcept=default
Creates the new handler.
std::size_t addLowPriority(ListenerType &&listener)
Adds the low priority listener (to the "low priority" group) It will be called after the "main" liste...
Definition Handler.hpp:358
void operator-=(std::size_t id)
Removes a listener by the id.
Definition Handler.hpp:417
std::size_t operator%=(ListenerType &&listener)
Adds the low priority listener (to the "low priority" group).
Definition Handler.hpp:389
std::size_t add(ListenerType &&listener)
Adds the listener to "main" group.
Definition Handler.hpp:337
Universal functional object that allows searching std::unordered_map for string-like keys.
Definition Common.hpp:911
A simple wrapper around strings or something similar to strings to reduce the amount of code for meth...
Definition Common.hpp:794
Utility class for parsing and formatting dates and times in ISO-compatible format.
Definition TimeFormat.hpp:29
std::string format(std::int64_t timestamp) const
Converts timestamp into string according to the format.
Definition TimeFormat.cpp:55
static const TimeFormat GMT
An instance of TimeFormat that corresponds to GMT timezone as returned by TimeZone::getTimeZone("GMT"...
Definition TimeFormat.hpp:41
std::int64_t parse(const StringLikeWrapper &value) const
Reads Date from String and returns timestamp.
Definition TimeFormat.cpp:49
static const TimeFormat DEFAULT
An instance of TimeFormat that corresponds to default timezone as returned by TimeZone::getDefault() ...
Definition TimeFormat.hpp:33
The simple key-value structure that represents an endpoint's property.
Definition api.h:184
const char * key
The property's key.
Definition api.h:186
const char * value
The property's value.
Definition api.h:188