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

com.hedera.hashgraph.sdk.proto.AddressBookServiceGrpc Maven / Gradle / Ivy

There is a newer version: 2.45.0
Show newest version
package com.hedera.hashgraph.sdk.proto;

import static io.grpc.MethodDescriptor.generateFullMethodName;

/**
 * 
 **
 * The Address Book service provides the ability for Hedera network node
 * administrators to add, update, and remove consensus nodes. This addition,
 * update, or removal of a consensus node requires governing council approval,
 * but each node operator may update their own operational attributes without
 * additional approval, reducing overhead for routine operations.
 * Most operations are `privileged operations` and require governing council
 * approval.
 * ### For a node creation transaction.
 * - The node operator SHALL create a `createNode` transaction.
 *    - The node operator SHALL sign this transaction with the active `key` for
 *      the account to be assigned as the "node account".
 *    - The node operator MUST deliver the signed transaction to the Hedera
 *      council representative.
 *    - The Hedera council representative SHALL arrange for council members to
 *      review and sign the transaction.
 *    - Once sufficient council members have signed the transaction, the
 *      Hedera council representative SHALL submit the transaction to the
 *      network.
 * - Upon receipt of a valid and signed node creation transaction the network
 *   software SHALL
 *    - Validate the threshold signature for the Hedera governing council
 *    - Validate the signature of the active `key` for the account to be
 *      assigned as the "node account".
 *    - Create the new node in state, this new node SHALL NOT be active in the
 *      network at this time.
 *    - When executing the next `freeze` transaction with `freeze_type` set to
 *      `PREPARE_UPGRADE`, update network configuration and bring the
 *      new node to an active status within the network. The node to be added
 *      SHALL be active in the network following this upgrade.
 * ### For a node deletion transaction.
 * - The node operator or Hedera council representative SHALL create a
 *   `deleteNode` transaction.
 *    - If the node operator creates the transaction
 *       - The node operator MUST sign this transaction with the active `key`
 *         for the account assigned as the "node account".
 *       - The node operator SHALL deliver the signed transaction to the Hedera
 *         council representative.
 *    - The Hedera council representative SHALL arrange for council members to
 *      review and sign the transaction.
 *    - Once sufficient council members have signed the transaction, the
 *      Hedera council representative SHALL submit the transaction to the
 *      network.
 * - Upon receipt of a valid and signed node deletion transaction the network
 *   software SHALL
 *    - Validate the threshold signature for the Hedera governing council
 *    - Remove the existing node from network state. The node SHALL still
 *      be active in the network at this time.
 *    - When executing the next `freeze` transaction with `freeze_type` set to
 *      `PREPARE_UPGRADE`, update network configuration and remove the
 *      node to be deleted from the network. The node to be deleted SHALL NOT
 *      be active in the network following this upgrade.
 * ### For a node update transaction.
 * - The node operator or Hedera council representative SHALL create an
 *   `updateNode` transaction.
 *    - If the node operator creates the transaction
 *       - The node operator MUST sign this transaction with the active `key`
 *         for the account assigned as the current "node account".
 *       - If the transaction changes the value of the "node account" the
 *         node operator MUST _also_ sign this transaction with the active `key`
 *         for the account to be assigned as the new "node account".
 *       - The node operator SHALL submit the transaction to the
 *         network.  Hedera council approval SHALL NOT be sought for this
 *         transaction
 *    - If the Hedera council representative creates the transaction
 *       - The Hedera council representative SHALL arrange for council members
 *         to review and sign the transaction.
 *       - Once sufficient council members have signed the transaction, the
 *         Hedera council representative SHALL submit the transaction to the
 *         network.
 * - Upon receipt of a valid and signed node update transaction the network
 *   software SHALL
 *    - If the transaction is signed by the Hedera governing council
 *       - Validate the threshold signature for the Hedera governing council
 *    - If the transaction is signed by the active `key` for the node account
 *       - Validate the signature of the active `key` for the account assigned
 *         as the "node account".
 *    - If the transaction modifies the value of the "node account",
 *       - Validate the signature of the _new_ `key` for the account to be
 *         assigned as the new "node account".
 *    - Modify the node information held in network state with the changes
 *      requested in the update transaction. The node changes SHALL NOT be
 *      applied to network configuration, and SHALL NOT affect network
 *      operation at this time.
 *    - When executing the next `freeze` transaction with `freeze_type` set to
 *      `PREPARE_UPGRADE`, update network configuration according to the
 *      modified information in network state. The requested changes SHALL
 *      affect network operation following this upgrade.
 * 
*/ @io.grpc.stub.annotations.GrpcGenerated public final class AddressBookServiceGrpc { private AddressBookServiceGrpc() {} public static final java.lang.String SERVICE_NAME = "proto.AddressBookService"; // Static method descriptors that strictly reflect the proto. private static volatile io.grpc.MethodDescriptor getCreateNodeMethod; @io.grpc.stub.annotations.RpcMethod( fullMethodName = SERVICE_NAME + '/' + "createNode", requestType = com.hedera.hashgraph.sdk.proto.Transaction.class, responseType = com.hedera.hashgraph.sdk.proto.TransactionResponse.class, methodType = io.grpc.MethodDescriptor.MethodType.UNARY) public static io.grpc.MethodDescriptor getCreateNodeMethod() { io.grpc.MethodDescriptor getCreateNodeMethod; if ((getCreateNodeMethod = AddressBookServiceGrpc.getCreateNodeMethod) == null) { synchronized (AddressBookServiceGrpc.class) { if ((getCreateNodeMethod = AddressBookServiceGrpc.getCreateNodeMethod) == null) { AddressBookServiceGrpc.getCreateNodeMethod = getCreateNodeMethod = io.grpc.MethodDescriptor.newBuilder() .setType(io.grpc.MethodDescriptor.MethodType.UNARY) .setFullMethodName(generateFullMethodName(SERVICE_NAME, "createNode")) .setSampledToLocalTracing(true) .setRequestMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.Transaction.getDefaultInstance())) .setResponseMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.TransactionResponse.getDefaultInstance())) .setSchemaDescriptor(new AddressBookServiceMethodDescriptorSupplier("createNode")) .build(); } } } return getCreateNodeMethod; } private static volatile io.grpc.MethodDescriptor getDeleteNodeMethod; @io.grpc.stub.annotations.RpcMethod( fullMethodName = SERVICE_NAME + '/' + "deleteNode", requestType = com.hedera.hashgraph.sdk.proto.Transaction.class, responseType = com.hedera.hashgraph.sdk.proto.TransactionResponse.class, methodType = io.grpc.MethodDescriptor.MethodType.UNARY) public static io.grpc.MethodDescriptor getDeleteNodeMethod() { io.grpc.MethodDescriptor getDeleteNodeMethod; if ((getDeleteNodeMethod = AddressBookServiceGrpc.getDeleteNodeMethod) == null) { synchronized (AddressBookServiceGrpc.class) { if ((getDeleteNodeMethod = AddressBookServiceGrpc.getDeleteNodeMethod) == null) { AddressBookServiceGrpc.getDeleteNodeMethod = getDeleteNodeMethod = io.grpc.MethodDescriptor.newBuilder() .setType(io.grpc.MethodDescriptor.MethodType.UNARY) .setFullMethodName(generateFullMethodName(SERVICE_NAME, "deleteNode")) .setSampledToLocalTracing(true) .setRequestMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.Transaction.getDefaultInstance())) .setResponseMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.TransactionResponse.getDefaultInstance())) .setSchemaDescriptor(new AddressBookServiceMethodDescriptorSupplier("deleteNode")) .build(); } } } return getDeleteNodeMethod; } private static volatile io.grpc.MethodDescriptor getUpdateNodeMethod; @io.grpc.stub.annotations.RpcMethod( fullMethodName = SERVICE_NAME + '/' + "updateNode", requestType = com.hedera.hashgraph.sdk.proto.Transaction.class, responseType = com.hedera.hashgraph.sdk.proto.TransactionResponse.class, methodType = io.grpc.MethodDescriptor.MethodType.UNARY) public static io.grpc.MethodDescriptor getUpdateNodeMethod() { io.grpc.MethodDescriptor getUpdateNodeMethod; if ((getUpdateNodeMethod = AddressBookServiceGrpc.getUpdateNodeMethod) == null) { synchronized (AddressBookServiceGrpc.class) { if ((getUpdateNodeMethod = AddressBookServiceGrpc.getUpdateNodeMethod) == null) { AddressBookServiceGrpc.getUpdateNodeMethod = getUpdateNodeMethod = io.grpc.MethodDescriptor.newBuilder() .setType(io.grpc.MethodDescriptor.MethodType.UNARY) .setFullMethodName(generateFullMethodName(SERVICE_NAME, "updateNode")) .setSampledToLocalTracing(true) .setRequestMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.Transaction.getDefaultInstance())) .setResponseMarshaller(io.grpc.protobuf.ProtoUtils.marshaller( com.hedera.hashgraph.sdk.proto.TransactionResponse.getDefaultInstance())) .setSchemaDescriptor(new AddressBookServiceMethodDescriptorSupplier("updateNode")) .build(); } } } return getUpdateNodeMethod; } /** * Creates a new async stub that supports all call types for the service */ public static AddressBookServiceStub newStub(io.grpc.Channel channel) { io.grpc.stub.AbstractStub.StubFactory factory = new io.grpc.stub.AbstractStub.StubFactory() { @java.lang.Override public AddressBookServiceStub newStub(io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceStub(channel, callOptions); } }; return AddressBookServiceStub.newStub(factory, channel); } /** * Creates a new blocking-style stub that supports unary and streaming output calls on the service */ public static AddressBookServiceBlockingStub newBlockingStub( io.grpc.Channel channel) { io.grpc.stub.AbstractStub.StubFactory factory = new io.grpc.stub.AbstractStub.StubFactory() { @java.lang.Override public AddressBookServiceBlockingStub newStub(io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceBlockingStub(channel, callOptions); } }; return AddressBookServiceBlockingStub.newStub(factory, channel); } /** * Creates a new ListenableFuture-style stub that supports unary calls on the service */ public static AddressBookServiceFutureStub newFutureStub( io.grpc.Channel channel) { io.grpc.stub.AbstractStub.StubFactory factory = new io.grpc.stub.AbstractStub.StubFactory() { @java.lang.Override public AddressBookServiceFutureStub newStub(io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceFutureStub(channel, callOptions); } }; return AddressBookServiceFutureStub.newStub(factory, channel); } /** *
   **
   * The Address Book service provides the ability for Hedera network node
   * administrators to add, update, and remove consensus nodes. This addition,
   * update, or removal of a consensus node requires governing council approval,
   * but each node operator may update their own operational attributes without
   * additional approval, reducing overhead for routine operations.
   * Most operations are `privileged operations` and require governing council
   * approval.
   * ### For a node creation transaction.
   * - The node operator SHALL create a `createNode` transaction.
   *    - The node operator SHALL sign this transaction with the active `key` for
   *      the account to be assigned as the "node account".
   *    - The node operator MUST deliver the signed transaction to the Hedera
   *      council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node creation transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Validate the signature of the active `key` for the account to be
   *      assigned as the "node account".
   *    - Create the new node in state, this new node SHALL NOT be active in the
   *      network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and bring the
   *      new node to an active status within the network. The node to be added
   *      SHALL be active in the network following this upgrade.
   * ### For a node deletion transaction.
   * - The node operator or Hedera council representative SHALL create a
   *   `deleteNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the "node account".
   *       - The node operator SHALL deliver the signed transaction to the Hedera
   *         council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node deletion transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Remove the existing node from network state. The node SHALL still
   *      be active in the network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and remove the
   *      node to be deleted from the network. The node to be deleted SHALL NOT
   *      be active in the network following this upgrade.
   * ### For a node update transaction.
   * - The node operator or Hedera council representative SHALL create an
   *   `updateNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the current "node account".
   *       - If the transaction changes the value of the "node account" the
   *         node operator MUST _also_ sign this transaction with the active `key`
   *         for the account to be assigned as the new "node account".
   *       - The node operator SHALL submit the transaction to the
   *         network.  Hedera council approval SHALL NOT be sought for this
   *         transaction
   *    - If the Hedera council representative creates the transaction
   *       - The Hedera council representative SHALL arrange for council members
   *         to review and sign the transaction.
   *       - Once sufficient council members have signed the transaction, the
   *         Hedera council representative SHALL submit the transaction to the
   *         network.
   * - Upon receipt of a valid and signed node update transaction the network
   *   software SHALL
   *    - If the transaction is signed by the Hedera governing council
   *       - Validate the threshold signature for the Hedera governing council
   *    - If the transaction is signed by the active `key` for the node account
   *       - Validate the signature of the active `key` for the account assigned
   *         as the "node account".
   *    - If the transaction modifies the value of the "node account",
   *       - Validate the signature of the _new_ `key` for the account to be
   *         assigned as the new "node account".
   *    - Modify the node information held in network state with the changes
   *      requested in the update transaction. The node changes SHALL NOT be
   *      applied to network configuration, and SHALL NOT affect network
   *      operation at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration according to the
   *      modified information in network state. The requested changes SHALL
   *      affect network operation following this upgrade.
   * 
*/ public interface AsyncService { /** *
     **
     * A transaction to create a new consensus node in the network.
     * address book.
     * <p>
     * This transaction, once complete, SHALL add a new consensus node to the
     * network state.<br/>
     * The new consensus node SHALL remain in state, but SHALL NOT participate
     * in network consensus until the network updates the network configuration.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ default void createNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ServerCalls.asyncUnimplementedUnaryCall(getCreateNodeMethod(), responseObserver); } /** *
     **
     * A transaction to remove a consensus node from the network address
     * book.
     * <p>
     * This transaction, once complete, SHALL remove the identified consensus
     * node from the network state.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ default void deleteNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ServerCalls.asyncUnimplementedUnaryCall(getDeleteNodeMethod(), responseObserver); } /** *
     **
     * A transaction to update an existing consensus node from the network
     * address book.
     * <p>
     * This transaction, once complete, SHALL modify the identified consensus
     * node state as requested.
     * <p>
     * This transaction MAY be authorized by either the node operator OR the
     * Hedera governing council.
     * 
*/ default void updateNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ServerCalls.asyncUnimplementedUnaryCall(getUpdateNodeMethod(), responseObserver); } } /** * Base class for the server implementation of the service AddressBookService. *
   **
   * The Address Book service provides the ability for Hedera network node
   * administrators to add, update, and remove consensus nodes. This addition,
   * update, or removal of a consensus node requires governing council approval,
   * but each node operator may update their own operational attributes without
   * additional approval, reducing overhead for routine operations.
   * Most operations are `privileged operations` and require governing council
   * approval.
   * ### For a node creation transaction.
   * - The node operator SHALL create a `createNode` transaction.
   *    - The node operator SHALL sign this transaction with the active `key` for
   *      the account to be assigned as the "node account".
   *    - The node operator MUST deliver the signed transaction to the Hedera
   *      council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node creation transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Validate the signature of the active `key` for the account to be
   *      assigned as the "node account".
   *    - Create the new node in state, this new node SHALL NOT be active in the
   *      network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and bring the
   *      new node to an active status within the network. The node to be added
   *      SHALL be active in the network following this upgrade.
   * ### For a node deletion transaction.
   * - The node operator or Hedera council representative SHALL create a
   *   `deleteNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the "node account".
   *       - The node operator SHALL deliver the signed transaction to the Hedera
   *         council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node deletion transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Remove the existing node from network state. The node SHALL still
   *      be active in the network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and remove the
   *      node to be deleted from the network. The node to be deleted SHALL NOT
   *      be active in the network following this upgrade.
   * ### For a node update transaction.
   * - The node operator or Hedera council representative SHALL create an
   *   `updateNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the current "node account".
   *       - If the transaction changes the value of the "node account" the
   *         node operator MUST _also_ sign this transaction with the active `key`
   *         for the account to be assigned as the new "node account".
   *       - The node operator SHALL submit the transaction to the
   *         network.  Hedera council approval SHALL NOT be sought for this
   *         transaction
   *    - If the Hedera council representative creates the transaction
   *       - The Hedera council representative SHALL arrange for council members
   *         to review and sign the transaction.
   *       - Once sufficient council members have signed the transaction, the
   *         Hedera council representative SHALL submit the transaction to the
   *         network.
   * - Upon receipt of a valid and signed node update transaction the network
   *   software SHALL
   *    - If the transaction is signed by the Hedera governing council
   *       - Validate the threshold signature for the Hedera governing council
   *    - If the transaction is signed by the active `key` for the node account
   *       - Validate the signature of the active `key` for the account assigned
   *         as the "node account".
   *    - If the transaction modifies the value of the "node account",
   *       - Validate the signature of the _new_ `key` for the account to be
   *         assigned as the new "node account".
   *    - Modify the node information held in network state with the changes
   *      requested in the update transaction. The node changes SHALL NOT be
   *      applied to network configuration, and SHALL NOT affect network
   *      operation at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration according to the
   *      modified information in network state. The requested changes SHALL
   *      affect network operation following this upgrade.
   * 
*/ public static abstract class AddressBookServiceImplBase implements io.grpc.BindableService, AsyncService { @java.lang.Override public final io.grpc.ServerServiceDefinition bindService() { return AddressBookServiceGrpc.bindService(this); } } /** * A stub to allow clients to do asynchronous rpc calls to service AddressBookService. *
   **
   * The Address Book service provides the ability for Hedera network node
   * administrators to add, update, and remove consensus nodes. This addition,
   * update, or removal of a consensus node requires governing council approval,
   * but each node operator may update their own operational attributes without
   * additional approval, reducing overhead for routine operations.
   * Most operations are `privileged operations` and require governing council
   * approval.
   * ### For a node creation transaction.
   * - The node operator SHALL create a `createNode` transaction.
   *    - The node operator SHALL sign this transaction with the active `key` for
   *      the account to be assigned as the "node account".
   *    - The node operator MUST deliver the signed transaction to the Hedera
   *      council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node creation transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Validate the signature of the active `key` for the account to be
   *      assigned as the "node account".
   *    - Create the new node in state, this new node SHALL NOT be active in the
   *      network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and bring the
   *      new node to an active status within the network. The node to be added
   *      SHALL be active in the network following this upgrade.
   * ### For a node deletion transaction.
   * - The node operator or Hedera council representative SHALL create a
   *   `deleteNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the "node account".
   *       - The node operator SHALL deliver the signed transaction to the Hedera
   *         council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node deletion transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Remove the existing node from network state. The node SHALL still
   *      be active in the network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and remove the
   *      node to be deleted from the network. The node to be deleted SHALL NOT
   *      be active in the network following this upgrade.
   * ### For a node update transaction.
   * - The node operator or Hedera council representative SHALL create an
   *   `updateNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the current "node account".
   *       - If the transaction changes the value of the "node account" the
   *         node operator MUST _also_ sign this transaction with the active `key`
   *         for the account to be assigned as the new "node account".
   *       - The node operator SHALL submit the transaction to the
   *         network.  Hedera council approval SHALL NOT be sought for this
   *         transaction
   *    - If the Hedera council representative creates the transaction
   *       - The Hedera council representative SHALL arrange for council members
   *         to review and sign the transaction.
   *       - Once sufficient council members have signed the transaction, the
   *         Hedera council representative SHALL submit the transaction to the
   *         network.
   * - Upon receipt of a valid and signed node update transaction the network
   *   software SHALL
   *    - If the transaction is signed by the Hedera governing council
   *       - Validate the threshold signature for the Hedera governing council
   *    - If the transaction is signed by the active `key` for the node account
   *       - Validate the signature of the active `key` for the account assigned
   *         as the "node account".
   *    - If the transaction modifies the value of the "node account",
   *       - Validate the signature of the _new_ `key` for the account to be
   *         assigned as the new "node account".
   *    - Modify the node information held in network state with the changes
   *      requested in the update transaction. The node changes SHALL NOT be
   *      applied to network configuration, and SHALL NOT affect network
   *      operation at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration according to the
   *      modified information in network state. The requested changes SHALL
   *      affect network operation following this upgrade.
   * 
*/ public static final class AddressBookServiceStub extends io.grpc.stub.AbstractAsyncStub { private AddressBookServiceStub( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { super(channel, callOptions); } @java.lang.Override protected AddressBookServiceStub build( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceStub(channel, callOptions); } /** *
     **
     * A transaction to create a new consensus node in the network.
     * address book.
     * <p>
     * This transaction, once complete, SHALL add a new consensus node to the
     * network state.<br/>
     * The new consensus node SHALL remain in state, but SHALL NOT participate
     * in network consensus until the network updates the network configuration.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public void createNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ClientCalls.asyncUnaryCall( getChannel().newCall(getCreateNodeMethod(), getCallOptions()), request, responseObserver); } /** *
     **
     * A transaction to remove a consensus node from the network address
     * book.
     * <p>
     * This transaction, once complete, SHALL remove the identified consensus
     * node from the network state.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public void deleteNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ClientCalls.asyncUnaryCall( getChannel().newCall(getDeleteNodeMethod(), getCallOptions()), request, responseObserver); } /** *
     **
     * A transaction to update an existing consensus node from the network
     * address book.
     * <p>
     * This transaction, once complete, SHALL modify the identified consensus
     * node state as requested.
     * <p>
     * This transaction MAY be authorized by either the node operator OR the
     * Hedera governing council.
     * 
*/ public void updateNode(com.hedera.hashgraph.sdk.proto.Transaction request, io.grpc.stub.StreamObserver responseObserver) { io.grpc.stub.ClientCalls.asyncUnaryCall( getChannel().newCall(getUpdateNodeMethod(), getCallOptions()), request, responseObserver); } } /** * A stub to allow clients to do synchronous rpc calls to service AddressBookService. *
   **
   * The Address Book service provides the ability for Hedera network node
   * administrators to add, update, and remove consensus nodes. This addition,
   * update, or removal of a consensus node requires governing council approval,
   * but each node operator may update their own operational attributes without
   * additional approval, reducing overhead for routine operations.
   * Most operations are `privileged operations` and require governing council
   * approval.
   * ### For a node creation transaction.
   * - The node operator SHALL create a `createNode` transaction.
   *    - The node operator SHALL sign this transaction with the active `key` for
   *      the account to be assigned as the "node account".
   *    - The node operator MUST deliver the signed transaction to the Hedera
   *      council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node creation transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Validate the signature of the active `key` for the account to be
   *      assigned as the "node account".
   *    - Create the new node in state, this new node SHALL NOT be active in the
   *      network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and bring the
   *      new node to an active status within the network. The node to be added
   *      SHALL be active in the network following this upgrade.
   * ### For a node deletion transaction.
   * - The node operator or Hedera council representative SHALL create a
   *   `deleteNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the "node account".
   *       - The node operator SHALL deliver the signed transaction to the Hedera
   *         council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node deletion transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Remove the existing node from network state. The node SHALL still
   *      be active in the network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and remove the
   *      node to be deleted from the network. The node to be deleted SHALL NOT
   *      be active in the network following this upgrade.
   * ### For a node update transaction.
   * - The node operator or Hedera council representative SHALL create an
   *   `updateNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the current "node account".
   *       - If the transaction changes the value of the "node account" the
   *         node operator MUST _also_ sign this transaction with the active `key`
   *         for the account to be assigned as the new "node account".
   *       - The node operator SHALL submit the transaction to the
   *         network.  Hedera council approval SHALL NOT be sought for this
   *         transaction
   *    - If the Hedera council representative creates the transaction
   *       - The Hedera council representative SHALL arrange for council members
   *         to review and sign the transaction.
   *       - Once sufficient council members have signed the transaction, the
   *         Hedera council representative SHALL submit the transaction to the
   *         network.
   * - Upon receipt of a valid and signed node update transaction the network
   *   software SHALL
   *    - If the transaction is signed by the Hedera governing council
   *       - Validate the threshold signature for the Hedera governing council
   *    - If the transaction is signed by the active `key` for the node account
   *       - Validate the signature of the active `key` for the account assigned
   *         as the "node account".
   *    - If the transaction modifies the value of the "node account",
   *       - Validate the signature of the _new_ `key` for the account to be
   *         assigned as the new "node account".
   *    - Modify the node information held in network state with the changes
   *      requested in the update transaction. The node changes SHALL NOT be
   *      applied to network configuration, and SHALL NOT affect network
   *      operation at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration according to the
   *      modified information in network state. The requested changes SHALL
   *      affect network operation following this upgrade.
   * 
*/ public static final class AddressBookServiceBlockingStub extends io.grpc.stub.AbstractBlockingStub { private AddressBookServiceBlockingStub( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { super(channel, callOptions); } @java.lang.Override protected AddressBookServiceBlockingStub build( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceBlockingStub(channel, callOptions); } /** *
     **
     * A transaction to create a new consensus node in the network.
     * address book.
     * <p>
     * This transaction, once complete, SHALL add a new consensus node to the
     * network state.<br/>
     * The new consensus node SHALL remain in state, but SHALL NOT participate
     * in network consensus until the network updates the network configuration.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public com.hedera.hashgraph.sdk.proto.TransactionResponse createNode(com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.blockingUnaryCall( getChannel(), getCreateNodeMethod(), getCallOptions(), request); } /** *
     **
     * A transaction to remove a consensus node from the network address
     * book.
     * <p>
     * This transaction, once complete, SHALL remove the identified consensus
     * node from the network state.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public com.hedera.hashgraph.sdk.proto.TransactionResponse deleteNode(com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.blockingUnaryCall( getChannel(), getDeleteNodeMethod(), getCallOptions(), request); } /** *
     **
     * A transaction to update an existing consensus node from the network
     * address book.
     * <p>
     * This transaction, once complete, SHALL modify the identified consensus
     * node state as requested.
     * <p>
     * This transaction MAY be authorized by either the node operator OR the
     * Hedera governing council.
     * 
*/ public com.hedera.hashgraph.sdk.proto.TransactionResponse updateNode(com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.blockingUnaryCall( getChannel(), getUpdateNodeMethod(), getCallOptions(), request); } } /** * A stub to allow clients to do ListenableFuture-style rpc calls to service AddressBookService. *
   **
   * The Address Book service provides the ability for Hedera network node
   * administrators to add, update, and remove consensus nodes. This addition,
   * update, or removal of a consensus node requires governing council approval,
   * but each node operator may update their own operational attributes without
   * additional approval, reducing overhead for routine operations.
   * Most operations are `privileged operations` and require governing council
   * approval.
   * ### For a node creation transaction.
   * - The node operator SHALL create a `createNode` transaction.
   *    - The node operator SHALL sign this transaction with the active `key` for
   *      the account to be assigned as the "node account".
   *    - The node operator MUST deliver the signed transaction to the Hedera
   *      council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node creation transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Validate the signature of the active `key` for the account to be
   *      assigned as the "node account".
   *    - Create the new node in state, this new node SHALL NOT be active in the
   *      network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and bring the
   *      new node to an active status within the network. The node to be added
   *      SHALL be active in the network following this upgrade.
   * ### For a node deletion transaction.
   * - The node operator or Hedera council representative SHALL create a
   *   `deleteNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the "node account".
   *       - The node operator SHALL deliver the signed transaction to the Hedera
   *         council representative.
   *    - The Hedera council representative SHALL arrange for council members to
   *      review and sign the transaction.
   *    - Once sufficient council members have signed the transaction, the
   *      Hedera council representative SHALL submit the transaction to the
   *      network.
   * - Upon receipt of a valid and signed node deletion transaction the network
   *   software SHALL
   *    - Validate the threshold signature for the Hedera governing council
   *    - Remove the existing node from network state. The node SHALL still
   *      be active in the network at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration and remove the
   *      node to be deleted from the network. The node to be deleted SHALL NOT
   *      be active in the network following this upgrade.
   * ### For a node update transaction.
   * - The node operator or Hedera council representative SHALL create an
   *   `updateNode` transaction.
   *    - If the node operator creates the transaction
   *       - The node operator MUST sign this transaction with the active `key`
   *         for the account assigned as the current "node account".
   *       - If the transaction changes the value of the "node account" the
   *         node operator MUST _also_ sign this transaction with the active `key`
   *         for the account to be assigned as the new "node account".
   *       - The node operator SHALL submit the transaction to the
   *         network.  Hedera council approval SHALL NOT be sought for this
   *         transaction
   *    - If the Hedera council representative creates the transaction
   *       - The Hedera council representative SHALL arrange for council members
   *         to review and sign the transaction.
   *       - Once sufficient council members have signed the transaction, the
   *         Hedera council representative SHALL submit the transaction to the
   *         network.
   * - Upon receipt of a valid and signed node update transaction the network
   *   software SHALL
   *    - If the transaction is signed by the Hedera governing council
   *       - Validate the threshold signature for the Hedera governing council
   *    - If the transaction is signed by the active `key` for the node account
   *       - Validate the signature of the active `key` for the account assigned
   *         as the "node account".
   *    - If the transaction modifies the value of the "node account",
   *       - Validate the signature of the _new_ `key` for the account to be
   *         assigned as the new "node account".
   *    - Modify the node information held in network state with the changes
   *      requested in the update transaction. The node changes SHALL NOT be
   *      applied to network configuration, and SHALL NOT affect network
   *      operation at this time.
   *    - When executing the next `freeze` transaction with `freeze_type` set to
   *      `PREPARE_UPGRADE`, update network configuration according to the
   *      modified information in network state. The requested changes SHALL
   *      affect network operation following this upgrade.
   * 
*/ public static final class AddressBookServiceFutureStub extends io.grpc.stub.AbstractFutureStub { private AddressBookServiceFutureStub( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { super(channel, callOptions); } @java.lang.Override protected AddressBookServiceFutureStub build( io.grpc.Channel channel, io.grpc.CallOptions callOptions) { return new AddressBookServiceFutureStub(channel, callOptions); } /** *
     **
     * A transaction to create a new consensus node in the network.
     * address book.
     * <p>
     * This transaction, once complete, SHALL add a new consensus node to the
     * network state.<br/>
     * The new consensus node SHALL remain in state, but SHALL NOT participate
     * in network consensus until the network updates the network configuration.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public com.google.common.util.concurrent.ListenableFuture createNode( com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.futureUnaryCall( getChannel().newCall(getCreateNodeMethod(), getCallOptions()), request); } /** *
     **
     * A transaction to remove a consensus node from the network address
     * book.
     * <p>
     * This transaction, once complete, SHALL remove the identified consensus
     * node from the network state.
     * <p>
     * Hedera governing council authorization is REQUIRED for this transaction.
     * 
*/ public com.google.common.util.concurrent.ListenableFuture deleteNode( com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.futureUnaryCall( getChannel().newCall(getDeleteNodeMethod(), getCallOptions()), request); } /** *
     **
     * A transaction to update an existing consensus node from the network
     * address book.
     * <p>
     * This transaction, once complete, SHALL modify the identified consensus
     * node state as requested.
     * <p>
     * This transaction MAY be authorized by either the node operator OR the
     * Hedera governing council.
     * 
*/ public com.google.common.util.concurrent.ListenableFuture updateNode( com.hedera.hashgraph.sdk.proto.Transaction request) { return io.grpc.stub.ClientCalls.futureUnaryCall( getChannel().newCall(getUpdateNodeMethod(), getCallOptions()), request); } } private static final int METHODID_CREATE_NODE = 0; private static final int METHODID_DELETE_NODE = 1; private static final int METHODID_UPDATE_NODE = 2; private static final class MethodHandlers implements io.grpc.stub.ServerCalls.UnaryMethod, io.grpc.stub.ServerCalls.ServerStreamingMethod, io.grpc.stub.ServerCalls.ClientStreamingMethod, io.grpc.stub.ServerCalls.BidiStreamingMethod { private final AsyncService serviceImpl; private final int methodId; MethodHandlers(AsyncService serviceImpl, int methodId) { this.serviceImpl = serviceImpl; this.methodId = methodId; } @java.lang.Override @java.lang.SuppressWarnings("unchecked") public void invoke(Req request, io.grpc.stub.StreamObserver responseObserver) { switch (methodId) { case METHODID_CREATE_NODE: serviceImpl.createNode((com.hedera.hashgraph.sdk.proto.Transaction) request, (io.grpc.stub.StreamObserver) responseObserver); break; case METHODID_DELETE_NODE: serviceImpl.deleteNode((com.hedera.hashgraph.sdk.proto.Transaction) request, (io.grpc.stub.StreamObserver) responseObserver); break; case METHODID_UPDATE_NODE: serviceImpl.updateNode((com.hedera.hashgraph.sdk.proto.Transaction) request, (io.grpc.stub.StreamObserver) responseObserver); break; default: throw new AssertionError(); } } @java.lang.Override @java.lang.SuppressWarnings("unchecked") public io.grpc.stub.StreamObserver invoke( io.grpc.stub.StreamObserver responseObserver) { switch (methodId) { default: throw new AssertionError(); } } } public static final io.grpc.ServerServiceDefinition bindService(AsyncService service) { return io.grpc.ServerServiceDefinition.builder(getServiceDescriptor()) .addMethod( getCreateNodeMethod(), io.grpc.stub.ServerCalls.asyncUnaryCall( new MethodHandlers< com.hedera.hashgraph.sdk.proto.Transaction, com.hedera.hashgraph.sdk.proto.TransactionResponse>( service, METHODID_CREATE_NODE))) .addMethod( getDeleteNodeMethod(), io.grpc.stub.ServerCalls.asyncUnaryCall( new MethodHandlers< com.hedera.hashgraph.sdk.proto.Transaction, com.hedera.hashgraph.sdk.proto.TransactionResponse>( service, METHODID_DELETE_NODE))) .addMethod( getUpdateNodeMethod(), io.grpc.stub.ServerCalls.asyncUnaryCall( new MethodHandlers< com.hedera.hashgraph.sdk.proto.Transaction, com.hedera.hashgraph.sdk.proto.TransactionResponse>( service, METHODID_UPDATE_NODE))) .build(); } private static abstract class AddressBookServiceBaseDescriptorSupplier implements io.grpc.protobuf.ProtoFileDescriptorSupplier, io.grpc.protobuf.ProtoServiceDescriptorSupplier { AddressBookServiceBaseDescriptorSupplier() {} @java.lang.Override public com.google.protobuf.Descriptors.FileDescriptor getFileDescriptor() { return com.hedera.hashgraph.sdk.proto.AddressBookServiceOuterClass.getDescriptor(); } @java.lang.Override public com.google.protobuf.Descriptors.ServiceDescriptor getServiceDescriptor() { return getFileDescriptor().findServiceByName("AddressBookService"); } } private static final class AddressBookServiceFileDescriptorSupplier extends AddressBookServiceBaseDescriptorSupplier { AddressBookServiceFileDescriptorSupplier() {} } private static final class AddressBookServiceMethodDescriptorSupplier extends AddressBookServiceBaseDescriptorSupplier implements io.grpc.protobuf.ProtoMethodDescriptorSupplier { private final java.lang.String methodName; AddressBookServiceMethodDescriptorSupplier(java.lang.String methodName) { this.methodName = methodName; } @java.lang.Override public com.google.protobuf.Descriptors.MethodDescriptor getMethodDescriptor() { return getServiceDescriptor().findMethodByName(methodName); } } private static volatile io.grpc.ServiceDescriptor serviceDescriptor; public static io.grpc.ServiceDescriptor getServiceDescriptor() { io.grpc.ServiceDescriptor result = serviceDescriptor; if (result == null) { synchronized (AddressBookServiceGrpc.class) { result = serviceDescriptor; if (result == null) { serviceDescriptor = result = io.grpc.ServiceDescriptor.newBuilder(SERVICE_NAME) .setSchemaDescriptor(new AddressBookServiceFileDescriptorSupplier()) .addMethod(getCreateNodeMethod()) .addMethod(getDeleteNodeMethod()) .addMethod(getUpdateNodeMethod()) .build(); } } } return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy