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

io.zeebe.broker.clustering.handler.BrokerPartitionState Maven / Gradle / Ivy

There is a newer version: 0.21.0-alpha1
Show newest version
/*
 * Zeebe Broker Core
 * Copyright © 2017 camunda services GmbH ([email protected])
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see .
 */
package io.zeebe.broker.clustering.handler;

import io.zeebe.msgpack.UnpackedObject;
import io.zeebe.msgpack.property.EnumProperty;
import io.zeebe.msgpack.property.IntegerProperty;
import io.zeebe.msgpack.property.StringProperty;
import io.zeebe.raft.state.RaftState;
import org.agrona.DirectBuffer;


public class BrokerPartitionState extends UnpackedObject
{
    private final EnumProperty stateProp = new EnumProperty<>("state", RaftState.class);
    protected StringProperty topicNameProp = new StringProperty("topicName");
    protected IntegerProperty partitionIdProp = new IntegerProperty("partitionId");

    public BrokerPartitionState()
    {
        this
            .declareProperty(stateProp)
            .declareProperty(topicNameProp)
            .declareProperty(partitionIdProp);
    }

    public RaftState getState()
    {
        return stateProp.getValue();
    }

    public BrokerPartitionState setState(RaftState eventType)
    {
        this.stateProp.setValue(eventType);
        return this;
    }

    public BrokerPartitionState setTopicName(final DirectBuffer topicName, final int offset, final int length)
    {
        this.topicNameProp.setValue(topicName, offset, length);
        return this;
    }

    public int getPartitionId()
    {
        return partitionIdProp.getValue();
    }

    public BrokerPartitionState setPartitionId(final int partitionId)
    {
        partitionIdProp.setValue(partitionId);
        return this;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy