| // Copyright 2018 The Bazel Authors. All rights reserved. |
| // |
| // 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 |
| // |
| // http://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 remote_logging; |
| |
| import "google/protobuf/timestamp.proto"; |
| import "google/bytestream/bytestream.proto"; |
| import "google/devtools/remoteexecution/v1test/remote_execution.proto"; |
| import "google/longrunning/operations.proto"; |
| import "google/rpc/status.proto"; |
| import "google/watcher/v1/watch.proto"; |
| |
| option java_package = "com.google.devtools.build.lib.remote.logging"; |
| |
| // A single log entry for gRPC calls related to remote execution. |
| message LogEntry { |
| // Request metadata included in call. |
| google.devtools.remoteexecution.v1test.RequestMetadata metadata = 1; |
| |
| // Status of the call on close. |
| google.rpc.Status status = 2; |
| |
| // Full method name of the method called as returned from |
| // io.grpc.MethodDescriptor.getFullMethodName() (i.e. in format |
| // $FULL_SERVICE_NAME/$METHOD_NAME). |
| string method_name = 3; |
| |
| // Method specific details for this call. |
| RpcCallDetails details = 4; |
| |
| // Time the call started. |
| google.protobuf.Timestamp start_time = 5; |
| |
| // Time the call closed. |
| google.protobuf.Timestamp end_time = 6; |
| } |
| |
| // Details for a call to |
| // google.devtools.remoteexecution.v1test.Execution.Execute. |
| message ExecuteDetails { |
| // The google.devtools.remoteexecution.v1test.ExecuteRequest sent by the |
| // call. |
| google.devtools.remoteexecution.v1test.ExecuteRequest request = 1; |
| |
| // The google.longrunning.Operation received by the Execute call. |
| google.longrunning.Operation response = 2; |
| } |
| |
| // Details for a call to |
| // google.devtools.remoteexecution.v1test.ActionCache.GetActionResult. |
| message GetActionResultDetails { |
| // The google.devtools.remoteexecution.v1test.GetActionResultRequest sent by |
| // the call. |
| google.devtools.remoteexecution.v1test.GetActionResultRequest request = 1; |
| |
| // The received google.devtools.remoteexecution.v1test.ActionResult. |
| google.devtools.remoteexecution.v1test.ActionResult response = 2; |
| } |
| |
| // Details for a call to google.watcher.v1.Watch. |
| message WatchDetails { |
| // The google.watcher.v1.Request sent by the Watch call. |
| google.watcher.v1.Request request = 1; |
| |
| // Each google.watcher.v1.ChangeBatch response received from the |
| // Watch call in order. |
| repeated google.watcher.v1.ChangeBatch responses = 2; |
| } |
| |
| // Details for a call to |
| // google.devtools.remoteexecution.v1test.ContentAddressableStorage.FindMissingBlobs. |
| message FindMissingBlobsDetails { |
| // The google.devtools.remoteexecution.v1test.FindMissingBlobsRequest request |
| // sent. |
| google.devtools.remoteexecution.v1test.FindMissingBlobsRequest request = 1; |
| |
| // The google.devtools.remoteexecution.v1test.FindMissingBlobsResponse |
| // received. |
| google.devtools.remoteexecution.v1test.FindMissingBlobsResponse response = 2; |
| } |
| |
| // Details for a call to google.bytestream.Read. |
| message ReadDetails { |
| // The google.bytestream.ReadRequest sent. |
| google.bytestream.ReadRequest request = 1; |
| |
| // The number of reads performed in this call. |
| int64 num_reads = 2; |
| |
| // The total number of bytes read totalled over all stream responses. |
| int64 bytes_read = 3; |
| } |
| |
| // Details for a call to google.bytestream.Write. |
| message WriteDetails { |
| // The names of resources requested to be written to in this call in the order |
| // they were first requested in. If the ByteStream protocol is followed |
| // according to specification, this should only contain have a single element, |
| // which is the resource name specified in the first message of the stream. |
| repeated string resource_names = 1; |
| |
| // The number of writes performed in this call. |
| int64 num_writes = 2; |
| |
| // The total number of bytes sent over the stream. |
| int64 bytes_sent = 3; |
| |
| // The received google.bytestream.WriteResponse. |
| google.bytestream.WriteResponse response = 4; |
| } |
| |
| // Contains details for specific types of calls. |
| message RpcCallDetails { |
| oneof details { |
| ExecuteDetails execute = 1; |
| GetActionResultDetails get_action_result = 2; |
| WatchDetails watch = 3; |
| FindMissingBlobsDetails find_missing_blobs = 4; |
| ReadDetails read = 5; |
| WriteDetails write = 6; |
| } |
| } |