You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
2.0 KiB
70 lines
2.0 KiB
4 months ago
|
// Copyright 2020 The Pigweed Authors
|
||
|
//
|
||
|
// 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
|
||
|
//
|
||
|
// https://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.
|
||
|
syntax = "proto3";
|
||
|
|
||
|
package pw.rpc.internal;
|
||
|
|
||
|
option java_package = "dev.pigweed.pw.rpc.internal";
|
||
|
|
||
|
enum PacketType {
|
||
|
// To simplify identifying the origin of a packet, client-to-server packets
|
||
|
// use even numbers and server-to-client packets use odd numbers.
|
||
|
|
||
|
// Client-to-server packets
|
||
|
|
||
|
// A request from a client for a service method.
|
||
|
REQUEST = 0;
|
||
|
|
||
|
// A client stream has completed.
|
||
|
CLIENT_STREAM_END = 2;
|
||
|
|
||
|
// The client received a packet for an RPC it did not request.
|
||
|
CLIENT_ERROR = 4;
|
||
|
|
||
|
// The client requests cancellation of an ongoing server stream.
|
||
|
CANCEL_SERVER_STREAM = 6;
|
||
|
|
||
|
// Server-to-client packets
|
||
|
|
||
|
// A response from a server for a service method.
|
||
|
RESPONSE = 1;
|
||
|
|
||
|
// A server streaming or bidirectional RPC has completed.
|
||
|
SERVER_STREAM_END = 3;
|
||
|
|
||
|
// The server was unable to process a request.
|
||
|
SERVER_ERROR = 5;
|
||
|
}
|
||
|
|
||
|
message RpcPacket {
|
||
|
// The type of packet. Determines which other fields are used.
|
||
|
PacketType type = 1;
|
||
|
|
||
|
// Channel through which the packet is sent.
|
||
|
uint32 channel_id = 2;
|
||
|
|
||
|
// Hash of the fully-qualified name of the service with which this packet is
|
||
|
// associated. For RPC packets, this is the service that processes the packet.
|
||
|
fixed32 service_id = 3;
|
||
|
|
||
|
// Hash of the name of the method which should process this packet.
|
||
|
fixed32 method_id = 4;
|
||
|
|
||
|
// The packet's payload, which is an encoded protobuf.
|
||
|
bytes payload = 5;
|
||
|
|
||
|
// Status code for the RPC response or error.
|
||
|
uint32 status = 6;
|
||
|
}
|