public abstract static class CommandSubmissionServiceGrpc.CommandSubmissionServiceImplBase
extends java.lang.Object
implements io.grpc.BindableService
Allows clients to attempt advancing the ledger's state by submitting commands. The final states of their submissions are disclosed by the Command Completion Service. The on-ledger effects of their submissions are disclosed by the Transaction Service. Commands may fail in 2 distinct manners: 1. Failure communicated synchronously in the gRPC error of the submission. 2. Failure communicated asynchronously in a Completion, see ``completion.proto``. Note that not only successfully submitted commands MAY produce a completion event. For example, the participant MAY choose to produce a completion event for a rejection of a duplicate command. Clients that do not receive a successful completion about their submission MUST NOT assume that it was successful. Clients SHOULD subscribe to the CompletionStream before starting to submit commands to prevent race conditions.
Constructor and Description |
---|
CommandSubmissionServiceImplBase() |
Modifier and Type | Method and Description |
---|---|
io.grpc.ServerServiceDefinition |
bindService() |
void |
submit(CommandSubmissionServiceOuterClass.SubmitRequest request,
io.grpc.stub.StreamObserver<com.google.protobuf.Empty> responseObserver)
Submit a single composite command.
|
public void submit(CommandSubmissionServiceOuterClass.SubmitRequest request, io.grpc.stub.StreamObserver<com.google.protobuf.Empty> responseObserver)
Submit a single composite command. Errors: - ``UNAUTHENTICATED``: if the request does not include a valid access token - ``PERMISSION_DENIED``: if the claims in the token are insufficient to perform a given operation - ``NOT_FOUND``: if the request does not include a valid ledger id - ``INVALID_ARGUMENT``: if the payload is malformed or is missing required fields - ``UNAVAILABLE``: if the participant is not yet ready to submit commands or if the service has been shut down. - ``RESOURCE_EXHAUSTED``: if the participant or the ledger is overloaded. Clients should back off exponentially and retry. - ``ABORTED``: if a contract key is missing or duplicated due to for example contention on resources
public final io.grpc.ServerServiceDefinition bindService()
bindService
in interface io.grpc.BindableService