mirror of
https://github.com/XRPLF/clio.git
synced 2025-11-18 18:55:51 +00:00
* Implement logging abstraction (#371) Fixes #290 * Fix pre-commit to only check staged files * Implement account ownership check and fix paging (#383) Fixes #222 * Remove the github action package signing step This will be done elsewhere. * include searched_all in error response of tx (#407) * helper function for subscribe to ensure cleanup (#402) * Add closed to header for all paths of ledger_data (#416) Fixes #219 * Add custom error for malformed owner and request (#417) Fixes #274 * Use custom malformedAddress error in ledger_entry (#419) Fixes #272 * Return lgrIdxsInvalid error for ledger_max_index less than ledger_min_index (#339) Fixes #263 * Update headers to use #pragma once * Add custom error for malformed request (#414) Fixes #276 * Return srcCurMalformed on invalid taker_pays in book_offers (#413) Fixes #267 * Fix source_location issue on MacOSX and Debug build (#431) Fixes #428 * Implement always adding git ref to version string (#430) Fixes #427 * add connection counting (#433) * Fix malformed output format over ws rpc (#426) Fixes #405 * Remove branch name from version string (#437) Fixes a bug from #430 * Implement cli parsing using boost::po (#436) Fixes #367 * Update documentation and config with ssl_cert_file and ssl_key_file (#443) Fixes #424 * Fix gateway balances to match rippled output (#441) Fixes #271 * Update README and example config to describe start_sequence (#438) Fixes #250 * Add copyright to top of each source file (#444) Fixes #411 * Increase file descriptor limit (#449) * Update readme with more log configurations (#447) Fixes #446 * Document dos_guard in example config. Log when client surpasses rate limit (#451) * Add unit tests for DOSGuard (#453) Fixes #452 * Build macOS and Ubuntu 22.04 (#456) build release/x.y.z branches * Add time measurement profiler (#458) Rebase * Match format to rippled error code (#461) Fixes #263 * Change error message to match rippled (#463) Fixes #263 * Add requests limit to DosGuard (#462) Fixing #448 * Set version to 1.0.4-rc2 Co-authored-by: Alex Kremer <akremer@ripple.com> Co-authored-by: CJ Cobb <46455409+cjcobb23@users.noreply.github.com> Co-authored-by: Francis Mendoza <francissamuelmendoza7@gmail.com> Co-authored-by: cyan317 <120398799+cindyyan317@users.noreply.github.com>
257 lines
6.3 KiB
C++
257 lines
6.3 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of clio: https://github.com/XRPLF/clio
|
|
Copyright (c) 2022, the clio developers.
|
|
|
|
Permission to use, copy, modify, and distribute this software for any
|
|
purpose with or without fee is hereby granted, provided that the above
|
|
copyright notice and this permission notice appear in all copies.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
//==============================================================================
|
|
|
|
#pragma once
|
|
|
|
#include <ripple/protocol/ErrorCodes.h>
|
|
|
|
#include <boost/json.hpp>
|
|
|
|
#include <optional>
|
|
#include <string>
|
|
#include <string_view>
|
|
#include <variant>
|
|
|
|
namespace RPC {
|
|
|
|
/**
|
|
* @brief Custom clio RPC Errors.
|
|
*/
|
|
enum class ClioError {
|
|
rpcMALFORMED_CURRENCY = 5000,
|
|
rpcMALFORMED_REQUEST = 5001,
|
|
rpcMALFORMED_OWNER = 5002,
|
|
rpcMALFORMED_ADDRESS = 5003,
|
|
};
|
|
|
|
/**
|
|
* @brief Holds info about a particular @ref ClioError.
|
|
*/
|
|
struct ClioErrorInfo
|
|
{
|
|
ClioError const code;
|
|
std::string_view const error;
|
|
std::string_view const message;
|
|
};
|
|
|
|
/**
|
|
* @brief Clio uses compatible Rippled error codes for most RPC errors.
|
|
*/
|
|
using RippledError = ripple::error_code_i;
|
|
|
|
/**
|
|
* @brief Clio operates on a combination of Rippled and Custom Clio error codes.
|
|
*
|
|
* @see RippledError For rippled error codes
|
|
* @see ClioError For custom clio error codes
|
|
*/
|
|
using CombinedError = std::variant<RippledError, ClioError>;
|
|
|
|
/**
|
|
* @brief A status returned from any RPC handler.
|
|
*/
|
|
struct Status
|
|
{
|
|
CombinedError code = RippledError::rpcSUCCESS;
|
|
std::string error = "";
|
|
std::string message = "";
|
|
std::optional<boost::json::object> extraInfo;
|
|
|
|
Status() = default;
|
|
/* implicit */ Status(CombinedError code) : code(code){};
|
|
Status(CombinedError code, boost::json::object&& extraInfo)
|
|
: code(code), extraInfo(std::move(extraInfo)){};
|
|
|
|
// HACK. Some rippled handlers explicitly specify errors.
|
|
// This means that we have to be able to duplicate this
|
|
// functionality.
|
|
explicit Status(std::string const& message)
|
|
: code(ripple::rpcUNKNOWN), message(message)
|
|
{
|
|
}
|
|
|
|
Status(CombinedError code, std::string message)
|
|
: code(code), message(message)
|
|
{
|
|
}
|
|
|
|
Status(CombinedError code, std::string error, std::string message)
|
|
: code(code), error(error), message(message)
|
|
{
|
|
}
|
|
|
|
/**
|
|
* @brief Returns true if the Status is *not* OK.
|
|
*/
|
|
operator bool() const
|
|
{
|
|
if (auto err = std::get_if<RippledError>(&code))
|
|
return *err != RippledError::rpcSUCCESS;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @brief Returns true if the Status contains the desired @ref RippledError
|
|
*
|
|
* @param other The RippledError to match
|
|
* @return bool true if status matches given error; false otherwise
|
|
*/
|
|
bool
|
|
operator==(RippledError other) const
|
|
{
|
|
if (auto err = std::get_if<RippledError>(&code))
|
|
return *err == other;
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* @brief Returns true if the Status contains the desired @ref ClioError
|
|
*
|
|
* @param other The RippledError to match
|
|
* @return bool true if status matches given error; false otherwise
|
|
*/
|
|
bool
|
|
operator==(ClioError other) const
|
|
{
|
|
if (auto err = std::get_if<ClioError>(&code))
|
|
return *err == other;
|
|
return false;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @brief Warning codes that can be returned by clio.
|
|
*/
|
|
enum WarningCode {
|
|
warnUNKNOWN = -1,
|
|
warnRPC_CLIO = 2001,
|
|
warnRPC_OUTDATED = 2002,
|
|
warnRPC_RATE_LIMIT = 2003
|
|
};
|
|
|
|
/**
|
|
* @brief Holds information about a clio warning.
|
|
*/
|
|
struct WarningInfo
|
|
{
|
|
constexpr WarningInfo() = default;
|
|
constexpr WarningInfo(WarningCode code, char const* message)
|
|
: code(code), message(message)
|
|
{
|
|
}
|
|
|
|
WarningCode code = warnUNKNOWN;
|
|
std::string_view const message = "unknown warning";
|
|
};
|
|
|
|
/**
|
|
* @brief Invalid parameters error.
|
|
*/
|
|
class InvalidParamsError : public std::exception
|
|
{
|
|
std::string msg;
|
|
|
|
public:
|
|
explicit InvalidParamsError(std::string const& msg) : msg(msg)
|
|
{
|
|
}
|
|
|
|
const char*
|
|
what() const throw() override
|
|
{
|
|
return msg.c_str();
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @brief Account not found error.
|
|
*/
|
|
class AccountNotFoundError : public std::exception
|
|
{
|
|
std::string account;
|
|
|
|
public:
|
|
explicit AccountNotFoundError(std::string const& acct) : account(acct)
|
|
{
|
|
}
|
|
const char*
|
|
what() const throw() override
|
|
{
|
|
return account.c_str();
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @brief A globally available @ref Status that represents a successful state
|
|
*/
|
|
static Status OK;
|
|
|
|
/**
|
|
* @brief Get the warning info object from a warning code.
|
|
*
|
|
* @param code The warning code
|
|
* @return WarningInfo const& A reference to the static warning info
|
|
*/
|
|
WarningInfo const&
|
|
getWarningInfo(WarningCode code);
|
|
|
|
/**
|
|
* @brief Generate JSON from a warning code.
|
|
*
|
|
* @param code The @ref WarningCode
|
|
* @return boost::json::object The JSON output
|
|
*/
|
|
boost::json::object
|
|
makeWarning(WarningCode code);
|
|
|
|
/**
|
|
* @brief Generate JSON from a @ref Status.
|
|
*
|
|
* @param status The @ref Status
|
|
* @return boost::json::object The JSON output
|
|
*/
|
|
boost::json::object
|
|
makeError(Status const& status);
|
|
|
|
/**
|
|
* @brief Generate JSON from a @ref RippledError.
|
|
*
|
|
* @param status The rippled @ref RippledError
|
|
* @return boost::json::object The JSON output
|
|
*/
|
|
boost::json::object
|
|
makeError(
|
|
RippledError err,
|
|
std::optional<std::string_view> customError = std::nullopt,
|
|
std::optional<std::string_view> customMessage = std::nullopt);
|
|
|
|
/**
|
|
* @brief Generate JSON from a @ref ClioError.
|
|
*
|
|
* @param status The clio's custom @ref ClioError
|
|
* @return boost::json::object The JSON output
|
|
*/
|
|
boost::json::object
|
|
makeError(
|
|
ClioError err,
|
|
std::optional<std::string_view> customError = std::nullopt,
|
|
std::optional<std::string_view> customMessage = std::nullopt);
|
|
|
|
} // namespace RPC
|