|
27 | 27 | import java.util.concurrent.atomic.AtomicInteger; |
28 | 28 | import java.util.function.Consumer; |
29 | 29 | import java.util.function.Function; |
30 | | -import java.util.function.Supplier; |
31 | 30 | import javax.annotation.Nullable; |
32 | | - |
33 | 31 | import org.jctools.maps.NonBlockingHashMapLong; |
34 | 32 | import org.reactivestreams.Publisher; |
35 | 33 | import org.reactivestreams.Subscriber; |
@@ -185,7 +183,7 @@ public Flux<Payload> requestStream(Payload payload) { |
185 | 183 |
|
186 | 184 | @Override |
187 | 185 | public Flux<Payload> requestChannel(Publisher<Payload> payloads) { |
188 | | - return handleChannel(Flux.from(payloads), FrameType.REQUEST_CHANNEL); |
| 186 | + return handleChannel(Flux.from(payloads)); |
189 | 187 | } |
190 | 188 |
|
191 | 189 | @Override |
@@ -289,108 +287,88 @@ private Mono<Payload> handleRequestResponse(final Payload payload) { |
289 | 287 | })); |
290 | 288 | } |
291 | 289 |
|
292 | | - private Flux<Payload> handleChannel(Flux<Payload> request, FrameType requestType) { |
| 290 | + private Flux<Payload> handleChannel(Flux<Payload> request) { |
293 | 291 | return started.thenMany( |
294 | 292 | Flux.defer( |
295 | | - new Supplier<Flux<Payload>>() { |
| 293 | + () -> { |
296 | 294 | final UnicastProcessor<Payload> receiver = UnicastProcessor.create(); |
297 | 295 | final int streamId = streamIdSupplier.nextStreamId(); |
298 | | - volatile @Nullable MonoProcessor<Void> subscribedRequests; |
299 | | - boolean firstRequest = true; |
300 | | - |
301 | | - boolean isValidToSendFrame() { |
302 | | - return contains(streamId) && !receiver.isDisposed(); |
303 | | - } |
304 | | - |
305 | | - void sendOneFrame(Frame frame) { |
306 | | - if (isValidToSendFrame()) { |
307 | | - sendProcessor.onNext(frame); |
308 | | - } |
309 | | - } |
310 | | - |
311 | | - @Override |
312 | | - public Flux<Payload> get() { |
313 | | - return receiver |
314 | | - .doOnRequest( |
315 | | - l -> { |
316 | | - boolean _firstRequest = false; |
317 | | - synchronized (RSocketClient.this) { |
318 | | - if (firstRequest) { |
319 | | - _firstRequest = true; |
320 | | - firstRequest = false; |
321 | | - } |
322 | | - } |
| 296 | + final AtomicBoolean firstRequest = new AtomicBoolean(true); |
323 | 297 |
|
324 | | - if (_firstRequest) { |
325 | | - AtomicBoolean firstPayload = new AtomicBoolean(true); |
326 | | - Flux<Frame> requestFrames = |
327 | | - request |
328 | | - .transform( |
329 | | - f -> { |
330 | | - LimitableRequestPublisher<Payload> wrapped = |
331 | | - LimitableRequestPublisher.wrap(f); |
332 | | - // Need to set this to one for first the frame |
333 | | - wrapped.increaseRequestLimit(1); |
334 | | - senders.put(streamId, wrapped); |
335 | | - receivers.put(streamId, receiver); |
336 | | - |
337 | | - return wrapped; |
338 | | - }) |
339 | | - .map( |
340 | | - new Function<Payload, Frame>() { |
341 | | - |
342 | | - @Override |
343 | | - public Frame apply(Payload payload) { |
344 | | - final Frame requestFrame; |
345 | | - if (firstPayload.compareAndSet(true, false)) { |
346 | | - requestFrame = |
347 | | - Frame.Request.from( |
348 | | - streamId, requestType, payload, l); |
349 | | - } else { |
350 | | - requestFrame = |
351 | | - Frame.PayloadFrame.from( |
352 | | - streamId, FrameType.NEXT, payload); |
353 | | - } |
354 | | - payload.release(); |
355 | | - return requestFrame; |
356 | | - } |
357 | | - }) |
358 | | - .doOnComplete( |
359 | | - () -> { |
360 | | - if (FrameType.REQUEST_CHANNEL == requestType) { |
361 | | - sendOneFrame( |
362 | | - Frame.PayloadFrame.from( |
363 | | - streamId, FrameType.COMPLETE)); |
364 | | - if (firstPayload.get()) { |
365 | | - receiver.onComplete(); |
366 | | - } |
367 | | - } |
368 | | - }); |
369 | | - |
370 | | - requestFrames.subscribe( |
371 | | - sendProcessor::onNext, |
372 | | - t -> { |
373 | | - errorConsumer.accept(t); |
374 | | - receiver.dispose(); |
375 | | - }); |
376 | | - } else { |
377 | | - sendOneFrame(Frame.RequestN.from(streamId, l)); |
378 | | - } |
379 | | - }) |
380 | | - .doOnError(t -> sendOneFrame(Frame.Error.from(streamId, t))) |
381 | | - .doOnCancel( |
382 | | - () -> { |
383 | | - sendOneFrame(Frame.Cancel.from(streamId)); |
384 | | - if (subscribedRequests != null) { |
385 | | - subscribedRequests.cancel(); |
| 298 | + return receiver |
| 299 | + .doOnRequest( |
| 300 | + n -> { |
| 301 | + if (firstRequest.compareAndSet(true, false)) { |
| 302 | + final AtomicBoolean firstPayload = new AtomicBoolean(true); |
| 303 | + final Flux<Frame> requestFrames = |
| 304 | + request |
| 305 | + .transform( |
| 306 | + f -> { |
| 307 | + LimitableRequestPublisher<Payload> wrapped = |
| 308 | + LimitableRequestPublisher.wrap(f); |
| 309 | + // Need to set this to one for first the frame |
| 310 | + wrapped.increaseRequestLimit(1); |
| 311 | + senders.put(streamId, wrapped); |
| 312 | + receivers.put(streamId, receiver); |
| 313 | + |
| 314 | + return wrapped; |
| 315 | + }) |
| 316 | + .map( |
| 317 | + payload -> { |
| 318 | + final Frame requestFrame; |
| 319 | + if (firstPayload.compareAndSet(true, false)) { |
| 320 | + requestFrame = |
| 321 | + Frame.Request.from( |
| 322 | + streamId, FrameType.REQUEST_CHANNEL, payload, n); |
| 323 | + } else { |
| 324 | + requestFrame = |
| 325 | + Frame.PayloadFrame.from( |
| 326 | + streamId, FrameType.NEXT, payload); |
| 327 | + } |
| 328 | + payload.release(); |
| 329 | + return requestFrame; |
| 330 | + }) |
| 331 | + .doOnComplete( |
| 332 | + () -> { |
| 333 | + if (contains(streamId) && !receiver.isDisposed()) { |
| 334 | + sendProcessor.onNext( |
| 335 | + Frame.PayloadFrame.from( |
| 336 | + streamId, FrameType.COMPLETE)); |
| 337 | + } |
| 338 | + if (firstPayload.get()) { |
| 339 | + receiver.onComplete(); |
| 340 | + } |
| 341 | + }); |
| 342 | + |
| 343 | + requestFrames.subscribe( |
| 344 | + sendProcessor::onNext, |
| 345 | + t -> { |
| 346 | + errorConsumer.accept(t); |
| 347 | + receiver.dispose(); |
| 348 | + }); |
| 349 | + } else { |
| 350 | + if (contains(streamId) && !receiver.isDisposed()) { |
| 351 | + sendProcessor.onNext(Frame.RequestN.from(streamId, n)); |
386 | 352 | } |
387 | | - }) |
388 | | - .doFinally( |
389 | | - s -> { |
390 | | - receivers.remove(streamId); |
391 | | - senders.remove(streamId); |
392 | | - }); |
393 | | - } |
| 353 | + } |
| 354 | + }) |
| 355 | + .doOnError( |
| 356 | + t -> { |
| 357 | + if (contains(streamId) && !receiver.isDisposed()) { |
| 358 | + sendProcessor.onNext(Frame.Error.from(streamId, t)); |
| 359 | + } |
| 360 | + }) |
| 361 | + .doOnCancel( |
| 362 | + () -> { |
| 363 | + if (contains(streamId) && !receiver.isDisposed()) { |
| 364 | + sendProcessor.onNext(Frame.Cancel.from(streamId)); |
| 365 | + } |
| 366 | + }) |
| 367 | + .doFinally( |
| 368 | + s -> { |
| 369 | + receivers.remove(streamId); |
| 370 | + senders.remove(streamId); |
| 371 | + }); |
394 | 372 | })); |
395 | 373 | } |
396 | 374 |
|
|
0 commit comments