123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- // Copyright 2017 Google Inc.
- //
- // 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 google.rpc;
- import "google/protobuf/duration.proto";
- option go_package = "google.golang.org/genproto/googleapis/rpc/errdetails;errdetails";
- option java_multiple_files = true;
- option java_outer_classname = "ErrorDetailsProto";
- option java_package = "com.google.rpc";
- option objc_class_prefix = "RPC";
- // Describes when the clients can retry a failed request. Clients could ignore
- // the recommendation here or retry when this information is missing from error
- // responses.
- //
- // It's always recommended that clients should use exponential backoff when
- // retrying.
- //
- // Clients should wait until `retry_delay` amount of time has passed since
- // receiving the error response before retrying. If retrying requests also
- // fail, clients should use an exponential backoff scheme to gradually increase
- // the delay between retries based on `retry_delay`, until either a maximum
- // number of retires have been reached or a maximum retry delay cap has been
- // reached.
- message RetryInfo {
- // Clients should wait at least this long between retrying the same request.
- google.protobuf.Duration retry_delay = 1;
- }
- // Describes additional debugging info.
- message DebugInfo {
- // The stack trace entries indicating where the error occurred.
- repeated string stack_entries = 1;
- // Additional debugging information provided by the server.
- string detail = 2;
- }
- // Describes how a quota check failed.
- //
- // For example if a daily limit was exceeded for the calling project,
- // a service could respond with a QuotaFailure detail containing the project
- // id and the description of the quota limit that was exceeded. If the
- // calling project hasn't enabled the service in the developer console, then
- // a service could respond with the project id and set `service_disabled`
- // to true.
- //
- // Also see RetryDetail and Help types for other details about handling a
- // quota failure.
- message QuotaFailure {
- // A message type used to describe a single quota violation. For example, a
- // daily quota or a custom quota that was exceeded.
- message Violation {
- // The subject on which the quota check failed.
- // For example, "clientip:<ip address of client>" or "project:<Google
- // developer project id>".
- string subject = 1;
- // A description of how the quota check failed. Clients can use this
- // description to find more about the quota configuration in the service's
- // public documentation, or find the relevant quota limit to adjust through
- // developer console.
- //
- // For example: "Service disabled" or "Daily Limit for read operations
- // exceeded".
- string description = 2;
- }
- // Describes all quota violations.
- repeated Violation violations = 1;
- }
- // Describes what preconditions have failed.
- //
- // For example, if an RPC failed because it required the Terms of Service to be
- // acknowledged, it could list the terms of service violation in the
- // PreconditionFailure message.
- message PreconditionFailure {
- // A message type used to describe a single precondition failure.
- message Violation {
- // The type of PreconditionFailure. We recommend using a service-specific
- // enum type to define the supported precondition violation types. For
- // example, "TOS" for "Terms of Service violation".
- string type = 1;
- // The subject, relative to the type, that failed.
- // For example, "google.com/cloud" relative to the "TOS" type would
- // indicate which terms of service is being referenced.
- string subject = 2;
- // A description of how the precondition failed. Developers can use this
- // description to understand how to fix the failure.
- //
- // For example: "Terms of service not accepted".
- string description = 3;
- }
- // Describes all precondition violations.
- repeated Violation violations = 1;
- }
- // Describes violations in a client request. This error type focuses on the
- // syntactic aspects of the request.
- message BadRequest {
- // A message type used to describe a single bad request field.
- message FieldViolation {
- // A path leading to a field in the request body. The value will be a
- // sequence of dot-separated identifiers that identify a protocol buffer
- // field. E.g., "field_violations.field" would identify this field.
- string field = 1;
- // A description of why the request element is bad.
- string description = 2;
- }
- // Describes all violations in a client request.
- repeated FieldViolation field_violations = 1;
- }
- // Contains metadata about the request that clients can attach when filing a bug
- // or providing other forms of feedback.
- message RequestInfo {
- // An opaque string that should only be interpreted by the service generating
- // it. For example, it can be used to identify requests in the service's logs.
- string request_id = 1;
- // Any data that was used to serve this request. For example, an encrypted
- // stack trace that can be sent back to the service provider for debugging.
- string serving_data = 2;
- }
- // Describes the resource that is being accessed.
- message ResourceInfo {
- // A name for the type of resource being accessed, e.g. "sql table",
- // "cloud storage bucket", "file", "Google calendar"; or the type URL
- // of the resource: e.g. "type.googleapis.com/google.pubsub.v1.Topic".
- string resource_type = 1;
- // The name of the resource being accessed. For example, a shared calendar
- // name: "example.com_4fghdhgsrgh@group.calendar.google.com", if the current
- // error is [google.rpc.Code.PERMISSION_DENIED][google.rpc.Code.PERMISSION_DENIED].
- string resource_name = 2;
- // The owner of the resource (optional).
- // For example, "user:<owner email>" or "project:<Google developer project
- // id>".
- string owner = 3;
- // Describes what error is encountered when accessing this resource.
- // For example, updating a cloud project may require the `writer` permission
- // on the developer console project.
- string description = 4;
- }
- // Provides links to documentation or for performing an out of band action.
- //
- // For example, if a quota check failed with an error indicating the calling
- // project hasn't enabled the accessed service, this can contain a URL pointing
- // directly to the right place in the developer console to flip the bit.
- message Help {
- // Describes a URL link.
- message Link {
- // Describes what the link offers.
- string description = 1;
- // The URL of the link.
- string url = 2;
- }
- // URL(s) pointing to additional information on handling the current error.
- repeated Link links = 1;
- }
- // Provides a localized error message that is safe to return to the user
- // which can be attached to an RPC error.
- message LocalizedMessage {
- // The locale used following the specification defined at
- // http://www.rfc-editor.org/rfc/bcp/bcp47.txt.
- // Examples are: "en-US", "fr-CH", "es-MX"
- string locale = 1;
- // The localized error message in the above locale.
- string message = 2;
- }
|