cubefs
244 строки · 8.9 Кб
1/*
2*
3* Copyright 2014 gRPC authors.
4*
5* Licensed under the Apache License, Version 2.0 (the "License");
6* you may not use this file except in compliance with the License.
7* You may obtain a copy of the License at
8*
9* http://www.apache.org/licenses/LICENSE-2.0
10*
11* Unless required by applicable law or agreed to in writing, software
12* distributed under the License is distributed on an "AS IS" BASIS,
13* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14* See the License for the specific language governing permissions and
15* limitations under the License.
16*
17*/
18
19// Package codes defines the canonical error codes used by gRPC. It is
20// consistent across various languages.
21package codes // import "google.golang.org/grpc/codes"22
23import (24"fmt"25"strconv"26)
27
28// A Code is an unsigned 32-bit error code as defined in the gRPC spec.
29type Code uint3230
31const (32// OK is returned on success.33OK Code = 034
35// Canceled indicates the operation was canceled (typically by the caller).36//37// The gRPC framework will generate this error code when cancellation38// is requested.39Canceled Code = 140
41// Unknown error. An example of where this error may be returned is42// if a Status value received from another address space belongs to43// an error-space that is not known in this address space. Also44// errors raised by APIs that do not return enough error information45// may be converted to this error.46//47// The gRPC framework will generate this error code in the above two48// mentioned cases.49Unknown Code = 250
51// InvalidArgument indicates client specified an invalid argument.52// Note that this differs from FailedPrecondition. It indicates arguments53// that are problematic regardless of the state of the system54// (e.g., a malformed file name).55//56// This error code will not be generated by the gRPC framework.57InvalidArgument Code = 358
59// DeadlineExceeded means operation expired before completion.60// For operations that change the state of the system, this error may be61// returned even if the operation has completed successfully. For62// example, a successful response from a server could have been delayed63// long enough for the deadline to expire.64//65// The gRPC framework will generate this error code when the deadline is66// exceeded.67DeadlineExceeded Code = 468
69// NotFound means some requested entity (e.g., file or directory) was70// not found.71//72// This error code will not be generated by the gRPC framework.73NotFound Code = 574
75// AlreadyExists means an attempt to create an entity failed because one76// already exists.77//78// This error code will not be generated by the gRPC framework.79AlreadyExists Code = 680
81// PermissionDenied indicates the caller does not have permission to82// execute the specified operation. It must not be used for rejections83// caused by exhausting some resource (use ResourceExhausted84// instead for those errors). It must not be85// used if the caller cannot be identified (use Unauthenticated86// instead for those errors).87//88// This error code will not be generated by the gRPC core framework,89// but expect authentication middleware to use it.90PermissionDenied Code = 791
92// ResourceExhausted indicates some resource has been exhausted, perhaps93// a per-user quota, or perhaps the entire file system is out of space.94//95// This error code will be generated by the gRPC framework in96// out-of-memory and server overload situations, or when a message is97// larger than the configured maximum size.98ResourceExhausted Code = 899
100// FailedPrecondition indicates operation was rejected because the101// system is not in a state required for the operation's execution.102// For example, directory to be deleted may be non-empty, an rmdir103// operation is applied to a non-directory, etc.104//105// A litmus test that may help a service implementor in deciding106// between FailedPrecondition, Aborted, and Unavailable:107// (a) Use Unavailable if the client can retry just the failing call.108// (b) Use Aborted if the client should retry at a higher-level109// (e.g., restarting a read-modify-write sequence).110// (c) Use FailedPrecondition if the client should not retry until111// the system state has been explicitly fixed. E.g., if an "rmdir"112// fails because the directory is non-empty, FailedPrecondition113// should be returned since the client should not retry unless114// they have first fixed up the directory by deleting files from it.115// (d) Use FailedPrecondition if the client performs conditional116// REST Get/Update/Delete on a resource and the resource on the117// server does not match the condition. E.g., conflicting118// read-modify-write on the same resource.119//120// This error code will not be generated by the gRPC framework.121FailedPrecondition Code = 9122
123// Aborted indicates the operation was aborted, typically due to a124// concurrency issue like sequencer check failures, transaction aborts,125// etc.126//127// See litmus test above for deciding between FailedPrecondition,128// Aborted, and Unavailable.129//130// This error code will not be generated by the gRPC framework.131Aborted Code = 10132
133// OutOfRange means operation was attempted past the valid range.134// E.g., seeking or reading past end of file.135//136// Unlike InvalidArgument, this error indicates a problem that may137// be fixed if the system state changes. For example, a 32-bit file138// system will generate InvalidArgument if asked to read at an139// offset that is not in the range [0,2^32-1], but it will generate140// OutOfRange if asked to read from an offset past the current141// file size.142//143// There is a fair bit of overlap between FailedPrecondition and144// OutOfRange. We recommend using OutOfRange (the more specific145// error) when it applies so that callers who are iterating through146// a space can easily look for an OutOfRange error to detect when147// they are done.148//149// This error code will not be generated by the gRPC framework.150OutOfRange Code = 11151
152// Unimplemented indicates operation is not implemented or not153// supported/enabled in this service.154//155// This error code will be generated by the gRPC framework. Most156// commonly, you will see this error code when a method implementation157// is missing on the server. It can also be generated for unknown158// compression algorithms or a disagreement as to whether an RPC should159// be streaming.160Unimplemented Code = 12161
162// Internal errors. Means some invariants expected by underlying163// system has been broken. If you see one of these errors,164// something is very broken.165//166// This error code will be generated by the gRPC framework in several167// internal error conditions.168Internal Code = 13169
170// Unavailable indicates the service is currently unavailable.171// This is a most likely a transient condition and may be corrected172// by retrying with a backoff. Note that it is not always safe to retry173// non-idempotent operations.174//175// See litmus test above for deciding between FailedPrecondition,176// Aborted, and Unavailable.177//178// This error code will be generated by the gRPC framework during179// abrupt shutdown of a server process or network connection.180Unavailable Code = 14181
182// DataLoss indicates unrecoverable data loss or corruption.183//184// This error code will not be generated by the gRPC framework.185DataLoss Code = 15186
187// Unauthenticated indicates the request does not have valid188// authentication credentials for the operation.189//190// The gRPC framework will generate this error code when the191// authentication metadata is invalid or a Credentials callback fails,192// but also expect authentication middleware to generate it.193Unauthenticated Code = 16194
195_maxCode = 17196)
197
198var strToCode = map[string]Code{199`"OK"`: OK,200`"CANCELLED"`:/* [sic] */ Canceled,201`"UNKNOWN"`: Unknown,202`"INVALID_ARGUMENT"`: InvalidArgument,203`"DEADLINE_EXCEEDED"`: DeadlineExceeded,204`"NOT_FOUND"`: NotFound,205`"ALREADY_EXISTS"`: AlreadyExists,206`"PERMISSION_DENIED"`: PermissionDenied,207`"RESOURCE_EXHAUSTED"`: ResourceExhausted,208`"FAILED_PRECONDITION"`: FailedPrecondition,209`"ABORTED"`: Aborted,210`"OUT_OF_RANGE"`: OutOfRange,211`"UNIMPLEMENTED"`: Unimplemented,212`"INTERNAL"`: Internal,213`"UNAVAILABLE"`: Unavailable,214`"DATA_LOSS"`: DataLoss,215`"UNAUTHENTICATED"`: Unauthenticated,216}
217
218// UnmarshalJSON unmarshals b into the Code.
219func (c *Code) UnmarshalJSON(b []byte) error {220// From json.Unmarshaler: By convention, to approximate the behavior of221// Unmarshal itself, Unmarshalers implement UnmarshalJSON([]byte("null")) as222// a no-op.223if string(b) == "null" {224return nil225}226if c == nil {227return fmt.Errorf("nil receiver passed to UnmarshalJSON")228}229
230if ci, err := strconv.ParseUint(string(b), 10, 32); err == nil {231if ci >= _maxCode {232return fmt.Errorf("invalid code: %q", ci)233}234
235*c = Code(ci)236return nil237}238
239if jc, ok := strToCode[string(b)]; ok {240*c = jc241return nil242}243return fmt.Errorf("invalid code: %q", string(b))244}
245