* ppy marketplace 1 - add evaluators and objects * NFT object and basic operations * ci: update .gitlab-ci.yml * ci: update .gitlab-ci.yml * NFT evaluators and basic tests, no evaluator checks * Evaluator checks in place * ppy marketplace 2 - batch sale, offer_object escrow * Database API * Wallet API * NFT metadata implemented * Fix NFT tests * Database API for NFT metadata and enumerables * ppy marketplace 4 - Add tests NFT+Marketplace * ppy marketplace 5 - Add revenue split * ppy marketplace 6 - Remove unnecessary files * ppy marketplace 7 - Add db, wallet changes and some NFT fixes * ppy marketplace 8 - Add pagination for list APIs * New DB API, list all NFTs, list NFTs by owner * Marketplace + NFT + RBAC (#368) * rbac1 - evaluators and op validators added * rbac2 - op_type hf checks * rbac3 - tx auth verify changes * Update .gitlab-ci.yml * rbac4 - basic op tests * rbac5 - clear expired and deleted permission linked auths * rbac6 - more tests * rbac7 - more tests * rbac8 - more tests * rbac9 - wallet and db api changes * rbac10 - db api changes for required signature fetch * rbac11 - add db_api tests * rbac12 - add missing code for key auths Co-authored-by: satyakoneru <15652887+satyakoneru@users.noreply.github.com> Co-authored-by: Roshan Syed <roshan.syed.rs@gmail.com> Co-authored-by: sierra19XX <15652887+sierra19XX@users.noreply.github.com> * Fix nft_get_token_uri returning empty string * Fix nft_mint_evaluator to save token_uri * Fix cli_wallet to properly pass metadata id for nft_create * ppy marketplace 9 - FC_REFLECT offer create op * Add stricter checks to NFTs * Unlisting offers, add result in offer history object * Reverting genesis.json wrong commit * Add non-transferable non-sellable properties to NFTs * Review comments - change variable names, use scoped enums * nft_metadata_update changes * NFT HF checks and op fee addition changes * NFT make revenue_split integer from double * revenue_split condition check allow zero or above Co-authored-by: Srdjan Obucina <obucinac@gmail.com> Co-authored-by: Roshan Syed <roshan.syed.rs@gmail.com> Co-authored-by: Satyanarayana Koneru <skoneru@SK-GT.local> Co-authored-by: obucina <11353193+obucina@users.noreply.github.com> Co-authored-by: satyakoneru <15652887+satyakoneru@users.noreply.github.com>
96 lines
3.7 KiB
C++
96 lines
3.7 KiB
C++
/*
|
|
* Copyright (c) 2015 Cryptonomex, Inc., and contributors.
|
|
*
|
|
* The MIT License
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
#include <graphene/chain/database.hpp>
|
|
#include <graphene/chain/account_object.hpp>
|
|
#include <graphene/chain/proposal_object.hpp>
|
|
|
|
namespace graphene { namespace chain {
|
|
|
|
bool proposal_object::is_authorized_to_execute(database& db) const
|
|
{
|
|
transaction_evaluation_state dry_run_eval(&db);
|
|
|
|
try {
|
|
verify_authority( proposed_transaction.operations,
|
|
available_key_approvals,
|
|
[&]( account_id_type id ){ return &id(db).active; },
|
|
[&]( account_id_type id ){ return &id(db).owner; },
|
|
[&]( account_id_type id, const operation& op ){
|
|
return db.get_account_custom_authorities(id, op); },
|
|
db.get_global_properties().parameters.max_authority_depth,
|
|
true, /* allow committee */
|
|
available_active_approvals,
|
|
available_owner_approvals );
|
|
}
|
|
catch ( const fc::exception& e )
|
|
{
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
void required_approval_index::object_inserted( const object& obj )
|
|
{
|
|
assert( dynamic_cast<const proposal_object*>(&obj) );
|
|
const proposal_object& p = static_cast<const proposal_object&>(obj);
|
|
|
|
for( const auto& a : p.required_active_approvals )
|
|
_account_to_proposals[a].insert( p.id );
|
|
for( const auto& a : p.required_owner_approvals )
|
|
_account_to_proposals[a].insert( p.id );
|
|
for( const auto& a : p.available_active_approvals )
|
|
_account_to_proposals[a].insert( p.id );
|
|
for( const auto& a : p.available_owner_approvals )
|
|
_account_to_proposals[a].insert( p.id );
|
|
}
|
|
|
|
void required_approval_index::remove( account_id_type a, proposal_id_type p )
|
|
{
|
|
auto itr = _account_to_proposals.find(a);
|
|
if( itr != _account_to_proposals.end() )
|
|
{
|
|
itr->second.erase( p );
|
|
if( itr->second.empty() )
|
|
_account_to_proposals.erase( itr->first );
|
|
}
|
|
}
|
|
|
|
void required_approval_index::object_removed( const object& obj )
|
|
{
|
|
assert( dynamic_cast<const proposal_object*>(&obj) );
|
|
const proposal_object& p = static_cast<const proposal_object&>(obj);
|
|
|
|
for( const auto& a : p.required_active_approvals )
|
|
remove( a, p.id );
|
|
for( const auto& a : p.required_owner_approvals )
|
|
remove( a, p.id );
|
|
for( const auto& a : p.available_active_approvals )
|
|
remove( a, p.id );
|
|
for( const auto& a : p.available_owner_approvals )
|
|
remove( a, p.id );
|
|
}
|
|
|
|
} } // graphene::chain
|
|
|
|
GRAPHENE_EXTERNAL_SERIALIZATION( /*not extern*/, graphene::chain::proposal_object )
|