| // 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/bytestream/bytestream.proto"; | 
 | import "google/longrunning/operations.proto"; | 
 | import "google/protobuf/timestamp.proto"; | 
 | import "google/rpc/status.proto"; | 
 | import "build/bazel/remote/execution/v2/remote_execution.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.UpdateActionResultRequest 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 contain at most two elements: | 
 |   // The resource name specified in the first message of the stream, and an | 
 |   // empty string specified in each successive request if num_writes > 1. | 
 |   repeated string resource_names = 1; | 
 |  | 
 |   // The offsets sent for the initial request and any non-sequential offsets | 
 |   // specified over the course of the call. If the ByteStream protocol is | 
 |   // followed according to specification, this should contain a single element | 
 |   // which is the starting point for the write call. | 
 |   repeated int64 offsets = 5; | 
 |  | 
 |   // The effective final size for each request sent with finish_write true | 
 |   // specified over the course of the call. If the ByteStream protocol is | 
 |   // followed according to specification, this should contain a single element | 
 |   // which is the total size of the written resource, including the initial | 
 |   // offset. | 
 |   repeated int64 finish_writes = 6; | 
 |  | 
 |   // 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; | 
 | } | 
 |  | 
 | // Details for a call to google.bytestream.QueryWriteStatus. | 
 | message QueryWriteStatusDetails { | 
 |   // The google.bytestream.QueryWriteStatusRequest sent by the call. | 
 |   google.bytestream.QueryWriteStatusRequest request = 1; | 
 |  | 
 |   // The received google.bytestream.QueryWriteStatusResponse. | 
 |   google.bytestream.QueryWriteStatusResponse response = 2; | 
 | } | 
 |  | 
 | // 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; | 
 |     QueryWriteStatusDetails query_write_status = 14; | 
 |     GetCapabilitiesDetails get_capabilities = 12; | 
 |     UpdateActionResultDetails update_action_result = 13; | 
 |   } | 
 | } |