From 03080aee288059e1d789154981745927c32adec8 Mon Sep 17 00:00:00 2001 From: Cesar Rodriguez Date: Sun, 3 Jun 2018 13:45:17 +0200 Subject: [PATCH 01/11] ricardian contracts added --- .../eosio.system/eosio.system-bidname-rc.md | 7 + .../eosio.system/eosio.system-buyram-rc.md | 16 + .../eosio.system-buyrambytes-rc.md | 16 + .../eosio.system-canceldelay-rc.md | 7 + .../eosio.system-claimrewards-rc.md | 7 + .../eosio.system-clause-constitution-rc.md | 61 + .../eosio.system-delegatebw-rc.md | 20 + .../eosio.system-newaccount-rc.md | 7 + .../eosio.system/eosio.system-refund-rc.md | 7 + .../eosio.system-regproducer-rc.md | 53 + .../eosio.system/eosio.system-sellram-rc.md | 7 + .../eosio.system/eosio.system-setprods-rc.md | 9 + .../eosio.system-undelegatebw-rc.md | 13 + .../eosio.system/eosio.system-unregprod-rc.md | 7 + .../eosio.system-voteproducer-rc.md | 13 + contracts/eosio.system/eosio.system.abi | 1189 ++++++++++++----- .../eosio.token/eosio.token-transfer-rc.md | 11 + contracts/eosio.token/eosio.token.abi | 140 +- contracts/eosiolib/core_symbol.hpp | 2 +- 19 files changed, 1244 insertions(+), 348 deletions(-) create mode 100644 contracts/eosio.system/eosio.system-bidname-rc.md create mode 100644 contracts/eosio.system/eosio.system-buyram-rc.md create mode 100644 contracts/eosio.system/eosio.system-buyrambytes-rc.md create mode 100644 contracts/eosio.system/eosio.system-canceldelay-rc.md create mode 100644 contracts/eosio.system/eosio.system-claimrewards-rc.md create mode 100644 contracts/eosio.system/eosio.system-clause-constitution-rc.md create mode 100644 contracts/eosio.system/eosio.system-delegatebw-rc.md create mode 100644 contracts/eosio.system/eosio.system-newaccount-rc.md create mode 100644 contracts/eosio.system/eosio.system-refund-rc.md create mode 100644 contracts/eosio.system/eosio.system-regproducer-rc.md create mode 100644 contracts/eosio.system/eosio.system-sellram-rc.md create mode 100644 contracts/eosio.system/eosio.system-setprods-rc.md create mode 100644 contracts/eosio.system/eosio.system-undelegatebw-rc.md create mode 100644 contracts/eosio.system/eosio.system-unregprod-rc.md create mode 100644 contracts/eosio.system/eosio.system-voteproducer-rc.md create mode 100644 contracts/eosio.token/eosio.token-transfer-rc.md diff --git a/contracts/eosio.system/eosio.system-bidname-rc.md b/contracts/eosio.system/eosio.system-bidname-rc.md new file mode 100644 index 00000000000..d077abce72f --- /dev/null +++ b/contracts/eosio.system/eosio.system-bidname-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ bidname }}` + +## Description + +The `{{ bidname }}` action places a bid on a premium account name, in the knowledge that the high bid will purchase the name. + +As an authorized party I {{ signer }} wish to bid on behalf of {{ bidder }} the amount of {{ bid }} toward purchase of the account name {{ newname }}. diff --git a/contracts/eosio.system/eosio.system-buyram-rc.md b/contracts/eosio.system/eosio.system-buyram-rc.md new file mode 100644 index 00000000000..98c775d794a --- /dev/null +++ b/contracts/eosio.system/eosio.system-buyram-rc.md @@ -0,0 +1,16 @@ +# Action - `{{ buyram }}` + +### Description + +This action will attempt to reserve about {{quant}} worth of RAM on behalf of {{receiver}}. + +{{buyer}} authorizes this contract to transfer {{quant}} to buy RAM based upon the current price as determined by the market maker algorithm. + +{{buyer}} accepts that a 0.5% fee will be charged on the amount spent and that the actual RAM received may be slightly less than expected due to the approximations necessary to enable this service. +{{buyer}} accepts that a 0.5% fee will be charged if and when they sell the RAM received. +{{buyer}} accepts that rounding errors resulting from limits of computational precision may result in less RAM being allocated. +{{buyer}} acknowledges that the supply of RAM may be increased at any time up to the limits of off-the-shelf computer equipment and that this may result in RAM selling for less than purchase price. +{{buyer}} acknowledges that the price of RAM may increase or decrease over time according to supply and demand. +{{buyer}} acknowledges that RAM is non-transferrable. +{{buyer}} acknowledges RAM currently in use by their account cannot be sold until it is freed and that freeing RAM may be subject to terms of other contracts. + diff --git a/contracts/eosio.system/eosio.system-buyrambytes-rc.md b/contracts/eosio.system/eosio.system-buyrambytes-rc.md new file mode 100644 index 00000000000..15e5b5dd8d6 --- /dev/null +++ b/contracts/eosio.system/eosio.system-buyrambytes-rc.md @@ -0,0 +1,16 @@ +# Action - `{{ buyrambytes }}` + +### Description + +This action will attempt to reserve about {{bytes}} bytes of RAM on behalf of {{receiver}}. + +{{buyer}} authorizes this contract to transfer sufficient EOS tokens to buy the RAM based upon the current price as determined by the market maker algorithm. + +{{buyer}} accepts that a 0.5% fee will be charged on the EOS spent and that the actual RAM received may be slightly less than requested due to the approximations necessary to enable this service. +{{buyer}} accepts that a 0.5% fee will be charged if and when they sell the RAM received. +{{buyer}} accepts that rounding errors resulting from limits of computational precision may result in less RAM being allocated. +{{buyer}} acknowledges that the supply of RAM may be increased at any time up to the limits of off-the-shelf computer equipment and that this may result in RAM selling for less than purchase price. +{{buyer}} acknowledges that the price of RAM may increase or decrease over time according to supply and demand. +{{buyer}} acknowledges that RAM is non-transferable. +{{buyer}} acknowledges RAM currently in use by their account cannot be sold until it is freed and that freeing RAM may be subject to terms of other contracts. + diff --git a/contracts/eosio.system/eosio.system-canceldelay-rc.md b/contracts/eosio.system/eosio.system-canceldelay-rc.md new file mode 100644 index 00000000000..90f9317e949 --- /dev/null +++ b/contracts/eosio.system/eosio.system-canceldelay-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ canceldelay }}` + +### Description + +The `{{ canceldelay }}` action cancels an existing delayed transaction. + +As an authorized party I {{ signer }} wish to invoke the authority of {{ canceling_auth }} to cancel the transaction with ID {{ trx_id }}. diff --git a/contracts/eosio.system/eosio.system-claimrewards-rc.md b/contracts/eosio.system/eosio.system-claimrewards-rc.md new file mode 100644 index 00000000000..b9f786c6c06 --- /dev/null +++ b/contracts/eosio.system/eosio.system-claimrewards-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ claimrewards }}` + +## Description + +The `{{ claimrewards }}` action allows a block producer (active or standby) to claim the system rewards due them for producing blocks and receiving votes. + +As an authorized party I {{ signer }} wish to have the rewards earned by {{ owner }} deposited into the {{ owner }} account. diff --git a/contracts/eosio.system/eosio.system-clause-constitution-rc.md b/contracts/eosio.system/eosio.system-clause-constitution-rc.md new file mode 100644 index 00000000000..a54f06c5232 --- /dev/null +++ b/contracts/eosio.system/eosio.system-clause-constitution-rc.md @@ -0,0 +1,61 @@ +This Constitution is a multi-party contract entered into by the Members by virtue of their use of this blockchain. + +# Article I - No Initiation of Violence +Members shall not initiate violence or the threat of violence against another Member. Lawful prosecution of crimes with the goal of preserving life, liberty and property does not constitute initiation of violence. + +# Article II - No Perjury +Members shall be liable for losses caused by false or misleading attestations and shall forfeit any profit gained thereby. + +# Article III - Rights +The Members grant the right of contract and of private property to each other, therefore no property shall change hands except with the consent of the owner, by a valid Arbitrator’s order, or via community referendum. This Constitution creates no positive rights for or between any Members. + +# Article IV - No Vote Buying +No Member shall offer nor accept anything of value in exchange for a vote of any type, nor shall any Member unduly influence the vote of another. + +# Article V - No Fiduciary +No Member nor EOS token holder shall have fiduciary responsibility to support the value of the EOS token. The Members do not authorize anyone to hold assets, borrow, nor contract on behalf of EOS token holders collectively. This blockchain has no owners, managers or fiduciaries; therefore, no Member shall have beneficial interest in more than 10% of the EOS token supply. + +# Article VI - Restitution +Each Member agrees that penalties for breach of contract may include, but are not limited to, fines, loss of account, and other restitution. + +# Article VII - Open Source +Each Member who makes available a smart contract on this blockchain shall be a Developer. Each Developer shall offer their smart contracts via a free and open source license, and each smart contract shall be documented with a Ricardian Contract stating the intent of all parties and naming the Arbitration Forum that will resolve disputes arising from that contract. + +# Article VIII - Language +Multi-lingual contracts must specify one prevailing language in case of dispute and the author of any translation shall be liable for losses due to their false, misleading, or ambiguous attested translations. + +# Article IX - Dispute Resolution +All disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Arbitration of the International Chamber of Commerce by one or more arbitrators appointed in accordance with the said Rules. + +# Article X - Choice of Law +Choice of law for disputes shall be, in order of precedence, this Constitution and the Maxims of Equity. + +# Article XI - Amending +This Constitution and its subordinate documents shall not be amended except by a vote of the token holders with no less than 15% vote participation among tokens and no fewer than 10% more Yes than No votes, sustained for 30 continuous days within a 120 day period. + +# Article XII - Publishing +Members may only publish information to the Blockchain that is within their right to publish. Furthermore, Members voluntarily consent for all Members to permanently and irrevocably retain a copy, analyze, and distribute all broadcast transactions and derivative information. + +# Article XIII - Informed Consent +All service providers who produce tools to facilitate the construction and signing of transactions on behalf of other Members shall present to said other Members the full Ricardian contract terms of this Constitution and other referenced contracts. Service providers shall be liable for losses resulting from failure to disclose the full Ricardian contract terms to users. + +# Article XIV - Severability +If any part of this Constitution is declared unenforceable or invalid, the remainder will continue to be valid and enforceable. + +# Article XV - Termination of Agreement +A Member is automatically released from all revocable obligations under this Constitution 3 years after the last transaction signed by that Member is incorporated into the blockchain. After 3 years of inactivity an account may be put up for auction and the proceeds distributed to all Members according to the system contract provisions then in effect for such redistribution. + +# Article XVI - Developer Liability +Members agree to hold software developers harmless for unintentional mistakes made in the expression of contractual intent, whether or not said mistakes were due to actual or perceived negligence. + +# Article XVII - Consideration +All rights and obligations under this Constitution are mutual and reciprocal and of equally significant value and cost to all parties. + +# Article XVIII - Acceptance +A contract is deemed accepted when a member signs a transaction which incorporates a TAPOS proof of a block whose implied state incorporates an ABI of said contract and said transaction is incorporated into the blockchain. + +# Article XIX - Counterparts +This Constitution may be executed in any number of counterparts, each of which when executed and delivered shall constitute a duplicate original, but all counterparts together shall constitute a single agreement. + +# Article XX - Interim Constitution +This constitution is interim and is intended to remain in effect until a permanent constitution is written and ratified in a referendum. diff --git a/contracts/eosio.system/eosio.system-delegatebw-rc.md b/contracts/eosio.system/eosio.system-delegatebw-rc.md new file mode 100644 index 00000000000..5db46687683 --- /dev/null +++ b/contracts/eosio.system/eosio.system-delegatebw-rc.md @@ -0,0 +1,20 @@ +# eosio.system delegatebw + +## delegatebw + (account_name-from; + account_name-to; + asset-stake_net_quantity; + asset-stake_cpu_quantity; + bool:transfer) + +_Intent: stake tokens for bandwidth and/or CPU and optionally transfer ownership_ + +As an authorized party I {{ signer }} wish to stake {{ asset-stake_cpu_quantity }} for CPU and {{ asset-stake_net_quantity }} for bandwidth from the liquid tokens of {{ account_name-from }} for the use of delegatee {{ account_name-to }}. + + {{if bool:transfer }} + +It is {{ bool:transfer }} that I wish these tokens to become immediately owned by the delegatee. + + {{/if}} + +As signer I stipulate that, if I am not the beneficial owner of these tokens, I have proof that I’ve been authorized to take this action by their beneficial owner(s). diff --git a/contracts/eosio.system/eosio.system-newaccount-rc.md b/contracts/eosio.system/eosio.system-newaccount-rc.md new file mode 100644 index 00000000000..35fddd67a57 --- /dev/null +++ b/contracts/eosio.system/eosio.system-newaccount-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ newaccount }}` + +### Description + +The `{{ newaccount }}` action creates a new account. + +As an authorized party I {{ signer }} wish to exercise the authority of {{ creator }} to create a new account on this system named {{ name }} such that the new account's owner public key shall be {{ owner }} and the active public key shall be {{ active }}. diff --git a/contracts/eosio.system/eosio.system-refund-rc.md b/contracts/eosio.system/eosio.system-refund-rc.md new file mode 100644 index 00000000000..6e9a8ba564d --- /dev/null +++ b/contracts/eosio.system/eosio.system-refund-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ refund }}` + +### Description + +The intent of the `{{ refund }}` action is to return previously unstaked tokens to an account after the unstaking period has elapsed. + +As an authorized party I {{ signer }} wish to have the unstaked tokens of {{ owner }} returned. diff --git a/contracts/eosio.system/eosio.system-regproducer-rc.md b/contracts/eosio.system/eosio.system-regproducer-rc.md new file mode 100644 index 00000000000..5412f8fcaad --- /dev/null +++ b/contracts/eosio.system/eosio.system-regproducer-rc.md @@ -0,0 +1,53 @@ +# eosio.system regproducer + +I, {{producer}}, hereby nominate myself for consideration as an elected block producer. + +If {{producer}} is selected to produce blocks by the eosio contract, I will sign blocks with {{producer_key}} and I hereby attest that I will keep this key secret and secure. + +If {{producer}} is unable to perform obligations under this contract I will resign my position by resubmitting this contract with the null producer key. + +I acknowledge that a block is 'objectively valid' if it conforms to the deterministic blockchain rules in force at the time of its creation, and is 'objectively invalid' if it fails to conform to those rules. + +{{producer}} hereby agrees to only use {{producer_key}} to sign messages under the following scenarios: +proposing an objectively valid block at the time appointed by the block scheduling algorithm +pre-confirming a block produced by another producer in the schedule when I find said block objectively valid +confirming a block for which {{producer}} has received 2/3+ pre-confirmation messages from other producers + +I hereby accept liability for any and all provable damages that result from my: +signing two different block proposals with the same timestamp with {{producer_key} +signing two different block proposals with the same block number with {{producer_key} +signing any block proposal which builds off of an objectively invalid block +signing a pre-confirmation for an objectively invalid block +signing a confirmation for a block for which I do not possess pre-confirmation messages from 2/3+ other producers + +I hereby agree that double-signing for a timestamp or block number in concert with 2 or more other producers shall automatically be deemed malicious and subject to a fine equal to the past year of compensation received and imediate disqualification from being a producer, and other damages. An exception may be made if {{producer}} can demonstrate that the double-signing occured due to a bug in the reference software; the burden of proof is on {{producer}}. + +I hereby agree not to interfere with the producer election process. I agree to process all producer election transactions that occur in blocks I create, to sign all objectively valid blocks I create that contain election transactions, and to sign all pre-confirmations and confirmations necessary to facilitate transfer of control to the next set of producers as determined by the system contract. + +I hereby acknowledge that 2/3+ other elected producers may vote to disqualify {{producer}} in the event {{producer}} is unable to produce blocks or is unable to be reached, according to criteria agreed to among producers. + +If {{producer}} qualifies for and chooses to collect compensation due to votes received, {{producer}} will provide a public endpoint allowing at least 100 peers to maintain synchronization with the blockchain and/or submit transactions to be included. {{producer}} shall maintain at least 1 validating node with full state and signature checking and shall report any objectively invalid blocks produced by the active block producers. Reporting shall be via a method to be agreed to among producers, said method and reports to be made public. + +The community agrees to allow {{producer}} to authenticate peers as necessary to prevent abuse and denial of service attacks; however, {{producer}} agrees not to discriminate against non-abusive peers. + +I agree to process transactions on a FIFO best-effort basis and to honestly bill transactions for measured execution time. + +I {{producer}} agree not to manipulate the contents of blocks in order to derive profit from: +the order in which transactions are included +the hash of the block that is produced + +I, {{producer}}, hereby agree to disclose and attest under penalty of perjury all ultimate beneficial owners of my company who own more than 10% and all direct shareholders. + +I, {{producer}}, hereby agree to cooperate with other block producers to carry out our respective and mutual obligations under this agreement, including but not limited to maintaining network stability and a valid blockchain. + +I, {{producer}}, agree to maintain a website hosted at {{url}} which contains up-to-date information on all disclosures required by this contract. + +I, {{producer}}, agree to set {{location}} such that {{producer}} is scheduled with minimal latency between my previous and next peer. + +I, {{producer}}, agree to maintain time synchronization within 10 ms of global atomic clock time, using a method agreed to among producers. + +I, {{producer}}, agree not to produce blocks before my scheduled time unless I have received all blocks produced by the prior producer. + +I, {{producer}}, agree not to publish blocks with timestamps more than 500ms in the future unless the prior block is more than 75% full by either CPU or network bandwidth metrics. + +I, {{producer}}, agree not to set the RAM supply to more RAM than my nodes contain and to resign if I am unable to provide the RAM approved by 2/3+ producers, as shown in the system parameters. diff --git a/contracts/eosio.system/eosio.system-sellram-rc.md b/contracts/eosio.system/eosio.system-sellram-rc.md new file mode 100644 index 00000000000..b66cf73ff42 --- /dev/null +++ b/contracts/eosio.system/eosio.system-sellram-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ sellram }}` + +## Description + +The `{{ sellram }}` action sells unused RAM for tokens. + +As an authorized party I {{ signer }} wish to sell {{ bytes }} of unused RAM from account {{ account }}. diff --git a/contracts/eosio.system/eosio.system-setprods-rc.md b/contracts/eosio.system/eosio.system-setprods-rc.md new file mode 100644 index 00000000000..e7c7349c397 --- /dev/null +++ b/contracts/eosio.system/eosio.system-setprods-rc.md @@ -0,0 +1,9 @@ +# Action - `{{ setprods }}` + +## Description + +The `{{ setprods }}` action creates a new schedule of active producers, who will produce blocks in the order given. + +THIS IS A SYSTEM COMMAND NOT AVAILABLE FOR DIRECT ACCESS BY USERS. + +As an authorized party I {{ signer }} wish to set the rotation of producers to be {{ schedule }}. diff --git a/contracts/eosio.system/eosio.system-undelegatebw-rc.md b/contracts/eosio.system/eosio.system-undelegatebw-rc.md new file mode 100644 index 00000000000..e7a1fcf3929 --- /dev/null +++ b/contracts/eosio.system/eosio.system-undelegatebw-rc.md @@ -0,0 +1,13 @@ +# eosio.system undelegatebw + +## undelegatebw + (account_name-from; + account_name-to; + asset-unstake_net_quantity; + asset-unstake_cpu_quantity) + +_Intent: unstake tokens from bandwidth_ + +As an authorized party I {{ signer }} wish to unstake {{ asset-unstake_cpu_quantity }} from CPU and {{ asset-unstake_net_quantity }} from bandwidth from the tokens owned by {{ account_name-from }} previously delegated for the use of delegatee {{ account_name-to }}. + +If I as signer am not the beneficial owner of these tokens I stipulate I have proof that I’ve been authorized to take this action by their beneficial owner(s). diff --git a/contracts/eosio.system/eosio.system-unregprod-rc.md b/contracts/eosio.system/eosio.system-unregprod-rc.md new file mode 100644 index 00000000000..8b4cc631f5f --- /dev/null +++ b/contracts/eosio.system/eosio.system-unregprod-rc.md @@ -0,0 +1,7 @@ +# Action - `{{ unregprod }}` + +## Description + +The `{{ unregprod }}` action unregisters a previously registered block producer candidate. + +As an authorized party I {{ signer }} wish to unregister the block producer candidate {{ producer }}, rendering that candidate no longer able to receive votes. diff --git a/contracts/eosio.system/eosio.system-voteproducer-rc.md b/contracts/eosio.system/eosio.system-voteproducer-rc.md new file mode 100644 index 00000000000..ad1e92f8152 --- /dev/null +++ b/contracts/eosio.system/eosio.system-voteproducer-rc.md @@ -0,0 +1,13 @@ +# Ricardian Contract for *voteproducer* + +## VOTEPRODUCER (voter; array:producers) + +_Intent: cast a valid vote for up to 30 BP candidates_ + +As an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ array:producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. + +If I am not the beneficial owner of these shares I stipulate I have proof that I’ve been authorized to vote these shares by their beneficial owner(s). + +I stipulate I have not and will not accept anything of value in exchange for these votes, on penalty of confiscation of these tokens, and other penalties. + +I acknowledge that using any system of automatic voting, re-voting, or vote refreshing, or allowing such a system to be used on my behalf or on behalf of another, is forbidden and doing so violates this contract. diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index de5389ac409..60d939aea24 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -1,566 +1,1143 @@ { - "version": "eosio::abi/1.0", - "types": [{ + "version": "eosio::abi/1.0", + "types": [ + { "new_type_name": "account_name", "type": "name" - },{ + }, + { "new_type_name": "permission_name", "type": "name" - },{ + }, + { "new_type_name": "action_name", "type": "name" - },{ + }, + { "new_type_name": "transaction_id_type", "type": "checksum256" - },{ + }, + { "new_type_name": "weight_type", "type": "uint16" - }], - "____comment": "eosio.bios structs: set_account_limits, setpriv, set_global_limits, producer_key, set_producers, require_auth are provided so abi available for deserialization in future.", - "structs": [{ + } + ], + "____comment": "eosio.bios structs: set_account_limits, setpriv, set_global_limits, producer_key, set_producers, require_auth are provided so abi available for deserialization in future.", + "structs": [ + { "name": "permission_level", "base": "", "fields": [ - {"name":"actor", "type":"account_name"}, - {"name":"permission", "type":"permission_name"} + { + "name": "actor", + "type": "account_name" + }, + { + "name": "permission", + "type": "permission_name" + } ] - },{ + }, + { "name": "key_weight", "base": "", "fields": [ - {"name":"key", "type":"public_key"}, - {"name":"weight", "type":"weight_type"} + { + "name": "key", + "type": "public_key" + }, + { + "name": "weight", + "type": "weight_type" + } ] - },{ + }, + { "name": "bidname", "base": "", "fields": [ - {"name":"bidder", "type":"account_name"}, - {"name":"newname", "type":"account_name"}, - {"name":"bid", "type":"asset"} + { + "name": "bidder", + "type": "account_name" + }, + { + "name": "newname", + "type": "account_name" + }, + { + "name": "bid", + "type": "asset" + } ] - },{ + }, + { "name": "permission_level_weight", "base": "", "fields": [ - {"name":"permission", "type":"permission_level"}, - {"name":"weight", "type":"weight_type"} + { + "name": "permission", + "type": "permission_level" + }, + { + "name": "weight", + "type": "weight_type" + } ] - },{ + }, + { "name": "wait_weight", "base": "", "fields": [ - {"name":"wait_sec", "type":"uint32"}, - {"name":"weight", "type":"weight_type"} + { + "name": "wait_sec", + "type": "uint32" + }, + { + "name": "weight", + "type": "weight_type" + } ] - },{ + }, + { "name": "authority", "base": "", "fields": [ - {"name":"threshold", "type":"uint32"}, - {"name":"keys", "type":"key_weight[]"}, - {"name":"accounts", "type":"permission_level_weight[]"}, - {"name":"waits", "type":"wait_weight[]"} + { + "name": "threshold", + "type": "uint32" + }, + { + "name": "keys", + "type": "key_weight[]" + }, + { + "name": "accounts", + "type": "permission_level_weight[]" + }, + { + "name": "waits", + "type": "wait_weight[]" + } ] - },{ + }, + { "name": "newaccount", "base": "", "fields": [ - {"name":"creator", "type":"account_name"}, - {"name":"name", "type":"account_name"}, - {"name":"owner", "type":"authority"}, - {"name":"active", "type":"authority"} + { + "name": "creator", + "type": "account_name" + }, + { + "name": "name", + "type": "account_name" + }, + { + "name": "owner", + "type": "authority" + }, + { + "name": "active", + "type": "authority" + } ] - },{ + }, + { "name": "setcode", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"vmtype", "type":"uint8"}, - {"name":"vmversion", "type":"uint8"}, - {"name":"code", "type":"bytes"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "vmtype", + "type": "uint8" + }, + { + "name": "vmversion", + "type": "uint8" + }, + { + "name": "code", + "type": "bytes" + } ] - },{ + }, + { "name": "setabi", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"abi", "type":"bytes"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "abi", + "type": "bytes" + } ] - },{ + }, + { "name": "updateauth", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"permission", "type":"permission_name"}, - {"name":"parent", "type":"permission_name"}, - {"name":"auth", "type":"authority"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "permission", + "type": "permission_name" + }, + { + "name": "parent", + "type": "permission_name" + }, + { + "name": "auth", + "type": "authority" + } ] - },{ + }, + { "name": "deleteauth", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"permission", "type":"permission_name"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "permission", + "type": "permission_name" + } ] - },{ + }, + { "name": "linkauth", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"code", "type":"account_name"}, - {"name":"type", "type":"action_name"}, - {"name":"requirement", "type":"permission_name"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "code", + "type": "account_name" + }, + { + "name": "type", + "type": "action_name" + }, + { + "name": "requirement", + "type": "permission_name" + } ] - },{ + }, + { "name": "unlinkauth", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"code", "type":"account_name"}, - {"name":"type", "type":"action_name"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "code", + "type": "account_name" + }, + { + "name": "type", + "type": "action_name" + } ] - },{ + }, + { "name": "canceldelay", "base": "", "fields": [ - {"name":"canceling_auth", "type":"permission_level"}, - {"name":"trx_id", "type":"transaction_id_type"} + { + "name": "canceling_auth", + "type": "permission_level" + }, + { + "name": "trx_id", + "type": "transaction_id_type" + } ] - },{ + }, + { "name": "onerror", "base": "", "fields": [ - {"name":"sender_id", "type":"uint128"}, - {"name":"sent_trx", "type":"bytes"} + { + "name": "sender_id", + "type": "uint128" + }, + { + "name": "sent_trx", + "type": "bytes" + } ] - },{ + }, + { "name": "buyrambytes", "base": "", "fields": [ - {"name":"payer", "type":"account_name"}, - {"name":"receiver", "type":"account_name"}, - {"name":"bytes", "type":"uint32"} + { + "name": "payer", + "type": "account_name" + }, + { + "name": "receiver", + "type": "account_name" + }, + { + "name": "bytes", + "type": "uint32" + } ] - },{ + }, + { "name": "sellram", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"bytes", "type":"uint64"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "bytes", + "type": "uint64" + } ] - },{ + }, + { "name": "buyram", "base": "", "fields": [ - {"name":"payer", "type":"account_name"}, - {"name":"receiver", "type":"account_name"}, - {"name":"quant", "type":"asset"} + { + "name": "payer", + "type": "account_name" + }, + { + "name": "receiver", + "type": "account_name" + }, + { + "name": "quant", + "type": "asset" + } ] - },{ + }, + { "name": "delegatebw", "base": "", "fields": [ - {"name":"from", "type":"account_name"}, - {"name":"receiver", "type":"account_name"}, - {"name":"stake_net_quantity", "type":"asset"}, - {"name":"stake_cpu_quantity", "type":"asset"}, - {"name":"transfer", "type":"bool"} + { + "name": "from", + "type": "account_name" + }, + { + "name": "receiver", + "type": "account_name" + }, + { + "name": "stake_net_quantity", + "type": "asset" + }, + { + "name": "stake_cpu_quantity", + "type": "asset" + }, + { + "name": "transfer", + "type": "bool" + } ] - },{ + }, + { "name": "undelegatebw", "base": "", "fields": [ - {"name":"from", "type":"account_name"}, - {"name":"receiver", "type":"account_name"}, - {"name":"unstake_net_quantity", "type":"asset"}, - {"name":"unstake_cpu_quantity", "type":"asset"} + { + "name": "from", + "type": "account_name" + }, + { + "name": "receiver", + "type": "account_name" + }, + { + "name": "unstake_net_quantity", + "type": "asset" + }, + { + "name": "unstake_cpu_quantity", + "type": "asset" + } ] - },{ + }, + { "name": "refund", "base": "", "fields": [ - {"name":"owner", "type":"account_name"} + { + "name": "owner", + "type": "account_name" + } ] - },{ + }, + { "name": "delegated_bandwidth", "base": "", "fields": [ - {"name":"from", "type":"account_name"}, - {"name":"to", "type":"account_name"}, - {"name":"net_weight", "type":"asset"}, - {"name":"cpu_weight", "type":"asset"} + { + "name": "from", + "type": "account_name" + }, + { + "name": "to", + "type": "account_name" + }, + { + "name": "net_weight", + "type": "asset" + }, + { + "name": "cpu_weight", + "type": "asset" + } ] - },{ + }, + { "name": "user_resources", "base": "", "fields": [ - {"name":"owner", "type":"account_name"}, - {"name":"net_weight", "type":"asset"}, - {"name":"cpu_weight", "type":"asset"}, - {"name":"ram_bytes", "type":"uint64"} + { + "name": "owner", + "type": "account_name" + }, + { + "name": "net_weight", + "type": "asset" + }, + { + "name": "cpu_weight", + "type": "asset" + }, + { + "name": "ram_bytes", + "type": "uint64" + } ] - },{ + }, + { "name": "total_resources", "base": "", "fields": [ - {"name":"owner", "type":"account_name"}, - {"name":"net_weight", "type":"asset"}, - {"name":"cpu_weight", "type":"asset"}, - {"name":"ram_bytes", "type":"uint64"} + { + "name": "owner", + "type": "account_name" + }, + { + "name": "net_weight", + "type": "asset" + }, + { + "name": "cpu_weight", + "type": "asset" + }, + { + "name": "ram_bytes", + "type": "uint64" + } ] - },{ + }, + { "name": "refund_request", "base": "", "fields": [ - {"name":"owner", "type":"account_name"}, - {"name":"request_time", "type":"time_point_sec"}, - {"name":"net_amount", "type":"asset"}, - {"name":"cpu_amount", "type":"asset"} + { + "name": "owner", + "type": "account_name" + }, + { + "name": "request_time", + "type": "time_point_sec" + }, + { + "name": "net_amount", + "type": "asset" + }, + { + "name": "cpu_amount", + "type": "asset" + } ] - },{ + }, + { "name": "blockchain_parameters", "base": "", "fields": [ - - {"name":"max_block_net_usage", "type":"uint64"}, - {"name":"target_block_net_usage_pct", "type":"uint32"}, - {"name":"max_transaction_net_usage", "type":"uint32"}, - {"name":"base_per_transaction_net_usage", "type":"uint32"}, - {"name":"net_usage_leeway", "type":"uint32"}, - {"name":"context_free_discount_net_usage_num", "type":"uint32"}, - {"name":"context_free_discount_net_usage_den", "type":"uint32"}, - {"name":"max_block_cpu_usage", "type":"uint32"}, - {"name":"target_block_cpu_usage_pct", "type":"uint32"}, - {"name":"max_transaction_cpu_usage", "type":"uint32"}, - {"name":"min_transaction_cpu_usage", "type":"uint32"}, - {"name":"max_transaction_lifetime", "type":"uint32"}, - {"name":"deferred_trx_expiration_window", "type":"uint32"}, - {"name":"max_transaction_delay", "type":"uint32"}, - {"name":"max_inline_action_size", "type":"uint32"}, - {"name":"max_inline_action_depth", "type":"uint16"}, - {"name":"max_authority_depth", "type":"uint16"} - - ] - },{ + { + "name": "max_block_net_usage", + "type": "uint64" + }, + { + "name": "target_block_net_usage_pct", + "type": "uint32" + }, + { + "name": "max_transaction_net_usage", + "type": "uint32" + }, + { + "name": "base_per_transaction_net_usage", + "type": "uint32" + }, + { + "name": "net_usage_leeway", + "type": "uint32" + }, + { + "name": "context_free_discount_net_usage_num", + "type": "uint32" + }, + { + "name": "context_free_discount_net_usage_den", + "type": "uint32" + }, + { + "name": "max_block_cpu_usage", + "type": "uint32" + }, + { + "name": "target_block_cpu_usage_pct", + "type": "uint32" + }, + { + "name": "max_transaction_cpu_usage", + "type": "uint32" + }, + { + "name": "min_transaction_cpu_usage", + "type": "uint32" + }, + { + "name": "max_transaction_lifetime", + "type": "uint32" + }, + { + "name": "deferred_trx_expiration_window", + "type": "uint32" + }, + { + "name": "max_transaction_delay", + "type": "uint32" + }, + { + "name": "max_inline_action_size", + "type": "uint32" + }, + { + "name": "max_inline_action_depth", + "type": "uint16" + }, + { + "name": "max_authority_depth", + "type": "uint16" + } + ] + }, + { "name": "eosio_global_state", "base": "blockchain_parameters", "fields": [ - {"name":"max_ram_size", "type":"uint64"}, - {"name":"total_ram_bytes_reserved", "type":"uint64"}, - {"name":"total_ram_stake", "type":"int64"}, - {"name":"last_producer_schedule_update", "type":"block_timestamp_type"}, - {"name":"last_pervote_bucket_fill", "type":"uint64"}, - {"name":"pervote_bucket", "type":"int64"}, - {"name":"perblock_bucket", "type":"int64"}, - {"name":"total_unpaid_blocks", "type":"uint32"}, - {"name":"total_activated_stake", "type":"int64"}, - {"name":"thresh_activated_stake_time", "type":"uint64"}, - {"name":"last_producer_schedule_size", "type":"uint16"}, - {"name":"total_producer_vote_weight", "type":"float64"}, - {"name":"last_name_close", "type":"block_timestamp_type"} - ] - },{ + { + "name": "max_ram_size", + "type": "uint64" + }, + { + "name": "total_ram_bytes_reserved", + "type": "uint64" + }, + { + "name": "total_ram_stake", + "type": "int64" + }, + { + "name": "last_producer_schedule_update", + "type": "block_timestamp_type" + }, + { + "name": "last_pervote_bucket_fill", + "type": "uint64" + }, + { + "name": "pervote_bucket", + "type": "int64" + }, + { + "name": "perblock_bucket", + "type": "int64" + }, + { + "name": "total_unpaid_blocks", + "type": "uint32" + }, + { + "name": "total_activated_stake", + "type": "int64" + }, + { + "name": "thresh_activated_stake_time", + "type": "uint64" + }, + { + "name": "last_producer_schedule_size", + "type": "uint16" + }, + { + "name": "total_producer_vote_weight", + "type": "float64" + }, + { + "name": "last_name_close", + "type": "block_timestamp_type" + } + ] + }, + { "name": "producer_info", "base": "", "fields": [ - {"name":"owner", "type":"account_name"}, - {"name":"total_votes", "type":"float64"}, - {"name":"producer_key", "type":"public_key"}, - {"name":"is_active", "type":"bool"}, - {"name":"url", "type":"string"}, - {"name":"unpaid_blocks", "type":"uint32"}, - {"name":"last_claim_time", "type":"uint64"}, - {"name":"location", "type":"uint16"} + { + "name": "owner", + "type": "account_name" + }, + { + "name": "total_votes", + "type": "float64" + }, + { + "name": "producer_key", + "type": "public_key" + }, + { + "name": "is_active", + "type": "bool" + }, + { + "name": "url", + "type": "string" + }, + { + "name": "unpaid_blocks", + "type": "uint32" + }, + { + "name": "last_claim_time", + "type": "uint64" + }, + { + "name": "location", + "type": "uint16" + } ] - },{ + }, + { "name": "regproducer", "base": "", "fields": [ - {"name":"producer", "type":"account_name"}, - {"name":"producer_key", "type":"public_key"}, - {"name":"url", "type":"string"}, - {"name":"location", "type":"uint16"} + { + "name": "producer", + "type": "account_name" + }, + { + "name": "producer_key", + "type": "public_key" + }, + { + "name": "url", + "type": "string" + }, + { + "name": "location", + "type": "uint16" + } ] - },{ + }, + { "name": "unregprod", "base": "", "fields": [ - {"name":"producer", "type":"account_name"} + { + "name": "producer", + "type": "account_name" + } ] - },{ + }, + { "name": "setram", "base": "", "fields": [ - {"name":"max_ram_size", "type":"uint64"} + { + "name": "max_ram_size", + "type": "uint64" + } ] - },{ + }, + { "name": "regproxy", "base": "", "fields": [ - {"name":"proxy", "type":"account_name"}, - {"name":"isproxy", "type":"bool"} + { + "name": "proxy", + "type": "account_name" + }, + { + "name": "isproxy", + "type": "bool" + } ] - },{ + }, + { "name": "voteproducer", "base": "", "fields": [ - {"name":"voter", "type":"account_name"}, - {"name":"proxy", "type":"account_name"}, - {"name":"producers", "type":"account_name[]"} + { + "name": "voter", + "type": "account_name" + }, + { + "name": "proxy", + "type": "account_name" + }, + { + "name": "producers", + "type": "account_name[]" + } ] - },{ + }, + { "name": "voter_info", "base": "", "fields": [ - {"name":"owner", "type":"account_name"}, - {"name":"proxy", "type":"account_name"}, - {"name":"producers", "type":"account_name[]"}, - {"name":"staked", "type":"int64"}, - {"name":"last_vote_weight", "type":"float64"}, - {"name":"proxied_vote_weight", "type":"float64"}, - {"name":"is_proxy", "type":"bool"}, - {"name":"deferred_trx_id", "type":"uint32"}, - {"name":"last_unstake_time", "type":"time_point_sec"}, - {"name":"unstaking", "type":"asset"} + { + "name": "owner", + "type": "account_name" + }, + { + "name": "proxy", + "type": "account_name" + }, + { + "name": "producers", + "type": "account_name[]" + }, + { + "name": "staked", + "type": "int64" + }, + { + "name": "last_vote_weight", + "type": "float64" + }, + { + "name": "proxied_vote_weight", + "type": "float64" + }, + { + "name": "is_proxy", + "type": "bool" + }, + { + "name": "deferred_trx_id", + "type": "uint32" + }, + { + "name": "last_unstake_time", + "type": "time_point_sec" + }, + { + "name": "unstaking", + "type": "asset" + } ] - },{ + }, + { "name": "claimrewards", "base": "", "fields": [ - {"name":"owner", "type":"account_name"} + { + "name": "owner", + "type": "account_name" + } ] - },{ + }, + { "name": "setpriv", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"is_priv", "type":"int8"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "is_priv", + "type": "int8" + } ] - },{ + }, + { "name": "rmvproducer", "base": "", "fields": [ - {"name":"producer", "type":"account_name"} + { + "name": "producer", + "type": "account_name" + } ] - },{ + }, + { "name": "set_account_limits", "base": "", "fields": [ - {"name":"account", "type":"account_name"}, - {"name":"ram_bytes", "type":"int64"}, - {"name":"net_weight", "type":"int64"}, - {"name":"cpu_weight", "type":"int64"} + { + "name": "account", + "type": "account_name" + }, + { + "name": "ram_bytes", + "type": "int64" + }, + { + "name": "net_weight", + "type": "int64" + }, + { + "name": "cpu_weight", + "type": "int64" + } ] - },{ + }, + { "name": "set_global_limits", "base": "", "fields": [ - {"name":"cpu_usec_per_period", "type":"int64"} + { + "name": "cpu_usec_per_period", + "type": "int64" + } ] - },{ + }, + { "name": "producer_key", "base": "", "fields": [ - {"name":"producer_name", "type":"account_name"}, - {"name":"block_signing_key", "type":"public_key"} + { + "name": "producer_name", + "type": "account_name" + }, + { + "name": "block_signing_key", + "type": "public_key" + } ] - },{ + }, + { "name": "set_producers", "base": "", "fields": [ - {"name":"schedule", "type":"producer_key[]"} + { + "name": "schedule", + "type": "producer_key[]" + } ] - },{ + }, + { "name": "require_auth", "base": "", "fields": [ - {"name":"from", "type":"account_name"} + { + "name": "from", + "type": "account_name" + } ] - },{ + }, + { "name": "setparams", "base": "", "fields": [ - {"name":"params", "type":"blockchain_parameters"} + { + "name": "params", + "type": "blockchain_parameters" + } ] - },{ + }, + { "name": "connector", "base": "", "fields": [ - {"name":"balance", "type":"asset"}, - {"name":"weight", "type":"float64"} + { + "name": "balance", + "type": "asset" + }, + { + "name": "weight", + "type": "float64" + } ] - },{ + }, + { "name": "exchange_state", "base": "", "fields": [ - {"name":"supply", "type":"asset"}, - {"name":"base", "type":"connector"}, - {"name":"quote", "type":"connector"} + { + "name": "supply", + "type": "asset" + }, + { + "name": "base", + "type": "connector" + }, + { + "name": "quote", + "type": "connector" + } ] } - ], - "actions": [{ - "name": "newaccount", - "type": "newaccount", - "ricardian_contract": "" - },{ - "name": "setcode", - "type": "setcode", - "ricardian_contract": "" - },{ - "name": "setabi", - "type": "setabi", - "ricardian_contract": "" - },{ - "name": "updateauth", - "type": "updateauth", - "ricardian_contract": "" - },{ - "name": "deleteauth", - "type": "deleteauth", - "ricardian_contract": "" - },{ - "name": "linkauth", - "type": "linkauth", - "ricardian_contract": "" - },{ - "name": "unlinkauth", - "type": "unlinkauth", - "ricardian_contract": "" - },{ - "name": "canceldelay", - "type": "canceldelay", - "ricardian_contract": "" - },{ - "name": "onerror", - "type": "onerror", - "ricardian_contract": "" - },{ + ], + "actions": [ + { + "name": "newaccount", + "type": "newaccount", + "ricardian_contract": "# Action - `{{ newaccount }}`\n\n### Description\n\nThe `{{ newaccount }}` action creates a new account.\n\nAs an authorized party I {{ signer }} wish to exercise the authority of {{ creator }} to create a new account on this system named {{ name }} such that the new account's owner public key shall be {{ owner }} and the active public key shall be {{ active }}.\n" + }, + { + "name": "setcode", + "type": "setcode", + "ricardian_contract": "" + }, + { + "name": "setabi", + "type": "setabi", + "ricardian_contract": "" + }, + { + "name": "updateauth", + "type": "updateauth", + "ricardian_contract": "" + }, + { + "name": "deleteauth", + "type": "deleteauth", + "ricardian_contract": "" + }, + { + "name": "linkauth", + "type": "linkauth", + "ricardian_contract": "" + }, + { + "name": "unlinkauth", + "type": "unlinkauth", + "ricardian_contract": "" + }, + { + "name": "canceldelay", + "type": "canceldelay", + "ricardian_contract": "# Action - `{{ canceldelay }}`\n\n### Description\n\nThe `{{ canceldelay }}` action cancels an existing delayed transaction.\n\nAs an authorized party I {{ signer }} wish to invoke the authority of {{ canceling_auth }} to cancel the transaction with ID {{ trx_id }}.\n" + }, + { + "name": "onerror", + "type": "onerror", + "ricardian_contract": "" + }, + { "name": "buyrambytes", "type": "buyrambytes", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ buyrambytes }}`\n\n### Description\n\nThis action will attempt to reserve about {{bytes}} bytes of RAM on behalf of {{receiver}}. \n\n{{buyer}} authorizes this contract to transfer sufficient EOS tokens to buy the RAM based upon the current price as determined by the market maker algorithm.\n\n{{buyer}} accepts that a 0.5% fee will be charged on the EOS spent and that the actual RAM received may be slightly less than requested due to the approximations necessary to enable this service.\n{{buyer}} accepts that a 0.5% fee will be charged if and when they sell the RAM received.\n{{buyer}} accepts that rounding errors resulting from limits of computational precision may result in less RAM being allocated.\n{{buyer}} acknowledges that the supply of RAM may be increased at any time up to the limits of off-the-shelf computer equipment and that this may result in RAM selling for less than purchase price.\n{{buyer}} acknowledges that the price of RAM may increase or decrease over time according to supply and demand.\n{{buyer}} acknowledges that RAM is non-transferable. \n{{buyer}} acknowledges RAM currently in use by their account cannot be sold until it is freed and that freeing RAM may be subject to terms of other contracts.\n\n" + }, + { "name": "buyram", "type": "buyram", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ buyram }}`\n\n### Description\n\nThis action will attempt to reserve about {{quant}} worth of RAM on behalf of {{receiver}}. \n\n{{buyer}} authorizes this contract to transfer {{quant}} to buy RAM based upon the current price as determined by the market maker algorithm.\n\n{{buyer}} accepts that a 0.5% fee will be charged on the amount spent and that the actual RAM received may be slightly less than expected due to the approximations necessary to enable this service.\n{{buyer}} accepts that a 0.5% fee will be charged if and when they sell the RAM received.\n{{buyer}} accepts that rounding errors resulting from limits of computational precision may result in less RAM being allocated.\n{{buyer}} acknowledges that the supply of RAM may be increased at any time up to the limits of off-the-shelf computer equipment and that this may result in RAM selling for less than purchase price.\n{{buyer}} acknowledges that the price of RAM may increase or decrease over time according to supply and demand.\n{{buyer}} acknowledges that RAM is non-transferrable. \n{{buyer}} acknowledges RAM currently in use by their account cannot be sold until it is freed and that freeing RAM may be subject to terms of other contracts.\n\n" + }, + { "name": "sellram", "type": "sellram", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ sellram }}`\n\n## Description\n\nThe `{{ sellram }}` action sells unused RAM for tokens.\n\nAs an authorized party I {{ signer }} wish to sell {{ bytes }} of unused RAM from account {{ account }}. \n" + }, + { "name": "delegatebw", "type": "delegatebw", - "ricardian_contract": "" - },{ + "ricardian_contract": "# eosio.system delegatebw\n\n## delegatebw\n (account_name-from; \n account_name-to; \n asset-stake_net_quantity; \n asset-stake_cpu_quantity; \n bool:transfer)\n\n_Intent: stake tokens for bandwidth and/or CPU and optionally transfer ownership_\n\nAs an authorized party I {{ signer }} wish to stake {{ asset-stake_cpu_quantity }} for CPU and {{ asset-stake_net_quantity }} for bandwidth from the liquid tokens of {{ account_name-from }} for the use of delegatee {{ account_name-to }}. \n \n {{if bool:transfer }}\n \nIt is {{ bool:transfer }} that I wish these tokens to become immediately owned by the delegatee.\n \n {{/if}}\n\nAs signer I stipulate that, if I am not the beneficial owner of these tokens, I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" + }, + { "name": "undelegatebw", "type": "undelegatebw", - "ricardian_contract": "" - },{ + "ricardian_contract": "# eosio.system undelegatebw\n\n## undelegatebw \n (account_name-from; \n account_name-to; \n asset-unstake_net_quantity; \n asset-unstake_cpu_quantity)\n\n_Intent: unstake tokens from bandwidth_\n\nAs an authorized party I {{ signer }} wish to unstake {{ asset-unstake_cpu_quantity }} from CPU and {{ asset-unstake_net_quantity }} from bandwidth from the tokens owned by {{ account_name-from }} previously delegated for the use of delegatee {{ account_name-to }}. \n\nIf I as signer am not the beneficial owner of these tokens I stipulate I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" + }, + { "name": "refund", "type": "refund", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ refund }}`\n\n### Description\n\nThe intent of the `{{ refund }}` action is to return previously unstaked tokens to an account after the unstaking period has elapsed. \n\nAs an authorized party I {{ signer }} wish to have the unstaked tokens of {{ owner }} returned.\n" + }, + { "name": "regproducer", "type": "regproducer", - "ricardian_contract": "" - },{ + "ricardian_contract": "# eosio.system regproducer\n\nI, {{producer}}, hereby nominate myself for consideration as an elected block producer.\n\nIf {{producer}} is selected to produce blocks by the eosio contract, I will sign blocks with {{producer_key}} and I hereby attest that I will keep this key secret and secure.\n\nIf {{producer}} is unable to perform obligations under this contract I will resign my position by resubmitting this contract with the null producer key.\n\nI acknowledge that a block is 'objectively valid' if it conforms to the deterministic blockchain rules in force at the time of its creation, and is 'objectively invalid' if it fails to conform to those rules.\n\n{{producer}} hereby agrees to only use {{producer_key}} to sign messages under the following scenarios:\nproposing an objectively valid block at the time appointed by the block scheduling algorithm\npre-confirming a block produced by another producer in the schedule when I find said block objectively valid\nconfirming a block for which {{producer}} has received 2/3+ pre-confirmation messages from other producers\n\nI hereby accept liability for any and all provable damages that result from my:\nsigning two different block proposals with the same timestamp with {{producer_key}\nsigning two different block proposals with the same block number with {{producer_key}\nsigning any block proposal which builds off of an objectively invalid block\nsigning a pre-confirmation for an objectively invalid block\nsigning a confirmation for a block for which I do not possess pre-confirmation messages from 2/3+ other producers\n\nI hereby agree that double-signing for a timestamp or block number in concert with 2 or more other producers shall automatically be deemed malicious and subject to a fine equal to the past year of compensation received and imediate disqualification from being a producer, and other damages. An exception may be made if {{producer}} can demonstrate that the double-signing occured due to a bug in the reference software; the burden of proof is on {{producer}}.\n\nI hereby agree not to interfere with the producer election process. I agree to process all producer election transactions that occur in blocks I create, to sign all objectively valid blocks I create that contain election transactions, and to sign all pre-confirmations and confirmations necessary to facilitate transfer of control to the next set of producers as determined by the system contract.\n\nI hereby acknowledge that 2/3+ other elected producers may vote to disqualify {{producer}} in the event {{producer}} is unable to produce blocks or is unable to be reached, according to criteria agreed to among producers.\n\nIf {{producer}} qualifies for and chooses to collect compensation due to votes received, {{producer}} will provide a public endpoint allowing at least 100 peers to maintain synchronization with the blockchain and/or submit transactions to be included. {{producer}} shall maintain at least 1 validating node with full state and signature checking and shall report any objectively invalid blocks produced by the active block producers. Reporting shall be via a method to be agreed to among producers, said method and reports to be made public.\n\nThe community agrees to allow {{producer}} to authenticate peers as necessary to prevent abuse and denial of service attacks; however, {{producer}} agrees not to discriminate against non-abusive peers.\n\nI agree to process transactions on a FIFO best-effort basis and to honestly bill transactions for measured execution time.\n\nI {{producer}} agree not to manipulate the contents of blocks in order to derive profit from:\nthe order in which transactions are included\nthe hash of the block that is produced\n\nI, {{producer}}, hereby agree to disclose and attest under penalty of perjury all ultimate beneficial owners of my company who own more than 10% and all direct shareholders.\n\nI, {{producer}}, hereby agree to cooperate with other block producers to carry out our respective and mutual obligations under this agreement, including but not limited to maintaining network stability and a valid blockchain.\n\nI, {{producer}}, agree to maintain a website hosted at {{url}} which contains up-to-date information on all disclosures required by this contract.\n\nI, {{producer}}, agree to set {{location}} such that {{producer}} is scheduled with minimal latency between my previous and next peer.\n\nI, {{producer}}, agree to maintain time synchronization within 10 ms of global atomic clock time, using a method agreed to among producers.\n\nI, {{producer}}, agree not to produce blocks before my scheduled time unless I have received all blocks produced by the prior producer.\n\nI, {{producer}}, agree not to publish blocks with timestamps more than 500ms in the future unless the prior block is more than 75% full by either CPU or network bandwidth metrics.\n\nI, {{producer}}, agree not to set the RAM supply to more RAM than my nodes contain and to resign if I am unable to provide the RAM approved by 2/3+ producers, as shown in the system parameters.\n" + }, + { "name": "setram", "type": "setram", "ricardian_contract": "" - },{ + }, + { "name": "bidname", "type": "bidname", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ bidname }}`\n\n## Description\n\nThe `{{ bidname }}` action places a bid on a premium account name, in the knowledge that the high bid will purchase the name.\n\nAs an authorized party I {{ signer }} wish to bid on behalf of {{ bidder }} the amount of {{ bid }} toward purchase of the account name {{ newname }}.\n" + }, + { "name": "unregprod", "type": "unregprod", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ unregprod }}`\n\n## Description\n\nThe `{{ unregprod }}` action unregisters a previously registered block producer candidate.\n\nAs an authorized party I {{ signer }} wish to unregister the block producer candidate {{ producer }}, rendering that candidate no longer able to receive votes.\n" + }, + { "name": "regproxy", "type": "regproxy", "ricardian_contract": "" - },{ + }, + { "name": "voteproducer", "type": "voteproducer", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Ricardian Contract for *voteproducer*\n\n## VOTEPRODUCER (voter; array:producers)\n\n_Intent: cast a valid vote for up to 30 BP candidates_\n\nAs an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ array:producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. \n\nIf I am not the beneficial owner of these shares I stipulate I have proof that I\u2019ve been authorized to vote these shares by their beneficial owner(s). \n\nI stipulate I have not and will not accept anything of value in exchange for these votes, on penalty of confiscation of these tokens, and other penalties. \n\nI acknowledge that using any system of automatic voting, re-voting, or vote refreshing, or allowing such a system to be used on my behalf or on behalf of another, is forbidden and doing so violates this contract.\n" + }, + { "name": "claimrewards", "type": "claimrewards", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ claimrewards }}`\n\n## Description\n\nThe `{{ claimrewards }}` action allows a block producer (active or standby) to claim the system rewards due them for producing blocks and receiving votes.\n\nAs an authorized party I {{ signer }} wish to have the rewards earned by {{ owner }} deposited into the {{ owner }} account.\n" + }, + { "name": "setpriv", "type": "setpriv", "ricardian_contract": "" - },{ + }, + { "name": "rmvproducer", "type": "rmvproducer", "ricardian_contract": "" - },{ + }, + { "name": "setalimits", "type": "set_account_limits", "ricardian_contract": "" - },{ + }, + { "name": "setglimits", "type": "set_global_limits", "ricardian_contract": "" - },{ + }, + { "name": "setprods", "type": "set_producers", - "ricardian_contract": "" - },{ + "ricardian_contract": "# Action - `{{ setprods }}`\n\n## Description\n\nThe `{{ setprods }}` action creates a new schedule of active producers, who will produce blocks in the order given.\n\nTHIS IS A SYSTEM COMMAND NOT AVAILABLE FOR DIRECT ACCESS BY USERS.\n\nAs an authorized party I {{ signer }} wish to set the rotation of producers to be {{ schedule }}.\n" + }, + { "name": "reqauth", "type": "require_auth", "ricardian_contract": "" - },{ + }, + { "name": "setparams", "type": "setparams", "ricardian_contract": "" - }], - "tables": [{ + } + ], + "tables": [ + { "name": "producers", "type": "producer_info", "index_type": "i64", - "key_names" : ["owner"], - "key_types" : ["uint64"] - },{ + "key_names": [ + "owner" + ], + "key_types": [ + "uint64" + ] + }, + { "name": "global", "type": "eosio_global_state", "index_type": "i64", - "key_names" : [], - "key_types" : [] - },{ + "key_names": [], + "key_types": [] + }, + { "name": "voters", "type": "voter_info", "index_type": "i64", - "key_names" : ["owner"], - "key_types" : ["account_name"] - },{ + "key_names": [ + "owner" + ], + "key_types": [ + "account_name" + ] + }, + { "name": "userres", "type": "user_resources", "index_type": "i64", - "key_names" : ["owner"], - "key_types" : ["uint64"] - },{ + "key_names": [ + "owner" + ], + "key_types": [ + "uint64" + ] + }, + { "name": "delband", "type": "delegated_bandwidth", "index_type": "i64", - "key_names" : ["to"], - "key_types" : ["uint64"] - },{ + "key_names": [ + "to" + ], + "key_types": [ + "uint64" + ] + }, + { "name": "rammarket", "type": "exchange_state", "index_type": "i64", - "key_names" : ["supply"], - "key_types" : ["uint64"] - },{ + "key_names": [ + "supply" + ], + "key_types": [ + "uint64" + ] + }, + { "name": "refunds", "type": "refund_request", "index_type": "i64", - "key_names" : ["owner"], - "key_types" : ["uint64"] + "key_names": [ + "owner" + ], + "key_types": [ + "uint64" + ] + } + ], + "ricardian_clauses": [ + { + "id": "constitution", + "body": "This Constitution is a multi-party contract entered into by the Members by virtue of their use of this blockchain.\n\n# Article I - No Initiation of Violence\nMembers shall not initiate violence or the threat of violence against another Member. Lawful prosecution of crimes with the goal of preserving life, liberty and property does not constitute initiation of violence.\n\n# Article II - No Perjury\nMembers shall be liable for losses caused by false or misleading attestations and shall forfeit any profit gained thereby.\n\n# Article III - Rights\nThe Members grant the right of contract and of private property to each other, therefore no property shall change hands except with the consent of the owner, by a valid Arbitrator\u2019s order, or via community referendum. This Constitution creates no positive rights for or between any Members.\n\n# Article IV - No Vote Buying\nNo Member shall offer nor accept anything of value in exchange for a vote of any type, nor shall any Member unduly influence the vote of another.\n\n# Article V - No Fiduciary\nNo Member nor EOS token holder shall have fiduciary responsibility to support the value of the EOS token. The Members do not authorize anyone to hold assets, borrow, nor contract on behalf of EOS token holders collectively. This blockchain has no owners, managers or fiduciaries; therefore, no Member shall have beneficial interest in more than 10% of the EOS token supply.\n\n# Article VI - Restitution\nEach Member agrees that penalties for breach of contract may include, but are not limited to, fines, loss of account, and other restitution.\n\n# Article VII - Open Source\nEach Member who makes available a smart contract on this blockchain shall be a Developer. Each Developer shall offer their smart contracts via a free and open source license, and each smart contract shall be documented with a Ricardian Contract stating the intent of all parties and naming the Arbitration Forum that will resolve disputes arising from that contract.\n\n# Article VIII - Language\nMulti-lingual contracts must specify one prevailing language in case of dispute and the author of any translation shall be liable for losses due to their false, misleading, or ambiguous attested translations.\n\n# Article IX - Dispute Resolution\nAll disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Arbitration of the International Chamber of Commerce by one or more arbitrators appointed in accordance with the said Rules.\n\n# Article X - Choice of Law\nChoice of law for disputes shall be, in order of precedence, this Constitution and the Maxims of Equity.\n\n# Article XI - Amending\nThis Constitution and its subordinate documents shall not be amended except by a vote of the token holders with no less than 15% vote participation among tokens and no fewer than 10% more Yes than No votes, sustained for 30 continuous days within a 120 day period.\n\n# Article XII - Publishing\nMembers may only publish information to the Blockchain that is within their right to publish. Furthermore, Members voluntarily consent for all Members to permanently and irrevocably retain a copy, analyze, and distribute all broadcast transactions and derivative information.\n\n# Article XIII - Informed Consent\nAll service providers who produce tools to facilitate the construction and signing of transactions on behalf of other Members shall present to said other Members the full Ricardian contract terms of this Constitution and other referenced contracts. Service providers shall be liable for losses resulting from failure to disclose the full Ricardian contract terms to users.\n\n# Article XIV - Severability\nIf any part of this Constitution is declared unenforceable or invalid, the remainder will continue to be valid and enforceable.\n\n# Article XV - Termination of Agreement\nA Member is automatically released from all revocable obligations under this Constitution 3 years after the last transaction signed by that Member is incorporated into the blockchain. After 3 years of inactivity an account may be put up for auction and the proceeds distributed to all Members according to the system contract provisions then in effect for such redistribution.\n\n# Article XVI - Developer Liability\nMembers agree to hold software developers harmless for unintentional mistakes made in the expression of contractual intent, whether or not said mistakes were due to actual or perceived negligence.\n\n# Article XVII - Consideration\nAll rights and obligations under this Constitution are mutual and reciprocal and of equally significant value and cost to all parties.\n\n# Article XVIII - Acceptance\nA contract is deemed accepted when a member signs a transaction which incorporates a TAPOS proof of a block whose implied state incorporates an ABI of said contract and said transaction is incorporated into the blockchain.\n\n# Article XIX - Counterparts\nThis Constitution may be executed in any number of counterparts, each of which when executed and delivered shall constitute a duplicate original, but all counterparts together shall constitute a single agreement.\n\n# Article XX - Interim Constitution\nThis constitution is interim and is intended to remain in effect until a permanent constitution is written and ratified in a referendum.\n" } - ], - "ricardian_clauses": [], - "abi_extensions": [] -} + ], + "abi_extensions": [] +} \ No newline at end of file diff --git a/contracts/eosio.token/eosio.token-transfer-rc.md b/contracts/eosio.token/eosio.token-transfer-rc.md new file mode 100644 index 00000000000..ec3e68e5f0a --- /dev/null +++ b/contracts/eosio.token/eosio.token-transfer-rc.md @@ -0,0 +1,11 @@ +## Transfer Terms & Conditions + +I, {{from}}, certify the following to be true to the best of my knowledge: + +1. I certify that {{quantity}} is not the proceeds of fraudulent or violent activities. +2. I certify that, to the best of my knowledge, {{to}} is not supporting initiation of violence against others. +3. I have disclosed any contractual terms & conditions with respect to {{quantity}} to {{to}}. + +I understand that funds transfers are not reversible after the {{transaction.delay}} seconds or other delay as configured by {{from}}'s permissions. + +If this action fails to be irreversibly confirmed after receiving goods or services from '{{to}}', I agree to either return the goods or services or resend {{quantity}} in a timely manner. diff --git a/contracts/eosio.token/eosio.token.abi b/contracts/eosio.token/eosio.token.abi index d769deb331b..a8e5cf4ef9f 100644 --- a/contracts/eosio.token/eosio.token.abi +++ b/contracts/eosio.token/eosio.token.abi @@ -1,78 +1,136 @@ { - "version": "eosio::abi/1.0", - "types": [{ + "version": "eosio::abi/1.0", + "types": [ + { "new_type_name": "account_name", "type": "name" - }], - "structs": [{ + } + ], + "structs": [ + { "name": "transfer", "base": "", "fields": [ - {"name":"from", "type":"account_name"}, - {"name":"to", "type":"account_name"}, - {"name":"quantity", "type":"asset"}, - {"name":"memo", "type":"string"} + { + "name": "from", + "type": "account_name" + }, + { + "name": "to", + "type": "account_name" + }, + { + "name": "quantity", + "type": "asset" + }, + { + "name": "memo", + "type": "string" + } ] - },{ - "name": "create", - "base": "", - "fields": [ - {"name":"issuer", "type":"account_name"}, - {"name":"maximum_supply", "type":"asset"} - ] - },{ - "name": "issue", - "base": "", - "fields": [ - {"name":"to", "type":"account_name"}, - {"name":"quantity", "type":"asset"}, - {"name":"memo", "type":"string"} - ] - },{ + }, + { + "name": "create", + "base": "", + "fields": [ + { + "name": "issuer", + "type": "account_name" + }, + { + "name": "maximum_supply", + "type": "asset" + } + ] + }, + { + "name": "issue", + "base": "", + "fields": [ + { + "name": "to", + "type": "account_name" + }, + { + "name": "quantity", + "type": "asset" + }, + { + "name": "memo", + "type": "string" + } + ] + }, + { "name": "account", "base": "", "fields": [ - {"name":"balance", "type":"asset"} + { + "name": "balance", + "type": "asset" + } ] - },{ + }, + { "name": "currency_stats", "base": "", "fields": [ - {"name":"supply", "type":"asset"}, - {"name":"max_supply", "type":"asset"}, - {"name":"issuer", "type":"account_name"} + { + "name": "supply", + "type": "asset" + }, + { + "name": "max_supply", + "type": "asset" + }, + { + "name": "issuer", + "type": "account_name" + } ] } ], - "actions": [{ + "actions": [ + { "name": "transfer", "type": "transfer", - "ricardian_contract": "" - },{ + "ricardian_contract": "## Transfer Terms & Conditions\n\nI, {{from}}, certify the following to be true to the best of my knowledge:\n\n1. I certify that {{quantity}} is not the proceeds of fraudulent or violent activities.\n2. I certify that, to the best of my knowledge, {{to}} is not supporting initiation of violence against others.\n3. I have disclosed any contractual terms & conditions with respect to {{quantity}} to {{to}}.\n\nI understand that funds transfers are not reversible after the {{transaction.delay}} seconds or other delay as configured by {{from}}'s permissions.\n\nIf this action fails to be irreversibly confirmed after receiving goods or services from '{{to}}', I agree to either return the goods or services or resend {{quantity}} in a timely manner.\n" + }, + { "name": "issue", "type": "issue", "ricardian_contract": "" - }, { + }, + { "name": "create", "type": "create", "ricardian_contract": "" } - ], - "tables": [{ + "tables": [ + { "name": "accounts", "type": "account", "index_type": "i64", - "key_names" : ["currency"], - "key_types" : ["uint64"] - },{ + "key_names": [ + "currency" + ], + "key_types": [ + "uint64" + ] + }, + { "name": "stat", "type": "currency_stats", "index_type": "i64", - "key_names" : ["currency"], - "key_types" : ["uint64"] + "key_names": [ + "currency" + ], + "key_types": [ + "uint64" + ] } ], "ricardian_clauses": [], "abi_extensions": [] -} +} \ No newline at end of file diff --git a/contracts/eosiolib/core_symbol.hpp b/contracts/eosiolib/core_symbol.hpp index b4b86071f70..6e41939bb3c 100644 --- a/contracts/eosiolib/core_symbol.hpp +++ b/contracts/eosiolib/core_symbol.hpp @@ -4,4 +4,4 @@ * \warning This file is machine generated. DO NOT EDIT. See core_symbol.hpp.in for changes. */ -#define CORE_SYMBOL S(4,SYS) +#define CORE_SYMBOL S(4,EOS) From 5f964d4cef7efaa7b76221c33616810afa8332e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9sar=20Rodr=C3=ADguez?= Date: Sun, 3 Jun 2018 13:47:52 +0200 Subject: [PATCH 02/11] Update core_symbol.hpp --- contracts/eosiolib/core_symbol.hpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contracts/eosiolib/core_symbol.hpp b/contracts/eosiolib/core_symbol.hpp index 6e41939bb3c..b4b86071f70 100644 --- a/contracts/eosiolib/core_symbol.hpp +++ b/contracts/eosiolib/core_symbol.hpp @@ -4,4 +4,4 @@ * \warning This file is machine generated. DO NOT EDIT. See core_symbol.hpp.in for changes. */ -#define CORE_SYMBOL S(4,EOS) +#define CORE_SYMBOL S(4,SYS) From af9ecd7e77176466e3a1f452a4db0fed24af1639 Mon Sep 17 00:00:00 2001 From: Cesar Rodriguez Date: Mon, 4 Jun 2018 17:36:24 +0200 Subject: [PATCH 03/11] contracts updated --- .../eosio.system/eosio.system-delegatebw-rc.md | 17 ++++++----------- .../eosio.system/eosio.system-regproducer-rc.md | 10 +++++++--- .../eosio.system-undelegatebw-rc.md | 12 ++++-------- .../eosio.system-voteproducer-rc.md | 8 ++++---- contracts/eosio.system/eosio.system.abi | 8 ++++---- 5 files changed, 25 insertions(+), 30 deletions(-) diff --git a/contracts/eosio.system/eosio.system-delegatebw-rc.md b/contracts/eosio.system/eosio.system-delegatebw-rc.md index 5db46687683..d75b61e9a9b 100644 --- a/contracts/eosio.system/eosio.system-delegatebw-rc.md +++ b/contracts/eosio.system/eosio.system-delegatebw-rc.md @@ -1,19 +1,14 @@ -# eosio.system delegatebw +# Action - `{{ delegatebw }}` -## delegatebw - (account_name-from; - account_name-to; - asset-stake_net_quantity; - asset-stake_cpu_quantity; - bool:transfer) +## Description -_Intent: stake tokens for bandwidth and/or CPU and optionally transfer ownership_ +The intent of the `{{ delegatebw }}` action is to stake tokens for bandwidth and/or CPU and optionally transfer ownership. -As an authorized party I {{ signer }} wish to stake {{ asset-stake_cpu_quantity }} for CPU and {{ asset-stake_net_quantity }} for bandwidth from the liquid tokens of {{ account_name-from }} for the use of delegatee {{ account_name-to }}. +As an authorized party I {{ signer }} wish to stake {{ stake_cpu_quantity }} for CPU and {{ stake_net_quantity }} for bandwidth from the liquid tokens of {{ from }} for the use of delegatee {{ to }}. - {{if bool:transfer }} + {{if transfer }} -It is {{ bool:transfer }} that I wish these tokens to become immediately owned by the delegatee. +It is {{ transfer }} that I wish these tokens to become immediately owned by the delegatee. {{/if}} diff --git a/contracts/eosio.system/eosio.system-regproducer-rc.md b/contracts/eosio.system/eosio.system-regproducer-rc.md index 5412f8fcaad..4fb47afcaf0 100644 --- a/contracts/eosio.system/eosio.system-regproducer-rc.md +++ b/contracts/eosio.system/eosio.system-regproducer-rc.md @@ -1,4 +1,8 @@ -# eosio.system regproducer +# Action - `{{ regproducer }}` + +## Description + +The intent of the `{{ regproducer }}` action is to register an account as a BP candidate. I, {{producer}}, hereby nominate myself for consideration as an elected block producer. @@ -14,8 +18,8 @@ pre-confirming a block produced by another producer in the schedule when I find confirming a block for which {{producer}} has received 2/3+ pre-confirmation messages from other producers I hereby accept liability for any and all provable damages that result from my: -signing two different block proposals with the same timestamp with {{producer_key} -signing two different block proposals with the same block number with {{producer_key} +signing two different block proposals with the same timestamp with {{producer_key}} +signing two different block proposals with the same block number with {{producer_key}} signing any block proposal which builds off of an objectively invalid block signing a pre-confirmation for an objectively invalid block signing a confirmation for a block for which I do not possess pre-confirmation messages from 2/3+ other producers diff --git a/contracts/eosio.system/eosio.system-undelegatebw-rc.md b/contracts/eosio.system/eosio.system-undelegatebw-rc.md index e7a1fcf3929..d37d7718592 100644 --- a/contracts/eosio.system/eosio.system-undelegatebw-rc.md +++ b/contracts/eosio.system/eosio.system-undelegatebw-rc.md @@ -1,13 +1,9 @@ -# eosio.system undelegatebw +# Action - `{{ undelegatebw }}` -## undelegatebw - (account_name-from; - account_name-to; - asset-unstake_net_quantity; - asset-unstake_cpu_quantity) +## Description -_Intent: unstake tokens from bandwidth_ +The intent of the `{{ undelegatebw }}` action is to unstake tokens from CPU and/or bandwidth. -As an authorized party I {{ signer }} wish to unstake {{ asset-unstake_cpu_quantity }} from CPU and {{ asset-unstake_net_quantity }} from bandwidth from the tokens owned by {{ account_name-from }} previously delegated for the use of delegatee {{ account_name-to }}. +As an authorized party I {{ signer }} wish to unstake {{ unstake_cpu_quantity }} from CPU and {{ unstake_net_quantity }} from bandwidth from the tokens owned by {{ from }} previously delegated for the use of delegatee {{ to }}. If I as signer am not the beneficial owner of these tokens I stipulate I have proof that I’ve been authorized to take this action by their beneficial owner(s). diff --git a/contracts/eosio.system/eosio.system-voteproducer-rc.md b/contracts/eosio.system/eosio.system-voteproducer-rc.md index ad1e92f8152..dc52f21dcf0 100644 --- a/contracts/eosio.system/eosio.system-voteproducer-rc.md +++ b/contracts/eosio.system/eosio.system-voteproducer-rc.md @@ -1,10 +1,10 @@ -# Ricardian Contract for *voteproducer* +# Action - `{{ voteproducer }}` -## VOTEPRODUCER (voter; array:producers) +## Description -_Intent: cast a valid vote for up to 30 BP candidates_ +The intent of the `{{ voteproducer }}` action is to cast a valid vote for up to 30 BP candidates. -As an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ array:producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. +As an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. If I am not the beneficial owner of these shares I stipulate I have proof that I’ve been authorized to vote these shares by their beneficial owner(s). diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index 60d939aea24..3294215b6c5 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -975,12 +975,12 @@ { "name": "delegatebw", "type": "delegatebw", - "ricardian_contract": "# eosio.system delegatebw\n\n## delegatebw\n (account_name-from; \n account_name-to; \n asset-stake_net_quantity; \n asset-stake_cpu_quantity; \n bool:transfer)\n\n_Intent: stake tokens for bandwidth and/or CPU and optionally transfer ownership_\n\nAs an authorized party I {{ signer }} wish to stake {{ asset-stake_cpu_quantity }} for CPU and {{ asset-stake_net_quantity }} for bandwidth from the liquid tokens of {{ account_name-from }} for the use of delegatee {{ account_name-to }}. \n \n {{if bool:transfer }}\n \nIt is {{ bool:transfer }} that I wish these tokens to become immediately owned by the delegatee.\n \n {{/if}}\n\nAs signer I stipulate that, if I am not the beneficial owner of these tokens, I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" + "ricardian_contract": "# Action - `{{ delegatebw }}`\n\n## Description\n\nThe intent of the `{{ delegatebw }}` action is to stake tokens for bandwidth and/or CPU and optionally transfer ownership.\n\nAs an authorized party I {{ signer }} wish to stake {{ stake_cpu_quantity }} for CPU and {{ stake_net_quantity }} for bandwidth from the liquid tokens of {{ from }} for the use of delegatee {{ to }}. \n \n {{if transfer }}\n \nIt is {{ transfer }} that I wish these tokens to become immediately owned by the delegatee.\n \n {{/if}}\n\nAs signer I stipulate that, if I am not the beneficial owner of these tokens, I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" }, { "name": "undelegatebw", "type": "undelegatebw", - "ricardian_contract": "# eosio.system undelegatebw\n\n## undelegatebw \n (account_name-from; \n account_name-to; \n asset-unstake_net_quantity; \n asset-unstake_cpu_quantity)\n\n_Intent: unstake tokens from bandwidth_\n\nAs an authorized party I {{ signer }} wish to unstake {{ asset-unstake_cpu_quantity }} from CPU and {{ asset-unstake_net_quantity }} from bandwidth from the tokens owned by {{ account_name-from }} previously delegated for the use of delegatee {{ account_name-to }}. \n\nIf I as signer am not the beneficial owner of these tokens I stipulate I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" + "ricardian_contract": "# Action - `{{ undelegatebw }}`\n\n## Description\n\nThe intent of the `{{ undelegatebw }}` action is to unstake tokens from CPU and/or bandwidth. \n\nAs an authorized party I {{ signer }} wish to unstake {{ unstake_cpu_quantity }} from CPU and {{ unstake_net_quantity }} from bandwidth from the tokens owned by {{ from }} previously delegated for the use of delegatee {{ to }}. \n\nIf I as signer am not the beneficial owner of these tokens I stipulate I have proof that I\u2019ve been authorized to take this action by their beneficial owner(s). \n" }, { "name": "refund", @@ -990,7 +990,7 @@ { "name": "regproducer", "type": "regproducer", - "ricardian_contract": "# eosio.system regproducer\n\nI, {{producer}}, hereby nominate myself for consideration as an elected block producer.\n\nIf {{producer}} is selected to produce blocks by the eosio contract, I will sign blocks with {{producer_key}} and I hereby attest that I will keep this key secret and secure.\n\nIf {{producer}} is unable to perform obligations under this contract I will resign my position by resubmitting this contract with the null producer key.\n\nI acknowledge that a block is 'objectively valid' if it conforms to the deterministic blockchain rules in force at the time of its creation, and is 'objectively invalid' if it fails to conform to those rules.\n\n{{producer}} hereby agrees to only use {{producer_key}} to sign messages under the following scenarios:\nproposing an objectively valid block at the time appointed by the block scheduling algorithm\npre-confirming a block produced by another producer in the schedule when I find said block objectively valid\nconfirming a block for which {{producer}} has received 2/3+ pre-confirmation messages from other producers\n\nI hereby accept liability for any and all provable damages that result from my:\nsigning two different block proposals with the same timestamp with {{producer_key}\nsigning two different block proposals with the same block number with {{producer_key}\nsigning any block proposal which builds off of an objectively invalid block\nsigning a pre-confirmation for an objectively invalid block\nsigning a confirmation for a block for which I do not possess pre-confirmation messages from 2/3+ other producers\n\nI hereby agree that double-signing for a timestamp or block number in concert with 2 or more other producers shall automatically be deemed malicious and subject to a fine equal to the past year of compensation received and imediate disqualification from being a producer, and other damages. An exception may be made if {{producer}} can demonstrate that the double-signing occured due to a bug in the reference software; the burden of proof is on {{producer}}.\n\nI hereby agree not to interfere with the producer election process. I agree to process all producer election transactions that occur in blocks I create, to sign all objectively valid blocks I create that contain election transactions, and to sign all pre-confirmations and confirmations necessary to facilitate transfer of control to the next set of producers as determined by the system contract.\n\nI hereby acknowledge that 2/3+ other elected producers may vote to disqualify {{producer}} in the event {{producer}} is unable to produce blocks or is unable to be reached, according to criteria agreed to among producers.\n\nIf {{producer}} qualifies for and chooses to collect compensation due to votes received, {{producer}} will provide a public endpoint allowing at least 100 peers to maintain synchronization with the blockchain and/or submit transactions to be included. {{producer}} shall maintain at least 1 validating node with full state and signature checking and shall report any objectively invalid blocks produced by the active block producers. Reporting shall be via a method to be agreed to among producers, said method and reports to be made public.\n\nThe community agrees to allow {{producer}} to authenticate peers as necessary to prevent abuse and denial of service attacks; however, {{producer}} agrees not to discriminate against non-abusive peers.\n\nI agree to process transactions on a FIFO best-effort basis and to honestly bill transactions for measured execution time.\n\nI {{producer}} agree not to manipulate the contents of blocks in order to derive profit from:\nthe order in which transactions are included\nthe hash of the block that is produced\n\nI, {{producer}}, hereby agree to disclose and attest under penalty of perjury all ultimate beneficial owners of my company who own more than 10% and all direct shareholders.\n\nI, {{producer}}, hereby agree to cooperate with other block producers to carry out our respective and mutual obligations under this agreement, including but not limited to maintaining network stability and a valid blockchain.\n\nI, {{producer}}, agree to maintain a website hosted at {{url}} which contains up-to-date information on all disclosures required by this contract.\n\nI, {{producer}}, agree to set {{location}} such that {{producer}} is scheduled with minimal latency between my previous and next peer.\n\nI, {{producer}}, agree to maintain time synchronization within 10 ms of global atomic clock time, using a method agreed to among producers.\n\nI, {{producer}}, agree not to produce blocks before my scheduled time unless I have received all blocks produced by the prior producer.\n\nI, {{producer}}, agree not to publish blocks with timestamps more than 500ms in the future unless the prior block is more than 75% full by either CPU or network bandwidth metrics.\n\nI, {{producer}}, agree not to set the RAM supply to more RAM than my nodes contain and to resign if I am unable to provide the RAM approved by 2/3+ producers, as shown in the system parameters.\n" + "ricardian_contract": "# Action - `{{ regproducer }}`\n\n## Description\n\nThe intent of the `{{ regproducer }}` action is to register an account as a BP candidate.\n\nI, {{producer}}, hereby nominate myself for consideration as an elected block producer.\n\nIf {{producer}} is selected to produce blocks by the eosio contract, I will sign blocks with {{producer_key}} and I hereby attest that I will keep this key secret and secure.\n\nIf {{producer}} is unable to perform obligations under this contract I will resign my position by resubmitting this contract with the null producer key.\n\nI acknowledge that a block is 'objectively valid' if it conforms to the deterministic blockchain rules in force at the time of its creation, and is 'objectively invalid' if it fails to conform to those rules.\n\n{{producer}} hereby agrees to only use {{producer_key}} to sign messages under the following scenarios:\nproposing an objectively valid block at the time appointed by the block scheduling algorithm\npre-confirming a block produced by another producer in the schedule when I find said block objectively valid\nconfirming a block for which {{producer}} has received 2/3+ pre-confirmation messages from other producers\n\nI hereby accept liability for any and all provable damages that result from my:\nsigning two different block proposals with the same timestamp with {{producer_key}}\nsigning two different block proposals with the same block number with {{producer_key}}\nsigning any block proposal which builds off of an objectively invalid block\nsigning a pre-confirmation for an objectively invalid block\nsigning a confirmation for a block for which I do not possess pre-confirmation messages from 2/3+ other producers\n\nI hereby agree that double-signing for a timestamp or block number in concert with 2 or more other producers shall automatically be deemed malicious and subject to a fine equal to the past year of compensation received and imediate disqualification from being a producer, and other damages. An exception may be made if {{producer}} can demonstrate that the double-signing occured due to a bug in the reference software; the burden of proof is on {{producer}}.\n\nI hereby agree not to interfere with the producer election process. I agree to process all producer election transactions that occur in blocks I create, to sign all objectively valid blocks I create that contain election transactions, and to sign all pre-confirmations and confirmations necessary to facilitate transfer of control to the next set of producers as determined by the system contract.\n\nI hereby acknowledge that 2/3+ other elected producers may vote to disqualify {{producer}} in the event {{producer}} is unable to produce blocks or is unable to be reached, according to criteria agreed to among producers.\n\nIf {{producer}} qualifies for and chooses to collect compensation due to votes received, {{producer}} will provide a public endpoint allowing at least 100 peers to maintain synchronization with the blockchain and/or submit transactions to be included. {{producer}} shall maintain at least 1 validating node with full state and signature checking and shall report any objectively invalid blocks produced by the active block producers. Reporting shall be via a method to be agreed to among producers, said method and reports to be made public.\n\nThe community agrees to allow {{producer}} to authenticate peers as necessary to prevent abuse and denial of service attacks; however, {{producer}} agrees not to discriminate against non-abusive peers.\n\nI agree to process transactions on a FIFO best-effort basis and to honestly bill transactions for measured execution time.\n\nI {{producer}} agree not to manipulate the contents of blocks in order to derive profit from:\nthe order in which transactions are included\nthe hash of the block that is produced\n\nI, {{producer}}, hereby agree to disclose and attest under penalty of perjury all ultimate beneficial owners of my company who own more than 10% and all direct shareholders.\n\nI, {{producer}}, hereby agree to cooperate with other block producers to carry out our respective and mutual obligations under this agreement, including but not limited to maintaining network stability and a valid blockchain.\n\nI, {{producer}}, agree to maintain a website hosted at {{url}} which contains up-to-date information on all disclosures required by this contract.\n\nI, {{producer}}, agree to set {{location}} such that {{producer}} is scheduled with minimal latency between my previous and next peer.\n\nI, {{producer}}, agree to maintain time synchronization within 10 ms of global atomic clock time, using a method agreed to among producers.\n\nI, {{producer}}, agree not to produce blocks before my scheduled time unless I have received all blocks produced by the prior producer.\n\nI, {{producer}}, agree not to publish blocks with timestamps more than 500ms in the future unless the prior block is more than 75% full by either CPU or network bandwidth metrics.\n\nI, {{producer}}, agree not to set the RAM supply to more RAM than my nodes contain and to resign if I am unable to provide the RAM approved by 2/3+ producers, as shown in the system parameters.\n" }, { "name": "setram", @@ -1015,7 +1015,7 @@ { "name": "voteproducer", "type": "voteproducer", - "ricardian_contract": "# Ricardian Contract for *voteproducer*\n\n## VOTEPRODUCER (voter; array:producers)\n\n_Intent: cast a valid vote for up to 30 BP candidates_\n\nAs an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ array:producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. \n\nIf I am not the beneficial owner of these shares I stipulate I have proof that I\u2019ve been authorized to vote these shares by their beneficial owner(s). \n\nI stipulate I have not and will not accept anything of value in exchange for these votes, on penalty of confiscation of these tokens, and other penalties. \n\nI acknowledge that using any system of automatic voting, re-voting, or vote refreshing, or allowing such a system to be used on my behalf or on behalf of another, is forbidden and doing so violates this contract.\n" + "ricardian_contract": "# Action - `{{ voteproducer }}`\n\n## Description\n\nThe intent of the `{{ voteproducer }}` action is to cast a valid vote for up to 30 BP candidates. \n\nAs an authorized party I {{ signer }} wish to vote on behalf of {{ voter }} in favor of the block producer candidates {{ producers }} with a voting weight equal to all tokens currently owned by {{ voter }} and staked for CPU or bandwidth. \n\nIf I am not the beneficial owner of these shares I stipulate I have proof that I\u2019ve been authorized to vote these shares by their beneficial owner(s). \n\nI stipulate I have not and will not accept anything of value in exchange for these votes, on penalty of confiscation of these tokens, and other penalties. \n\nI acknowledge that using any system of automatic voting, re-voting, or vote refreshing, or allowing such a system to be used on my behalf or on behalf of another, is forbidden and doing so violates this contract.\n" }, { "name": "claimrewards", From ea369831b4827b510abaeb1722706ee187f373c9 Mon Sep 17 00:00:00 2001 From: Denis Date: Fri, 8 Jun 2018 14:25:26 -0700 Subject: [PATCH 04/11] Sync Gov - Rolls back change to article IX Ref: https://github.com/EOS-Mainnet/governance/pull/15 --- contracts/eosio.system/eosio.system-clause-constitution-rc.md | 2 +- contracts/eosio.system/eosio.system.abi | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/contracts/eosio.system/eosio.system-clause-constitution-rc.md b/contracts/eosio.system/eosio.system-clause-constitution-rc.md index a54f06c5232..56050cb952d 100644 --- a/contracts/eosio.system/eosio.system-clause-constitution-rc.md +++ b/contracts/eosio.system/eosio.system-clause-constitution-rc.md @@ -25,7 +25,7 @@ Each Member who makes available a smart contract on this blockchain shall be a D Multi-lingual contracts must specify one prevailing language in case of dispute and the author of any translation shall be liable for losses due to their false, misleading, or ambiguous attested translations. # Article IX - Dispute Resolution -All disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Arbitration of the International Chamber of Commerce by one or more arbitrators appointed in accordance with the said Rules. +All disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Dispute Resolution of the EOS Core Arbitration Forum by one or more arbitrators appointed in accordance with the said Rules. # Article X - Choice of Law Choice of law for disputes shall be, in order of precedence, this Constitution and the Maxims of Equity. diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index 3294215b6c5..23d77e106f1 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -1136,7 +1136,7 @@ "ricardian_clauses": [ { "id": "constitution", - "body": "This Constitution is a multi-party contract entered into by the Members by virtue of their use of this blockchain.\n\n# Article I - No Initiation of Violence\nMembers shall not initiate violence or the threat of violence against another Member. Lawful prosecution of crimes with the goal of preserving life, liberty and property does not constitute initiation of violence.\n\n# Article II - No Perjury\nMembers shall be liable for losses caused by false or misleading attestations and shall forfeit any profit gained thereby.\n\n# Article III - Rights\nThe Members grant the right of contract and of private property to each other, therefore no property shall change hands except with the consent of the owner, by a valid Arbitrator\u2019s order, or via community referendum. This Constitution creates no positive rights for or between any Members.\n\n# Article IV - No Vote Buying\nNo Member shall offer nor accept anything of value in exchange for a vote of any type, nor shall any Member unduly influence the vote of another.\n\n# Article V - No Fiduciary\nNo Member nor EOS token holder shall have fiduciary responsibility to support the value of the EOS token. The Members do not authorize anyone to hold assets, borrow, nor contract on behalf of EOS token holders collectively. This blockchain has no owners, managers or fiduciaries; therefore, no Member shall have beneficial interest in more than 10% of the EOS token supply.\n\n# Article VI - Restitution\nEach Member agrees that penalties for breach of contract may include, but are not limited to, fines, loss of account, and other restitution.\n\n# Article VII - Open Source\nEach Member who makes available a smart contract on this blockchain shall be a Developer. Each Developer shall offer their smart contracts via a free and open source license, and each smart contract shall be documented with a Ricardian Contract stating the intent of all parties and naming the Arbitration Forum that will resolve disputes arising from that contract.\n\n# Article VIII - Language\nMulti-lingual contracts must specify one prevailing language in case of dispute and the author of any translation shall be liable for losses due to their false, misleading, or ambiguous attested translations.\n\n# Article IX - Dispute Resolution\nAll disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Arbitration of the International Chamber of Commerce by one or more arbitrators appointed in accordance with the said Rules.\n\n# Article X - Choice of Law\nChoice of law for disputes shall be, in order of precedence, this Constitution and the Maxims of Equity.\n\n# Article XI - Amending\nThis Constitution and its subordinate documents shall not be amended except by a vote of the token holders with no less than 15% vote participation among tokens and no fewer than 10% more Yes than No votes, sustained for 30 continuous days within a 120 day period.\n\n# Article XII - Publishing\nMembers may only publish information to the Blockchain that is within their right to publish. Furthermore, Members voluntarily consent for all Members to permanently and irrevocably retain a copy, analyze, and distribute all broadcast transactions and derivative information.\n\n# Article XIII - Informed Consent\nAll service providers who produce tools to facilitate the construction and signing of transactions on behalf of other Members shall present to said other Members the full Ricardian contract terms of this Constitution and other referenced contracts. Service providers shall be liable for losses resulting from failure to disclose the full Ricardian contract terms to users.\n\n# Article XIV - Severability\nIf any part of this Constitution is declared unenforceable or invalid, the remainder will continue to be valid and enforceable.\n\n# Article XV - Termination of Agreement\nA Member is automatically released from all revocable obligations under this Constitution 3 years after the last transaction signed by that Member is incorporated into the blockchain. After 3 years of inactivity an account may be put up for auction and the proceeds distributed to all Members according to the system contract provisions then in effect for such redistribution.\n\n# Article XVI - Developer Liability\nMembers agree to hold software developers harmless for unintentional mistakes made in the expression of contractual intent, whether or not said mistakes were due to actual or perceived negligence.\n\n# Article XVII - Consideration\nAll rights and obligations under this Constitution are mutual and reciprocal and of equally significant value and cost to all parties.\n\n# Article XVIII - Acceptance\nA contract is deemed accepted when a member signs a transaction which incorporates a TAPOS proof of a block whose implied state incorporates an ABI of said contract and said transaction is incorporated into the blockchain.\n\n# Article XIX - Counterparts\nThis Constitution may be executed in any number of counterparts, each of which when executed and delivered shall constitute a duplicate original, but all counterparts together shall constitute a single agreement.\n\n# Article XX - Interim Constitution\nThis constitution is interim and is intended to remain in effect until a permanent constitution is written and ratified in a referendum.\n" + "body": "This Constitution is a multi-party contract entered into by the Members by virtue of their use of this blockchain.\n\n# Article I - No Initiation of Violence\nMembers shall not initiate violence or the threat of violence against another Member. Lawful prosecution of crimes with the goal of preserving life, liberty and property does not constitute initiation of violence.\n\n# Article II - No Perjury\nMembers shall be liable for losses caused by false or misleading attestations and shall forfeit any profit gained thereby.\n\n# Article III - Rights\nThe Members grant the right of contract and of private property to each other, therefore no property shall change hands except with the consent of the owner, by a valid Arbitrator\u2019s order, or via community referendum. This Constitution creates no positive rights for or between any Members.\n\n# Article IV - No Vote Buying\nNo Member shall offer nor accept anything of value in exchange for a vote of any type, nor shall any Member unduly influence the vote of another.\n\n# Article V - No Fiduciary\nNo Member nor EOS token holder shall have fiduciary responsibility to support the value of the EOS token. The Members do not authorize anyone to hold assets, borrow, nor contract on behalf of EOS token holders collectively. This blockchain has no owners, managers or fiduciaries; therefore, no Member shall have beneficial interest in more than 10% of the EOS token supply.\n\n# Article VI - Restitution\nEach Member agrees that penalties for breach of contract may include, but are not limited to, fines, loss of account, and other restitution.\n\n# Article VII - Open Source\nEach Member who makes available a smart contract on this blockchain shall be a Developer. Each Developer shall offer their smart contracts via a free and open source license, and each smart contract shall be documented with a Ricardian Contract stating the intent of all parties and naming the Arbitration Forum that will resolve disputes arising from that contract.\n\n# Article VIII - Language\nMulti-lingual contracts must specify one prevailing language in case of dispute and the author of any translation shall be liable for losses due to their false, misleading, or ambiguous attested translations.\n\n# Article IX - Dispute Resolution\nAll disputes arising out of or in connection with this Constitution shall be finally settled under the Rules of Dispute Resolution of the EOS Core Arbitration Forum by one or more arbitrators appointed in accordance with the said Rules.\n\n# Article X - Choice of Law\nChoice of law for disputes shall be, in order of precedence, this Constitution and the Maxims of Equity.\n\n# Article XI - Amending\nThis Constitution and its subordinate documents shall not be amended except by a vote of the token holders with no less than 15% vote participation among tokens and no fewer than 10% more Yes than No votes, sustained for 30 continuous days within a 120 day period.\n\n# Article XII - Publishing\nMembers may only publish information to the Blockchain that is within their right to publish. Furthermore, Members voluntarily consent for all Members to permanently and irrevocably retain a copy, analyze, and distribute all broadcast transactions and derivative information.\n\n# Article XIII - Informed Consent\nAll service providers who produce tools to facilitate the construction and signing of transactions on behalf of other Members shall present to said other Members the full Ricardian contract terms of this Constitution and other referenced contracts. Service providers shall be liable for losses resulting from failure to disclose the full Ricardian contract terms to users.\n\n# Article XIV - Severability\nIf any part of this Constitution is declared unenforceable or invalid, the remainder will continue to be valid and enforceable.\n\n# Article XV - Termination of Agreement\nA Member is automatically released from all revocable obligations under this Constitution 3 years after the last transaction signed by that Member is incorporated into the blockchain. After 3 years of inactivity an account may be put up for auction and the proceeds distributed to all Members according to the system contract provisions then in effect for such redistribution.\n\n# Article XVI - Developer Liability\nMembers agree to hold software developers harmless for unintentional mistakes made in the expression of contractual intent, whether or not said mistakes were due to actual or perceived negligence.\n\n# Article XVII - Consideration\nAll rights and obligations under this Constitution are mutual and reciprocal and of equally significant value and cost to all parties.\n\n# Article XVIII - Acceptance\nA contract is deemed accepted when a member signs a transaction which incorporates a TAPOS proof of a block whose implied state incorporates an ABI of said contract and said transaction is incorporated into the blockchain.\n\n# Article XIX - Counterparts\nThis Constitution may be executed in any number of counterparts, each of which when executed and delivered shall constitute a duplicate original, but all counterparts together shall constitute a single agreement.\n\n# Article XX - Interim Constitution\nThis constitution is interim and is intended to remain in effect until a permanent constitution is written and ratified in a referendum.\n" } ], "abi_extensions": [] From ee33a904ed27611ebef8dee9add10ae66b13dfc2 Mon Sep 17 00:00:00 2001 From: Denis Date: Fri, 8 Jun 2018 19:23:55 -0700 Subject: [PATCH 05/11] Update eosio.system.abi --- contracts/eosio.system/eosio.system.abi | 58 +++++++++++++++++-------- 1 file changed, 40 insertions(+), 18 deletions(-) diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index a102fc28be3..b0a60f087e6 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -909,15 +909,28 @@ "type": "connector" } ] - }, { - "name": "namebid_info", - "base": "", - "fields": [ - {"name":"newname", "type":"account_name"}, - {"name":"high_bidder", "type":"account_name"}, - {"name":"high_bid", "type":"int64"}, - {"name":"last_bid_time", "type":"uint64"} - ] + }, + { + "name": "namebid_info", + "base": "", + "fields": [ + { + "name": "newname", + "type": "account_name" + }, + { + "name": "high_bidder", + "type": "account_name" + }, + { + "name": "high_bid", + "type": "int64" + }, + { + "name": "last_bid_time", + "type": "uint64" + } + ] } ], "actions": [ @@ -1134,14 +1147,23 @@ "name": "refunds", "type": "refund_request", "index_type": "i64", - "key_names" : ["owner"], - "key_types" : ["uint64"] - },{ - "name": "namebids", - "type": "namebid_info", - "index_type": "i64", - "key_names" : ["newname"], - "key_types" : ["account_name"] + "key_names": [ + "owner" + ], + "key_types": [ + "uint64" + ] + }, + { + "name": "namebids", + "type": "namebid_info", + "index_type": "i64", + "key_names": [ + "newname" + ], + "key_types": [ + "account_name" + ] } ], "ricardian_clauses": [ @@ -1151,4 +1173,4 @@ } ], "abi_extensions": [] -} \ No newline at end of file +} From 63f6a87a4eb5ba427c91f1acb0f7ddfec603e3c1 Mon Sep 17 00:00:00 2001 From: winlin Date: Sat, 9 Jun 2018 18:18:36 +0800 Subject: [PATCH 06/11] finish the delegated_bandwidth->self_delegated_bandwidth --- contracts/eosio.system/delegate_bandwidth.cpp | 6 +++--- contracts/eosio.system/eosio.system.abi | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/contracts/eosio.system/delegate_bandwidth.cpp b/contracts/eosio.system/delegate_bandwidth.cpp index c235d5c8e9d..9e2eedfa4bf 100644 --- a/contracts/eosio.system/delegate_bandwidth.cpp +++ b/contracts/eosio.system/delegate_bandwidth.cpp @@ -47,7 +47,7 @@ namespace eosiosystem { /** * Every user 'from' has a scope/table that uses every receipient 'to' as the primary key. */ - struct delegated_bandwidth { + struct self_delegated_bandwidth { account_name from; account_name to; asset net_weight; @@ -56,7 +56,7 @@ namespace eosiosystem { uint64_t primary_key()const { return to; } // explicit serialization macro is not necessary, used here only to improve compilation time - EOSLIB_SERIALIZE( delegated_bandwidth, (from)(to)(net_weight)(cpu_weight) ) + EOSLIB_SERIALIZE( self_delegated_bandwidth, (from)(to)(net_weight)(cpu_weight) ) }; @@ -77,7 +77,7 @@ namespace eosiosystem { * facilitates simpler API for per-user queries */ typedef eosio::multi_index< N(userres), user_resources> user_resources_table; - typedef eosio::multi_index< N(delband), delegated_bandwidth> del_bandwidth_table; + typedef eosio::multi_index< N(delband), self_delegated_bandwidth> del_bandwidth_table; typedef eosio::multi_index< N(refunds), refund_request> refunds_table; diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index a102fc28be3..d658ab390ea 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -391,7 +391,7 @@ ] }, { - "name": "delegated_bandwidth", + "name": "self_delegated_bandwidth", "base": "", "fields": [ { @@ -1110,7 +1110,7 @@ }, { "name": "delband", - "type": "delegated_bandwidth", + "type": "self_delegated_bandwidth", "index_type": "i64", "key_names": [ "to" From 2e598621af716a24327cdcc3a31ca5ee1f85fcc0 Mon Sep 17 00:00:00 2001 From: Jae Chung Date: Sat, 9 Jun 2018 22:20:20 +0800 Subject: [PATCH 07/11] Revert "finish the delegated_bandwidth->self_delegated_bandwidth" --- contracts/eosio.system/delegate_bandwidth.cpp | 6 +++--- contracts/eosio.system/eosio.system.abi | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/contracts/eosio.system/delegate_bandwidth.cpp b/contracts/eosio.system/delegate_bandwidth.cpp index 9e2eedfa4bf..c235d5c8e9d 100644 --- a/contracts/eosio.system/delegate_bandwidth.cpp +++ b/contracts/eosio.system/delegate_bandwidth.cpp @@ -47,7 +47,7 @@ namespace eosiosystem { /** * Every user 'from' has a scope/table that uses every receipient 'to' as the primary key. */ - struct self_delegated_bandwidth { + struct delegated_bandwidth { account_name from; account_name to; asset net_weight; @@ -56,7 +56,7 @@ namespace eosiosystem { uint64_t primary_key()const { return to; } // explicit serialization macro is not necessary, used here only to improve compilation time - EOSLIB_SERIALIZE( self_delegated_bandwidth, (from)(to)(net_weight)(cpu_weight) ) + EOSLIB_SERIALIZE( delegated_bandwidth, (from)(to)(net_weight)(cpu_weight) ) }; @@ -77,7 +77,7 @@ namespace eosiosystem { * facilitates simpler API for per-user queries */ typedef eosio::multi_index< N(userres), user_resources> user_resources_table; - typedef eosio::multi_index< N(delband), self_delegated_bandwidth> del_bandwidth_table; + typedef eosio::multi_index< N(delband), delegated_bandwidth> del_bandwidth_table; typedef eosio::multi_index< N(refunds), refund_request> refunds_table; diff --git a/contracts/eosio.system/eosio.system.abi b/contracts/eosio.system/eosio.system.abi index f3ba1350e9e..b0a60f087e6 100644 --- a/contracts/eosio.system/eosio.system.abi +++ b/contracts/eosio.system/eosio.system.abi @@ -391,7 +391,7 @@ ] }, { - "name": "self_delegated_bandwidth", + "name": "delegated_bandwidth", "base": "", "fields": [ { @@ -1123,7 +1123,7 @@ }, { "name": "delband", - "type": "self_delegated_bandwidth", + "type": "delegated_bandwidth", "index_type": "i64", "key_names": [ "to" From b16df8d64320aa6e316a4159c3e9485f85b61a5b Mon Sep 17 00:00:00 2001 From: Jae Chung Date: Sat, 9 Jun 2018 22:28:53 +0800 Subject: [PATCH 08/11] Update chain_plugin.cpp --- plugins/chain_plugin/chain_plugin.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/chain_plugin/chain_plugin.cpp b/plugins/chain_plugin/chain_plugin.cpp index 0a07bb4c58e..e8c665366b4 100644 --- a/plugins/chain_plugin/chain_plugin.cpp +++ b/plugins/chain_plugin/chain_plugin.cpp @@ -1024,7 +1024,7 @@ read_only::get_account_results read_only::get_account( const get_account_params& if ( it != idx.end() ) { vector data; copy_inline_row(*it, data); - result.self_delegated_bandwidth = abis.binary_to_variant( "self_delegated_bandwidth", data ); + result.self_delegated_bandwidth = abis.binary_to_variant( "delegated_bandwidth", data ); } } From 6058a43d272df92810db47e84fcfd0db403b4b17 Mon Sep 17 00:00:00 2001 From: HuweyII Date: Sat, 9 Jun 2018 08:10:22 -0700 Subject: [PATCH 09/11] Create BP_Instructions.md --- BP_Instructions.md | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 BP_Instructions.md diff --git a/BP_Instructions.md b/BP_Instructions.md new file mode 100644 index 00000000000..da42f4d53cb --- /dev/null +++ b/BP_Instructions.md @@ -0,0 +1,20 @@ +

Important Information for Block Producers

+ +This document is indented to contain the information a BPC need to know to build and connect. +This document assumes a working knowledge of the EOSIO software + +Node OS Version (nodeos -v): 3679913985 +Github: https://github.com/EOS-Mainnet/eos +Tag: mainnet-1.0.2.2 + + +Peer List Location: https://docs.google.com/spreadsheets/d/1K_un5Vak3eDh_b4Wdh43sOersuhs0A76HMCfeQplDOY/edit#gid=0 +Genesis: https://github.com/EOS-Mainnet/eos/blob/master/mainnet-genesis.json +Chain ID: aca376f206b8fc25a6ed44dbdc66547c36c6c33e3a119ffbeaef943642f0e906 + +Status: Chain is frozen, please mesh and verify chain contents ASAP. Report findings to EMLG channel + +

Schedule

+01:00 UTC Sunday (Jun 10) — EMLG meeting, check up, verify number of peers + +13:00 UTC Sunday (Jun 10) — ELMG Meeting to agree on validation, if validation is good unfreeze From 7b2ec4c624509ee68ceb0176c1dc89f9113cdd70 Mon Sep 17 00:00:00 2001 From: HuweyII Date: Sat, 9 Jun 2018 08:10:39 -0700 Subject: [PATCH 10/11] Add files via upload --- mainnet-genesis.json | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 mainnet-genesis.json diff --git a/mainnet-genesis.json b/mainnet-genesis.json new file mode 100644 index 00000000000..1d784c7c5f6 --- /dev/null +++ b/mainnet-genesis.json @@ -0,0 +1,23 @@ +{ + "initial_timestamp": "2018-06-08T08:08:08.888", + "initial_key": "EOS7EarnUhcyYqmdnPon8rm7mBCTnBoot6o7fE2WzjvEX2TdggbL3", + "initial_configuration": { + "max_block_net_usage": 1048576, + "target_block_net_usage_pct": 1000, + "max_transaction_net_usage": 524288, + "base_per_transaction_net_usage": 12, + "net_usage_leeway": 500, + "context_free_discount_net_usage_num": 20, + "context_free_discount_net_usage_den": 100, + "max_block_cpu_usage": 200000, + "target_block_cpu_usage_pct": 1000, + "max_transaction_cpu_usage": 150000, + "min_transaction_cpu_usage": 100, + "max_transaction_lifetime": 3600, + "deferred_trx_expiration_window": 600, + "max_transaction_delay": 3888000, + "max_inline_action_size": 4096, + "max_inline_action_depth": 4, + "max_authority_depth": 6 + } +} \ No newline at end of file From 28af326182acbde8009890d47812ec8dfa12aa30 Mon Sep 17 00:00:00 2001 From: HuweyII Date: Sat, 9 Jun 2018 08:11:12 -0700 Subject: [PATCH 11/11] Update BP_Instructions.md --- BP_Instructions.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/BP_Instructions.md b/BP_Instructions.md index da42f4d53cb..95b6693c0fc 100644 --- a/BP_Instructions.md +++ b/BP_Instructions.md @@ -9,7 +9,7 @@ Tag: mainnet-1.0.2.2 Peer List Location: https://docs.google.com/spreadsheets/d/1K_un5Vak3eDh_b4Wdh43sOersuhs0A76HMCfeQplDOY/edit#gid=0 -Genesis: https://github.com/EOS-Mainnet/eos/blob/master/mainnet-genesis.json +Genesis: https://github.com/EOS-Mainnet/eos/blob/launch-rc-1.0.2/mainnet-genesis.json Chain ID: aca376f206b8fc25a6ed44dbdc66547c36c6c33e3a119ffbeaef943642f0e906 Status: Chain is frozen, please mesh and verify chain contents ASAP. Report findings to EMLG channel