| // 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 "build/bazel/remote/execution/v2/remote_execution.proto"; | 
 | import "google/protobuf/timestamp.proto"; | 
 | import "google/bytestream/bytestream.proto"; | 
 | import "google/longrunning/operations.proto"; | 
 | import "google/rpc/status.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. | 
 |   build.bazel.remote.execution.v2.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 | 
 | // build.bazel.remote.execution.v2.ActionCache.GetCapabilities. | 
 | message GetCapabilitiesDetails { | 
 |   // The build.bazel.remote.execution.v2.GetCapabilitiesRequest sent by | 
 |   // the call. | 
 |   build.bazel.remote.execution.v2.GetCapabilitiesRequest request = 1; | 
 |  | 
 |   // The received build.bazel.remote.execution.v2.ServerCapabilities. | 
 |   build.bazel.remote.execution.v2.ServerCapabilities response = 2; | 
 | } | 
 |  | 
 | // Details for a call to | 
 | // build.bazel.remote.execution.v2.Execution.Execute. | 
 | message ExecuteDetails { | 
 |   // The build.bazel.remote.execution.v2.ExecuteRequest sent by the | 
 |   // call. | 
 |   build.bazel.remote.execution.v2.ExecuteRequest request = 1; | 
 |  | 
 |   // Each google.longrunning.Operation received by the Execute call in order. | 
 |   repeated google.longrunning.Operation responses = 2; | 
 | } | 
 |  | 
 | // Details for a call to | 
 | // build.bazel.remote.execution.v2.ActionCache.GetActionResult. | 
 | message GetActionResultDetails { | 
 |   // The build.bazel.remote.execution.v2.GetActionResultRequest sent by | 
 |   // the call. | 
 |   build.bazel.remote.execution.v2.GetActionResultRequest request = 1; | 
 |  | 
 |   // The received build.bazel.remote.execution.v2.ActionResult. | 
 |   build.bazel.remote.execution.v2.ActionResult response = 2; | 
 | } | 
 |  | 
 | // Details for a call to | 
 | // build.bazel.remote.execution.v2.ActionCache.UpdateActionResult. | 
 | message UpdateActionResultDetails { | 
 |   // The build.bazel.remote.execution.v2.GetActionResultRequest sent by | 
 |   // the call. | 
 |   build.bazel.remote.execution.v2.UpdateActionResultRequest request = 1; | 
 |  | 
 |   // The received build.bazel.remote.execution.v2.ActionResult. | 
 |   build.bazel.remote.execution.v2.ActionResult response = 2; | 
 | } | 
 |  | 
 | // Details for a call to build.bazel.remote.execution.v2.WaitExecution. | 
 | message WaitExecutionDetails { | 
 |   // The google.watcher.v1.Request sent by the Watch call. | 
 |   build.bazel.remote.execution.v2.WaitExecutionRequest request = 1; | 
 |  | 
 |   // Each google.longrunning.Operation received by the call in order. | 
 |   repeated google.longrunning.Operation responses = 2; | 
 | } | 
 |  | 
 | // Details for a call to | 
 | // build.bazel.remote.execution.v2.ContentAddressableStorage.FindMissingBlobs. | 
 | message FindMissingBlobsDetails { | 
 |   // The build.bazel.remote.execution.v2.FindMissingBlobsRequest request | 
 |   // sent. | 
 |   build.bazel.remote.execution.v2.FindMissingBlobsRequest request = 1; | 
 |  | 
 |   // The build.bazel.remote.execution.v2.FindMissingBlobsResponse | 
 |   // received. | 
 |   build.bazel.remote.execution.v2.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 { | 
 |   reserved 1 to 4, 11; | 
 |   oneof details { | 
 |     ExecuteDetails execute = 7; | 
 |     GetActionResultDetails get_action_result = 8; | 
 |     WaitExecutionDetails wait_execution = 9; | 
 |     FindMissingBlobsDetails find_missing_blobs = 10; | 
 |     ReadDetails read = 5; | 
 |     WriteDetails write = 6; | 
 |     GetCapabilitiesDetails get_capabilities = 12; | 
 |     UpdateActionResultDetails update_action_result = 13; | 
 |   } | 
 | } |