errors.go 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. // Copyright 2015 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package rpc
  17. import "fmt"
  18. // request is for an unknown service
  19. type methodNotFoundError struct {
  20. service string
  21. method string
  22. }
  23. func (e *methodNotFoundError) ErrorCode() int { return -32601 }
  24. func (e *methodNotFoundError) Error() string {
  25. return fmt.Sprintf("The method %s%s%s does not exist/is not available", e.service, serviceMethodSeparator, e.method)
  26. }
  27. // received message isn't a valid request
  28. type invalidRequestError struct{ message string }
  29. func (e *invalidRequestError) ErrorCode() int { return -32600 }
  30. func (e *invalidRequestError) Error() string { return e.message }
  31. // received message is invalid
  32. type invalidMessageError struct{ message string }
  33. func (e *invalidMessageError) ErrorCode() int { return -32700 }
  34. func (e *invalidMessageError) Error() string { return e.message }
  35. // unable to decode supplied params, or an invalid number of parameters
  36. type invalidParamsError struct{ message string }
  37. func (e *invalidParamsError) ErrorCode() int { return -32602 }
  38. func (e *invalidParamsError) Error() string { return e.message }
  39. // logic error, callback returned an error
  40. type callbackError struct{ message string }
  41. func (e *callbackError) ErrorCode() int { return -32000 }
  42. func (e *callbackError) Error() string { return e.message }
  43. // issued when a request is received after the server is issued to stop.
  44. type shutdownError struct{}
  45. func (e *shutdownError) ErrorCode() int { return -32000 }
  46. func (e *shutdownError) Error() string { return "server is shutting down" }