rippled
multisign.cpp
1 //------------------------------------------------------------------------------
2 /*
3  This file is part of rippled: https://github.com/ripple/rippled
4  Copyright (c) 2012, 2013 Ripple Labs Inc.
5 
6  Permission to use, copy, modify, and/or distribute this software for any
7  purpose with or without fee is hereby granted, provided that the above
8  copyright notice and this permission notice appear in all copies.
9 
10  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13  ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 */
18 //==============================================================================
19 
20 #include <test/jtx/multisign.h>
21 #include <test/jtx/utility.h>
22 #include <ripple/protocol/HashPrefix.h>
23 #include <ripple/protocol/jss.h>
24 #include <ripple/protocol/Sign.h>
25 #include <ripple/protocol/UintTypes.h>
26 #include <ripple/basics/contract.h>
27 
28 namespace ripple {
29 namespace test {
30 namespace jtx {
31 
33 signers (Account const& account,
34  std::uint32_t quorum,
35  std::vector<signer> const& v)
36 {
37  Json::Value jv;
38  jv[jss::Account] = account.human();
39  jv[jss::TransactionType] = jss::SignerListSet;
40  jv[sfSignerQuorum.getJsonName()] = quorum;
41  auto& ja = jv[sfSignerEntries.getJsonName()];
42  for(std::size_t i = 0; i < v.size(); ++i)
43  {
44  auto const& e = v[i];
45  auto& je = ja[i][sfSignerEntry.getJsonName()];
46  je[jss::Account] = e.account.human();
47  je[sfSignerWeight.getJsonName()] = e.weight;
48  }
49  return jv;
50 }
51 
53 signers (Account const& account, none_t)
54 {
55  Json::Value jv;
56  jv[jss::Account] = account.human();
57  jv[jss::TransactionType] = jss::SignerListSet;
58  jv[sfSignerQuorum.getJsonName()] = 0;
59  return jv;
60 }
61 
62 //------------------------------------------------------------------------------
63 
65  : signers(std::move(signers_))
66 {
67  // Signatures must be applied in sorted order.
68  std::sort(signers.begin(), signers.end(),
69  [](msig::Reg const& lhs, msig::Reg const& rhs)
70  {
71  return lhs.acct.id() < rhs.acct.id();
72  });
73 }
74 
75 void
76 msig::operator()(Env& env, JTx& jt) const
77 {
78  auto const mySigners = signers;
79  jt.signer = [mySigners, &env](Env&, JTx& jtx)
80  {
81  jtx[sfSigningPubKey.getJsonName()] = "";
82  boost::optional<STObject> st;
83  try
84  {
85  st = parse(jtx.jv);
86  }
87  catch(parse_error const&)
88  {
89  env.test.log << pretty(jtx.jv) << std::endl;
90  Rethrow();
91  }
92  auto& js = jtx[sfSigners.getJsonName()];
93  for(std::size_t i = 0; i < mySigners.size(); ++i)
94  {
95  auto const& e = mySigners[i];
96  auto& jo = js[i][sfSigner.getJsonName()];
97  jo[jss::Account] = e.acct.human();
98  jo[jss::SigningPubKey] = strHex(e.sig.pk().slice());
99 
100  Serializer ss {buildMultiSigningData (*st, e.acct.id())};
101  auto const sig = ripple::sign (
102  *publicKeyType(e.sig.pk().slice()), e.sig.sk(), ss.slice());
104  strHex(Slice{ sig.data(), sig.size() });
105  }
106  };
107 }
108 
109 } // jtx
110 } // test
111 } // ripple
ripple::test::jtx::parse_error
Thrown when parse fails.
Definition: utility.h:34
ripple::publicKeyType
boost::optional< KeyType > publicKeyType(Slice const &slice)
Returns the type of public key.
Definition: PublicKey.cpp:207
ripple::sfSigners
const SField sfSigners(access, STI_ARRAY, 3, "Signers", SField::sMD_Default, SField::notSigning)
Definition: SField.h:495
ripple::Slice
An immutable linear range of bytes.
Definition: Slice.h:43
ripple::sfSigningPubKey
const SF_Blob sfSigningPubKey(access, STI_VL, 3, "SigningPubKey")
Definition: SField.h:442
ripple::sfSignerQuorum
const SF_U32 sfSignerQuorum(access, STI_UINT32, 35, "SignerQuorum")
Definition: SField.h:372
std::vector
STL class.
std::vector::size
T size(T... args)
ripple::test::jtx::msig::msig
msig(std::vector< Reg > signers_)
Definition: multisign.cpp:64
ripple::test::jtx::msig::Reg
Definition: multisign.h:62
ripple::test::jtx::none_t
Definition: tags.h:28
ripple::sfSigner
const SField sfSigner(access, STI_OBJECT, 16, "Signer")
Definition: SField.h:489
ripple::SField::getJsonName
Json::StaticString const & getJsonName() const
Definition: SField.h:178
ripple::sfSignerEntries
const SField sfSignerEntries(access, STI_ARRAY, 4, "SignerEntries")
Definition: SField.h:496
std::sort
T sort(T... args)
ripple::test::jtx::signers
Json::Value signers(Account const &account, std::uint32_t quorum, std::vector< signer > const &v)
Definition: multisign.cpp:33
ripple::Rethrow
void Rethrow()
Rethrow the exception currently being handled.
Definition: contract.h:50
ripple::test::jtx::JTx
Execution context for applying a JSON transaction.
Definition: JTx.h:41
ripple::sfTxnSignature
const SF_Blob sfTxnSignature(access, STI_VL, 4, "TxnSignature", SField::sMD_Default, SField::notSigning)
Definition: SField.h:443
ripple::sfSignerEntry
const SField sfSignerEntry(access, STI_OBJECT, 11, "SignerEntry")
Definition: SField.h:488
std::uint32_t
ripple::test::jtx::sig
Set the regular signature on a JTx.
Definition: sig.h:33
ripple::test::jtx::msig::operator()
void operator()(Env &, JTx &jt) const
Definition: multisign.cpp:76
ripple::test::jtx::Env::test
beast::unit_test::suite & test
Definition: Env.h:120
ripple::test::jtx::JTx::signer
std::function< void(Env &, JTx &)> signer
Definition: JTx.h:50
ripple::Serializer
Definition: Serializer.h:43
ripple::test::jtx::msig::signers
std::vector< Reg > signers
Definition: multisign.h:93
ripple::sfSignerWeight
const SF_U16 sfSignerWeight(access, STI_UINT16, 3, "SignerWeight")
Definition: SField.h:332
ripple
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition: RCLCensorshipDetector.h:29
std::endl
T endl(T... args)
ripple::sign
Buffer sign(PublicKey const &pk, SecretKey const &sk, Slice const &m)
Generate a signature for a message.
Definition: SecretKey.cpp:132
std
STL namespace.
std::size_t
ripple::test::jtx::Account
Immutable cryptographic account descriptor.
Definition: Account.h:37
ripple::strHex
std::string strHex(FwdIt begin, FwdIt end)
Definition: strHex.h:70
ripple::test::jtx::parse
STObject parse(Json::Value const &jv)
Convert JSON to STObject.
Definition: utility.cpp:35
ripple::buildMultiSigningData
Serializer buildMultiSigningData(STObject const &obj, AccountID const &signingID)
Return a Serializer suitable for computing a multisigning TxnSignature.
Definition: Sign.cpp:83
ripple::test::jtx::Env
A transaction testing environment.
Definition: Env.h:117
Json::Value
Represents a JSON value.
Definition: json_value.h:141