-
Notifications
You must be signed in to change notification settings - Fork 649
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
have verify_account_authority check passed-in keys #1384
Changes from 6 commits
7d44c3a
824ed4f
48fa400
c2b63f5
5db31f5
7e4e033
e03d329
673ac2b
f523ad6
b078310
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -663,9 +663,12 @@ class database_api | |
bool verify_authority( const signed_transaction& trx )const; | ||
|
||
/** | ||
* @return true if the signers have enough authority to authorize an account | ||
* @brief Verify that the public keys have enough authority to authorize a transaction | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why this change? There is no transaction in the API. |
||
* @param account_name_or_id the account to check | ||
* @param signers the public keys | ||
* @return true if the passed in keys have enough authority to authorize a transaction | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why this? There is no transaction in the API. |
||
*/ | ||
bool verify_account_authority( const string& account_name_or_id, const flat_set<public_key_type>& signers )const; | ||
bool verify_account_authority( const string& account_name_or_id, const flat_set<public_key_type>& signers )const; | ||
|
||
/** | ||
* Validates a transaction against the current state without broadcasting it on the network. | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -26,6 +26,7 @@ | |
|
||
#include <graphene/app/database_api.hpp> | ||
#include <graphene/wallet/wallet.hpp> | ||
#include <fc/crypto/digest.hpp> | ||
|
||
#include <iostream> | ||
|
||
|
@@ -45,7 +46,7 @@ BOOST_FIXTURE_TEST_SUITE(wallet_tests, database_fixture) | |
/*** | ||
* Act | ||
*/ | ||
int nbr_keys_desired = 3; | ||
unsigned int nbr_keys_desired = 3; | ||
vector<brain_key_info> derived_keys = graphene::wallet::utility::derive_owner_keys_from_brain_key("SOME WORDS GO HERE", nbr_keys_desired); | ||
|
||
|
||
|
@@ -70,10 +71,122 @@ BOOST_FIXTURE_TEST_SUITE(wallet_tests, database_fixture) | |
string expected_prefix = GRAPHENE_ADDRESS_PREFIX; | ||
for (auto info : derived_keys) { | ||
string description = (string) info.pub_key; | ||
BOOST_CHECK_EQUAL(0, description.find(expected_prefix)); | ||
BOOST_CHECK_EQUAL(0u, description.find(expected_prefix)); | ||
} | ||
|
||
} FC_LOG_AND_RETHROW() | ||
} | ||
|
||
BOOST_AUTO_TEST_CASE(verify_account_authority) { | ||
try { | ||
|
||
ACTORS( (nathan) ); | ||
graphene::app::database_api db_api(db); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think it's better to move these test cases to database_api_tests.cpp. |
||
|
||
// good keys | ||
flat_set<public_key_type> public_keys; | ||
public_keys.emplace(nathan_public_key); | ||
BOOST_CHECK(db_api.verify_account_authority( "nathan", public_keys)); | ||
|
||
// bad keys | ||
flat_set<public_key_type> bad_public_keys; | ||
bad_public_keys.emplace(public_key_type("BTS6MkMxwBjFWmcDjXRoJ4mW9Hd4LCSPwtv9tKG1qYW5Kgu4AhoZy")); | ||
BOOST_CHECK(!db_api.verify_account_authority( "nathan", bad_public_keys)); | ||
|
||
} FC_LOG_AND_RETHROW() | ||
} | ||
|
||
BOOST_AUTO_TEST_CASE( any_two_of_three ) | ||
{ | ||
try { | ||
fc::ecc::private_key nathan_key1 = fc::ecc::private_key::regenerate(fc::digest("key1")); | ||
fc::ecc::private_key nathan_key2 = fc::ecc::private_key::regenerate(fc::digest("key2")); | ||
fc::ecc::private_key nathan_key3 = fc::ecc::private_key::regenerate(fc::digest("key3")); | ||
const account_object& nathan = create_account("nathan", nathan_key1.get_public_key() ); | ||
fund(nathan); | ||
graphene::app::database_api db_api(db); | ||
|
||
try { | ||
account_update_operation op; | ||
op.account = nathan.id; | ||
op.active = authority(2, public_key_type(nathan_key1.get_public_key()), 1, | ||
public_key_type(nathan_key2.get_public_key()), 1, public_key_type(nathan_key3.get_public_key()), 1); | ||
op.owner = *op.active; | ||
trx.operations.push_back(op); | ||
sign(trx, nathan_key1); | ||
PUSH_TX( db, trx, database::skip_transaction_dupe_check ); | ||
trx.clear(); | ||
} FC_CAPTURE_AND_RETHROW ((nathan.active)) | ||
|
||
// two keys should work | ||
{ | ||
flat_set<public_key_type> public_keys; | ||
public_keys.emplace(nathan_key1.get_public_key()); | ||
public_keys.emplace(nathan_key2.get_public_key()); | ||
BOOST_CHECK(db_api.verify_account_authority("nathan", public_keys)); | ||
} | ||
|
||
// the other two keys should work | ||
{ | ||
flat_set<public_key_type> public_keys; | ||
public_keys.emplace(nathan_key2.get_public_key()); | ||
public_keys.emplace(nathan_key3.get_public_key()); | ||
BOOST_CHECK(db_api.verify_account_authority("nathan", public_keys)); | ||
} | ||
|
||
// just one key should not work | ||
{ | ||
flat_set<public_key_type> public_keys; | ||
public_keys.emplace(nathan_key1.get_public_key()); | ||
BOOST_CHECK(!db_api.verify_account_authority("nathan", public_keys)); | ||
} | ||
} catch (fc::exception& e) { | ||
edump((e.to_detail_string())); | ||
throw; | ||
} | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please add a test where nathan's account has a multisig from one key and two other accounts. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Added what I think you are asking. It is not much different than the last, so I may be misunderstanding your request. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. IMHO we should check different combinations as in |
||
|
||
BOOST_AUTO_TEST_CASE( verify_authority_multiple_accounts ) | ||
{ | ||
try { | ||
fc::ecc::private_key nathan_key = fc::ecc::private_key::regenerate(fc::digest("key1")); | ||
fc::ecc::private_key alice_key = fc::ecc::private_key::regenerate(fc::digest("key2")); | ||
fc::ecc::private_key bob_key = fc::ecc::private_key::regenerate(fc::digest("key3")); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please use |
||
|
||
const account_object& nathan = create_account("nathan", nathan_key.get_public_key() ); | ||
fund(nathan); | ||
|
||
create_account("alice", alice_key.get_public_key() ); | ||
create_account("bob", bob_key.get_public_key() ); | ||
|
||
graphene::app::database_api db_api(db); | ||
|
||
try { | ||
account_update_operation op; | ||
op.account = nathan.id; | ||
op.active = authority(3, public_key_type(nathan_key.get_public_key()), 1, | ||
public_key_type(alice_key.get_public_key()), 1, public_key_type(bob_key.get_public_key()), 1); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Here you should use alice_id and bob_id, not their keys |
||
op.owner = *op.active; | ||
trx.operations.push_back(op); | ||
sign(trx, nathan_key); | ||
PUSH_TX( db, trx, database::skip_transaction_dupe_check ); | ||
trx.clear(); | ||
} FC_CAPTURE_AND_RETHROW ((nathan.active)) | ||
|
||
// requires 3 signatures | ||
{ | ||
flat_set<public_key_type> public_keys; | ||
public_keys.emplace(nathan_key.get_public_key()); | ||
public_keys.emplace(alice_key.get_public_key()); | ||
public_keys.emplace(bob_key.get_public_key()); | ||
BOOST_CHECK(db_api.verify_account_authority("nathan", public_keys)); | ||
} | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also need a negative test, e. g. alice_key missing. |
||
} catch (fc::exception& e) { | ||
edump((e.to_detail_string())); | ||
throw; | ||
} | ||
} | ||
|
||
BOOST_AUTO_TEST_SUITE_END() | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why not just to create
signed_transaction
and call it'sverify_authority
method ?So the full implementation of
verify_account_authority
might be like next:It's less code and more simple IMHO.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice idea, but IMO the signees field should be used as an internal cache only, not part of the tx struct's interface.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
graphene::chain::verify_authority
will usesignees
returned bysigned_transaction::get_signature_keys
method, so it should work