All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.scalecube.cluster.metadata.GetMetadataResponse Maven / Gradle / Ivy

There is a newer version: 2.7.0.RC1
Show newest version
package io.scalecube.cluster.metadata;

import io.scalecube.cluster.Member;
import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.nio.ByteBuffer;
import java.util.StringJoiner;

/**
 * DTO class. Stands for response for preceding remote request on getting metadata in remote
 * MetadataStore.
 */
final class GetMetadataResponse implements Externalizable {

  private static final long serialVersionUID = 1L;

  /** Target member with metadata. */
  private Member member;

  /** Cluster member metadata. */
  private ByteBuffer metadata;

  public GetMetadataResponse() {}

  GetMetadataResponse(Member member, ByteBuffer metadata) {
    this.member = member;
    this.metadata = metadata;
  }

  Member getMember() {
    return member;
  }

  ByteBuffer getMetadata() {
    return metadata;
  }

  @Override
  public void writeExternal(ObjectOutput out) throws IOException {
    // member
    out.writeObject(member);
    // metadata
    byte[] metadataBytes = metadata.array();
    out.writeInt(metadataBytes.length);
    out.write(metadataBytes);
  }

  @Override
  public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
    // member
    member = (Member) in.readObject();
    // metadata
    int metadataSize = in.readInt();
    byte[] metadataBytes = new byte[metadataSize];
    in.readFully(metadataBytes);
    metadata = ByteBuffer.wrap(metadataBytes);
  }

  @Override
  public String toString() {
    return new StringJoiner(", ", GetMetadataResponse.class.getSimpleName() + "[", "]")
        .add("member=" + member)
        .add("metadata(b=" + metadata.remaining() + ")")
        .toString();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy