All Downloads are FREE. Search and download functionalities are using the official Maven repository.

reactor.groovy.config.StreamEventRouter Maven / Gradle / Ivy

The newest version!
package reactor.groovy.config;

import reactor.core.composable.Deferred;
import reactor.core.composable.Stream;
import reactor.event.Event;
import reactor.event.registry.Registration;
import reactor.event.routing.ConsumerFilteringEventRouter;
import reactor.event.routing.ConsumerInvoker;
import reactor.event.support.CallbackEvent;
import reactor.filter.Filter;
import reactor.function.Consumer;
import reactor.function.support.CancelConsumerException;

import java.util.List;

/**
 * @author Stephane Maldini
 */
public class StreamEventRouter extends ConsumerFilteringEventRouter {

	public static final String KEY_HEADER = "___key";

	private final Deferred, Stream>> stream;

	public StreamEventRouter(Filter filter, ConsumerInvoker consumerInvoker, Deferred,
			Stream>> stream) {
		super(filter, consumerInvoker);
		this.stream = stream;
	}

	@Override
	public void route(final Object key, final Event event,
	                  final List>>> consumers,
	                  final Consumer completionConsumer, final Consumer errorConsumer) {

		try {
			event.getHeaders().set(KEY_HEADER, key.toString());
		} catch (Exception e) {
			//ignore
		}

		stream.acceptEvent(new CallbackEvent>(
				event.getHeaders(),
				event,
				new Consumer>() {
					@Override
					public void accept(Event _event) {
						Event hydratedEvent = event.copy(_event != null ? _event.getData() : null);
						if (null != consumers) {
							for (Registration>> reg : getFilter().filter(consumers, key)) {
								if (reg.isCancelled() || reg.isPaused()) {
									continue;
								}
								try {
									if (null != reg.getSelector().getHeaderResolver()) {
										event.getHeaders().setAll(reg.getSelector().getHeaderResolver().resolve(key));
									}
									getConsumerInvoker().invoke(reg.getObject(), Void.TYPE, event);
								} catch (CancelConsumerException cancel) {
									reg.cancel();
								} catch (Throwable t) {
									if (null != hydratedEvent.getErrorConsumer()) {
										hydratedEvent.consumeError(t);
									} else if (null != errorConsumer) {
										errorConsumer.accept(t);
									}
									stream.accept(t);
								} finally {
									if (reg.isCancelAfterUse()) {
										reg.cancel();
									}
								}
							}
						}
						if (null != completionConsumer) {
							try {
								getConsumerInvoker().invoke(completionConsumer, Void.TYPE, hydratedEvent);
							} catch (Exception e) {
								if (null != errorConsumer) {
									errorConsumer.accept(e);
								}
								stream.accept(e);
							}
						}
					}
				}
		));
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy