/*
* Copyright 2017 Red Hat, Inc.
*
* Red Hat licenses this file to you 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 io.vertx.ext.cluster.infinispan.impl;
import io.vertx.core.eventbus.impl.clustered.ClusterNodeInfo;
import io.vertx.core.net.impl.ServerID;
import org.infinispan.commons.marshall.Externalizer;
import org.infinispan.commons.marshall.SerializeWith;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Objects;
Author: Thomas Segismont
/**
* @author Thomas Segismont
*/
@SerializeWith(InfinispanClusterNodeInfo.InfinispanClusterNodeInfoExternalizer.class)
public class InfinispanClusterNodeInfo {
private final ClusterNodeInfo clusterNodeInfo;
public InfinispanClusterNodeInfo(ClusterNodeInfo clusterNodeInfo) {
Objects.requireNonNull(clusterNodeInfo);
this.clusterNodeInfo = clusterNodeInfo;
}
public ClusterNodeInfo getClusterNodeInfo() {
return clusterNodeInfo;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
InfinispanClusterNodeInfo that = (InfinispanClusterNodeInfo) o;
return clusterNodeInfo.equals(that.clusterNodeInfo);
}
@Override
public int hashCode() {
return clusterNodeInfo.hashCode();
}
public static class InfinispanClusterNodeInfoExternalizer implements Externalizer<InfinispanClusterNodeInfo> {
@Override
public void writeObject(ObjectOutput output, InfinispanClusterNodeInfo object) throws IOException {
output.writeUTF(object.clusterNodeInfo.nodeId);
output.writeInt(object.clusterNodeInfo.serverID.port);
output.writeUTF(object.clusterNodeInfo.serverID.host);
}
@Override
public InfinispanClusterNodeInfo readObject(ObjectInput input) throws IOException, ClassNotFoundException {
ClusterNodeInfo clusterNodeInfo = new ClusterNodeInfo(input.readUTF(), new ServerID(input.readInt(), input.readUTF()));
return new InfinispanClusterNodeInfo(clusterNodeInfo);
}
}
}