1 // This file is @generated by prost-build.
2 /// The `Status` type defines a logical error model that is suitable for
3 /// different programming environments, including REST APIs and RPC APIs. It is
4 /// used by [gRPC](<https://github.com/grpc>). Each `Status` message contains
5 /// three pieces of data: error code, error message, and error details.
6 ///
7 /// You can find out more about this error model and how to work with it in the
8 /// [API Design Guide](<https://cloud.google.com/apis/design/errors>).
9 #[derive(Clone, PartialEq, ::prost::Message)]
10 pub struct Status {
11     /// The status code, which should be an enum value of \[google.rpc.Code\]\[google.rpc.Code\].
12     #[prost(int32, tag = "1")]
13     pub code: i32,
14     /// A developer-facing error message, which should be in English. Any
15     /// user-facing error message should be localized and sent in the
16     /// \[google.rpc.Status.details\]\[google.rpc.Status.details\] field, or localized by the client.
17     #[prost(string, tag = "2")]
18     pub message: ::prost::alloc::string::String,
19     /// A list of messages that carry the error details.  There is a common set of
20     /// message types for APIs to use.
21     #[prost(message, repeated, tag = "3")]
22     pub details: ::prost::alloc::vec::Vec<::prost_types::Any>,
23 }
24 /// Describes when the clients can retry a failed request. Clients could ignore
25 /// the recommendation here or retry when this information is missing from error
26 /// responses.
27 ///
28 /// It's always recommended that clients should use exponential backoff when
29 /// retrying.
30 ///
31 /// Clients should wait until `retry_delay` amount of time has passed since
32 /// receiving the error response before retrying.  If retrying requests also
33 /// fail, clients should use an exponential backoff scheme to gradually increase
34 /// the delay between retries based on `retry_delay`, until either a maximum
35 /// number of retries have been reached or a maximum retry delay cap has been
36 /// reached.
37 #[derive(Clone, Copy, PartialEq, ::prost::Message)]
38 pub struct RetryInfo {
39     /// Clients should wait at least this long between retrying the same request.
40     #[prost(message, optional, tag = "1")]
41     pub retry_delay: ::core::option::Option<::prost_types::Duration>,
42 }
43 /// Describes additional debugging info.
44 #[derive(Clone, PartialEq, ::prost::Message)]
45 pub struct DebugInfo {
46     /// The stack trace entries indicating where the error occurred.
47     #[prost(string, repeated, tag = "1")]
48     pub stack_entries: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
49     /// Additional debugging information provided by the server.
50     #[prost(string, tag = "2")]
51     pub detail: ::prost::alloc::string::String,
52 }
53 /// Describes how a quota check failed.
54 ///
55 /// For example if a daily limit was exceeded for the calling project,
56 /// a service could respond with a QuotaFailure detail containing the project
57 /// id and the description of the quota limit that was exceeded.  If the
58 /// calling project hasn't enabled the service in the developer console, then
59 /// a service could respond with the project id and set `service_disabled`
60 /// to true.
61 ///
62 /// Also see RetryInfo and Help types for other details about handling a
63 /// quota failure.
64 #[derive(Clone, PartialEq, ::prost::Message)]
65 pub struct QuotaFailure {
66     /// Describes all quota violations.
67     #[prost(message, repeated, tag = "1")]
68     pub violations: ::prost::alloc::vec::Vec<quota_failure::Violation>,
69 }
70 /// Nested message and enum types in `QuotaFailure`.
71 pub mod quota_failure {
72     /// A message type used to describe a single quota violation.  For example, a
73     /// daily quota or a custom quota that was exceeded.
74     #[derive(Clone, PartialEq, ::prost::Message)]
75     pub struct Violation {
76         /// The subject on which the quota check failed.
77         /// For example, "clientip:<ip address of client>" or "project:<Google
78         /// developer project id>".
79         #[prost(string, tag = "1")]
80         pub subject: ::prost::alloc::string::String,
81         /// A description of how the quota check failed. Clients can use this
82         /// description to find more about the quota configuration in the service's
83         /// public documentation, or find the relevant quota limit to adjust through
84         /// developer console.
85         ///
86         /// For example: "Service disabled" or "Daily Limit for read operations
87         /// exceeded".
88         #[prost(string, tag = "2")]
89         pub description: ::prost::alloc::string::String,
90     }
91 }
92 /// Describes the cause of the error with structured details.
93 ///
94 /// Example of an error when contacting the "pubsub.googleapis.com" API when it
95 /// is not enabled:
96 ///
97 /// ```text,json
98 ///     { "reason": "API_DISABLED"
99 ///       "domain": "googleapis.com"
100 ///       "metadata": {
101 ///         "resource": "projects/123",
102 ///         "service": "pubsub.googleapis.com"
103 ///       }
104 ///     }
105 /// ```
106 ///
107 /// This response indicates that the pubsub.googleapis.com API is not enabled.
108 ///
109 /// Example of an error that is returned when attempting to create a Spanner
110 /// instance in a region that is out of stock:
111 ///
112 /// ```text,json
113 ///     { "reason": "STOCKOUT"
114 ///       "domain": "spanner.googleapis.com",
115 ///       "metadata": {
116 ///         "availableRegions": "us-central1,us-east2"
117 ///       }
118 ///     }
119 /// ```
120 #[derive(Clone, PartialEq, ::prost::Message)]
121 pub struct ErrorInfo {
122     /// The reason of the error. This is a constant value that identifies the
123     /// proximate cause of the error. Error reasons are unique within a particular
124     /// domain of errors. This should be at most 63 characters and match
125     /// /\[A-Z0-9\_\]+/.
126     #[prost(string, tag = "1")]
127     pub reason: ::prost::alloc::string::String,
128     /// The logical grouping to which the "reason" belongs. The error domain
129     /// is typically the registered service name of the tool or product that
130     /// generates the error. Example: "pubsub.googleapis.com". If the error is
131     /// generated by some common infrastructure, the error domain must be a
132     /// globally unique value that identifies the infrastructure. For Google API
133     /// infrastructure, the error domain is "googleapis.com".
134     #[prost(string, tag = "2")]
135     pub domain: ::prost::alloc::string::String,
136     /// Additional structured details about this error.
137     ///
138     /// Keys should match /\[a-zA-Z0-9-\_\]/ and be limited to 64 characters in
139     /// length. When identifying the current value of an exceeded limit, the units
140     /// should be contained in the key, not the value.  For example, rather than
141     /// {"instanceLimit": "100/request"}, should be returned as,
142     /// {"instanceLimitPerRequest": "100"}, if the client exceeds the number of
143     /// instances that can be created in a single (batch) request.
144     #[prost(map = "string, string", tag = "3")]
145     pub metadata: ::std::collections::HashMap<
146         ::prost::alloc::string::String,
147         ::prost::alloc::string::String,
148     >,
149 }
150 /// Describes what preconditions have failed.
151 ///
152 /// For example, if an RPC failed because it required the Terms of Service to be
153 /// acknowledged, it could list the terms of service violation in the
154 /// PreconditionFailure message.
155 #[derive(Clone, PartialEq, ::prost::Message)]
156 pub struct PreconditionFailure {
157     /// Describes all precondition violations.
158     #[prost(message, repeated, tag = "1")]
159     pub violations: ::prost::alloc::vec::Vec<precondition_failure::Violation>,
160 }
161 /// Nested message and enum types in `PreconditionFailure`.
162 pub mod precondition_failure {
163     /// A message type used to describe a single precondition failure.
164     #[derive(Clone, PartialEq, ::prost::Message)]
165     pub struct Violation {
166         /// The type of PreconditionFailure. We recommend using a service-specific
167         /// enum type to define the supported precondition violation subjects. For
168         /// example, "TOS" for "Terms of Service violation".
169         #[prost(string, tag = "1")]
170         pub r#type: ::prost::alloc::string::String,
171         /// The subject, relative to the type, that failed.
172         /// For example, "google.com/cloud" relative to the "TOS" type would indicate
173         /// which terms of service is being referenced.
174         #[prost(string, tag = "2")]
175         pub subject: ::prost::alloc::string::String,
176         /// A description of how the precondition failed. Developers can use this
177         /// description to understand how to fix the failure.
178         ///
179         /// For example: "Terms of service not accepted".
180         #[prost(string, tag = "3")]
181         pub description: ::prost::alloc::string::String,
182     }
183 }
184 /// Describes violations in a client request. This error type focuses on the
185 /// syntactic aspects of the request.
186 #[derive(Clone, PartialEq, ::prost::Message)]
187 pub struct BadRequest {
188     /// Describes all violations in a client request.
189     #[prost(message, repeated, tag = "1")]
190     pub field_violations: ::prost::alloc::vec::Vec<bad_request::FieldViolation>,
191 }
192 /// Nested message and enum types in `BadRequest`.
193 pub mod bad_request {
194     /// A message type used to describe a single bad request field.
195     #[derive(Clone, PartialEq, ::prost::Message)]
196     pub struct FieldViolation {
197         /// A path leading to a field in the request body. The value will be a
198         /// sequence of dot-separated identifiers that identify a protocol buffer
199         /// field. E.g., "field_violations.field" would identify this field.
200         #[prost(string, tag = "1")]
201         pub field: ::prost::alloc::string::String,
202         /// A description of why the request element is bad.
203         #[prost(string, tag = "2")]
204         pub description: ::prost::alloc::string::String,
205     }
206 }
207 /// Contains metadata about the request that clients can attach when filing a bug
208 /// or providing other forms of feedback.
209 #[derive(Clone, PartialEq, ::prost::Message)]
210 pub struct RequestInfo {
211     /// An opaque string that should only be interpreted by the service generating
212     /// it. For example, it can be used to identify requests in the service's logs.
213     #[prost(string, tag = "1")]
214     pub request_id: ::prost::alloc::string::String,
215     /// Any data that was used to serve this request. For example, an encrypted
216     /// stack trace that can be sent back to the service provider for debugging.
217     #[prost(string, tag = "2")]
218     pub serving_data: ::prost::alloc::string::String,
219 }
220 /// Describes the resource that is being accessed.
221 #[derive(Clone, PartialEq, ::prost::Message)]
222 pub struct ResourceInfo {
223     /// A name for the type of resource being accessed, e.g. "sql table",
224     /// "cloud storage bucket", "file", "Google calendar"; or the type URL
225     /// of the resource: e.g. "type.googleapis.com/google.pubsub.v1.Topic".
226     #[prost(string, tag = "1")]
227     pub resource_type: ::prost::alloc::string::String,
228     /// The name of the resource being accessed.  For example, a shared calendar
229     /// name: "[email protected]", if the current
230     /// error is \[google.rpc.Code.PERMISSION_DENIED\]\[google.rpc.Code.PERMISSION_DENIED\].
231     #[prost(string, tag = "2")]
232     pub resource_name: ::prost::alloc::string::String,
233     /// The owner of the resource (optional).
234     /// For example, "user:<owner email>" or "project:<Google developer project
235     /// id>".
236     #[prost(string, tag = "3")]
237     pub owner: ::prost::alloc::string::String,
238     /// Describes what error is encountered when accessing this resource.
239     /// For example, updating a cloud project may require the `writer` permission
240     /// on the developer console project.
241     #[prost(string, tag = "4")]
242     pub description: ::prost::alloc::string::String,
243 }
244 /// Provides links to documentation or for performing an out of band action.
245 ///
246 /// For example, if a quota check failed with an error indicating the calling
247 /// project hasn't enabled the accessed service, this can contain a URL pointing
248 /// directly to the right place in the developer console to flip the bit.
249 #[derive(Clone, PartialEq, ::prost::Message)]
250 pub struct Help {
251     /// URL(s) pointing to additional information on handling the current error.
252     #[prost(message, repeated, tag = "1")]
253     pub links: ::prost::alloc::vec::Vec<help::Link>,
254 }
255 /// Nested message and enum types in `Help`.
256 pub mod help {
257     /// Describes a URL link.
258     #[derive(Clone, PartialEq, ::prost::Message)]
259     pub struct Link {
260         /// Describes what the link offers.
261         #[prost(string, tag = "1")]
262         pub description: ::prost::alloc::string::String,
263         /// The URL of the link.
264         #[prost(string, tag = "2")]
265         pub url: ::prost::alloc::string::String,
266     }
267 }
268 /// Provides a localized error message that is safe to return to the user
269 /// which can be attached to an RPC error.
270 #[derive(Clone, PartialEq, ::prost::Message)]
271 pub struct LocalizedMessage {
272     /// The locale used following the specification defined at
273     /// <http://www.rfc-editor.org/rfc/bcp/bcp47.txt.>
274     /// Examples are: "en-US", "fr-CH", "es-MX"
275     #[prost(string, tag = "1")]
276     pub locale: ::prost::alloc::string::String,
277     /// The localized error message in the above locale.
278     #[prost(string, tag = "2")]
279     pub message: ::prost::alloc::string::String,
280 }
281