io.vlingo.lattice.exchange.local.LocalExchange Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vlingo-lattice Show documentation
Show all versions of vlingo-lattice Show documentation
Tooling for reactive Domain-Driven Design projects that are highly concurrent. Includes compute grid, actor caching, spaces, cross-node cluster messaging, CQRS, and Event Sourcing support.
// Copyright © 2012-2020 VLINGO LABS. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.
package io.vlingo.lattice.exchange.local;
import io.vlingo.common.message.Message;
import io.vlingo.common.message.MessageQueue;
import io.vlingo.common.message.MessageQueueListener;
import io.vlingo.lattice.exchange.Covey;
import io.vlingo.lattice.exchange.Exchange;
import io.vlingo.lattice.exchange.Forwarder;
public class LocalExchange implements Exchange, MessageQueueListener {
private static final Object Channel = new Object();
private static final Object Connection = new Object();
private final MessageQueue queue;
private final Forwarder forwarder;
public LocalExchange(final MessageQueue queue) {
this.queue = queue;
queue.registerListener(this);
this.forwarder = new Forwarder();
}
@Override
public void close() {
queue.close(true);
}
@Override
@SuppressWarnings("unchecked")
public Object channel() {
return Channel;
}
@Override
@SuppressWarnings("unchecked")
public Object connection() {
return Connection;
}
@Override
public String name() {
return "LocalExchange";
}
@Override
public Exchange register(final Covey covey) {
forwarder.register(covey);
return this;
}
@Override
public void send(final L local) {
forwarder.forwardToSender(local);
}
@Override
final public void handleMessage(final Message message) throws Exception {
forwarder.forwardToReceiver(message);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy