Skip to content

Commit

Permalink
Method 'changeparams' moved to 'eosio.init' contract + RAM, voting bl…
Browse files Browse the repository at this point in the history
…ockades
  • Loading branch information
Mariusz-Trela committed Nov 6, 2018
1 parent a67ca43 commit f4a8956
Show file tree
Hide file tree
Showing 11 changed files with 197 additions and 235 deletions.
33 changes: 2 additions & 31 deletions contracts/eosio.distribution/eosio.distribution.abi
Original file line number Diff line number Diff line change
Expand Up @@ -2,38 +2,9 @@
"____comment": "This file was generated by eosio-abigen. DO NOT EDIT - 2018-08-07T12:16:31",
"version": "eosio::abi/1.0",
"types": [],
"structs": [{
"name": "beos_global_state_element",
"base": "",
"fields": [
{"name":"starting_block_for_distribution", "type":"uint64"},
{"name":"ending_block_for_distribution", "type":"uint64"},
{"name":"distribution_payment_block_interval_for_distribution", "type":"uint64"},
{"name":"amount_of_reward", "type":"uint64"}
]
},{
"name": "beos_global_state",
"base": "",
"fields": [
{"name":"proxy_asset", "type":"asset"},
{"name":"starting_block_for_initial_witness_election", "type":"uint64"},
{"name":"beos", "type":"beos_global_state_element"},
{"name":"ram", "type":"beos_global_state_element"},
{"name":"trustee", "type":"beos_global_state_element"}
]
},{
"name": "changeparams",
"base": "",
"fields": [
{"name":"new_params", "type":"beos_global_state"}
]
},
"structs": [
],
"actions": [{
"name": "changeparams",
"type": "changeparams",
"ricardian_contract": ""
}
"actions": [
],
"tables": [],
"ricardian_clauses": [],
Expand Down
78 changes: 10 additions & 68 deletions contracts/eosio.distribution/eosio.distribution.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,61 +7,12 @@
namespace eosio {

distribution::distribution( account_name self )
: contract( self ),
_beos_global( _self, _self )
: contract( self )
{
_beos_gstate = _beos_global.exists() ? _beos_global.get() : get_beos_default_parameters();
}

distribution::~distribution()
{
_beos_global.set( _beos_gstate, _self );
}

beos_global_state distribution::get_beos_default_parameters()
{
beos_global_state dp;

dp.proxy_asset = eosio::init(N(beos.init)).get_proxy_asset();

dp.starting_block_for_initial_witness_election = eosio::init(N(beos.init)).get_starting_block_for_initial_witness_election();

dp.beos.starting_block_for_distribution = eosio::init(N(beos.init)).get_starting_block_for_beos_distribution();
dp.beos.ending_block_for_distribution = eosio::init(N(beos.init)).get_ending_block_for_beos_distribution();
dp.beos.distribution_payment_block_interval_for_distribution = eosio::init(N(beos.init)).get_distribution_payment_block_interval_for_beos_distribution();
dp.beos.amount_of_reward = eosio::init(N(beos.init)).get_amount_of_reward_beos();

dp.ram.starting_block_for_distribution = eosio::init(N(beos.init)).get_starting_block_for_ram_distribution();
dp.ram.ending_block_for_distribution = eosio::init(N(beos.init)).get_ending_block_for_ram_distribution();
dp.ram.distribution_payment_block_interval_for_distribution = eosio::init(N(beos.init)).get_distribution_payment_block_interval_for_ram_distribution();
dp.ram.amount_of_reward = eosio::init(N(beos.init)).get_amount_of_reward_ram();

dp.trustee.starting_block_for_distribution = eosio::init(N(beos.init)).get_starting_block_for_trustee_distribution();
dp.trustee.ending_block_for_distribution = eosio::init(N(beos.init)).get_ending_block_for_trustee_distribution();
dp.trustee.distribution_payment_block_interval_for_distribution = eosio::init(N(beos.init)).get_distribution_payment_block_interval_for_trustee_distribution();
dp.trustee.amount_of_reward = eosio::init(N(beos.init)).get_amount_of_reward_trustee();

checker( dp );

return dp;
}

void distribution::checker( const beos_global_state_element& state )
{
eosio_assert( state.starting_block_for_distribution > 0, "STARTING_BLOCK_FOR_DISTRIBUTION > 0" );
eosio_assert( state.ending_block_for_distribution > state.starting_block_for_distribution, "ENDING_BLOCK_FOR_DISTRIBUTION > STARTING_BLOCK_FOR_DISTRIBUTION" );
eosio_assert( state.distribution_payment_block_interval_for_distribution > 0, "DISTRIBUTION_PAYMENT_BLOCK_INTERVAL_FOR_DISTRIBUTION > 0" );
eosio_assert( state.amount_of_reward > 0, "AMOUNT_OF_REWARD > 0" );
}

//Checking basic dependencies between BEOS parameters.
void distribution::checker( const beos_global_state& state )
{
eosio_assert( state.starting_block_for_initial_witness_election > 0, "STARTING_BLOCK_FOR_INITIAL_WITNESS_ELECTION > 0" );

checker( state.beos );
checker( state.ram );
checker( state.trustee );
}

void distribution::execute( uint64_t block_nr, asset proxy_asset, uint64_t starting_block_for_any_distribution, uint64_t ending_block_for_any_distribution,
Expand Down Expand Up @@ -93,21 +44,23 @@ void distribution::execute( uint64_t block_nr, asset proxy_asset, uint64_t start
void distribution::onblock( block_timestamp timestamp, account_name producer )
{
uint64_t block_nr = static_cast< uint64_t >( get_blockchain_block_number() );
eosio::beos_global_state b_state = eosio::init( N(beos.init), true/*read_only*/ ).get_beos_global_state();

//Rewarding staked BEOSes, issuing BEOSes.
execute( block_nr, _beos_gstate.proxy_asset, _beos_gstate.beos.starting_block_for_distribution, _beos_gstate.beos.ending_block_for_distribution,
_beos_gstate.beos.distribution_payment_block_interval_for_distribution, _beos_gstate.beos.amount_of_reward, true/*is_beos_mode*/ );
execute( block_nr, b_state.proxy_asset, b_state.beos.starting_block_for_distribution, b_state.beos.ending_block_for_distribution,
b_state.beos.distribution_payment_block_interval_for_distribution, b_state.beos.amount_of_reward, true/*is_beos_mode*/ );

//Rewarding staked RAM, buying RAM.
execute( block_nr, _beos_gstate.proxy_asset, _beos_gstate.ram.starting_block_for_distribution, _beos_gstate.ram.ending_block_for_distribution,
_beos_gstate.ram.distribution_payment_block_interval_for_distribution, _beos_gstate.ram.amount_of_reward, false/*is_beos_mode*/ );
execute( block_nr, b_state.proxy_asset, b_state.ram.starting_block_for_distribution, b_state.ram.ending_block_for_distribution,
b_state.ram.distribution_payment_block_interval_for_distribution, b_state.ram.amount_of_reward, false/*is_beos_mode*/ );

}

uint64_t distribution::get_sum()
{
auto issued = eosio::token( N(eosio.token) ).get_supply( _beos_gstate.proxy_asset.symbol.name() ).amount;
auto withdrawn = eosio::token( N(eosio.token) ).check_balance( N(beos.gateway), _beos_gstate.proxy_asset.symbol.name() ).amount;
eosio::beos_global_state b_state = eosio::init( N(beos.init), true/*read_only*/ ).get_beos_global_state();
auto issued = eosio::token( N(eosio.token) ).get_supply( b_state.proxy_asset.symbol.name() ).amount;
auto withdrawn = eosio::token( N(eosio.token) ).check_balance( N(beos.gateway), b_state.proxy_asset.symbol.name() ).amount;

eosio_assert( issued >= withdrawn, "issued PXBTS >= withdrawn PXBTS" );

Expand Down Expand Up @@ -173,17 +126,6 @@ void distribution::review( ConstModifier&& mod )
}
}

//It is possible to change any parameter at runtime.
void distribution::changeparams( beos_global_state new_params )
{
require_auth( _self );

checker( new_params );

_beos_gstate = new_params;
_beos_global.set( _beos_gstate, _self );
}

} /// namespace eosio

EOSIO_ABI( eosio::distribution, (onblock)(changeparams) )
EOSIO_ABI( eosio::distribution, (onblock) )
48 changes: 0 additions & 48 deletions contracts/eosio.distribution/eosio.distribution.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,60 +12,14 @@
#include <eosio.init/eosio.init.hpp>
#include <eosio.gateway/eosio.gateway.hpp>

#include <string>

namespace eosio {

using std::string;

struct beos_global_state_element
{
uint64_t starting_block_for_distribution;
uint64_t ending_block_for_distribution;
uint64_t distribution_payment_block_interval_for_distribution;
uint64_t amount_of_reward;

EOSLIB_SERIALIZE( beos_global_state_element,

(starting_block_for_distribution)
(ending_block_for_distribution)
(distribution_payment_block_interval_for_distribution)
(amount_of_reward) )
};

struct beos_global_state
{
asset proxy_asset;
uint64_t starting_block_for_initial_witness_election;

beos_global_state_element beos;
beos_global_state_element ram;
beos_global_state_element trustee;

EOSLIB_SERIALIZE( beos_global_state,

(proxy_asset)
(starting_block_for_initial_witness_election)
(beos)
(ram)
(trustee) )
};

typedef eosio::singleton<N(beosglobal), beos_global_state> beos_global_state_singleton;

class distribution : public contract {

private:

using ConstModifier = std::function< void( const init_data& a )>;

beos_global_state _beos_gstate;
beos_global_state_singleton _beos_global;

beos_global_state get_beos_default_parameters();
void checker( const beos_global_state_element& state );
void checker( const beos_global_state& state );

uint64_t get_sum();
void review( ConstModifier&& mod );

Expand All @@ -81,8 +35,6 @@ namespace eosio {
~distribution();

void onblock( block_timestamp timestamp, account_name producer );
void changeparams( beos_global_state new_params );

};

} /// namespace eosio
33 changes: 31 additions & 2 deletions contracts/eosio.init/eosio.init.abi
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,37 @@
"____comment": "This file was generated by eosio-abigen. DO NOT EDIT - 2018-08-13T14:53:00",
"version": "eosio::abi/1.0",
"types": [],
"structs": [],
"actions": [],
"structs": [{
"name": "beos_global_state_element",
"base": "",
"fields": [
{"name":"starting_block_for_distribution", "type":"uint64"},
{"name":"ending_block_for_distribution", "type":"uint64"},
{"name":"distribution_payment_block_interval_for_distribution", "type":"uint64"},
{"name":"amount_of_reward", "type":"uint64"}
]
},{
"name": "beos_global_state",
"base": "",
"fields": [
{"name":"proxy_asset", "type":"asset"},
{"name":"starting_block_for_initial_witness_election", "type":"uint64"},
{"name":"beos", "type":"beos_global_state_element"},
{"name":"ram", "type":"beos_global_state_element"},
{"name":"trustee", "type":"beos_global_state_element"}
]
},{
"name": "changeparams",
"base": "",
"fields": [
{"name":"new_params", "type":"beos_global_state"}
]
}],
"actions": [{
"name": "changeparams",
"type": "changeparams",
"ricardian_contract": ""
}],
"tables": [],
"ricardian_clauses": [],
"error_messages": [],
Expand Down
13 changes: 12 additions & 1 deletion contracts/eosio.init/eosio.init.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,17 @@

namespace eosio {

//It is possible to change any parameter at runtime.
void init::changeparams( beos_global_state new_params )
{
require_auth( _self );

checker( new_params );

_beos_gstate = new_params;
_beos_global.set( _beos_gstate, _self );
}

} /// namespace eosio

EOSIO_ABI( eosio::init, )
EOSIO_ABI( eosio::init, (changeparams) )
2 changes: 1 addition & 1 deletion contracts/eosio.system/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@ configure_file("${ABI_FILES}" "${CMAKE_CURRENT_BINARY_DIR}" COPYONLY)

add_wast_executable(TARGET eosio.system
INCLUDE_FOLDERS ${STANDARD_INCLUDE_FOLDERS}
LIBRARIES libc++ libc eosiolib eosio.token
LIBRARIES libc++ libc eosiolib eosio.token beoslib
DESTINATION_FOLDER ${CMAKE_CURRENT_BINARY_DIR}
)
18 changes: 17 additions & 1 deletion contracts/eosio.system/delegate_bandwidth.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@

#include <eosio.token/eosio.token.hpp>

#include <eosio.init/eosio.init.hpp>
#include <beoslib/beos_privileged.hpp>

#include <cmath>
#include <map>
Expand Down Expand Up @@ -80,12 +82,20 @@ namespace eosiosystem {
typedef eosio::multi_index< N(delband), delegated_bandwidth> del_bandwidth_table;
typedef eosio::multi_index< N(refunds), refund_request> refunds_table;


bool system_contract::is_allowed_ram_operation() const {
//RAM shouldn't be liquid during distribution period.
uint64_t block_nr = static_cast< uint64_t >( get_blockchain_block_number() );
eosio::beos_global_state b_state = eosio::init( N(beos.init), true/*read_only*/ ).get_beos_global_state();
return block_nr > b_state.ram.ending_block_for_distribution;
}

/**
* This action will buy an exact amount of ram and bill the payer the current market price.
*/
void system_contract::buyrambytes( account_name payer, account_name receiver, uint32_t bytes ) {

eosio_assert( is_allowed_ram_operation(), "RAM shouldn't be liquid during distribution period" );

auto itr = _rammarket.find(S(4,RAMCORE));
auto tmp = *itr;
auto eosout = tmp.convert( asset(bytes,S(0,RAM)), CORE_SYMBOL );
Expand All @@ -104,6 +114,8 @@ namespace eosiosystem {
*/
void system_contract::buyram( account_name payer, account_name receiver, asset quant )
{
eosio_assert( is_allowed_ram_operation(), "RAM shouldn't be liquid during distribution period" );

require_auth( payer );
eosio_assert( quant.amount > 0, "must purchase a positive amount" );

Expand Down Expand Up @@ -221,6 +233,9 @@ namespace eosiosystem {
* for RAM over time.
*/
void system_contract::sellram( account_name account, int64_t bytes ) {

eosio_assert( is_allowed_ram_operation(), "RAM shouldn't be liquid during distribution period" );

require_auth( account );
eosio_assert( bytes > 0, "cannot sell negative byte" );

Expand Down Expand Up @@ -417,6 +432,7 @@ namespace eosiosystem {
}

// update voting power
if( is_allowed_vote_operation() )
{
asset total_update = stake_net_delta + stake_cpu_delta;
auto from_voter = _voters.find(from);
Expand Down
3 changes: 3 additions & 0 deletions contracts/eosio.system/eosio.system.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,9 @@ namespace eosiosystem {
void delegateram( account_name payer, account_name receiver, int64_t bytes );
void reward( account_name receiver, int64_t ram_bytes, asset net_weight, asset cpu_weight );

bool is_allowed_vote_operation() const;
bool is_allowed_ram_operation() const;

private:
void update_elected_producers( block_timestamp timestamp );

Expand Down
Loading

0 comments on commit f4a8956

Please sign in to comment.