mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-04 11:15:56 +00:00
- Restructures `STTx` signature checking code to be able to handle
a `sigObject`, which may be the full transaction, or may be an object
field containing a separate signature. Either way, the `sigObject` can
be a single- or multi-sign signature.
- This is distinct from 550f90a75e (#5594), which changed the check in
Transactor, which validates whether a given account is allowed to sign
for the given transaction. This cryptographically checks the signature
validity.
181 lines
4.6 KiB
C++
181 lines
4.6 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of rippled: https://github.com/ripple/rippled
|
|
Copyright (c) 2012, 2013 Ripple Labs Inc.
|
|
|
|
Permission to use, copy, modify, and/or 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.
|
|
*/
|
|
//==============================================================================
|
|
|
|
#ifndef RIPPLE_TEST_JTX_JTX_H_INCLUDED
|
|
#define RIPPLE_TEST_JTX_JTX_H_INCLUDED
|
|
|
|
#include <test/jtx/basic_prop.h>
|
|
#include <test/jtx/requires.h>
|
|
|
|
#include <xrpl/json/json_value.h>
|
|
#include <xrpl/protocol/ErrorCodes.h>
|
|
#include <xrpl/protocol/STTx.h>
|
|
#include <xrpl/protocol/TER.h>
|
|
|
|
#include <functional>
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
namespace ripple {
|
|
namespace test {
|
|
namespace jtx {
|
|
|
|
class Env;
|
|
|
|
/** Execution context for applying a JSON transaction.
|
|
This augments the transaction with various settings.
|
|
*/
|
|
struct JTx
|
|
{
|
|
Json::Value jv;
|
|
requires_t require;
|
|
std::optional<TER> ter = TER{tesSUCCESS};
|
|
std::optional<std::pair<error_code_i, std::string>> rpcCode = std::nullopt;
|
|
std::optional<std::pair<std::string, std::optional<std::string>>>
|
|
rpcException = std::nullopt;
|
|
bool fill_fee = true;
|
|
bool fill_seq = true;
|
|
bool fill_sig = true;
|
|
bool fill_netid = true;
|
|
std::shared_ptr<STTx const> stx;
|
|
// Functions that sign the transaction from the Account
|
|
std::vector<std::function<void(Env&, JTx&)>> mainSigners;
|
|
// Functions that sign something else after the mainSigners, such as
|
|
// sfCounterpartySignature
|
|
std::vector<std::function<void(Env&, JTx&)>> postSigners;
|
|
|
|
JTx() = default;
|
|
JTx(JTx const&) = default;
|
|
JTx&
|
|
operator=(JTx const&) = default;
|
|
JTx(JTx&&) = default;
|
|
JTx&
|
|
operator=(JTx&&) = default;
|
|
|
|
JTx(Json::Value&& jv_) : jv(std::move(jv_))
|
|
{
|
|
}
|
|
|
|
JTx(Json::Value const& jv_) : jv(jv_)
|
|
{
|
|
}
|
|
|
|
template <class Key>
|
|
Json::Value&
|
|
operator[](Key const& key)
|
|
{
|
|
return jv[key];
|
|
}
|
|
|
|
/** Return a property if it exists
|
|
|
|
@return nullptr if the Prop does not exist
|
|
*/
|
|
/** @{ */
|
|
template <class Prop>
|
|
Prop*
|
|
get()
|
|
{
|
|
for (auto& prop : props_.list)
|
|
{
|
|
if (auto test = dynamic_cast<prop_type<Prop>*>(prop.get()))
|
|
return &test->t;
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
template <class Prop>
|
|
Prop const*
|
|
get() const
|
|
{
|
|
for (auto& prop : props_.list)
|
|
{
|
|
if (auto test = dynamic_cast<prop_type<Prop> const*>(prop.get()))
|
|
return &test->t;
|
|
}
|
|
return nullptr;
|
|
}
|
|
/** @} */
|
|
|
|
/** Set a property
|
|
If the property already exists,
|
|
it is replaced.
|
|
*/
|
|
/** @{ */
|
|
void
|
|
set(std::unique_ptr<basic_prop> p)
|
|
{
|
|
for (auto& prop : props_.list)
|
|
{
|
|
if (prop->assignable(p.get()))
|
|
{
|
|
prop = std::move(p);
|
|
return;
|
|
}
|
|
}
|
|
props_.list.emplace_back(std::move(p));
|
|
}
|
|
|
|
template <class Prop, class... Args>
|
|
void
|
|
set(Args&&... args)
|
|
{
|
|
set(std::make_unique<prop_type<Prop>>(std::forward<Args>(args)...));
|
|
}
|
|
/** @} */
|
|
|
|
private:
|
|
struct prop_list
|
|
{
|
|
prop_list() = default;
|
|
|
|
prop_list(prop_list const& other)
|
|
{
|
|
for (auto const& prop : other.list)
|
|
list.emplace_back(prop->clone());
|
|
}
|
|
|
|
prop_list&
|
|
operator=(prop_list const& other)
|
|
{
|
|
if (this != &other)
|
|
{
|
|
list.clear();
|
|
for (auto const& prop : other.list)
|
|
list.emplace_back(prop->clone());
|
|
}
|
|
return *this;
|
|
}
|
|
|
|
prop_list(prop_list&& src) = default;
|
|
prop_list&
|
|
operator=(prop_list&& src) = default;
|
|
|
|
std::vector<std::unique_ptr<basic_prop>> list;
|
|
};
|
|
|
|
prop_list props_;
|
|
};
|
|
|
|
} // namespace jtx
|
|
} // namespace test
|
|
} // namespace ripple
|
|
|
|
#endif
|