From 61110fdf3dc7990fb4b044dad2037a88d9bae237 Mon Sep 17 00:00:00 2001 From: Denis Carriere Date: Tue, 18 Oct 2022 23:00:52 -0400 Subject: [PATCH 1/3] Fix setcontracts ref: https://github.com/eosnetworkfoundation/eosio.yield-contracts/issues/25 https://github.com/eosnetworkfoundation/eosio.yield-contracts/issues/24 --- contracts/eosio.yield/eosio.yield.cpp | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/contracts/eosio.yield/eosio.yield.cpp b/contracts/eosio.yield/eosio.yield.cpp index f0645a7..d3495bb 100644 --- a/contracts/eosio.yield/eosio.yield.cpp +++ b/contracts/eosio.yield/eosio.yield.cpp @@ -330,8 +330,10 @@ void yield::report( const name protocol, const time_point_sec period, const uint void yield::setcontracts( const name protocol, const set contracts ) { const auto config = get_config(); - const bool is_admin = has_auth( config.admin_contract ); - if ( !is_admin ) require_auth( protocol ); + + // override permission is required to allow certain protocols with nulled permission to be added to Yield+ + const bool is_override = has_auth( get_self() ); + if ( !is_override ) require_auth( protocol ); yield::protocols_table _protocols( get_self(), get_self().value ); auto & itr = _protocols.get(protocol.value, "yield::setcontracts: [protocol] does not exists"); @@ -339,18 +341,21 @@ void yield::setcontracts( const name protocol, const set contracts ) // require authority of all EOS contracts linked to protocol for ( const name contract : contracts ) { check( is_account( contract ), "yield::setcontracts: [contract=" + contract.to_string() + "] account does not exists"); - if ( !is_admin ) require_auth( contract ); + + // override permission does not need to validate contract permission + if ( !is_override ) require_auth( contract ); } // modify contracts - const set before_contracts = itr.contracts; - const name ram_payer = is_admin ? config.admin_contract : protocol; + const name ram_payer = is_override ? config.admin_contract : protocol; _protocols.modify( itr, ram_payer, [&]( auto& row ) { + check( row.contracts != contracts, "yield::setcontracts: [contracts] was not modified"); row.contracts = contracts; - if ( contracts.size() > 1 ) row.status = "pending"_n; // must be re-approved if contracts changed row.updated_at = current_time_point(); - check( row.contracts != before_contracts, "yield::setcontracts: [contracts] was not modified"); }); + + // protocol must be re-approved if `setcontracts` action is called + set_status( protocol, "pending"_n ); remove_active_protocol( protocol ); // logging From f78dbbc4d5e1bbc392029c06a1ee27a19db16ede Mon Sep 17 00:00:00 2001 From: Denis Carriere Date: Wed, 19 Oct 2022 09:50:10 -0400 Subject: [PATCH 2/3] fix set status --- contracts/eosio.yield/eosio.yield.cpp | 2 +- contracts/eosio.yield/eosio.yield.spec.ts | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/contracts/eosio.yield/eosio.yield.cpp b/contracts/eosio.yield/eosio.yield.cpp index d3495bb..94ce41a 100644 --- a/contracts/eosio.yield/eosio.yield.cpp +++ b/contracts/eosio.yield/eosio.yield.cpp @@ -142,8 +142,8 @@ void yield::set_status( const name protocol, const name status ) auto & itr = _protocols.get(protocol.value, "yield::set_status: [protocol] does not exists"); check( PROTOCOL_STATUS_TYPES.find( status ) != PROTOCOL_STATUS_TYPES.end(), "yield::set_status: [status] is invalid"); + if ( itr.status == status ) return; // no status change _protocols.modify( itr, same_payer, [&]( auto& row ) { - check( row.status != status, "yield::set_status: [status] not modified"); row.status = status; }); diff --git a/contracts/eosio.yield/eosio.yield.spec.ts b/contracts/eosio.yield/eosio.yield.spec.ts index 2fdf843..d8c13a0 100644 --- a/contracts/eosio.yield/eosio.yield.spec.ts +++ b/contracts/eosio.yield/eosio.yield.spec.ts @@ -145,7 +145,7 @@ describe('eosio.yield', () => { const protocol = getProtocol("myprotocol"); expect(protocol.contracts).toEqual(eos_contracts); - const action = contracts.yield.eosio.actions.setcontracts([ "not.exists", eos_contracts ]).send("admin.yield"); + const action = contracts.yield.eosio.actions.setcontracts([ "not.exists", eos_contracts ]).send(); await expectToThrow(action, "does not exists"); }); @@ -164,7 +164,7 @@ describe('eosio.yield', () => { }); it("setcontracts - protocol not included by default", async () => { - await contracts.yield.eosio.actions.setcontracts([ "myprotocol", ["vault"] ]).send("admin.yield"); + await contracts.yield.eosio.actions.setcontracts([ "myprotocol", ["vault"] ]).send(); const protocol = getProtocol("myprotocol"); expect(protocol.contracts).toEqual(["vault"]); }); From 65e84adba06661c1bc8347472ad0dab192b2245d Mon Sep 17 00:00:00 2001 From: Denis Carriere Date: Wed, 19 Oct 2022 11:22:39 -0400 Subject: [PATCH 3/3] Improve silent status logs Fixes https://github.com/eosnetworkfoundation/eosio.yield-contracts/issues/23 --- contracts/eosio.yield/eosio.yield.cpp | 20 +++++++++++++++----- contracts/oracle.yield/oracle.yield.cpp | 15 +++++++++++---- 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/contracts/eosio.yield/eosio.yield.cpp b/contracts/eosio.yield/eosio.yield.cpp index 94ce41a..dd00f33 100644 --- a/contracts/eosio.yield/eosio.yield.cpp +++ b/contracts/eosio.yield/eosio.yield.cpp @@ -26,7 +26,6 @@ void yield::regprotocol( const name protocol, const name category, const mapstatus == "denied"_n ) set_status(protocol, "pending"_n); + // logging yield::createlog_action createlog( get_self(), { get_self(), "active"_n }); yield::metadatalog_action metadatalog( get_self(), { get_self(), "active"_n }); @@ -65,11 +67,13 @@ void yield::setmetadata( const name protocol, const map metadata ) const auto config = get_config(); const name ram_payer = has_auth( config.admin_contract ) ? config.admin_contract : protocol; _protocols.modify( itr, ram_payer, [&]( auto& row ) { - if ( row.status == "denied"_n ) row.status = "pending"_n; // if denied revert back to pending row.metadata = metadata; row.updated_at = current_time_point(); }); + // if denied revert back to pending + if ( itr.status == "denied"_n ) set_status(protocol, "pending"_n); + // logging yield::metadatalog_action metadatalog( get_self(), { get_self(), "active"_n }); metadatalog.send( protocol, itr.status, itr.category, metadata ); @@ -88,12 +92,14 @@ void yield::setmetakey( const name protocol, const name key, const optional evm ) // modify contracts const set before_evm = itr.evm; _protocols.modify( itr, protocol, [&]( auto& row ) { - row.status = "pending"_n; // must be re-approved if contracts changed row.evm = evm; row.contracts.insert(protocol); // always include EOS protocol account row.updated_at = current_time_point(); check( row.evm != before_evm, "yield::setevm: [evm] was not modified"); }); + // must be re-approved if contracts changed + set_status(protocol, "pending"_n); + // logging yield::contractslog_action contractslog( get_self(), { get_self(), "active"_n }); contractslog.send( protocol, itr.status, itr.contracts, itr.evm ); diff --git a/contracts/oracle.yield/oracle.yield.cpp b/contracts/oracle.yield/oracle.yield.cpp index b0f861d..aafbd02 100644 --- a/contracts/oracle.yield/oracle.yield.cpp +++ b/contracts/oracle.yield/oracle.yield.cpp @@ -27,7 +27,6 @@ void oracle::regoracle( const name oracle, const map metadata ) const auto config = get_config(); auto insert = [&]( auto& row ) { - if ( row.status == "denied"_n ) row.status = "pending"_n; // if denied revert back to pending row.oracle = oracle; row.metadata = metadata; row.balance.contract = config.reward_per_update.contract; @@ -36,12 +35,16 @@ void oracle::regoracle( const name oracle, const map metadata ) row.updated_at = current_time_point(); }; + // modify or create auto itr = _oracles.find( oracle.value ); const bool is_exists = itr != _oracles.end(); if ( is_exists ) _oracles.modify( itr, oracle, insert ); else _oracles.emplace( oracle, insert ); + // if denied revert back to pending + if ( itr->status == "denied"_n ) set_status(oracle, "pending"_n); + // logging oracle::createlog_action createlog( get_self(), { get_self(), "active"_n }); oracle::metadatalog_action metadatalog( get_self(), { get_self(), "active"_n }); @@ -94,11 +97,13 @@ void oracle::setmetadata( const name oracle, const map metadata ) const name ram_payer = is_admin ? config.admin_contract : oracle; _oracles.modify( itr, ram_payer, [&]( auto& row ) { - if ( row.status == "denied"_n ) row.status = "pending"_n; // if denied revert back to pending row.metadata = metadata; row.updated_at = current_time_point(); }); + // if denied revert back to pending + if ( itr.status == "denied"_n ) set_status(oracle, "pending"_n); + // logging oracle::metadatalog_action metadatalog( get_self(), { get_self(), "active"_n }); metadatalog.send( oracle, itr.status, "oracle"_n, metadata ); @@ -117,12 +122,14 @@ void oracle::setmetakey( const name oracle, const name key, const optional