|
30 | 30 | #include "proton/receiver_options.hpp" |
31 | 31 | #include "proton/sender.hpp" |
32 | 32 | #include "proton/sender_options.hpp" |
| 33 | +#include "proton/target_options.hpp" |
33 | 34 | #include "proton/session.hpp" |
34 | 35 | #include "proton/tracker.hpp" |
35 | 36 | #include "proton/transport.hpp" |
@@ -69,6 +70,11 @@ void on_link_flow(messaging_handler& handler, pn_event_t* event) { |
69 | 70 | // TODO: process session flow data, if no link-specific data, just return. |
70 | 71 | if (!lnk) return; |
71 | 72 | int state = pn_link_state(lnk); |
| 73 | + if (pn_terminus_get_type(pn_link_remote_target(lnk))==PN_COORDINATOR) { |
| 74 | + std::cout << " on_link_flow, type: PN_COORDINATOR" << std::endl; |
| 75 | + return; |
| 76 | + |
| 77 | + } |
72 | 78 | if ((state&PN_LOCAL_ACTIVE) && (state&PN_REMOTE_ACTIVE)) { |
73 | 79 | link_context& lctx = link_context::get(lnk); |
74 | 80 | if (pn_link_is_sender(lnk)) { |
@@ -115,8 +121,14 @@ void on_delivery(messaging_handler& handler, pn_event_t* event) { |
115 | 121 | pn_delivery_t *dlv = pn_event_delivery(event); |
116 | 122 | link_context& lctx = link_context::get(lnk); |
117 | 123 | Tracing& ot = Tracing::getTracing(); |
| 124 | + if (pn_terminus_get_type(pn_link_remote_target(lnk))==PN_COORDINATOR) { |
| 125 | + std::cout<< " on_delivery: COOORINDATOR.. " << &handler << std::endl; |
| 126 | + tracker t(make_wrapper<tracker>(dlv)); |
| 127 | + std::cout<< " on_delivery: COOORINDATOR.. tracker" << &t << std::endl; |
| 128 | + handler.on_tracker_settle(t); |
| 129 | + } |
118 | 130 |
|
119 | | - if (pn_link_is_receiver(lnk)) { |
| 131 | + else if (pn_link_is_receiver(lnk)) { |
120 | 132 | delivery d(make_wrapper<delivery>(dlv)); |
121 | 133 | if (pn_delivery_aborted(dlv)) { |
122 | 134 | pn_delivery_settle(dlv); |
@@ -274,23 +286,73 @@ void on_link_local_open(messaging_handler& handler, pn_event_t* event) { |
274 | 286 |
|
275 | 287 | void on_link_remote_open(messaging_handler& handler, pn_event_t* event) { |
276 | 288 | auto lnk = pn_event_link(event); |
277 | | - // Currently don't implement (transaction) coordinator |
| 289 | + int type = pn_terminus_get_type(pn_link_remote_target(lnk)); |
| 290 | + std::cout << " on_link_remote_open, type:" << type << std::endl; |
278 | 291 | if (pn_terminus_get_type(pn_link_remote_target(lnk))==PN_COORDINATOR) { |
279 | | - auto error = pn_link_condition(lnk); |
280 | | - pn_condition_set_name(error, "amqp:not-implemented"); |
281 | | - pn_link_close(lnk); |
| 292 | + auto cond = pn_link_condition(lnk); |
| 293 | + if (pn_condition_is_set(cond)) { |
| 294 | + std::cout<<" Got condition on_link_remote_open(.PN_COORDINATOR): " |
| 295 | + << pn_event_type_name(pn_event_type(event)) << " " |
| 296 | + << pn_condition_get_name(cond) << " " |
| 297 | + << pn_condition_get_description(cond) << std::endl; |
| 298 | + |
| 299 | + pn_condition_set_name(cond, "amqp:on_link_remote_open:FAILED"); |
| 300 | + pn_link_close(lnk); |
| 301 | + return; |
| 302 | + } |
| 303 | + std::cout<<" IN on_link_remote_open(.PN_COORDINATOR) success " << std::endl; |
| 304 | + |
| 305 | + // WHY??? |
| 306 | + // pn_terminus_copy(pn_link_source(lnk), pn_link_remote_source(lnk)); |
| 307 | + // pn_terminus_copy(pn_link_target(lnk), pn_link_remote_target(lnk)); |
| 308 | + |
| 309 | + // We need a new class? |
| 310 | + // auto coordinator = pn_link_remote_target(lnk); |
| 311 | + |
| 312 | + |
| 313 | + // proton::target_options to; |
| 314 | + // std::vector<symbol> cap = {proton::symbol("amqp:local-transactions")}; |
| 315 | + // to.capabilities(cap); |
| 316 | + // to.type(PN_COORDINATOR); |
| 317 | + |
| 318 | + // proton::receiver_options ro; |
| 319 | + // ro.name("txn-ctrl"); |
| 320 | + // ro.target(to); |
| 321 | + // ro.handler(handler); |
| 322 | + // receiver r(make_wrapper<receiver>(lnk)); |
| 323 | + |
| 324 | + // proton::receiver rcv = r.connection().open_receiver("does not matter", ro); |
| 325 | + std::cout<<" IN on_link_remote_open(.PN_COORDINATOR) have handler " << &handler << std::endl; |
| 326 | + |
| 327 | + // handler.on_receiver_open(rcv); |
| 328 | + // credit_topup(lnk); |
| 329 | + |
| 330 | + // pn_delivery_t *dlv = pn_event_delivery(event); |
| 331 | + // tracker t(make_wrapper<tracker>(dlv)); |
| 332 | + |
| 333 | + // // sender s(make_wrapper<sender>(lnk)); |
| 334 | + // handler.on_tracker_settle(t); |
| 335 | + // TODO: find what to do... |
| 336 | + // HAHA.. treating coordinator like sender... |
| 337 | + // sender s(make_wrapper<sender>(lnk)); |
| 338 | + // handler.on_sender_open(s); |
| 339 | + // pn_link_close(lnk); |
282 | 340 | return; |
283 | 341 | } |
284 | 342 | if (pn_link_state(lnk) & PN_LOCAL_UNINIT) { // Incoming link |
285 | 343 | // Copy source and target from remote end. |
| 344 | + std::cout<<" Inside on_link_remote_open() .. PN_LOCAL_UNINIT " << std::endl; |
| 345 | + |
286 | 346 | pn_terminus_copy(pn_link_source(lnk), pn_link_remote_source(lnk)); |
287 | 347 | pn_terminus_copy(pn_link_target(lnk), pn_link_remote_target(lnk)); |
288 | 348 | } |
289 | 349 | if (pn_link_is_receiver(lnk)) { |
| 350 | + std::cout<<" Inside on_link_remote_open() .. pn_link_is_receiver " << std::endl; |
290 | 351 | receiver r(make_wrapper<receiver>(lnk)); |
291 | 352 | handler.on_receiver_open(r); |
292 | 353 | credit_topup(lnk); |
293 | 354 | } else { |
| 355 | + std::cout<<" Inside on_link_remote_open() .. sender " << std::endl; |
294 | 356 | sender s(make_wrapper<sender>(lnk)); |
295 | 357 | handler.on_sender_open(s); |
296 | 358 | } |
|
0 commit comments