net.e6tech.elements.network.cluster.messaging.Destination Maven / Gradle / Ivy
/*
* Copyright 2015-2019 Futeh Kao
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.e6tech.elements.network.cluster.messaging;
import akka.actor.ActorRef;
import akka.actor.typed.DispatcherSelector;
import akka.actor.typed.javadsl.Behaviors;
import akka.cluster.pubsub.DistributedPubSub;
import akka.cluster.pubsub.DistributedPubSubMediator;
import net.e6tech.elements.common.actor.typed.Receptor;
import net.e6tech.elements.common.actor.typed.Typed;
import net.e6tech.elements.common.subscribe.Notice;
import net.e6tech.elements.common.subscribe.Subscriber;
import java.io.Serializable;
public class Destination extends Receptor {
private Subscriber subscriber;
public Destination(Subscriber subscriber) {
this.subscriber = subscriber;
}
@Override
public void initialize() {
ActorRef mediator = DistributedPubSub.lookup().get(untypedContext().system()).mediator();
mediator.tell(new DistributedPubSubMediator.Put(untypedRef()), untypedRef());
getContext().spawnAnonymous(Behaviors.receive(DistributedPubSubMediator.SubscribeAck.class)
.onMessage(DistributedPubSubMediator.SubscribeAck.class,
msg -> {
getSystem().log().info("subscribing to {}", msg.toString());
return Behaviors.same();
}).build());
}
@SuppressWarnings("unchecked")
@Typed
private void send(MessagingEvents.Send send) {
getContext().getSystem().dispatchers().lookup(DispatcherSelector.defaultDispatcher())
.execute(() -> subscriber.receive(new Notice(send.destination, (Serializable) send.message)));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy