errors.go 3.64 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
// Copyright 2015 The go-ethereum Authors
// This file is part of the go-ethereum library.
//
// The go-ethereum library is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// The go-ethereum library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.

17
package rpc
18 19 20

import "fmt"

21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
// HTTPError is returned by client operations when the HTTP status code of the
// response is not a 2xx status.
type HTTPError struct {
	StatusCode int
	Status     string
	Body       []byte
}

func (err HTTPError) Error() string {
	if len(err.Body) == 0 {
		return err.Status
	}
	return fmt.Sprintf("%v: %s", err.Status, err.Body)
}

// Error wraps RPC errors, which contain an error code in addition to the message.
type Error interface {
	Error() string  // returns the message
	ErrorCode() int // returns the code
}

// A DataError contains some data in addition to the error message.
type DataError interface {
	Error() string          // returns the message
	ErrorData() interface{} // returns the error data
}

// Error types defined below are the built-in JSON-RPC errors.

50 51 52 53 54 55 56
var (
	_ Error = new(methodNotFoundError)
	_ Error = new(subscriptionNotFoundError)
	_ Error = new(parseError)
	_ Error = new(invalidRequestError)
	_ Error = new(invalidMessageError)
	_ Error = new(invalidParamsError)
57
	_ Error = new(internalServerError)
58 59
)

60 61 62 63 64 65
const (
	errcodeDefault                  = -32000
	errcodeNotificationsUnsupported = -32001
	errcodePanic                    = -32603
	errcodeMarshalError             = -32603
)
66 67

type methodNotFoundError struct{ method string }
68

69
func (e *methodNotFoundError) ErrorCode() int { return -32601 }
70 71

func (e *methodNotFoundError) Error() string {
72 73 74 75 76 77 78 79 80
	return fmt.Sprintf("the method %s does not exist/is not available", e.method)
}

type subscriptionNotFoundError struct{ namespace, subscription string }

func (e *subscriptionNotFoundError) ErrorCode() int { return -32601 }

func (e *subscriptionNotFoundError) Error() string {
	return fmt.Sprintf("no %q subscription in %s namespace", e.subscription, e.namespace)
81 82
}

83 84 85 86 87 88 89
// Invalid JSON was received by the server.
type parseError struct{ message string }

func (e *parseError) ErrorCode() int { return -32700 }

func (e *parseError) Error() string { return e.message }

90
// received message isn't a valid request
91
type invalidRequestError struct{ message string }
92

93
func (e *invalidRequestError) ErrorCode() int { return -32600 }
94

95
func (e *invalidRequestError) Error() string { return e.message }
96 97

// received message is invalid
98
type invalidMessageError struct{ message string }
99

100
func (e *invalidMessageError) ErrorCode() int { return -32700 }
101

102
func (e *invalidMessageError) Error() string { return e.message }
103 104

// unable to decode supplied params, or an invalid number of parameters
105
type invalidParamsError struct{ message string }
106

107
func (e *invalidParamsError) ErrorCode() int { return -32602 }
108

109
func (e *invalidParamsError) Error() string { return e.message }
110 111 112 113 114 115 116 117 118 119

// internalServerError is used for server errors during request processing.
type internalServerError struct {
	code    int
	message string
}

func (e *internalServerError) ErrorCode() int { return e.code }

func (e *internalServerError) Error() string { return e.message }