mirror of
https://github.com/XRPLF/rippled.git
synced 2025-12-06 17:27:55 +00:00
41 lines
1.1 KiB
C++
41 lines
1.1 KiB
C++
#ifndef XRPL_PROTOCOL_STPARSEDJSON_H_INCLUDED
|
|
#define XRPL_PROTOCOL_STPARSEDJSON_H_INCLUDED
|
|
|
|
#include <xrpl/protocol/STArray.h>
|
|
|
|
#include <optional>
|
|
|
|
namespace ripple {
|
|
|
|
/** Holds the serialized result of parsing an input JSON object.
|
|
This does validation and checking on the provided JSON.
|
|
*/
|
|
class STParsedJSONObject
|
|
{
|
|
public:
|
|
/** Parses and creates an STParsedJSON object.
|
|
The result of the parsing is stored in object and error.
|
|
Exceptions:
|
|
Does not throw.
|
|
@param name The name of the JSON field, used in diagnostics.
|
|
@param json The JSON-RPC to parse.
|
|
*/
|
|
STParsedJSONObject(std::string const& name, Json::Value const& json);
|
|
|
|
STParsedJSONObject() = delete;
|
|
STParsedJSONObject(STParsedJSONObject const&) = delete;
|
|
STParsedJSONObject&
|
|
operator=(STParsedJSONObject const&) = delete;
|
|
~STParsedJSONObject() = default;
|
|
|
|
/** The STObject if the parse was successful. */
|
|
std::optional<STObject> object;
|
|
|
|
/** On failure, an appropriate set of error values. */
|
|
Json::Value error;
|
|
};
|
|
|
|
} // namespace ripple
|
|
|
|
#endif
|