1 // Copyright (c) 2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2016 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
6 #ifndef BITCOIN_RPCPROTOCOL_H
7 #define BITCOIN_RPCPROTOCOL_H
22 HTTP_BAD_REQUEST
= 400,
23 HTTP_UNAUTHORIZED
= 401,
26 HTTP_BAD_METHOD
= 405,
27 HTTP_INTERNAL_SERVER_ERROR
= 500,
28 HTTP_SERVICE_UNAVAILABLE
= 503,
31 //! Bitcoin RPC error codes
34 //! Standard JSON-RPC 2.0 errors
35 // RPC_INVALID_REQUEST is internally mapped to HTTP_BAD_REQUEST (400).
36 // It should not be used for application-layer errors.
37 RPC_INVALID_REQUEST
= -32600,
38 // RPC_METHOD_NOT_FOUND is internally mapped to HTTP_NOT_FOUND (404).
39 // It should not be used for application-layer errors.
40 RPC_METHOD_NOT_FOUND
= -32601,
41 RPC_INVALID_PARAMS
= -32602,
42 // RPC_INTERNAL_ERROR should only be used for genuine errors in bitcoind
43 // (for example datadir corruption).
44 RPC_INTERNAL_ERROR
= -32603,
45 RPC_PARSE_ERROR
= -32700,
47 //! General application defined errors
48 RPC_MISC_ERROR
= -1, //!< std::exception thrown in command handling
49 RPC_FORBIDDEN_BY_SAFE_MODE
= -2, //!< Server is in safe mode, and command is not allowed in safe mode
50 RPC_TYPE_ERROR
= -3, //!< Unexpected type was passed as parameter
51 RPC_INVALID_ADDRESS_OR_KEY
= -5, //!< Invalid address or key
52 RPC_OUT_OF_MEMORY
= -7, //!< Ran out of memory during operation
53 RPC_INVALID_PARAMETER
= -8, //!< Invalid, missing or duplicate parameter
54 RPC_DATABASE_ERROR
= -20, //!< Database error
55 RPC_DESERIALIZATION_ERROR
= -22, //!< Error parsing or validating structure in raw format
56 RPC_VERIFY_ERROR
= -25, //!< General error during transaction or block submission
57 RPC_VERIFY_REJECTED
= -26, //!< Transaction or block was rejected by network rules
58 RPC_VERIFY_ALREADY_IN_CHAIN
= -27, //!< Transaction already in chain
59 RPC_IN_WARMUP
= -28, //!< Client still warming up
61 //! Aliases for backward compatibility
62 RPC_TRANSACTION_ERROR
= RPC_VERIFY_ERROR
,
63 RPC_TRANSACTION_REJECTED
= RPC_VERIFY_REJECTED
,
64 RPC_TRANSACTION_ALREADY_IN_CHAIN
= RPC_VERIFY_ALREADY_IN_CHAIN
,
67 RPC_CLIENT_NOT_CONNECTED
= -9, //!< Bitcoin is not connected
68 RPC_CLIENT_IN_INITIAL_DOWNLOAD
= -10, //!< Still downloading initial blocks
69 RPC_CLIENT_NODE_ALREADY_ADDED
= -23, //!< Node is already added
70 RPC_CLIENT_NODE_NOT_ADDED
= -24, //!< Node has not been added before
71 RPC_CLIENT_NODE_NOT_CONNECTED
= -29, //!< Node to disconnect not found in connected nodes
72 RPC_CLIENT_INVALID_IP_OR_SUBNET
= -30, //!< Invalid IP/Subnet
73 RPC_CLIENT_P2P_DISABLED
= -31, //!< No valid connection manager instance found
76 RPC_WALLET_ERROR
= -4, //!< Unspecified problem with wallet (key not found etc.)
77 RPC_WALLET_INSUFFICIENT_FUNDS
= -6, //!< Not enough funds in wallet or account
78 RPC_WALLET_INVALID_ACCOUNT_NAME
= -11, //!< Invalid account name
79 RPC_WALLET_KEYPOOL_RAN_OUT
= -12, //!< Keypool ran out, call keypoolrefill first
80 RPC_WALLET_UNLOCK_NEEDED
= -13, //!< Enter the wallet passphrase with walletpassphrase first
81 RPC_WALLET_PASSPHRASE_INCORRECT
= -14, //!< The wallet passphrase entered was incorrect
82 RPC_WALLET_WRONG_ENC_STATE
= -15, //!< Command given in wrong wallet encryption state (encrypting an encrypted wallet etc.)
83 RPC_WALLET_ENCRYPTION_FAILED
= -16, //!< Failed to encrypt the wallet
84 RPC_WALLET_ALREADY_UNLOCKED
= -17, //!< Wallet is already unlocked
85 RPC_WALLET_NOT_FOUND
= -18, //!< Invalid wallet specified
86 RPC_WALLET_NOT_SPECIFIED
= -19, //!< No wallet specified (error when there are multiple wallets loaded)
89 UniValue
JSONRPCRequestObj(const std::string
& strMethod
, const UniValue
& params
, const UniValue
& id
);
90 UniValue
JSONRPCReplyObj(const UniValue
& result
, const UniValue
& error
, const UniValue
& id
);
91 std::string
JSONRPCReply(const UniValue
& result
, const UniValue
& error
, const UniValue
& id
);
92 UniValue
JSONRPCError(int code
, const std::string
& message
);
94 /** Get name of RPC authentication cookie file */
95 fs::path
GetAuthCookieFile();
96 /** Generate a new RPC authentication cookie and write it to disk */
97 bool GenerateAuthCookie(std::string
*cookie_out
);
98 /** Read the RPC authentication cookie from disk */
99 bool GetAuthCookie(std::string
*cookie_out
);
100 /** Delete RPC authentication cookie from disk */
101 void DeleteAuthCookie();
103 #endif // BITCOIN_RPCPROTOCOL_H