|  | // Copyright 2016 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; | 
|  |  | 
|  | option go_package = "google.golang.org/genproto/googleapis/rpc/code;code"; | 
|  | option java_multiple_files = true; | 
|  | option java_outer_classname = "CodeProto"; | 
|  | option java_package = "com.google.rpc"; | 
|  | option objc_class_prefix = "RPC"; | 
|  |  | 
|  |  | 
|  | // The canonical error codes for Google APIs. | 
|  | // | 
|  | // | 
|  | // Sometimes multiple error codes may apply.  Services should return | 
|  | // the most specific error code that applies.  For example, prefer | 
|  | // `OUT_OF_RANGE` over `FAILED_PRECONDITION` if both codes apply. | 
|  | // Similarly prefer `NOT_FOUND` or `ALREADY_EXISTS` over `FAILED_PRECONDITION`. | 
|  | enum Code { | 
|  | // Not an error; returned on success | 
|  | // | 
|  | // HTTP Mapping: 200 OK | 
|  | OK = 0; | 
|  |  | 
|  | // The operation was cancelled, typically by the caller. | 
|  | // | 
|  | // HTTP Mapping: 499 Client Closed Request | 
|  | CANCELLED = 1; | 
|  |  | 
|  | // Unknown error.  For example, this error may be returned when | 
|  | // a `Status` value received from another address space belongs to | 
|  | // an error space that is not known in this address space.  Also | 
|  | // errors raised by APIs that do not return enough error information | 
|  | // may be converted to this error. | 
|  | // | 
|  | // HTTP Mapping: 500 Internal Server Error | 
|  | UNKNOWN = 2; | 
|  |  | 
|  | // The client specified an invalid argument.  Note that this differs | 
|  | // from `FAILED_PRECONDITION`.  `INVALID_ARGUMENT` indicates arguments | 
|  | // that are problematic regardless of the state of the system | 
|  | // (e.g., a malformed file name). | 
|  | // | 
|  | // HTTP Mapping: 400 Bad Request | 
|  | INVALID_ARGUMENT = 3; | 
|  |  | 
|  | // The deadline expired before the operation could complete. For operations | 
|  | // that change the state of the system, this error may be returned | 
|  | // even if the operation has completed successfully.  For example, a | 
|  | // successful response from a server could have been delayed long | 
|  | // enough for the deadline to expire. | 
|  | // | 
|  | // HTTP Mapping: 504 Gateway Timeout | 
|  | DEADLINE_EXCEEDED = 4; | 
|  |  | 
|  | // Some requested entity (e.g., file or directory) was not found. | 
|  | // For privacy reasons, this code *may* be returned when the client | 
|  | // does not have the access rights to the entity, though such usage is | 
|  | // discouraged. | 
|  | // | 
|  | // HTTP Mapping: 404 Not Found | 
|  | NOT_FOUND = 5; | 
|  |  | 
|  | // The entity that a client attempted to create (e.g., file or directory) | 
|  | // already exists. | 
|  | // | 
|  | // HTTP Mapping: 409 Conflict | 
|  | ALREADY_EXISTS = 6; | 
|  |  | 
|  | // The caller does not have permission to execute the specified | 
|  | // operation. `PERMISSION_DENIED` must not be used for rejections | 
|  | // caused by exhausting some resource (use `RESOURCE_EXHAUSTED` | 
|  | // instead for those errors). `PERMISSION_DENIED` must not be | 
|  | // used if the caller can not be identified (use `UNAUTHENTICATED` | 
|  | // instead for those errors). | 
|  | // | 
|  | // HTTP Mapping: 403 Forbidden | 
|  | PERMISSION_DENIED = 7; | 
|  |  | 
|  | // The request does not have valid authentication credentials for the | 
|  | // operation. | 
|  | // | 
|  | // HTTP Mapping: 401 Unauthorized | 
|  | UNAUTHENTICATED = 16; | 
|  |  | 
|  | // Some resource has been exhausted, perhaps a per-user quota, or | 
|  | // perhaps the entire file system is out of space. | 
|  | // | 
|  | // HTTP Mapping: 429 Too Many Requests | 
|  | RESOURCE_EXHAUSTED = 8; | 
|  |  | 
|  | // The operation was rejected because the system is not in a state | 
|  | // required for the operation's execution.  For example, the directory | 
|  | // to be deleted is non-empty, an rmdir operation is applied to | 
|  | // a non-directory, etc. | 
|  | // | 
|  | // Service implementors can use the following guidelines to decide | 
|  | // between `FAILED_PRECONDITION`, `ABORTED`, and `UNAVAILABLE`: | 
|  | //  (a) Use `UNAVAILABLE` if the client can retry just the failing call. | 
|  | //  (b) Use `ABORTED` if the client should retry at a higher level | 
|  | //      (e.g., restarting a read-modify-write sequence). | 
|  | //  (c) Use `FAILED_PRECONDITION` if the client should not retry until | 
|  | //      the system state has been explicitly fixed.  E.g., if an "rmdir" | 
|  | //      fails because the directory is non-empty, `FAILED_PRECONDITION` | 
|  | //      should be returned since the client should not retry unless | 
|  | //      the files are deleted from the directory. | 
|  | // | 
|  | // HTTP Mapping: 400 Bad Request | 
|  | FAILED_PRECONDITION = 9; | 
|  |  | 
|  | // The operation was aborted, typically due to a concurrency issue such as | 
|  | // a sequencer check failure or transaction abort. | 
|  | // | 
|  | // See the guidelines above for deciding between `FAILED_PRECONDITION`, | 
|  | // `ABORTED`, and `UNAVAILABLE`. | 
|  | // | 
|  | // HTTP Mapping: 409 Conflict | 
|  | ABORTED = 10; | 
|  |  | 
|  | // The operation was attempted past the valid range.  E.g., seeking or | 
|  | // reading past end-of-file. | 
|  | // | 
|  | // Unlike `INVALID_ARGUMENT`, this error indicates a problem that may | 
|  | // be fixed if the system state changes. For example, a 32-bit file | 
|  | // system will generate `INVALID_ARGUMENT` if asked to read at an | 
|  | // offset that is not in the range [0,2^32-1], but it will generate | 
|  | // `OUT_OF_RANGE` if asked to read from an offset past the current | 
|  | // file size. | 
|  | // | 
|  | // There is a fair bit of overlap between `FAILED_PRECONDITION` and | 
|  | // `OUT_OF_RANGE`.  We recommend using `OUT_OF_RANGE` (the more specific | 
|  | // error) when it applies so that callers who are iterating through | 
|  | // a space can easily look for an `OUT_OF_RANGE` error to detect when | 
|  | // they are done. | 
|  | // | 
|  | // HTTP Mapping: 400 Bad Request | 
|  | OUT_OF_RANGE = 11; | 
|  |  | 
|  | // The operation is not implemented or is not supported/enabled in this | 
|  | // service. | 
|  | // | 
|  | // HTTP Mapping: 501 Not Implemented | 
|  | UNIMPLEMENTED = 12; | 
|  |  | 
|  | // Internal errors.  This means that some invariants expected by the | 
|  | // underlying system have been broken.  This error code is reserved | 
|  | // for serious errors. | 
|  | // | 
|  | // HTTP Mapping: 500 Internal Server Error | 
|  | INTERNAL = 13; | 
|  |  | 
|  | // The service is currently unavailable.  This is most likely a | 
|  | // transient condition, which can be corrected by retrying with | 
|  | // a backoff. | 
|  | // | 
|  | // See the guidelines above for deciding between `FAILED_PRECONDITION`, | 
|  | // `ABORTED`, and `UNAVAILABLE`. | 
|  | // | 
|  | // HTTP Mapping: 503 Service Unavailable | 
|  | UNAVAILABLE = 14; | 
|  |  | 
|  | // Unrecoverable data loss or corruption. | 
|  | // | 
|  | // HTTP Mapping: 500 Internal Server Error | 
|  | DATA_LOSS = 15; | 
|  | } |