/* * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.controller.cluster.raft.protobuff.client.messages; import com.google.protobuf.GeneratedMessage; import org.opendaylight.controller.protobuff.messages.cluster.raft.AppendEntriesMessages; import java.util.Map; /** * An instance of a Payload class is meant to be used as the Payload for * AppendEntries. *
* * When an actor which is derived from RaftActor attempts to persistData it * must pass an instance of the Payload class. Similarly when state needs to * be applied to the derived RaftActor it will be passed an instance of the * Payload class. *
* * To define your own payload do the following, *
* {@code * * import "AppendEntriesMessages.proto"; * * package org.opendaylight.controller.cluster.raft; * * option java_package = "org.opendaylight.controller.cluster.raft.protobuff.messages"; * option java_outer_classname = "MockPayloadMessages"; * * extend AppendEntries.ReplicatedLogEntry.Payload { * optional string value = 2; * } * } ** */ public abstract class Payload { private String clientPayloadClassName; public String getClientPayloadClassName() { return this.getClass().getName(); } public void setClientPayloadClassName(String clientPayloadClassName) { this.clientPayloadClassName = clientPayloadClassName; } /** * Encode the payload data as a protocol buffer extension. *
* TODO: Add more meat in here
* @param