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

org.teamapps.universaldb.cluster.message.ClusterNodeStateInfo Maven / Gradle / Ivy

/*-
 * ========================LICENSE_START=================================
 * UniversalDB
 * ---
 * Copyright (C) 2014 - 2019 TeamApps.org
 * ---
 * 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.
 * =========================LICENSE_END==================================
 */
package org.teamapps.universaldb.cluster.message;

import org.teamapps.universaldb.cluster.ClusterNodeRole;
import org.teamapps.universaldb.cluster.ClusterNodeState;
import org.teamapps.universaldb.cluster.network.MessageType;

import java.nio.ByteBuffer;

public class ClusterNodeStateInfo implements ClusterMessage {

	private final int nodeId;
	private final int headNodeId;
	private final ClusterNodeRole operatingRole;
	private final ClusterNodeRole preferredRole;
	private final ClusterNodeState nodeState;
	private final int connectedNodesCount;
	private final int clusterQuorum;
	private final int electoralClusterNodes;
	private final int syncingWithNodeId;
	private final long syncingTransactionStarted;
	private final long lastTransactionId;
	private final long currentTransactionId;
	private final long transactionCount;

	private final byte[] data;

	public ClusterNodeStateInfo(int nodeId, int headNodeId, ClusterNodeRole operatingRole, ClusterNodeRole preferredRole, ClusterNodeState nodeState, int connectedNodesCount, int clusterQuorum, int electoralClusterNodes, int syncingWithNodeId, long syncingTransactionStarted, long lastTransactionId, long currentTransactionId, long transactionCount) {
		this.nodeId = nodeId;
		this.headNodeId = headNodeId;
		this.operatingRole = operatingRole;
		this.preferredRole = preferredRole;
		this.nodeState = nodeState;
		this.connectedNodesCount = connectedNodesCount;
		this.clusterQuorum = clusterQuorum;
		this.electoralClusterNodes = electoralClusterNodes;
		this.syncingWithNodeId = syncingWithNodeId;
		this.syncingTransactionStarted = syncingTransactionStarted;
		this.lastTransactionId = lastTransactionId;
		this.currentTransactionId = currentTransactionId;
		this.transactionCount = transactionCount;
		this.data = new byte[59];
		ByteBuffer buffer = ByteBuffer.wrap(data);
		buffer.putInt(nodeId);
		buffer.putInt(headNodeId);
		buffer.put((byte) operatingRole.getId());
		buffer.put((byte) preferredRole.getId());
		buffer.put((byte) nodeState.getId());
		buffer.putInt(connectedNodesCount);
		buffer.putInt(clusterQuorum);
		buffer.putInt(electoralClusterNodes);
		buffer.putInt(syncingWithNodeId);
		buffer.putLong(syncingTransactionStarted);
		buffer.putLong(lastTransactionId);
		buffer.putLong(currentTransactionId);
		buffer.putLong(transactionCount);
	}


	public ClusterNodeStateInfo(byte[] data) {
		this.data = data;
		ByteBuffer buffer = ByteBuffer.wrap(data);
		nodeId = buffer.getInt();
		headNodeId = buffer.getInt();
		operatingRole = ClusterNodeRole.getById(buffer.get());
		preferredRole = ClusterNodeRole.getById(buffer.get());
		nodeState = ClusterNodeState.getById(buffer.get());
		connectedNodesCount = buffer.getInt();
		clusterQuorum = buffer.getInt();
		electoralClusterNodes = buffer.getInt();
		syncingWithNodeId = buffer.getInt();
		syncingTransactionStarted = buffer.getLong();
		lastTransactionId = buffer.getLong();
		currentTransactionId = buffer.getLong();
		transactionCount = buffer.getLong();
	}

	public int getNodeId() {
		return nodeId;
	}

	public int getHeadNodeId() {
		return headNodeId;
	}

	public ClusterNodeRole getOperatingRole() {
		return operatingRole;
	}

	public ClusterNodeRole getPreferredRole() {
		return preferredRole;
	}

	public ClusterNodeState getNodeState() {
		return nodeState;
	}

	public int getConnectedNodesCount() {
		return connectedNodesCount;
	}

	public int getClusterQuorum() {
		return clusterQuorum;
	}

	public int getElectoralClusterNodes() {
		return electoralClusterNodes;
	}

	public int getSyncingWithNodeId() {
		return syncingWithNodeId;
	}

	public long getSyncingTransactionStarted() {
		return syncingTransactionStarted;
	}

	public long getLastTransactionId() {
		return lastTransactionId;
	}

	public long getCurrentTransactionId() {
		return currentTransactionId;
	}

	public long getTransactionCount() {
		return transactionCount;
	}

	@Override
	public MessageType getType() {
		return MessageType.CLUSTER_NODE_STATUS_INFO;
	}

	@Override
	public byte[] getData() {
		return data;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy