2013-04-16 22:31:09 +02:00
|
|
|
/**
|
2017-01-04 17:37:10 +01:00
|
|
|
* Copyright (C) 2009-2017 Lightbend Inc. <http://www.lightbend.com>
|
2013-04-16 22:31:09 +02:00
|
|
|
*/
|
|
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
package jdocs.io.japi;
|
2013-04-16 22:31:09 +02:00
|
|
|
|
|
|
|
|
import java.net.InetSocketAddress;
|
|
|
|
|
|
|
|
|
|
import akka.actor.ActorRef;
|
|
|
|
|
import akka.actor.Props;
|
|
|
|
|
import akka.actor.SupervisorStrategy;
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
import akka.actor.AbstractActor;
|
2013-04-16 22:31:09 +02:00
|
|
|
import akka.event.Logging;
|
|
|
|
|
import akka.event.LoggingAdapter;
|
|
|
|
|
import akka.io.Tcp;
|
|
|
|
|
import akka.io.Tcp.Bind;
|
|
|
|
|
import akka.io.Tcp.Bound;
|
|
|
|
|
import akka.io.Tcp.Connected;
|
|
|
|
|
import akka.io.TcpMessage;
|
|
|
|
|
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
public class EchoManager extends AbstractActor {
|
2013-04-16 22:31:09 +02:00
|
|
|
|
|
|
|
|
final LoggingAdapter log = Logging
|
2017-03-16 09:30:00 +01:00
|
|
|
.getLogger(getContext().getSystem(), getSelf());
|
2013-04-16 22:31:09 +02:00
|
|
|
|
|
|
|
|
final Class<?> handlerClass;
|
|
|
|
|
|
|
|
|
|
public EchoManager(Class<?> handlerClass) {
|
|
|
|
|
this.handlerClass = handlerClass;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public SupervisorStrategy supervisorStrategy() {
|
|
|
|
|
return SupervisorStrategy.stoppingStrategy();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void preStart() throws Exception {
|
|
|
|
|
//#manager
|
2017-03-16 09:30:00 +01:00
|
|
|
final ActorRef tcpManager = Tcp.get(getContext().getSystem()).manager();
|
2013-04-16 22:31:09 +02:00
|
|
|
//#manager
|
|
|
|
|
tcpManager.tell(
|
2017-03-17 10:18:15 +01:00
|
|
|
TcpMessage.bind(getSelf(), new InetSocketAddress("localhost", 0), 100),
|
2017-03-16 09:30:00 +01:00
|
|
|
getSelf());
|
2013-04-16 22:31:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void postRestart(Throwable arg0) throws Exception {
|
|
|
|
|
// do not restart
|
2017-03-17 10:18:15 +01:00
|
|
|
getContext().stop(getSelf());
|
2013-04-16 22:31:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
public Receive createReceive() {
|
|
|
|
|
return receiveBuilder()
|
|
|
|
|
.match(Bound.class, msg -> {
|
|
|
|
|
log.info("listening on [{}]", msg.localAddress());
|
|
|
|
|
})
|
|
|
|
|
.match(Tcp.CommandFailed.class, failed -> {
|
|
|
|
|
if (failed.cmd() instanceof Bind) {
|
|
|
|
|
log.warning("cannot bind to [{}]", ((Bind) failed.cmd()).localAddress());
|
2017-03-17 10:18:15 +01:00
|
|
|
getContext().stop(getSelf());
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
} else {
|
|
|
|
|
log.warning("unknown command failed [{}]", failed.cmd());
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.match(Connected.class, conn -> {
|
|
|
|
|
log.info("received connection from [{}]", conn.remoteAddress());
|
2017-03-16 09:30:00 +01:00
|
|
|
final ActorRef connection = getSender();
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
final ActorRef handler = getContext().actorOf(
|
|
|
|
|
Props.create(handlerClass, connection, conn.remoteAddress()));
|
|
|
|
|
//#echo-manager
|
|
|
|
|
connection.tell(TcpMessage.register(handler,
|
|
|
|
|
true, // <-- keepOpenOnPeerClosed flag
|
2017-03-16 09:30:00 +01:00
|
|
|
true), getSelf());
|
improve AbstractActor, #21717
* Receive class that wraps PartialFunction, to avoid
scary scala types
* move AbstractActorContext to AbstractActor.ActorContext
* converting docs, many, many UntypedActor
* removing UntypedActor docs
* add unit test for ReceiveBuilder
* MiMa filters
* consistent use of getContext(), self(), sender()
* rename cross references
* migration guide
* skip samples for now
* improve match type safetyi, add matchUnchecked
* the `? extends P` caused code like this to compile:
`match(String.class, (Integer i) -> {})`
* added matchUnchecked, since it can still be useful (um, convenient)
to be able to do:
`matchUnchecked(List.class, (List<String> list) -> {})`
* eleminate some scala.Option
* preRestart
* findChild
* ActorIdentity.getActorRef
2016-12-13 10:59:29 +01:00
|
|
|
//#echo-manager
|
|
|
|
|
})
|
|
|
|
|
.build();
|
2013-04-16 22:31:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|