- public static ReadData fromSerializable(Object serializable){
- ShardTransactionMessages.ReadData o = (ShardTransactionMessages.ReadData) serializable;
- return new ReadData(InstanceIdentifierUtils.fromSerializable(o.getInstanceIdentifierPathArguments()));
- }
+ @Override
+ public void processResponse(Object readResponse, SettableFuture<Optional<NormalizedNode<?, ?>>> returnFuture) {
+ if (ReadDataReply.isSerializedType(readResponse)) {
+ ReadDataReply reply = ReadDataReply.fromSerializable(readResponse);
+ returnFuture.set(Optional.<NormalizedNode<?, ?>>fromNullable(reply.getNormalizedNode()));
+ } else {
+ returnFuture.setException(new ReadFailedException("Invalid response reading data for path " + getPath()));
+ }
+ }
+
+ @Override
+ protected AbstractRead<Optional<NormalizedNode<?, ?>>> newInstance(short withVersion) {
+ return new ReadData(getPath(), withVersion);
+ }
+
+ public static ReadData fromSerializable(final Object serializable) {
+ Preconditions.checkArgument(serializable instanceof ReadData);
+ return (ReadData)serializable;
+ }
+
+ public static boolean isSerializedType(Object message) {
+ return message instanceof ReadData;
+ }