From 1963a906073c6c8c1d967ddf6ca70425aba63ed8 Mon Sep 17 00:00:00 2001 From: Dan Park Date: Mon, 27 May 2024 17:44:07 +0900 Subject: [PATCH] Deploy website - based on 0c1ee6d25ec56aba5c4e46a8f0026481fd3cb9ab --- 404.html | 4 ++-- assets/js/2b8c0123.4703d6db.js | 1 - assets/js/2b8c0123.fea95ca1.js | 1 + .../{runtime~main.4843e2aa.js => runtime~main.7ce872fe.js} | 2 +- developers.html | 4 ++-- developers/build-your-contract.html | 4 ++-- developers/build-your-contract/deploy-your-contract.html | 4 ++-- developers/build-your-contract/developer-tools.html | 4 ++-- developers/client-apis.html | 4 ++-- developers/deployed-contracts.html | 4 ++-- developers/differences-from-ethereum.html | 6 +++--- index.html | 4 ++-- learn.html | 4 ++-- learn/key-features/layered-architecture/ethanos.html | 4 ++-- learn/key-features/layered-architecture/overview.html | 4 ++-- learn/key-features/over-pos/overview.html | 4 ++-- learn/key-features/over-pos/requirements.html | 4 ++-- learn/key-features/over-pos/rewards-and-penalties.html | 4 ++-- learn/key-features/tokenomics/distribution.html | 4 ++-- learn/key-features/tokenomics/fee.html | 4 ++-- learn/key-features/tokenomics/feedback.html | 4 ++-- learn/key-features/tokenomics/overview.html | 4 ++-- operators.html | 4 ++-- operators/faqs.html | 4 ++-- operators/operate-restoration-client.html | 4 ++-- operators/operate-validators.html | 4 ++-- operators/run-a-node.html | 4 ++-- operators/system-requirements.html | 4 ++-- 28 files changed, 53 insertions(+), 53 deletions(-) delete mode 100644 assets/js/2b8c0123.4703d6db.js create mode 100644 assets/js/2b8c0123.fea95ca1.js rename assets/js/{runtime~main.4843e2aa.js => runtime~main.7ce872fe.js} (83%) diff --git a/404.html b/404.html index a62034e..ee377f4 100644 --- a/404.html +++ b/404.html @@ -4,13 +4,13 @@ Page Not Found | OverProtocol Docs - +
Skip to main content

Page Not Found

We could not find what you were looking for.

Please contact the owner of the site that linked you to the original URL and let them know their link is broken.

- + \ No newline at end of file diff --git a/assets/js/2b8c0123.4703d6db.js b/assets/js/2b8c0123.4703d6db.js deleted file mode 100644 index 5220be4..0000000 --- a/assets/js/2b8c0123.4703d6db.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkover_docs=self.webpackChunkover_docs||[]).push([[652],{3905:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>m});var r=n(7294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var c=r.createContext({}),l=function(e){var t=r.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},d=function(e){var t=l(e.components);return r.createElement(c.Provider,{value:t},e.children)},u="mdxType",p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},h=r.forwardRef((function(e,t){var n=e.components,a=e.mdxType,i=e.originalType,c=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),u=l(n),h=a,m=u["".concat(c,".").concat(h)]||u[h]||p[h]||i;return n?r.createElement(m,o(o({ref:t},d),{},{components:n})):r.createElement(m,o({ref:t},d))}));function m(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var i=n.length,o=new Array(i);o[0]=h;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s[u]="string"==typeof e?e:a,o[1]=s;for(var l=2;l{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>p,frontMatter:()=>i,metadata:()=>s,toc:()=>l});var r=n(7462),a=(n(7294),n(3905));const i={title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",lang:"en"},o=void 0,s={unversionedId:"developers/differences-from-ethereum",id:"developers/differences-from-ethereum",title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",source:"@site/docs/developers/differences-from-ethereum.md",sourceDirName:"developers",slug:"/developers/differences-from-ethereum",permalink:"/developers/differences-from-ethereum",draft:!1,editUrl:"https://github.com/overprotocol/overprotocol.github.io/edit/develop/docs/developers/differences-from-ethereum.md",tags:[],version:"current",frontMatter:{title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",lang:"en"},sidebar:"developersSidebar",previous:{title:"Getting Started",permalink:"/developers/"},next:{title:"Build Your Contract",permalink:"/developers/build-your-contract/"}},c={},l=[{value:"Account Expiration",id:"account-expiration",level:2},{value:"Differences in Contract Address Derivation",id:"differences-in-contract-address-derivation",level:2},{value:"Address Derivation",id:"address-derivation",level:3},{value:"Differences in Account Structure",id:"differences-in-account-structure",level:2},{value:"Account Nonce",id:"account-nonce",level:3},{value:"RestoredEpoch",id:"restoredepoch",level:3},{value:"nonce Field in Transaction",id:"nonce-field-in-transaction",level:4},{value:"Storage Count",id:"storage-count",level:3},{value:"UI Hash",id:"ui-hash",level:3},{value:"Misc",id:"misc",level:2},{value:"SELFDESTRUCT Operation",id:"selfdestruct-operation",level:3},{value:"Future Changes",id:"future-changes",level:2},{value:"Storage Layout Change",id:"storage-layout-change",level:3}],d={toc:l},u="wrapper";function p(e){let{components:t,...n}=e;return(0,a.kt)(u,(0,r.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"While OverProtocol is an independent Layer 1 protocol, it inherits the Ethereum Virtual Machine (EVM), making it compatible with Ethereum's established ecosystem. This compatibility allows developers familiar with Ethereum's development environment to transition smoothly and leverage their existing skills. Below, we outline the key aspects of OverProtocol that differentiate it from Ethereum, highlighting why understanding these distinctions is crucial for developers, as these differences can significantly impact how applications are built and function on this platform."),(0,a.kt)("h2",{id:"account-expiration"},"Account Expiration"),(0,a.kt)("p",null,"In OverProtocol, accounts that remain inactive for an extended period are subject to expiration. ",(0,a.kt)("a",{parentName:"p",href:"/learn/key-features/layered-architecture/ethanos"},"This mechanism")," is designed to optimize the network's efficiency and scalability by reducing the overhead of maintaining dormant accounts."),(0,a.kt)("p",null,"Account restoration in OverProtocol is not implemented at the opcode level but rather as a combination of a new transaction type and additional EVM functionalities."),(0,a.kt)("admonition",{type:"warning"},(0,a.kt)("p",{parentName:"admonition"},"Currently, contract accounts have restoration disabled to prevent their expiration. To keep a contract active and prevent it from expiring, it must be periodically used."),(0,a.kt)("p",{parentName:"admonition"},"Usage is defined as any transaction querying the contract account's state or calling its functions, including view functions. This ensures that contracts remain active and functional within the network ecosystem, adhering to the protocol's operational requirements.")),(0,a.kt)("h2",{id:"differences-in-contract-address-derivation"},"Differences in Contract Address Derivation"),(0,a.kt)("admonition",{type:"caution"},(0,a.kt)("p",{parentName:"admonition"},"While the same Externally Owned Account (EOA) address can be used across various EVM-compatible chains with the same private key, this does not apply to contract addresses.")),(0,a.kt)("h3",{id:"address-derivation"},"Address Derivation"),(0,a.kt)("p",null,"Due to the state expiry feature in OverProtocol, all accounts, including contract accounts, could eventually expire. To mitigate the risk of an expired contract address being reused by a newly created contract, the contract creation operation always incorporates the caller account's ",(0,a.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," value. This inclusion alters the outcome of the ",(0,a.kt)("inlineCode",{parentName:"p"},"CREATE")," operation, making the resulting addresses differ from those on other EVM chains."),(0,a.kt)("p",null,"As a result, even though the ",(0,a.kt)("inlineCode",{parentName:"p"},"CREATE2")," operation allows for deterministic address prediction and usage, it is not possible to reuse the same address across different chains as you would with EOA addresses."),(0,a.kt)("admonition",{type:"caution"},(0,a.kt)("p",{parentName:"admonition"},"To use ",(0,a.kt)("inlineCode",{parentName:"p"},"CREATE2")," for contract deployment, the address must be restored back to Epoch 0.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-go"},"// Create creates a new contract using code as deployment code.\nfunc (evm *EVM) Create(caller ContractRef, code []byte, gas uint64, value *big.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {\n contractAddr = crypto.CreateAddress(caller.Address(), evm.StateDB.GetRestoredEpoch(caller.Address()), evm.StateDB.GetNonce(caller.Address()))\n return evm.create(caller, &codeAndHash{code: code}, gas, value, contractAddr, CREATE)\n}\n\n// Create2 creates a new contract using code as deployment code.\n//\n// The different between Create2 with Create is Create2 uses keccak256(0xff ++ msg.sender ++ salt ++ keccak256(init_code))[12:]\n// instead of the usual sender-and-nonce-hash as the address where the contract is initialized at.\nfunc (evm *EVM) Create2(caller ContractRef, code []byte, gas uint64, endowment *big.Int, salt *uint256.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {\n codeAndHash := &codeAndHash{code: code}\n contractAddr = crypto.CreateAddress2(caller.Address(), salt.Bytes32(), codeAndHash.Hash().Bytes())\n return evm.create(caller, codeAndHash, gas, endowment, contractAddr, CREATE2)\n}\n")),(0,a.kt)("h2",{id:"differences-in-account-structure"},"Differences in Account Structure"),(0,a.kt)("h3",{id:"account-nonce"},"Account Nonce"),(0,a.kt)("p",null,"In traditional blockchain architectures, the ",(0,a.kt)("inlineCode",{parentName:"p"},"nonce")," primarily tracks the number of transactions sent from a given account, ensuring transaction order and preventing double-spending. However, due to the expiration feature in OverProtocol, distinguishing explicitly between expired accounts and newly created accounts becomes challenging, raising the possibility of ",(0,a.kt)("inlineCode",{parentName:"p"},"nonce")," overlap. To address this issue, OverProtocol introduces the ",(0,a.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," as a crucial component."),(0,a.kt)("h3",{id:"restoredepoch"},"RestoredEpoch"),(0,a.kt)("p",null,"The combination of the ",(0,a.kt)("inlineCode",{parentName:"p"},"nonce")," and the ",(0,a.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," value ensures uniqueness for each account. This system allows OverProtocol to maintain the integrity and distinction of account states over time, even through periods of account inactivity and expiration."),(0,a.kt)("p",null,"For a more detailed explanation, please refer to the ",(0,a.kt)("a",{parentName:"p",href:"/learn/key-features/layered-architecture/ethanos#dealing-with-crumb-accounts-restored-epoch"},"documentation"),"."),(0,a.kt)("h4",{id:"nonce-field-in-transaction"},(0,a.kt)("inlineCode",{parentName:"h4"},"nonce")," Field in Transaction"),(0,a.kt)("p",null,"In RPC requests, such as ",(0,a.kt)("inlineCode",{parentName:"p"},"eth_getTransactionCount"),", the response reflects this unique combination. The ",(0,a.kt)("inlineCode",{parentName:"p"},"nonce")," is split into a 64-bit field, with the first 32 bits representing the ",(0,a.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," and the remaining 32 bits functioning as the traditional ",(0,a.kt)("inlineCode",{parentName:"p"},"nonce"),". This adaptation allows developers to leverage existing Ethereum development environments while accommodating the unique features of OverProtocol."),(0,a.kt)("h3",{id:"storage-count"},"Storage Count"),(0,a.kt)("p",null,"This feature prepares for future functionalities where the cost associated with an account's storage usage might be billed. Each new storage slot created by an ",(0,a.kt)("inlineCode",{parentName:"p"},"SSTORE")," operation increases the count, while emptying a slot decreases it."),(0,a.kt)("h3",{id:"ui-hash"},"UI Hash"),(0,a.kt)("p",null,"Reserved space for future proof related to an account's interaction with external layers. Currently, this feature is not utilized but is planned for future enhancements to enhance cross-layer interactions and verifications."),(0,a.kt)("h2",{id:"misc"},"Misc"),(0,a.kt)("h3",{id:"selfdestruct-operation"},(0,a.kt)("inlineCode",{parentName:"h3"},"SELFDESTRUCT")," Operation"),(0,a.kt)("p",null,"The ",(0,a.kt)("inlineCode",{parentName:"p"},"SELFDESTRUCT")," opcode, updated in accordance with ",(0,a.kt)("a",{parentName:"p",href:"https://eips.ethereum.org/EIPS/eip-6780"},(0,a.kt)("inlineCode",{parentName:"a"},"EIP-6780")),", is implemented in such a way that while it does not actually destroy the contract account, it does process refunds. Contracts that are not used will naturally expire over time as the Ethanos epoch progresses."),(0,a.kt)("p",null,"The rationale behind incorporating EIP-6780 into OverProtocol differs significantly from its application in Ethereum. OverProtocol's implementation is specifically designed to avoid scenarios where a self-destructed contract account becomes indistinguishable from an Externally Owned Account (EOA). This distinction is crucial for maintaining clarity and integrity in the network's account management, ensuring that the lifecycle of contract accounts is handled in a better way."),(0,a.kt)("h2",{id:"future-changes"},"Future Changes"),(0,a.kt)("p",null,"As OverProtocol progresses towards the Ethanos endgame, significant changes are planned, particularly regarding how storage is managed within accounts. These adjustments will be designed to ensure that backward compatibility is maximally preserved and that a seamless migration can occur. This means that current dApp developers should not be overly concerned about the impending changes."),(0,a.kt)("h3",{id:"storage-layout-change"},"Storage Layout Change"),(0,a.kt)("p",null,"Upcoming updates to OverProtocol will include a comprehensive overhaul of the storage layout within accounts. This change aims to enhance the efficiency and scalability of data management on the blockchain. Details on the new storage system will be provided as development progresses, ensuring developers have ample time to adapt their applications. This transition is intended to be smooth, with support structures in place to assist developers in migrating existing applications without disruption."))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/2b8c0123.fea95ca1.js b/assets/js/2b8c0123.fea95ca1.js new file mode 100644 index 0000000..40fe62a --- /dev/null +++ b/assets/js/2b8c0123.fea95ca1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkover_docs=self.webpackChunkover_docs||[]).push([[652],{3905:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>m});var a=n(7294);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var c=a.createContext({}),l=function(e){var t=a.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},d=function(e){var t=l(e.components);return a.createElement(c.Provider,{value:t},e.children)},u="mdxType",p={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},h=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,r=e.originalType,c=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),u=l(n),h=o,m=u["".concat(c,".").concat(h)]||u[h]||p[h]||r;return n?a.createElement(m,i(i({ref:t},d),{},{components:n})):a.createElement(m,i({ref:t},d))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=n.length,i=new Array(r);i[0]=h;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s[u]="string"==typeof e?e:o,i[1]=s;for(var l=2;l{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>p,frontMatter:()=>r,metadata:()=>s,toc:()=>l});var a=n(7462),o=(n(7294),n(3905));const r={title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",lang:"en"},i=void 0,s={unversionedId:"developers/differences-from-ethereum",id:"developers/differences-from-ethereum",title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",source:"@site/docs/developers/differences-from-ethereum.md",sourceDirName:"developers",slug:"/developers/differences-from-ethereum",permalink:"/developers/differences-from-ethereum",draft:!1,editUrl:"https://github.com/overprotocol/overprotocol.github.io/edit/develop/docs/developers/differences-from-ethereum.md",tags:[],version:"current",frontMatter:{title:"Differences from Ethereum",description:"A list of differences from Ethereum that can significantly impact how applications are built and function on this platform.",lang:"en"},sidebar:"developersSidebar",previous:{title:"Getting Started",permalink:"/developers/"},next:{title:"Build Your Contract",permalink:"/developers/build-your-contract/"}},c={},l=[{value:"Your Accounts Can Be Expired",id:"your-accounts-can-be-expired",level:2},{value:"Actions to Take",id:"actions-to-take",level:3},{value:"You Can't Use the Same Contract Address in Ethereum",id:"you-cant-use-the-same-contract-address-in-ethereum",level:2},{value:"Actions to Take",id:"actions-to-take-1",level:3},{value:"Transaction has a restoredEpoch Field",id:"transaction-has-a-restoredepoch-field",level:2},{value:"RestoredEpoch",id:"restoredepoch",level:3},{value:"nonce Field in Transaction",id:"nonce-field-in-transaction",level:4},{value:"Actions to Take",id:"actions-to-take-2",level:3},{value:"Misc",id:"misc",level:2},{value:"SELFDESTRUCT Operation",id:"selfdestruct-operation",level:3},{value:"Future Changes",id:"future-changes",level:2},{value:"Storage Layout Change",id:"storage-layout-change",level:3}],d={toc:l},u="wrapper";function p(e){let{components:t,...n}=e;return(0,o.kt)(u,(0,a.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"OverProtocol is an independent Layer 1 protocol that inherits the Ethereum Virtual Machine (EVM), ensuring compatibility with Ethereum's established ecosystem. This compatibility enables developers familiar with Ethereum to transition smoothly and leverage their existing skills. However, there are key distinctions between OverProtocol and Ethereum that developers must understand, as these differences can significantly impact how applications are built and function on this platform. Here are the crucial aspects to consider and the actions to take:"),(0,o.kt)("h2",{id:"your-accounts-can-be-expired"},"Your Accounts Can Be Expired"),(0,o.kt)("p",null,"In OverProtocol, inactive accounts are subject to expiration. ",(0,o.kt)("a",{parentName:"p",href:"/learn/key-features/layered-architecture/ethanos"},"This mechanism")," optimizes network efficiency and scalability by reducing the overhead of maintaining dormant accounts. Account restoration involves ",(0,o.kt)("a",{parentName:"p",href:"/learn/key-features/layered-architecture/ethanos#restoration-transaction"},"a new transaction type")," and additional EVM functionalities rather than opcode-level implementation."),(0,o.kt)("p",null,"On the mainnet, the Ethanos cycle lasts approximately 3 months, meaning that it takes 3 to 6 months for an inactive account to expire. The assessment of activity is based on the Ethanos cycle, so if you were active near the end of a cycle, your account could remain active for one more cycle. Conversely, if you were active at the beginning, your account could last for two cycles."),(0,o.kt)("h3",{id:"actions-to-take"},"Actions to Take"),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"If Your Account is Expired"),":"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Do not worry; it can be restored without any penalties."),(0,o.kt)("li",{parentName:"ul"},"To restore your accounts, you can request to ",(0,o.kt)("a",{parentName:"li",href:"/operators/operate-restoration-client"},"restoration client")," for the restoration."),(0,o.kt)("li",{parentName:"ul"},"Currently, you need to operate your own restoration client, but future services will provide more convenient restoration options.")),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"If Your Account is Not Expired"),":"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Ensure that accounts, especially contract accounts, are periodically used to prevent expiration. Usage is defined as any transaction that queries the contract account's state or calls its functions, including view functions."),(0,o.kt)("li",{parentName:"ul"},"Regularly monitor account activity to avoid unintentional expiration and ensure continuity of service. A monitoring tool will be available soon."),(0,o.kt)("li",{parentName:"ul"},"Especially for contract accounts with significant storage, prevent expiration as restoring storage can be costly. Future advancements will improve storage management efficiency, but for now, some monitoring and inconvenience are necessary.")),(0,o.kt)("admonition",{type:"info"},(0,o.kt)("p",{parentName:"admonition"},"For contract accounts, especially those with extensive storage, expiration can be costly to restore. While we are developing more efficient storage management techniques, please bear with the current monitoring requirements to prevent expiration.")),(0,o.kt)("h2",{id:"you-cant-use-the-same-contract-address-in-ethereum"},"You Can't Use the Same Contract Address in Ethereum"),(0,o.kt)("admonition",{type:"tip"},(0,o.kt)("p",{parentName:"admonition"},"While the same Externally Owned Account (EOA) address can be used across various EVM-compatible chains with the same private key, this does not apply to contract addresses.")),(0,o.kt)("p",null,"Due to the state expiry feature in OverProtocol, all accounts, including contract accounts, could eventually expire. To mitigate the risk of an expired contract address being reused by a newly created contract, the contract creation operation always incorporates the caller account's ",(0,o.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," value. This inclusion alters the outcome of the ",(0,o.kt)("inlineCode",{parentName:"p"},"CREATE")," operation, making the resulting addresses differ from those on other EVM chains."),(0,o.kt)("p",null,"As a result, even though the ",(0,o.kt)("inlineCode",{parentName:"p"},"CREATE2")," operation allows for deterministic address prediction and usage, it is not possible to reuse the same address across different chains as you would with EOA addresses."),(0,o.kt)("h3",{id:"actions-to-take-1"},"Actions to Take"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Be aware that contract addresses on OverProtocol will differ from those on Ethereum and other EVM-compatible chains due to the inclusion of the ",(0,o.kt)("inlineCode",{parentName:"li"},"restoredEpoch")," value."),(0,o.kt)("li",{parentName:"ul"},"When deploying contracts, account for the different address derivation method and plan your deployment strategy accordingly.")),(0,o.kt)("pre",null,(0,o.kt)("code",{parentName:"pre",className:"language-go"},"// Create creates a new contract using code as deployment code.\nfunc (evm *EVM) Create(caller ContractRef, code []byte, gas uint64, value *big.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {\n contractAddr = crypto.CreateAddress(caller.Address(), evm.StateDB.GetRestoredEpoch(caller.Address()), evm.StateDB.GetNonce(caller.Address()))\n return evm.create(caller, &codeAndHash{code: code}, gas, value, contractAddr, CREATE)\n}\n\n// Create2 creates a new contract using code as deployment code.\n//\n// The different between Create2 with Create is Create2 uses keccak256(0xff ++ msg.sender ++ salt ++ keccak256(init_code))[12:]\n// instead of the usual sender-and-nonce-hash as the address where the contract is initialized at.\nfunc (evm *EVM) Create2(caller ContractRef, code []byte, gas uint64, endowment *big.Int, salt *uint256.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {\n codeAndHash := &codeAndHash{code: code}\n contractAddr = crypto.CreateAddress2(caller.Address(), salt.Bytes32(), codeAndHash.Hash().Bytes())\n return evm.create(caller, codeAndHash, gas, endowment, contractAddr, CREATE2)\n}\n")),(0,o.kt)("h2",{id:"transaction-has-a-restoredepoch-field"},"Transaction has a ",(0,o.kt)("inlineCode",{parentName:"h2"},"restoredEpoch")," Field"),(0,o.kt)("p",null,"In traditional blockchain architectures, the ",(0,o.kt)("inlineCode",{parentName:"p"},"nonce")," primarily tracks the number of transactions sent from a given account, ensuring transaction order and preventing double-spending. However, due to the expiration feature in OverProtocol, distinguishing explicitly between expired accounts and newly created accounts becomes challenging, raising the possibility of ",(0,o.kt)("inlineCode",{parentName:"p"},"nonce")," overlap. To address this issue, OverProtocol introduces the ",(0,o.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," as a crucial component."),(0,o.kt)("h3",{id:"restoredepoch"},"RestoredEpoch"),(0,o.kt)("p",null,"The combination of the ",(0,o.kt)("inlineCode",{parentName:"p"},"nonce")," and the ",(0,o.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," value ensures uniqueness for each account. This system allows OverProtocol to maintain the integrity and distinction of account states over time, even through periods of account inactivity and expiration."),(0,o.kt)("p",null,"For a more detailed explanation, please refer to the ",(0,o.kt)("a",{parentName:"p",href:"/learn/key-features/layered-architecture/ethanos#dealing-with-crumb-accounts-restored-epoch"},"documentation"),"."),(0,o.kt)("h4",{id:"nonce-field-in-transaction"},(0,o.kt)("inlineCode",{parentName:"h4"},"nonce")," Field in Transaction"),(0,o.kt)("p",null,"The existing ",(0,o.kt)("inlineCode",{parentName:"p"},"nonce")," field is split into a 64-bit field, with the first 32 bits representing the ",(0,o.kt)("inlineCode",{parentName:"p"},"restoredEpoch")," and the remaining 32 bits functioning as the traditional ",(0,o.kt)("inlineCode",{parentName:"p"},"nonce"),". This adaptation allows developers to leverage existing Ethereum development environments while accommodating the unique features of OverProtocol."),(0,o.kt)("h3",{id:"actions-to-take-2"},"Actions to Take"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Learn how ",(0,o.kt)("inlineCode",{parentName:"li"},"restoredEpoch")," functions and its interaction with the nonce to ensure each account's uniqueness."),(0,o.kt)("li",{parentName:"ul"},"Use RPC requests like ",(0,o.kt)("inlineCode",{parentName:"li"},"eth_getTransactionCount")," when making transactions. The response will include the correct ",(0,o.kt)("inlineCode",{parentName:"li"},"nonce")," value, considering both ",(0,o.kt)("inlineCode",{parentName:"li"},"nonce")," and ",(0,o.kt)("inlineCode",{parentName:"li"},"restoredEpoch"),".")),(0,o.kt)("h2",{id:"misc"},"Misc"),(0,o.kt)("h3",{id:"selfdestruct-operation"},(0,o.kt)("inlineCode",{parentName:"h3"},"SELFDESTRUCT")," Operation"),(0,o.kt)("p",null,"The ",(0,o.kt)("inlineCode",{parentName:"p"},"SELFDESTRUCT")," opcode, updated in accordance with ",(0,o.kt)("a",{parentName:"p",href:"https://eips.ethereum.org/EIPS/eip-6780"},(0,o.kt)("inlineCode",{parentName:"a"},"EIP-6780")),", is implemented in such a way that while it does not actually destroy the contract account, it does process refunds. Contracts that are not used will naturally expire over time as the Ethanos epoch progresses."),(0,o.kt)("p",null,"The rationale behind incorporating EIP-6780 into OverProtocol differs significantly from its application in Ethereum. OverProtocol's implementation is specifically designed to avoid scenarios where a self-destructed contract account becomes indistinguishable from an Externally Owned Account (EOA). This distinction is crucial for maintaining clarity and integrity in the network's account management, ensuring that the lifecycle of contract accounts is handled in a better way."),(0,o.kt)("h2",{id:"future-changes"},"Future Changes"),(0,o.kt)("p",null,"As OverProtocol progresses towards the Ethanos endgame, significant changes are planned, particularly regarding how storage is managed within accounts. These adjustments will be designed to ensure that backward compatibility is maximally preserved and that a seamless migration can occur. This means that current dApp developers should not be overly concerned about the impending changes."),(0,o.kt)("h3",{id:"storage-layout-change"},"Storage Layout Change"),(0,o.kt)("p",null,"Upcoming updates to OverProtocol will include a comprehensive overhaul of the storage layout within accounts. This change aims to enhance the efficiency and scalability of data management on the blockchain. Details on the new storage system will be provided as development progresses, ensuring developers have ample time to adapt their applications. This transition is intended to be smooth, with support structures in place to assist developers in migrating existing applications without disruption."))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.4843e2aa.js b/assets/js/runtime~main.7ce872fe.js similarity index 83% rename from assets/js/runtime~main.4843e2aa.js rename to assets/js/runtime~main.7ce872fe.js index b8acda8..a5d1121 100644 --- a/assets/js/runtime~main.4843e2aa.js +++ b/assets/js/runtime~main.7ce872fe.js @@ -1 +1 @@ -(()=>{"use strict";var e,t,r,a,o,f={},n={};function c(e){var t=n[e];if(void 0!==t)return t.exports;var r=n[e]={exports:{}};return f[e].call(r.exports,r,r.exports,c),r.exports}c.m=f,e=[],c.O=(t,r,a,o)=>{if(!r){var f=1/0;for(b=0;b=o)&&Object.keys(c.O).every((e=>c.O[e](r[d])))?r.splice(d--,1):(n=!1,o0&&e[b-1][2]>o;b--)e[b]=e[b-1];e[b]=[r,a,o]},c.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return c.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,c.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var o=Object.create(null);c.r(o);var f={};t=t||[null,r({}),r([]),r(r)];for(var n=2&a&&e;"object"==typeof n&&!~t.indexOf(n);n=r(n))Object.getOwnPropertyNames(n).forEach((t=>f[t]=()=>e[t]));return f.default=()=>e,c.d(o,f),o},c.d=(e,t)=>{for(var r in t)c.o(t,r)&&!c.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},c.f={},c.e=e=>Promise.all(Object.keys(c.f).reduce(((t,r)=>(c.f[r](e,t),t)),[])),c.u=e=>"assets/js/"+({47:"8c2d38e9",53:"935f2afb",143:"5f02ec4e",169:"6571d487",170:"98fd4a74",206:"a5d2c59e",241:"9ed7639c",382:"8def2dd5",433:"b97ac028",434:"caac22b6",454:"eff5f417",461:"eff783ef",514:"1be78505",558:"abafa56d",577:"7c85feac",579:"197156b8",652:"2b8c0123",803:"7e4ee331",819:"4052b245",822:"63925da8",859:"669e6444",874:"e1a65c49",899:"d4e72995",918:"17896441",971:"c377a04b",974:"72939e70",977:"53c49350",981:"15afe019"}[e]||e)+"."+{47:"4e01e2c9",53:"86575b49",143:"89b7056a",169:"2ae86a76",170:"f1b306d4",206:"e5b529de",241:"2766f086",382:"25cc2ffb",433:"d7918913",434:"3fc75a5d",454:"1d40d8d6",461:"dc970584",514:"54db1a75",558:"c343c35a",577:"b398bf13",579:"8f3e82a9",652:"4703d6db",803:"69d1831f",819:"e9a664b4",822:"b43ffc84",859:"5e95a6a8",874:"55b01fa4",899:"d9448e29",918:"267b3843",971:"ccfee8f6",972:"50480502",974:"e8fa250c",977:"0dbf2de6",981:"6b894f38"}[e]+".js",c.miniCssF=e=>{},c.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),c.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},o="over-docs:",c.l=(e,t,r,f)=>{if(a[e])a[e].push(t);else{var n,d;if(void 0!==r)for(var i=document.getElementsByTagName("script"),b=0;b{n.onerror=n.onload=null,clearTimeout(s);var o=a[e];if(delete a[e],n.parentNode&&n.parentNode.removeChild(n),o&&o.forEach((e=>e(r))),t)return t(r)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=l.bind(null,n.onerror),n.onload=l.bind(null,n.onload),d&&document.head.appendChild(n)}},c.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c.p="/",c.gca=function(e){return e={17896441:"918","8c2d38e9":"47","935f2afb":"53","5f02ec4e":"143","6571d487":"169","98fd4a74":"170",a5d2c59e:"206","9ed7639c":"241","8def2dd5":"382",b97ac028:"433",caac22b6:"434",eff5f417:"454",eff783ef:"461","1be78505":"514",abafa56d:"558","7c85feac":"577","197156b8":"579","2b8c0123":"652","7e4ee331":"803","4052b245":"819","63925da8":"822","669e6444":"859",e1a65c49:"874",d4e72995:"899",c377a04b:"971","72939e70":"974","53c49350":"977","15afe019":"981"}[e]||e,c.p+c.u(e)},(()=>{var e={303:0,532:0};c.f.j=(t,r)=>{var a=c.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(303|532)$/.test(t))e[t]=0;else{var o=new Promise(((r,o)=>a=e[t]=[r,o]));r.push(a[2]=o);var f=c.p+c.u(t),n=new Error;c.l(f,(r=>{if(c.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var o=r&&("load"===r.type?"missing":r.type),f=r&&r.target&&r.target.src;n.message="Loading chunk "+t+" failed.\n("+o+": "+f+")",n.name="ChunkLoadError",n.type=o,n.request=f,a[1](n)}}),"chunk-"+t,t)}},c.O.j=t=>0===e[t];var t=(t,r)=>{var a,o,f=r[0],n=r[1],d=r[2],i=0;if(f.some((t=>0!==e[t]))){for(a in n)c.o(n,a)&&(c.m[a]=n[a]);if(d)var b=d(c)}for(t&&t(r);i{"use strict";var e,t,r,a,o,f={},n={};function c(e){var t=n[e];if(void 0!==t)return t.exports;var r=n[e]={exports:{}};return f[e].call(r.exports,r,r.exports,c),r.exports}c.m=f,e=[],c.O=(t,r,a,o)=>{if(!r){var f=1/0;for(u=0;u=o)&&Object.keys(c.O).every((e=>c.O[e](r[d])))?r.splice(d--,1):(n=!1,o0&&e[u-1][2]>o;u--)e[u]=e[u-1];e[u]=[r,a,o]},c.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return c.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,c.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var o=Object.create(null);c.r(o);var f={};t=t||[null,r({}),r([]),r(r)];for(var n=2&a&&e;"object"==typeof n&&!~t.indexOf(n);n=r(n))Object.getOwnPropertyNames(n).forEach((t=>f[t]=()=>e[t]));return f.default=()=>e,c.d(o,f),o},c.d=(e,t)=>{for(var r in t)c.o(t,r)&&!c.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},c.f={},c.e=e=>Promise.all(Object.keys(c.f).reduce(((t,r)=>(c.f[r](e,t),t)),[])),c.u=e=>"assets/js/"+({47:"8c2d38e9",53:"935f2afb",143:"5f02ec4e",169:"6571d487",170:"98fd4a74",206:"a5d2c59e",241:"9ed7639c",382:"8def2dd5",433:"b97ac028",434:"caac22b6",454:"eff5f417",461:"eff783ef",514:"1be78505",558:"abafa56d",577:"7c85feac",579:"197156b8",652:"2b8c0123",803:"7e4ee331",819:"4052b245",822:"63925da8",859:"669e6444",874:"e1a65c49",899:"d4e72995",918:"17896441",971:"c377a04b",974:"72939e70",977:"53c49350",981:"15afe019"}[e]||e)+"."+{47:"4e01e2c9",53:"86575b49",143:"89b7056a",169:"2ae86a76",170:"f1b306d4",206:"e5b529de",241:"2766f086",382:"25cc2ffb",433:"d7918913",434:"3fc75a5d",454:"1d40d8d6",461:"dc970584",514:"54db1a75",558:"c343c35a",577:"b398bf13",579:"8f3e82a9",652:"fea95ca1",803:"69d1831f",819:"e9a664b4",822:"b43ffc84",859:"5e95a6a8",874:"55b01fa4",899:"d9448e29",918:"267b3843",971:"ccfee8f6",972:"50480502",974:"e8fa250c",977:"0dbf2de6",981:"6b894f38"}[e]+".js",c.miniCssF=e=>{},c.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),c.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},o="over-docs:",c.l=(e,t,r,f)=>{if(a[e])a[e].push(t);else{var n,d;if(void 0!==r)for(var i=document.getElementsByTagName("script"),u=0;u{n.onerror=n.onload=null,clearTimeout(s);var o=a[e];if(delete a[e],n.parentNode&&n.parentNode.removeChild(n),o&&o.forEach((e=>e(r))),t)return t(r)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=l.bind(null,n.onerror),n.onload=l.bind(null,n.onload),d&&document.head.appendChild(n)}},c.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c.p="/",c.gca=function(e){return e={17896441:"918","8c2d38e9":"47","935f2afb":"53","5f02ec4e":"143","6571d487":"169","98fd4a74":"170",a5d2c59e:"206","9ed7639c":"241","8def2dd5":"382",b97ac028:"433",caac22b6:"434",eff5f417:"454",eff783ef:"461","1be78505":"514",abafa56d:"558","7c85feac":"577","197156b8":"579","2b8c0123":"652","7e4ee331":"803","4052b245":"819","63925da8":"822","669e6444":"859",e1a65c49:"874",d4e72995:"899",c377a04b:"971","72939e70":"974","53c49350":"977","15afe019":"981"}[e]||e,c.p+c.u(e)},(()=>{var e={303:0,532:0};c.f.j=(t,r)=>{var a=c.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(303|532)$/.test(t))e[t]=0;else{var o=new Promise(((r,o)=>a=e[t]=[r,o]));r.push(a[2]=o);var f=c.p+c.u(t),n=new Error;c.l(f,(r=>{if(c.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var o=r&&("load"===r.type?"missing":r.type),f=r&&r.target&&r.target.src;n.message="Loading chunk "+t+" failed.\n("+o+": "+f+")",n.name="ChunkLoadError",n.type=o,n.request=f,a[1](n)}}),"chunk-"+t,t)}},c.O.j=t=>0===e[t];var t=(t,r)=>{var a,o,f=r[0],n=r[1],d=r[2],i=0;if(f.some((t=>0!==e[t]))){for(a in n)c.o(n,a)&&(c.m[a]=n[a]);if(d)var u=d(c)}for(t&&t(r);i Getting Started | OverProtocol Docs - +

Getting Started

Welcome to the OverProtocol developer documentation! This guide is designed to help developers set up and prepare for building applications on OverProtocol. Before diving into coding, there are a few crucial components you need to have in place to ensure a smooth and efficient development process.

Setting Up a Node with RPC Access

To interact with the OverProtocol network, you'll need access to a node capable of handling Remote Procedure Calls (RPC). This will enable you to query and interact with the network, deploy contracts, and perform transactions programmatically.

Options for Setting Up a Node:

  • Running Your Own Node: Setting up and maintaining your own node gives you full control over network interactions. This can be done by following the setup instructions. Running your own node is beneficial for extensive development work that requires high levels of data integrity and privacy.
  • Using Public Nodes: If you prefer not to manage your own node, you can use publicly available RPC endpoints. These are provided by various services and can be accessed easily, though they might come with limitations on the rate of requests and reduced control over the node configuration.

OverProtocol Testnet Configuration

tip

When working with OverProtocol, especially in a testnet environment, it's important to note that testnet configurations and details may change at any time. This variability is typical of test environments, which are often updated or reset to test new features and improvements in the blockchain protocol.

KeyValue
NetworkOverProtocol Creeper
RPC URLYOUR_OVER_RPC_URL
Chain ID27882
Currency symbolOVER
Block Explorer URLhttps://view.over.network/

Preparing an Account with OVER Tokens

Developing on OverProtocol typically requires interacting with the network, which can include transaction fees or testing token transactions. Therefore, it's essential to have an account loaded with OVER tokens.

Setting Up Your Developer Account:

  • Acquire OVER Tokens: If you are working on the main network, you'll need to acquire OVER tokens, which can be done through exchanges or from other token holders.
  • Testnet Tokens: For testing purposes, you can use the OverProtocol testnet, where tokens can often be acquired for free from a faucet that distributes small amounts of tokens for development use. Currently, you can receive 10 OVER testnet tokens every day from OverWallet.
  • Secure Your Account: Ensure that your account is secure, especially if you are working with real tokens. Utilize hardware wallets or secure key management solutions to protect your private keys and account credentials.
- + \ No newline at end of file diff --git a/developers/build-your-contract.html b/developers/build-your-contract.html index 26cb325..3ede5dc 100644 --- a/developers/build-your-contract.html +++ b/developers/build-your-contract.html @@ -4,13 +4,13 @@ Build Your Contract | OverProtocol Docs - +

Build Your Contract

To build and deploy your decentralized application (dApp) on OverProtocol, you can use Ethereum-compatible development environments like Hardhat, Foundry or Remix. Each tool has its own setup and configuration process, but generally, you'll need to make adjustments to your project’s network configuration to connect with the OverProtocol network.

- + \ No newline at end of file diff --git a/developers/build-your-contract/deploy-your-contract.html b/developers/build-your-contract/deploy-your-contract.html index f464182..746db26 100644 --- a/developers/build-your-contract/deploy-your-contract.html +++ b/developers/build-your-contract/deploy-your-contract.html @@ -4,13 +4,13 @@ Deploy Your Contract | OverProtocol Docs - +

Deploy Your Contract

caution

While OverProtocol is EVM-compatible, there are important differences that developers should be aware of. Please refer to the documentation thoroughly before proceeding to ensure you understand these distinctions.

OverProtocol's compatibility with the Ethereum Virtual Machine (EVM) allows you to leverage various Ethereum development environments to build and deploy your smart contracts. This guide outlines how to use popular tools like Foundry, Hardhat and Remix for developing on OverProtocol. Detailed steps and tips will ensure you understand the nuances of deploying effectively in each environment.

Build With Foundry

Foundry is a fast, portable, and modular toolkit for Ethereum application development. For detailed information and further utilization of Foundry, please refer to the official documentation.

Installation

Install Foundry by following the instructions on Foundry's GitHub repository and the installation guide.

Foundry consists of:

  • Forge: Ethereum testing framework (like Truffle, Hardhat and DappTools).
  • Cast: Swiss army knife for interacting with EVM smart contracts, sending transactions and getting chain data.
  • Anvil: Local Ethereum node, akin to Ganache, Hardhat Network.
  • Chisel: Fast, utilitarian, and verbose solidity REPL.

Creating a New Project

To start a new project with Foundry, use forge init

$ forge init hello_foundry

Let's check out what forge generated for us:

$ cd hello_foundry
$ ls

The default template comes with one dependency installed: Forge Standard Library. This is the preferred testing library used for Foundry projects. Additionally, the template also comes with an empty starter contract and a simple test.

We can build the project with forge build:

$ forge build
Compiling 27 files with 0.8.19
Solc 0.8.19 finished in 1.16s
Compiler run successful!

And run the tests with forge test:

$ forge test
No files changed, compilation skipped

Ran 2 tests for test/Counter.t.sol:CounterTest
[PASS] testFuzz_SetNumber(uint256) (runs: 256, μ: 30454, ~: 31310)
[PASS] test_Increment() (gas: 31325)
Suite result: ok. 2 passed; 0 failed; 0 skipped; finished in 9.15ms (8.89ms CPU time)

Ran 1 test suite in 13.66ms (9.15ms CPU time): 2 tests passed, 0 failed, 0 skipped (2 total tests)

You’ll notice that two new directories have popped up: out and cache.

The out directory contains your contract artifact, such as the ABI, while the cache is used by forge to only recompile what is necessary.

Deploying Your Contracts

You can find out the official Foundry's documentation here.

Forge can deploy smart contracts to a given network with the forge create command.

To deploy a contract, you must provide a RPC URL (env: ETH_RPC_URL) and the private key of the account that will deploy the contract.

To deploy MyContract to a network:

$ forge create --rpc-url <your_rpc_url> --private-key <your_private_key> src/MyContract.sol:MyContract
Compiling...
No files changed, compilation skipped
Deployer: 0x079E40B71d...
Deployed to: 0x92e9a5A338...
Transaction hash: 0x2c13f01a69...

Solidity files may contain multiple contracts. :MyContract above specifies which contract to deploy from the src/MyContract.sol file.

Use the --constructor-args flag to pass arguments to the constructor:

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.0;

import {ERC20} from "solmate/tokens/ERC20.sol";

contract MyToken is ERC20 {
constructor(
string memory name,
string memory symbol,
uint8 decimals,
uint256 initialSupply
) ERC20(name, symbol, decimals) {
_mint(msg.sender, initialSupply);
}
}

Build With Hardhat

Hardhat is a development environment for Ethereum software. It consists of different components for editing, compiling, debugging and deploying your smart contracts and dApps, all of which work together to create a complete development environment. For detailed information and further utilization of Hardhat, please refer to the official documentation.

Installation

Install Hardhat in your project by following the instructions on Hardhat's Installation Guide.

Creating a New Project

To create the sample project, run npx hardhat init in your project folder:

$ npx hardhat init
888 888 888 888 888
888 888 888 888 888
888 888 888 888 888
8888888888 8888b. 888d888 .d88888 88888b. 8888b. 888888
888 888 "88b 888P" d88" 888 888 "88b "88b 888
888 888 .d888888 888 888 888 888 888 .d888888 888
888 888 888 888 888 Y88b 888 888 888 888 888 Y88b.
888 888 "Y888888 888 "Y88888 888 888 "Y888888 "Y888

👷 Welcome to Hardhat v2.22.3 👷‍

? What do you want to do? …
❯ Create a JavaScript project
Create a TypeScript project
Create a TypeScript project (with Viem)
Create an empty hardhat.config.js
Quit

Compiling Your Contracts

Next, if you take a look in the contracts/ folder, you'll see Lock.sol:

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.24;

// Uncomment this line to use console.log
// import "hardhat/console.sol";

contract Lock {
uint public unlockTime;
address payable public owner;

event Withdrawal(uint amount, uint when);

constructor(uint _unlockTime) payable {
require(
block.timestamp < _unlockTime,
"Unlock time should be in the future"
);

unlockTime = _unlockTime;
owner = payable(msg.sender);
}

function withdraw() public {
// Uncomment this line, and the import of "hardhat/console.sol", to print a log in your terminal
// console.log("Unlock time is %o and block timestamp is %o", unlockTime, block.timestamp);

require(block.timestamp >= unlockTime, "You can't withdraw yet");
require(msg.sender == owner, "You aren't the owner");

emit Withdrawal(address(this).balance, block.timestamp);

owner.transfer(address(this).balance);
}
}

To compile it, simply run:

npx hardhat compile

Testing Your Contracts

Your project comes with tests that use Mocha, Chai, Ethers.js and Hardhat Ignition.

If you take a look in the test/ folder, you'll see a test file.

You can run your tests with npx hardhat test.

Deploying Your Contracts

Next, to deploy the contract we will use a Hardhat Ignition module.

Before run the module, we have to update hardhat.config.js.

// hardhat.config.js
require("@nomicfoundation/hardhat-toolbox");
require("dotenv").config();

/** @type import('hardhat/config').HardhatUserConfig */
module.exports = {
solidity: "0.8.24",
networks: {
over: {
url: OVER_RPC_URL,
accounts: [process.env.PRIVATE_KEY],
},
},
};

And run the following command to deploy your contract:

$ npx hardhat ignition deploy ignition/modules/Lock.js --network over
Deploying [ LockModule ]

Batch #1
Executing LockModule#Lock...
Batch #1
Executed LockModule#Lock

[ LockModule ] successfully deployed 🚀

Deployed Addresses

LockModule#Lock - 0x194B734f7f...

Build With Remix

Remix IDE is an open-source web and desktop application for creating and deploying Smart Contracts. For comprehensive guidance and advanced features of Remix, please refer to the official documentation.

Using Remix with OverProtocol

Access

Open Remix IDE in your web browser to begin. You can access it at https://remix.ethereum.org.

Connect

  • Configure MetaMask (or its alternatives): Ensure MetaMask or a similar compatible browser extension is installed in your browser and configured for the OverProtocol network.
  • Connect to OverProtocol: In the "Deploy & Run Transactions" plugin within Remix, select "Injected Web3" to connect Remix with the OverProtocol node through MetaMask.

Load Contracts

  • Write or Import Contracts: You can either write new smart contracts directly in the Remix editor or import existing files into the Remix environment.

Compile

  • Compile Contracts: Use Remix's Solidity compiler to compile your contracts. Make sure to select the appropriate compiler version that matches your contract's pragma statement.

Deploy

  • Deploy Contracts: Once compiled, deploy your contracts to OverProtocol by clicking on the "Deploy" button. Ensure that the correct environment (OverProtocol) and account are selected.

By following these steps, you can efficiently develop, test, and deploy smart contracts on OverProtocol, leveraging the powerful features of Remix IDE to enhance your development workflow.

- + \ No newline at end of file diff --git a/developers/build-your-contract/developer-tools.html b/developers/build-your-contract/developer-tools.html index b9d7ea4..174f5f7 100644 --- a/developers/build-your-contract/developer-tools.html +++ b/developers/build-your-contract/developer-tools.html @@ -4,13 +4,13 @@ Developer Tools | OverProtocol Docs - +

Developer Tools

This section offers an overview of the developer tools available for OverProtocol. Since OverProtocol is EVM-compatible, developers familiar with creating DApps on other EVM chains will find a seamless transition to building on OverProtocol.

Additionally, we are in the process of developing OverProtocol-specific, developer-friendly tools aimed at further lowering the entry barrier for application builders. Stay tuned for updates!

Smart Contract Programming Languages

Development Environments

Frontend Libraries

Wallets

- + \ No newline at end of file diff --git a/developers/client-apis.html b/developers/client-apis.html index c059a1e..4d98091 100644 --- a/developers/client-apis.html +++ b/developers/client-apis.html @@ -4,13 +4,13 @@ Client APIs | OverProtocol Docs - + - + \ No newline at end of file diff --git a/developers/deployed-contracts.html b/developers/deployed-contracts.html index f96fb69..9fa806d 100644 --- a/developers/deployed-contracts.html +++ b/developers/deployed-contracts.html @@ -4,13 +4,13 @@ Deployed Contracts | OverProtocol Docs - +

Deployed Contracts

To avoid unnecessary redeployment and to streamline your development process, we highly recommend utilizing our already deployed and verified contracts. This approach not only saves time and resources but also ensures that you are integrating with trusted and stable contract implementations.

Here, you can access comprehensive information for each contract, including source code links and ABI (Application Binary Interface) details. Using these verified contracts allows you to quickly integrate and interact with established functionalities on the network.

Over Creeper Testnet

nameaddress
Home staking0x000000000000000000000000000000000000beef
Palm staking0xe695a6b20c3dd09add46e0c1605650a1cf9a97a3
- + \ No newline at end of file diff --git a/developers/differences-from-ethereum.html b/developers/differences-from-ethereum.html index 1c5abd2..3171f16 100644 --- a/developers/differences-from-ethereum.html +++ b/developers/differences-from-ethereum.html @@ -4,13 +4,13 @@ Differences from Ethereum | OverProtocol Docs - +
-

Differences from Ethereum

While OverProtocol is an independent Layer 1 protocol, it inherits the Ethereum Virtual Machine (EVM), making it compatible with Ethereum's established ecosystem. This compatibility allows developers familiar with Ethereum's development environment to transition smoothly and leverage their existing skills. Below, we outline the key aspects of OverProtocol that differentiate it from Ethereum, highlighting why understanding these distinctions is crucial for developers, as these differences can significantly impact how applications are built and function on this platform.

Account Expiration

In OverProtocol, accounts that remain inactive for an extended period are subject to expiration. This mechanism is designed to optimize the network's efficiency and scalability by reducing the overhead of maintaining dormant accounts.

Account restoration in OverProtocol is not implemented at the opcode level but rather as a combination of a new transaction type and additional EVM functionalities.

danger

Currently, contract accounts have restoration disabled to prevent their expiration. To keep a contract active and prevent it from expiring, it must be periodically used.

Usage is defined as any transaction querying the contract account's state or calling its functions, including view functions. This ensures that contracts remain active and functional within the network ecosystem, adhering to the protocol's operational requirements.

Differences in Contract Address Derivation

caution

While the same Externally Owned Account (EOA) address can be used across various EVM-compatible chains with the same private key, this does not apply to contract addresses.

Address Derivation

Due to the state expiry feature in OverProtocol, all accounts, including contract accounts, could eventually expire. To mitigate the risk of an expired contract address being reused by a newly created contract, the contract creation operation always incorporates the caller account's restoredEpoch value. This inclusion alters the outcome of the CREATE operation, making the resulting addresses differ from those on other EVM chains.

As a result, even though the CREATE2 operation allows for deterministic address prediction and usage, it is not possible to reuse the same address across different chains as you would with EOA addresses.

caution

To use CREATE2 for contract deployment, the address must be restored back to Epoch 0.

// Create creates a new contract using code as deployment code.
func (evm *EVM) Create(caller ContractRef, code []byte, gas uint64, value *big.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {
contractAddr = crypto.CreateAddress(caller.Address(), evm.StateDB.GetRestoredEpoch(caller.Address()), evm.StateDB.GetNonce(caller.Address()))
return evm.create(caller, &codeAndHash{code: code}, gas, value, contractAddr, CREATE)
}

// Create2 creates a new contract using code as deployment code.
//
// The different between Create2 with Create is Create2 uses keccak256(0xff ++ msg.sender ++ salt ++ keccak256(init_code))[12:]
// instead of the usual sender-and-nonce-hash as the address where the contract is initialized at.
func (evm *EVM) Create2(caller ContractRef, code []byte, gas uint64, endowment *big.Int, salt *uint256.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {
codeAndHash := &codeAndHash{code: code}
contractAddr = crypto.CreateAddress2(caller.Address(), salt.Bytes32(), codeAndHash.Hash().Bytes())
return evm.create(caller, codeAndHash, gas, endowment, contractAddr, CREATE2)
}

Differences in Account Structure

Account Nonce

In traditional blockchain architectures, the nonce primarily tracks the number of transactions sent from a given account, ensuring transaction order and preventing double-spending. However, due to the expiration feature in OverProtocol, distinguishing explicitly between expired accounts and newly created accounts becomes challenging, raising the possibility of nonce overlap. To address this issue, OverProtocol introduces the restoredEpoch as a crucial component.

RestoredEpoch

The combination of the nonce and the restoredEpoch value ensures uniqueness for each account. This system allows OverProtocol to maintain the integrity and distinction of account states over time, even through periods of account inactivity and expiration.

For a more detailed explanation, please refer to the documentation.

nonce Field in Transaction

In RPC requests, such as eth_getTransactionCount, the response reflects this unique combination. The nonce is split into a 64-bit field, with the first 32 bits representing the restoredEpoch and the remaining 32 bits functioning as the traditional nonce. This adaptation allows developers to leverage existing Ethereum development environments while accommodating the unique features of OverProtocol.

Storage Count

This feature prepares for future functionalities where the cost associated with an account's storage usage might be billed. Each new storage slot created by an SSTORE operation increases the count, while emptying a slot decreases it.

UI Hash

Reserved space for future proof related to an account's interaction with external layers. Currently, this feature is not utilized but is planned for future enhancements to enhance cross-layer interactions and verifications.

Misc

SELFDESTRUCT Operation

The SELFDESTRUCT opcode, updated in accordance with EIP-6780, is implemented in such a way that while it does not actually destroy the contract account, it does process refunds. Contracts that are not used will naturally expire over time as the Ethanos epoch progresses.

The rationale behind incorporating EIP-6780 into OverProtocol differs significantly from its application in Ethereum. OverProtocol's implementation is specifically designed to avoid scenarios where a self-destructed contract account becomes indistinguishable from an Externally Owned Account (EOA). This distinction is crucial for maintaining clarity and integrity in the network's account management, ensuring that the lifecycle of contract accounts is handled in a better way.

Future Changes

As OverProtocol progresses towards the Ethanos endgame, significant changes are planned, particularly regarding how storage is managed within accounts. These adjustments will be designed to ensure that backward compatibility is maximally preserved and that a seamless migration can occur. This means that current dApp developers should not be overly concerned about the impending changes.

Storage Layout Change

Upcoming updates to OverProtocol will include a comprehensive overhaul of the storage layout within accounts. This change aims to enhance the efficiency and scalability of data management on the blockchain. Details on the new storage system will be provided as development progresses, ensuring developers have ample time to adapt their applications. This transition is intended to be smooth, with support structures in place to assist developers in migrating existing applications without disruption.

- +

Differences from Ethereum

OverProtocol is an independent Layer 1 protocol that inherits the Ethereum Virtual Machine (EVM), ensuring compatibility with Ethereum's established ecosystem. This compatibility enables developers familiar with Ethereum to transition smoothly and leverage their existing skills. However, there are key distinctions between OverProtocol and Ethereum that developers must understand, as these differences can significantly impact how applications are built and function on this platform. Here are the crucial aspects to consider and the actions to take:

Your Accounts Can Be Expired

In OverProtocol, inactive accounts are subject to expiration. This mechanism optimizes network efficiency and scalability by reducing the overhead of maintaining dormant accounts. Account restoration involves a new transaction type and additional EVM functionalities rather than opcode-level implementation.

On the mainnet, the Ethanos cycle lasts approximately 3 months, meaning that it takes 3 to 6 months for an inactive account to expire. The assessment of activity is based on the Ethanos cycle, so if you were active near the end of a cycle, your account could remain active for one more cycle. Conversely, if you were active at the beginning, your account could last for two cycles.

Actions to Take

If Your Account is Expired:

  • Do not worry; it can be restored without any penalties.
  • To restore your accounts, you can request to restoration client for the restoration.
  • Currently, you need to operate your own restoration client, but future services will provide more convenient restoration options.

If Your Account is Not Expired:

  • Ensure that accounts, especially contract accounts, are periodically used to prevent expiration. Usage is defined as any transaction that queries the contract account's state or calls its functions, including view functions.
  • Regularly monitor account activity to avoid unintentional expiration and ensure continuity of service. A monitoring tool will be available soon.
  • Especially for contract accounts with significant storage, prevent expiration as restoring storage can be costly. Future advancements will improve storage management efficiency, but for now, some monitoring and inconvenience are necessary.
info

For contract accounts, especially those with extensive storage, expiration can be costly to restore. While we are developing more efficient storage management techniques, please bear with the current monitoring requirements to prevent expiration.

You Can't Use the Same Contract Address in Ethereum

tip

While the same Externally Owned Account (EOA) address can be used across various EVM-compatible chains with the same private key, this does not apply to contract addresses.

Due to the state expiry feature in OverProtocol, all accounts, including contract accounts, could eventually expire. To mitigate the risk of an expired contract address being reused by a newly created contract, the contract creation operation always incorporates the caller account's restoredEpoch value. This inclusion alters the outcome of the CREATE operation, making the resulting addresses differ from those on other EVM chains.

As a result, even though the CREATE2 operation allows for deterministic address prediction and usage, it is not possible to reuse the same address across different chains as you would with EOA addresses.

Actions to Take

  • Be aware that contract addresses on OverProtocol will differ from those on Ethereum and other EVM-compatible chains due to the inclusion of the restoredEpoch value.
  • When deploying contracts, account for the different address derivation method and plan your deployment strategy accordingly.
// Create creates a new contract using code as deployment code.
func (evm *EVM) Create(caller ContractRef, code []byte, gas uint64, value *big.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {
contractAddr = crypto.CreateAddress(caller.Address(), evm.StateDB.GetRestoredEpoch(caller.Address()), evm.StateDB.GetNonce(caller.Address()))
return evm.create(caller, &codeAndHash{code: code}, gas, value, contractAddr, CREATE)
}

// Create2 creates a new contract using code as deployment code.
//
// The different between Create2 with Create is Create2 uses keccak256(0xff ++ msg.sender ++ salt ++ keccak256(init_code))[12:]
// instead of the usual sender-and-nonce-hash as the address where the contract is initialized at.
func (evm *EVM) Create2(caller ContractRef, code []byte, gas uint64, endowment *big.Int, salt *uint256.Int) (ret []byte, contractAddr common.Address, leftOverGas uint64, err error) {
codeAndHash := &codeAndHash{code: code}
contractAddr = crypto.CreateAddress2(caller.Address(), salt.Bytes32(), codeAndHash.Hash().Bytes())
return evm.create(caller, codeAndHash, gas, endowment, contractAddr, CREATE2)
}

Transaction has a restoredEpoch Field

In traditional blockchain architectures, the nonce primarily tracks the number of transactions sent from a given account, ensuring transaction order and preventing double-spending. However, due to the expiration feature in OverProtocol, distinguishing explicitly between expired accounts and newly created accounts becomes challenging, raising the possibility of nonce overlap. To address this issue, OverProtocol introduces the restoredEpoch as a crucial component.

RestoredEpoch

The combination of the nonce and the restoredEpoch value ensures uniqueness for each account. This system allows OverProtocol to maintain the integrity and distinction of account states over time, even through periods of account inactivity and expiration.

For a more detailed explanation, please refer to the documentation.

nonce Field in Transaction

The existing nonce field is split into a 64-bit field, with the first 32 bits representing the restoredEpoch and the remaining 32 bits functioning as the traditional nonce. This adaptation allows developers to leverage existing Ethereum development environments while accommodating the unique features of OverProtocol.

Actions to Take

  • Learn how restoredEpoch functions and its interaction with the nonce to ensure each account's uniqueness.
  • Use RPC requests like eth_getTransactionCount when making transactions. The response will include the correct nonce value, considering both nonce and restoredEpoch.

Misc

SELFDESTRUCT Operation

The SELFDESTRUCT opcode, updated in accordance with EIP-6780, is implemented in such a way that while it does not actually destroy the contract account, it does process refunds. Contracts that are not used will naturally expire over time as the Ethanos epoch progresses.

The rationale behind incorporating EIP-6780 into OverProtocol differs significantly from its application in Ethereum. OverProtocol's implementation is specifically designed to avoid scenarios where a self-destructed contract account becomes indistinguishable from an Externally Owned Account (EOA). This distinction is crucial for maintaining clarity and integrity in the network's account management, ensuring that the lifecycle of contract accounts is handled in a better way.

Future Changes

As OverProtocol progresses towards the Ethanos endgame, significant changes are planned, particularly regarding how storage is managed within accounts. These adjustments will be designed to ensure that backward compatibility is maximally preserved and that a seamless migration can occur. This means that current dApp developers should not be overly concerned about the impending changes.

Storage Layout Change

Upcoming updates to OverProtocol will include a comprehensive overhaul of the storage layout within accounts. This change aims to enhance the efficiency and scalability of data management on the blockchain. Details on the new storage system will be provided as development progresses, ensuring developers have ample time to adapt their applications. This transition is intended to be smooth, with support structures in place to assist developers in migrating existing applications without disruption.

+ \ No newline at end of file diff --git a/index.html b/index.html index 57ea200..faf0e3e 100644 --- a/index.html +++ b/index.html @@ -4,13 +4,13 @@ OverProtocol | OverProtocol Docs - + - + \ No newline at end of file diff --git a/learn.html b/learn.html index b1c956e..c55dc69 100644 --- a/learn.html +++ b/learn.html @@ -4,13 +4,13 @@ What is OverProtocol | OverProtocol Docs - +

What is OverProtocol

OverProtocol is a brand new layer 1 with lightweight nodes empowering personal computers, enabling anyone to run a node on their PCs and become a validator. This is made possible by OverProtocol's layered architecture through Ethanos, which significantly decrease the resources required for block validation.

The vision of OverProtocol is to create a blockchain-based system with high inclusivity, allowing more participants to own and utilize value within the system.

Blockchain is a system based on a cooperation mechanism that trusts the system’s operation rather than any specific entity. It becomes safer and garners more trust from participants when a variety of stakeholders, unlikely to collude, come together. This is the fundamental reason why participation in blockchain systems needs to be open and the barriers to entry low.

The trust established in this way plays a role in safeguarding "records." The blockchain system continuously records changing states, with its most critical and simplest use case being the ledger for transaction records. By protecting these transaction records, the system can contain and utilize various forms of value.

By creating a system that anyone can participate in and use, OverProtocol will spread the experience of owning and utilizing various forms of value to more people. Ultimately, OverProtocol seeks to transform traditional methods of owning and using value, ensuring that technology serves as a bridge rather than a barrier, thus enhancing the economic empowerment of all participants.

- + \ No newline at end of file diff --git a/learn/key-features/layered-architecture/ethanos.html b/learn/key-features/layered-architecture/ethanos.html index 8d7e7ca..c211fee 100644 --- a/learn/key-features/layered-architecture/ethanos.html +++ b/learn/key-features/layered-architecture/ethanos.html @@ -4,13 +4,13 @@ Ethanos | OverProtocol Docs - +

Ethanos

Ethanos is an effective mechanism for managing blockchain's state and history. It periodically resets the state, expiring old data and referencing previous cycles to manage a bounded state size. This approach lowers entry barriers, promotes decentralization, and fosters an inclusive blockchain system.

What is the Problem?

It is essential to address the ever-increasing data size issue in blockchain systems. The account-based blockchain system, which records the global state of accounts and balances separately from transactions, offers a simpler and more intuitive framework for developing smart contracts. These tiny Turing-complete programs execute specific tasks using account states when triggered by transactions, and their integrity is verified by every node in the blockchain.

Typically, as time progresses, the number of accounts and transactions in any blockchain grows, leading to an infinite increase in state and history data. This growth in data size results in higher memory usage, more disk operations, and significant performance burdens. Consequently, this also creates substantial barriers for new participants attempting to synchronize and engage with the blockchain system.

How Ethanos Works

Differentiating States

Ethanos segments the state into three tiers: active, staged, and inactive. Both active and staged states are maintained within the Over Layer, while inactive states are transferred to the Nether Layer.

Ethanos manages its operations through what are called sweep epochs, which are defined time cycles in the system, each composed of several blocks. At the start of each sweep epoch, Ethanos constructs a new empty state trie for the active states. It also references the entire set of the states from the previous epoch's last block, known as the "superblock", now designated as staged states for the current epoch. Both of these states are housed in the Over Layer.

During each transaction within an epoch, the current state trie is updated as follows: If a transaction involves a specific account, the system first checks the current epoch’s state trie. If the account is not found there, it then searches the previous epoch’s state trie. If located, the account details are seamlessly transferred to the current state trie. If the account is absent from both state tries, it indicates that the account has either been inactive in past epochs or is a completely new account. In both scenarios, Ethanos treats these as new accounts.

If an account from the last epoch’s trie is not involved in any transaction during the current epoch, it is then classified as inactive in the subsequent epoch and considered expired. These accounts enter a dormant status and are categorized as dormant accounts within the Nether Layer. However, being expired does not mean the account is permanently lost; a dormant account can be reactivated through restoration from the Nether Layer.

From the account's perspective, each interaction or read operation restores two life points. As each sweep epoch passes, all accounts lose one life point. If an account goes through two consecutive sweep epochs without any life point recovery, it can no longer reside in the Over Layer.

Distinguishing History

Ethanos employs the weak subjectivity point to purge data corresponding to the block body. This approach is straightforward but requires a mechanism to ensure the availability of the purged history. This aspect is still under research and development, with plans to leverage a light layer to facilitate this process.

Restoration Process

To restore a dormant account, proof is required of the last epoch in which the account was active. This is crucial to prevent attempts to recover an account to a state before assets were transferred out in subsequent epochs. The trie structure in which the state is stored can efficiently prove whether a specific account was present within a state, as long as there is a valid root value, using a Merkle proof.

Restoration involves providing both an existence proof for the state of the last active epoch's superblock and non-existence proofs for the epochs during which the account was inactive. Combining these proofs allows for the restoration of the account's state to its condition in the current epoch. This process ensures that restoration is both secure and accurate, preventing unauthorized manipulations of account histories.

Dealing with Crumb Accounts; Restored Epoch

As mentioned, Ethanos does not differentiate between expired accounts and accounts that never existed. In the current epoch, if an empty account receives funds and its value is initialized, the holder of the account's private key can begin to send transactions and engage in activities using this account. An account that was previously expired but has been reinitialized and put back into use is referred to as a "crumb account." The existence of crumb accounts adds complexity to the restoration process.

While we could have eliminated crumb accounts by requiring restoration to go back to the genesis epoch before activating any account, we chose not to adopt this approach for UX reasons. One significant issue with crumb accounts is that they undermine the purpose of the nonce, which exists to record the number of transactions an account has made, thereby preventing any transaction from being executed multiple times.

If nonces are reset to zero every time an account is initialized in each epoch, it could allow for the reuse of previously utilized nonces in transactions involving crumb accounts. This situation would make the network vulnerable to specific types of replay attacks. To mitigate such risks while maintaining the efficiency of the restoration process and the simplicity of nonce values, we decided to add a field called "restored epoch" to each account.

The "restored epoch" value for an account created in a specific epoch is set to max(0, current epoch number - 1). This signifies that the account did not exist in the state of one epoch prior, relative to the current epoch. The "restored epoch" value remains constant as long as the account remains active. For example, if an account is initialized with a "restored epoch" value of 2 in Epoch 3 and continues to be active until Epoch 9, the "restored epoch" value would still be 2. This constant value helps in tracking the initial restoration point of an account throughout its active period, providing a clear reference for any processes or checks that rely on the historical status of the account.

Restoration Process with Restored Epoch

The restoration process unfolds as follows: For the account to be restored, verification starts with a non-existence proof for the state of two epochs prior to the current one and proceeds in sequence until the last active state where an existence proof is available. A key consideration here is that the account being activated could be a crumb account. For such crumb accounts, there is no need to verify beyond the restored epoch value. Instead, proofs should be sequentially submitted up to the restored epoch minus one.

The restoration completes with the merging of the results after proofs are verified. For balances, this involves performing a sum operation, and similarly for nonces. The Restored Epoch value is determined by taking the minimum value, which indicates that the account's balance and nonce have been verified up to that particular epoch. For instance, accounts with a restored epoch value of 0 at any point signify that their balance and nonce have been consistently preserved from the genesis to the present.

Restoration can occur in parts. For example, an account that became active in epoch 6 does not necessarily need to be restored back to epoch 0. It can continue to operate with a restored epoch value of 5, thereby simplifying the restoration process and reducing unnecessary computational effort.

Specification

Sweep

A configuration known as SWEEP_EPOCH has been introduced to determine the frequency at which inactive accounts are expired. SWEEP_EPOCH defines the interval for performing sweeps, with sweeps occurring every epoch as designated by this setting.

The state trie captures the activities of each account in every epoch. At each superblock, the final block of the epoch, the current state trie is frozen and a new empty state trie is created. This frozen trie is referred to as a checkpoint trie.

In the following epochs, whenever an account's state needs updating and the account is not found in the current trie, a process is initiated to retrieve the account information from the previous checkpoint trie and integrate it into the current trie. If the account is already present in the current trie, the update is performed immediately.

Restored Epoch

When an account expires, its state values are reset to empty.

A restored_epoch field is added to each account to record the epoch during which it was last restored. This field is crucial for determining if an account has undergone restoration previously. The initial value for restored_epoch is set to max(0, current epoch number - 1).

The restored_epoch serves a function similar to that of the nonce during the restoration process by making it possible to selectively determine the point of restoration. This significantly reduces the complexity of verification as it eliminates the need to validate the state starting from the genesis block.

Furthermore, restored_epoch plays a vital role in contract creation. It helps ensure the uniqueness of contract addresses by preventing the regeneration of an address that has been previously used. This feature maintains the integrity and uniqueness of contract deployments on the blockchain.

Restoration Data

The format for restoration data is crucial for facilitating the recovery of accounts. The required data fields for initiating a recovery transaction include:

[chain_id, expire_epoch, target, target_epoch, fee, fee_recipient, signature_y_parity, signature_r, signature_s]

  • chain_id: Identifies the specific blockchain network where the recovery transaction will occur.
  • expire_epoch: Specifies the epoch limit for which this recovery data is valid.
  • target: The account address to be recovered.
  • target_epoch: The earliest epoch from which the account's data needs to be restored.
  • fee: The fee to be paid for the recovery to fee_recipient.
  • fee_recipient: The address designated to receive the fee for facilitating the recovery.
  • signature_y_parity, signature_r, signature_s: Components of the signature that authenticate the recovery request. This signature must be generated by the account responsible for paying the fee.

This data structure incentivizes data providers to provide the necessary historical data for recovery while also allowing an alternative account to cover the recovery fee. This mechanism ensures that recovery transactions are both secure and financially supported.

Restoration Transaction

For efficient recovery mechanisms within blockchain systems, it is essential to integrate recovery data within transactional frameworks. To facilitate this, we propose a new transaction type under EIP-2718 specifically designed for account restoration.

This new type extends the existing structure of EIP-1559 transactions by adding a restore_data field. The complete field structure is as follows:

[chain_id, nonce, max_priority_fee_per_gas, max_fee_per_gas, gas_limit, destination, amount, data, access_list, restore_data, signature_y_parity, signature_r, signature_s]

Restoration Process(Pseudocode)

Restoration process is done by following steps:

  1. Collect the account's state proofs for each required epoch
  2. Construct and send a restoration transaction with the collected proofs
  3. Upon receiving the restoration transaction:
    • For each proofs of epoch:
      1. Verify the proof
      2. Get the state of the epoch.
      3. Apply the state
def restore_account(account, proofs):
restored_epoch = account.restored_epoch

for proof in proofs:
root_hash = get_last_checkpoint_block_by_epoch(restored_epoch).state_root

if is_accurate_merkle_proof(root_hash, account, proof): # Proof is non-void proof
restored_account = extract_account(merkle_proof)
account.restored_epoch = restored_account.restored_epoch
account.balance += restored_account.balance
account.nonce += restored_account.nonce
elif is_accurate_void_proof(root_hash, account, proof): # Proof is void proof
restored_epoch -= 1
else: # Proof is invalid
raise Exception("Inaccurate proof")

Restoration Cost Breakdown

The recovery process entails several operations such as reading or verifying data and performing decoding tasks. Each task contributes to the total cost, which is determined by the number of epochs involved in the recovery and the amount of data processed.

Here is a breakdown of the costs associated with different operations during the recovery process:

OperationGas
read restoredEpoch20
read nonce20
read balance20
Keccak256100
Ecrecover3000
CallValueTransfer9000
CallNewAccount25000
read header800 per epoch
RLP decoding1 per word
verifyProof100 per epoch, 2 per word

Cost Per Epoch

For each epoch involved in the recovery process, the incurred costs include a verifyProof operation and a read header operation, each contributing to an approximate total of 900 gas per epoch. If the proof is for the existence proof, an additional RLP decoding operation is also necessary.

Variable costs are determined by the length of the input data, involving one RLP decoding and one verifyProof operation, both of which scale with the size of the input. These contribute an additional cost of 3 gas per word.

The formula for calculating the total recovery cost is structured as follows:

Total Restoration Cost=37000+900×Epoch+3×words+Memory Cost\text{Total Restoration Cost} = 37000 + 900\times{Epoch} + 3\times{words} + \text{Memory Cost}

Here, 37000 gas covers the initial operations such as account creation and transaction verification, 900 gas for each epoch reflects the fixed costs per epoch, 3 gas per word accounts for variable decoding and proof verification costs, and additional memory costs.

The Endgame

Future Directions for Contract Restoration

In Ethanos, state expiration occurs on an account-by-account basis. However, dealing with contracts poses a challenge due to the storage managed under contract accounts.

In the EVM, the storage owned by contracts can grow indefinitely in size. Handling unlimited data sizes within transaction forms to restore contracts is not feasible; it would potentially flood and paralyze the peer-to-peer network. Therefore, currently, OverProtocol has disabled the restoration functionality for contracts. Contracts must be managed in a way that prevents them from expiring.

In the ultimate vision of Ethanos, overcoming these limitations requires moving away from the traditional storage layout of the EVM. It becomes necessary to bound the size of data that accounts can own, and allow for contract-managed storages to be partially expired and restored.

In due time, a process of state and storage migration for all contracts will be implemented. This migration will occur between sweep epochs, facilitating a transition that maintains system integrity while accommodating the expansive nature of contract storage.

- + \ No newline at end of file diff --git a/learn/key-features/layered-architecture/overview.html b/learn/key-features/layered-architecture/overview.html index dd1fd62..3362d22 100644 --- a/learn/key-features/layered-architecture/overview.html +++ b/learn/key-features/layered-architecture/overview.html @@ -4,13 +4,13 @@ Layered Architecture | OverProtocol Docs - +

Layered Architecture

OverProtocol implements a layered approach to managing blockchain data, segmenting it into more manageable and essential components. The system differentiates between active and inactive states. Active states consist of accounts that are either frequently accessed or have been accessed recently. In contrast, inactive states encompass accounts that are less frequently accessed or have not been recently used. History is similarly bifurcated into recent and older segments. Data from newer blocks are classified as recent history, whereas data from all preceding blocks falls into the category of older history.

The essential data that nodes require to process and follow blockchain records includes active states, recent history, and block header information. This subset of data is referred to as the Over Layer. Conversely, the inactive state and older history data are grouped into what is known as the Nether Layer.

The Ethanos algorithm within OverProtocol establishes the criteria for distinguishing between the Over Layer and the Nether Layer. It also provides a mechanism for restoring data from the Nether Layer back to the Over Layer. By utilizing Ethanos, OverProtocol enforces its layered architecture, limiting the size of the data in the Over Layer. This restriction ensures a bounded, manageable size for the blockchain system, enabling sustainable and scalable participation.

- + \ No newline at end of file diff --git a/learn/key-features/over-pos/overview.html b/learn/key-features/over-pos/overview.html index 3ebf7bc..7eaad02 100644 --- a/learn/key-features/over-pos/overview.html +++ b/learn/key-features/over-pos/overview.html @@ -4,13 +4,13 @@ Over PoS Overview | OverProtocol Docs - +

Over PoS Overview

Consensus is important

In the world of blockchain, consensus algorithms are like the referees of a match, ensuring everyone's playing by the same rules. They keep every ledger in the network in sync, validating transactions, and maintaining a decentralized, tamper-proof system that instills trust among participants. There are various kinds of these algorithms, such as Proof-of-Work (PoW) which tasks miners with solving complicated math puzzles, and Proof-of-Stake (PoS) which selects validators based on their token holdings.

For OverProtocol, PoS sits at the heart of our operations. Participants prepare a substantial amount of OVER tokens from the market and put them up as collateral to create and validate blocks. If they perform their role successfully, they are rewarded with OVER. However, any malicious activity can lead to penalties - anything from suspension to a complete loss of staked OVER tokens. So, playing fair is not just encouraged, it's mandatory.

Why PoS

While there's a broad array of PoS algorithms available, we chose to align with Ethereum's Gasper for OverProtocol. Our mission is to build a blockchain that doesn't disproportionately favor a select few, and we wanted our choice of consensus algorithm to reflect that.

Many new blockchains are leaning towards a Delegated Proof of Stake (DPoS) format, where a small group of validators are seleceted (such as Cosmos BFT and Aptos etc). But this can cause performance issues if these validators don't meet high standards. They are expected to manage a robust node operation environment to ensure the speed and performance of the blockchain consensus, making it a tall order for the average person due to the need for advanced infrastructure and significant capital.

Contrastingly, Ethereum's Gasper allows for a larger pool of validators and is more accommodating to those with less sophisticated node operation environments. Aligned with Over's philosophy and vision for blockchain, we've adopted a slightly tweaked version of Gasper. This move ensures a more inclusive consensus process, making participation in the blockchain more accessible to everyone, regardless of their resources.

In reality, Ethereum's staking has shown a trend towards centralization, with close to 56\% of the staked amount held by the top four validators. This concentration goes against the core goal of decentralization, posing a significant roadblock. We believe the root cause lies in the high hardware requirements. Although the consensus protocol theoretically supports millions of validators, the practical requirements for running a node continue to be a formidable barrier.

OverProtocol aims to tackle this issue head-on by harnessing the power of lightweight client techniques. These techniques significantly trim down the resource requirements, making it possible for anyone with a basic PC to run a node and step into the role of a validator. By integrating these techniques with Gasper, Over brings the concept of home staking to life. Consequently, anyone can now contribute to the network's security and stability, regardless of their resources.

- + \ No newline at end of file diff --git a/learn/key-features/over-pos/requirements.html b/learn/key-features/over-pos/requirements.html index 6bfd1a8..7e052cd 100644 --- a/learn/key-features/over-pos/requirements.html +++ b/learn/key-features/over-pos/requirements.html @@ -4,14 +4,14 @@ Requirements | OverProtocol Docs - +

Requirements

The requirements for becoming and maintaining the status of a validator within the OverProtocol are set to balance the need for active participation and accessibility. These requirements ensure a stable and robust network while keeping participation as accessible as possible. By aligning the interests of validators with the network's stability and offering a carefully calibrated set of rules, OverProtocol aims to foster a thriving ecosystem where validators play an essential role. Below is an explanation of the primary requirements:

Stake Minimum Amount of OVER to be a validator

The minimum stake requirement of OVER ensures that validators have something significant at risk, motivating them to actively participate in the consensus. This helps stabilize the value of the coin and aids swift consensus. However, OverProtocol recognizes the need for accessibility and wants to avoid creating unnecessary barriers. For now, 256 OVER is selected as a staking requirement, considering the need to include as many participants as possible without compromising the system's integrity.

Maintain at Least 70% Uptime

Every validator must maintain an uptime of at least 70%. This criterion is crucial for the system's stability, as the consensus process depends on both the number of validators and each one's average uptime. Importantly, our mathematical modeling is conducted under the assumption that the system is operated solely by ordinary individuals, not a select few with specialized operational expertise (e.g., blockchain infrastructure providers). The calculations demonstrate that a 70% uptime from an ordinary validator guarantees system safety, assuming that more than 16,384 validators are involved (Ethereum's original design aimed to attract over 16,384 validators to ensure a smooth transition to the Proof-of-Stake (PoS) system).

In our system, we have instituted an evaluation scheme termed risk score to assess each validator's uptime. If a validator does not meet the uptime benchmark, its risk score escalates. Once the score exceeds a specific threshold, indicating a significant risk of that validator's participation in consensus, the validator is removed from the validation network. This strategy guarantees that validators remain dedicated to preserving their online presence, thereby positively influencing the network's reliability. For a comprehensive understanding, consult the Rewards and Penalties.

- + \ No newline at end of file diff --git a/learn/key-features/over-pos/rewards-and-penalties.html b/learn/key-features/over-pos/rewards-and-penalties.html index 7107381..d2e8714 100644 --- a/learn/key-features/over-pos/rewards-and-penalties.html +++ b/learn/key-features/over-pos/rewards-and-penalties.html @@ -4,13 +4,13 @@ Rewards and Penalties | OverProtocol Docs - +

Rewards and Penalties

The reward and penalty system serves as a mechanism to steer the blockchain network towards enhanced security. Rewards should be designed to encourage honest and diligent participants to continue contributing to the network. On the other hand, penalties should be crafted to deter or swiftly remove participants who might harm the network. However, care should be taken to ensure that excessively stringent penalties do not deter participation by creating psychological barriers.

Gasper's reward and penalty structure are delicately parameterized considering these factors. Validators, when given an opportunity to create a block, receive a relatively large reward. However, over extended periods of active validation, the rewards from participating in attestations in every epoch become more significant. In essence, the system rewards validators more as they remain diligently active. Conversely, penalties for not participating are balanced with potential rewards, ensuring that temporary downtimes, like short node outages, are not overly punitive.

However, direct threats to the consensus activate a stringent rule known as slashing, invoking strong penalties. Slashing comes into play in situations such as 1) when a proposer broadcasts conflicting blocks or 2) when an attester makes contradictory votes or engages in double-voting. Validators who witness these violations become whistleblowers, presenting evidence to the network. Violators face severe asset forfeiture and lose their validating rights.

Introducing Bailout - Rescuing Offline Validators

In OverProtocol, this foundational reward and penalty structure is augmented with an Bailout (rescuing offline validators) mechanism. The rescue mechanism swiftly removes validators not maintaining adequate uptime from the consensus. Validators are rescued out of the network if their risk score surpasses a set threshold, which increases during prolonged downtime and decreases upon uptime. The system thereby monitors and rescues those who consistently fail to maintain adequate uptime.

There are two primary reasons for implementing this risk score:

Reason 1. Safeguarding the Validator's Balance

In any consensus-driven blockchain system, validators pledge a certain amount of assets as collateral. This ensures their vested interest in the proper functioning and security of the network. When validators are inactive or misbehave, they are penalized, causing a deduction from this pledged balance. Over time, if a validator remains inactive, these penalties can accumulate, significantly eroding their collateral.

The rescue mechanism acts as a protective measure in such scenarios. By detecting and ejecting consistently inactive validators, the system prevents their balance from being drained excessively. It's analogous to a safety net, ensuring that validators do not incur irreversible financial damage due to prolonged inactivity, which might sometimes be beyond their control, such as technical glitches or unforeseen disruptions.

Moreover, this mechanism protects not just the individual validators but also the overall network's financial incentives. If validators see their peers losing vast amounts of collateral due to extended downtimes, it could deter potential validators from joining or continuing in the network, fearing substantial losses.

Reason 2. Ensuring System Security and Optimal Performance

A blockchain network thrives on the active participation of its validators. They are responsible for proposing, verifying, and finalizing transactions or blocks in the chain. Inactive validators can slow down this process. Moreover, a significant number of inactive validators can make the network more susceptible to attacks and reduce its overall security.

The rescue mechanism identifies and removes these inactive participants, ensuring that only active, reliable validators contribute to the consensus process. By doing so, it keeps the network's performance optimized and maintains its security standards.

How the Bailout Works

In essence, the rescue mechanism is both a protective and proactive feature, maintaining the financial health of validators and the operational integrity of the network. The risk score is designed to incentivize validators to maintain an uptime higher than 67%, assuming there are at least 16,384 validators in the network. At the network’s initial stage when there are fewer validators, the required uptime hurdle is set to 70%. As the number of validators increases, this hurdle gradually decreases to 67% uptime.

This design takes into account that a higher number of validators can inherently improve the system’s resilience from a statistical perspective, thereby allowing the validator uptime hurdle to be lowered. But, regardless of validator numbers in validator will face an increase in risk score during downtime and a decrease of the score during uptime.

About the Validator Risk Score

This part depicts the formula and illustration of the validator risk score. First, we define the following.

N:number of validatorsN: \text{number of validators}

P:validator uptime(0P1)P: \text{validator uptime} (0 \leq P\leq 1)

ΔSmax:maximum risk score increment at one epoch=1\Delta{S_{max}} : \text{maximum risk score increment at one epoch} = 1

Vmin:minimum number of validators required=16384V_{min}: \text{minimum number of validators required} = 16384.

Validator's risk score is added up by aa in downtime, and decreased by bb in uptime.

Then the expectation is risk score per epoch=a(1p)bp=(a+b)p+a\text{risk score per epoch} = a(1-p)-bp = -(a+b)p +a, and the x-intercept of this function would be aa+b\frac{a}{a+b}. We know that value aa is ΔSmax\Delta{S_{max}}, hence 1. So the x-intercept is 11+b\frac{1}{1+b}. We target the x-intercept to be the validator uptime threshold. That is, if we denote, ff: the step function which indicates the required uptime depending on each validator (Illustrated in the figure below), 11+b=f\frac{1}{1+b} = f

Required Validator Uptime

Then the relationship between the validator's uptime and risk score delta per epoch is shown in the following illustration and equation.

Delta Risk Score per epoch
ΔRisk Score per Epoch=ΔSmaxfP+ΔSmax\Delta\text{Risk Score per Epoch}= - \frac{\Delta S_{max}}{f}\cdot{P} + \Delta{S_{max}}

When there are a small number of validators participating in the system, you are required to maintain a relatively high uptime. That is, given N=VminN= V_{min}, risk score increases when P0.70P \leq 0.70. The figure's blue-colored line has an x-intercept at P=0.7P=0.7. As more validators participate in the system, the required uptime hurdle lowers. That is, when N=infN= inf, risk score increases when P23P \leq \frac{2}{3}. The figure's orange-colored line has an x-intercept near P=23P=\frac{2}{3}.

- + \ No newline at end of file diff --git a/learn/key-features/tokenomics/distribution.html b/learn/key-features/tokenomics/distribution.html index 62d0f4d..b8aa294 100644 --- a/learn/key-features/tokenomics/distribution.html +++ b/learn/key-features/tokenomics/distribution.html @@ -4,13 +4,13 @@ Token Distribution | OverProtocol Docs - +

Token Distribution

Over has a supply schedule that releases 1 billion OVER over 10 years. Upon entering the 11th year, no additional tokens will be issued.

Token Allocation

1. Staking Rewards

40% of the total tokens, equating to 400 million OVER, will be distributed over 10 years. The issuance plan allocates 200 million OVER as the minimum guaranteed reward, distributed in equal annual amounts to stakers. The remaining 200 million OVER will be used as an adjustable reward, modulated in real-time by the system without human intervention, based on the desired staking quantity. Further details are described below.

2. Over Community Access Program(OCAP)

Of the total supply, 15% is initially allocated to the OCAP. OCAP facilitates the distribution of OVER in various ways, such as airdrops for early community members and contributors, or through liquidity provision. The goal is to make participation in OverProtocol accessible to those who share our vision.

3. Others

The remaining 450 Million OVER is earmarked for distribution to 4 entities (Core Contributors, Investors, Over Technologies, and Over Foundation) over a 4-year schedule. Refer to Table \ref{table:0} for the yearly allocation amounts. Each percentage point indicates the proportion of allocation distribution relative to the total 1 billion OVER.

alloc_chart

Staking Rewards

Minimum Guaranteed Rewards

OverProtocol's token issuance plan allocates 200 million OVER as the minimum guaranteed reward, distributed in equal annual amounts to stakers. These rewards are proportionally distributed to validators based on their staking balance and required participation rate every epoch.

Adjustable Rewards

The actual release of staking rewards is adjusted by the protocol's predefined feedback mechanism. This mechanism acts as a reserve system to modulate the issuance levels: it reduces actual issuance when staking rewards are sufficient and increases issuance when additional rewards are needed. These adjustments are made based on the current staking rate, ranging between a minimum guaranteed reward of 20 million OVER per year to a maximum of 40 million OVER per year. Importantly, this reserve system is not managed by external entities but is governed by an internal feedback mechanism within the protocol. Refer to this page for a comprehensive overview of the feedback mechanism.

After the 10-year issuance period is over, any remaining reserve for the adjustable rewards will continue to be distributed to stakers.

YearMinimum IssuanceMaximum Issuance
Year 1 ~ 1020M OVER40M OVER
Year 11 ~0 OVER20M OVER
- + \ No newline at end of file diff --git a/learn/key-features/tokenomics/fee.html b/learn/key-features/tokenomics/fee.html index 9c7b7e0..32b08eb 100644 --- a/learn/key-features/tokenomics/fee.html +++ b/learn/key-features/tokenomics/fee.html @@ -4,13 +4,13 @@ Fees | OverProtocol Docs - +

Fees

Currently Effective

Transaction fee

The Transaction Fee is a charge applied to each transaction within the OverProtocol's on-chain activity. This fee serves to reduce the total circulating supply of OVER tokens.

There are two primary objectives that we aim to achieve through the transaction fee design. Firstly, we seek to align user gas usage with an appropriate gas target, ensuring efficient network operation. Secondly, we aim to induce deflationary pressure through the application of base fees, thereby promoting a balanced economic environment within the network. For this purpose, we use the commonly known EIP-1559, and adjust its design which we plan to achieve through several future updates.

In the protocol's initial stages, the base fee is collected and directed to the Over Treasury., supporting various ecosystem development initiatives. As the protocol matures, the collection strategy evolves: instead of accruing in the treasury, the base fee is directly burned from each transaction. This nuanced approach balances the initial growth needs with a longer-term strategy of reducing token supply, thereby sustaining the protocol’s economic health.

Over Treasury

The Over Treasury serves as a pivotal component in the sustainable growth and development of the OverProtocol ecosystem. In its initial years, the treasury, under the stewardship of the Over Foundation, will accumulate various fees generated by the blockchain's operations. This strategic collection of assets will be judiciously allocated to fuel a range of initiatives, notably including the funding of promising decentralized application (DApp) projects, and the cost of some restore transactions.

The primary objective of the treasury is to foster an environment of innovation and expansion within the OverProtocol community, ensuring a steady progression towards a robust, diverse, and thriving blockchain ecosystem. As the protocol matures, the governance of this treasury is planned to transition smoothly into a decentralized autonomous organization (DAO) model, reflecting the protocol's commitment to decentralization and community-driven development. This transition signifies a shift towards a more democratic and participatory framework, empowering the community to guide the strategic utilization of resources in alignment with the collective vision and long-term objectives of the OverProtocol.

Future Plans

Storage Rent Fee

The Storage rent fee is a charge on the contract accounts levied every certain period. It charges the use of storing data on the blockchain and reduces the total circulating supply of the OVER tokens.

Storage rent is a proposed economic mechanism designed to address the inefficiency of the 'pay once, use forever' model for state storage. In traditional blockchain models, once a user pays a fee to store data or execute a transaction, the associated data remains on the blockchain indefinitely, leading to an ever-growing state. This growth poses significant scalability and efficiency challenges.

With the storage rent fee, a blockchain storage user would consistenly pay the rent to compensate for the ongoing use of the storage space. This fee incentivizes users to only retain necessary and actively used data, thereby managing the size and efficiency of the blockchain's state. That is, we can expect users to be more judicious about the data they store on the blockchain and to potentially clean up or remove data that is no longer needed.

Such a fee is levied on every Ethanos epoch, and the amount depends on the quantity of data stored with the duration for which it was stored. The storage fee is collected and directed to the Over Treasury, supporting various ecosystem development initiatives.

Why it was hard to collect Storage Rent Fees

Implementing a storage rent fee design in conventional blockchain architectures is challenging due to the immense size of the state. For the protocol to levy storage rent, it must navigate through all state accounts to determine the appropriate charges and identify the account holders responsible for these fees. Additionally, the protocol needs to decide on the timing for such traversals. This process, under typical blockchain designs, presents significant complexities and operational inefficiencies, making the implementation of a storage rent fee system difficult. Consequently, in many cases, once a fee is paid for storing new values in the state, the space is occupied indefinitely, bypassing ongoing storage costs.

OverProtocol's Approach

Through its innovative Ethanos technique, the OverProtocol effectively manages state size and introduces periodic intervals, streamlining the process of imposing storage rent fees. This approach allows for a straightforward determination of when and which contract accounts should be charged. The whitepaper, OverProtocol: Towards True Decentralization, elaborates on Ethanos, but here we present its core principles.

OverProtocol distinguishes between active and inactive accounts by resetting states at regular intervals, leveraging the consistency of activity across these cycles. Active accounts, identified by their continuous operation through cycles, are seamlessly transferred from the finalized state of the previous cycle to the current cycle's state. This transfer occurs at the first transactional interaction in the new cycle.

At this juncture, storage rent is levied on contract accounts, employing the efficiency of the Ethanos technique without necessitating external state traversal. This efficiency is further enhanced by the protocol's managed state size. Additionally, accounts in OverProtocol are equipped with metadata that assesses their storage size, creating a system where larger storage spaces incur higher rent. This design facilitates a fair and usage-based charging model.

The storage rent design is still under development, with the goal of establishing a user-friendly framework that simultaneously fosters a robust storage economy.

- + \ No newline at end of file diff --git a/learn/key-features/tokenomics/feedback.html b/learn/key-features/tokenomics/feedback.html index e974a77..a7b0ef0 100644 --- a/learn/key-features/tokenomics/feedback.html +++ b/learn/key-features/tokenomics/feedback.html @@ -4,13 +4,13 @@ Deposit and Yield | OverProtocol Docs - +

Deposit and Yield

OverProtocol employs a proof-of-stake mechanism, requiring validators to deposit OVER tokens to participate in the network's block creation process. The yield is the key to attracting the deposit, and is the reward given to the validators. Let's delve into the role and significance of this deposit and yield in a PoS blockchain, focusing on OverProtocol's system design.

Deposit

The deposit in OverProtocol serves as an economic safeguard, deterring actions that could undermine the blockchain's integrity. To gain significant control over the chain, an attacker would need to acquire more than two-thirds of the total deposited tokens. Additionally, owning a third or more of these tokens could disrupt the consensus algorithm's finalization process. Therefore, the network's economic security is strengthened by increasing both the number of participants and the volume of deposited tokens.

While a higher token deposit undoubtedly enhances the chain's safety, the utility of OVER tokens goes beyond security. These tokens play a crucial role in the network, including paying network fees, acting as intermediaries in exchanges, and supporting liquidity in the OverProtocol's economic activities. Consequently, an excessively high deposit requirement could impede the ecosystem's growth and dynamism by limiting the availability of tokens for these essential functions.

Therefore, it is crucial to maintain an optimal deposit amount for the OverProtocol. This balance ensures that the deposit is not so low as to compromise the network's security, nor so high as to diminish the monetary value and utility of the OVER token. Striking this balance is key to preserving both the integrity of the blockchain and the dynamic functionality of the token within the ecosystem.

Target Deposit Ratio

The target deposit ratio is defined as the desired proportion of staked OVER tokens relative to the total circulating supply, as illustrated in the figure below:

Target Deposit Ratio

Initially, the OverProtocol sets a high target deposit ratio. This approach is adopted because, at the outset, the mainnet token often has a low market price, undermining its ability to secure the chain. A higher target deposit ratio compensates for this low value, ensuring adequate security.

However, reducing the deposit ratio can also be beneficial. The tokens not staked are crucial for on-chain activities, enhancing the monetary value of the OVER token. Therefore, once the deposit level is sufficient to assure security, it is advantageous to lower the target deposit ratio.

As the chain matures and expands its utility, gaining monetary value, a lower target deposit ratio becomes adequate for maintaining security. This gradual adjustment in the target deposit ratio is strategic, aiming to strike a harmonious balance between encouraging broad participation and efficiently managing the network's operational demands.

Target Deposit Amount

The target deposit amount represents the target aggregate quantity of OVER tokens staked within the system, as depicted in the picture below:

Target Deposit

This figure is crucial as it indicates the volume of tokens committed to securing the Proof of Stake (PoS) system. Therefore, setting an appropriate target deposit amount is a key strategic decision.

In the early stages, to align with the high target deposit ratio, it is essential to rapidly increase the total amount of tokens staked in the system. As the system evolves and stabilizes, the necessity to accumulate large new deposits diminishes. Eventually, a saturation point is reached where the accumulated deposits are sufficient to ensure system security. Following this, similar to the rationale behind reducing the target deposit ratio, the target deposit amount is capped. This cap, the max target deposit, is implemented to enhance the monetary utility of the non-staked OVER tokens, thereby supporting broader economic activities within the ecosystem.

Yield

Yield is the interest rate that measures the proportion of newly issued staking rewards given to the stakers in comparison to their original stake. Validators, responsible for executing assigned duties, earn these rewards. When the reward is minimal, approaching zero, it discourages contributions to the network, while a higher reward increases participation demand. This concept of yield plays a crucial role in maintaining a specific deposit ratio.

Base Yield

OverProtocol establishes a predetermined base yield as the foundational yield rate for staking. This base yield, applied to the maximum target deposit amount, determines the total allocation of OVER tokens as rewards for each epoch, thus forming the reward pool. In this system, the reward pool amount remains constant for each epoch, regardless of the time period. Consequently, the actual yield for each deposit is influenced by the total amount of stake deposits.

In the early stages, when a smaller amount of deposits shares the fixed reward pool, the reward distributed per token deposit is high, leading to a higher yield. However, as the total deposit volume increases, the yield per deposit decreases proportionately. Ultimately, when the deposit amount reaches the maximum target, the yield stabilizes, aligning with the predetermined base yield level.

The Feedback Mechanism

The base yield and the reward pool establish the foundational yield for validators at each specific moment within our protocol. However, the yield is dynamically adjusted from this baseline to assist the system in reaching the target deposit amount. If the actual deposit is below the target, the yield is increased; conversely, if it exceeds the target, the yield is decreased. This crucial adjustment process is known as the feedback mechanism.

The Need for Feedback Mechanism

The feedback mechanism is essential in managing fluctuations in yield demand, particularly when actual deposit deviates from our target deposit assumptions. For example, consider a scenario where the actual demand for yields is lower than expected, resulting in a deposit ratio below our projections, as depicted in the picture below. The converse situation is also plausible :

Discrepancy

Such discrepancies arise from changes in yield demand. A notable instance occurs when the US Federal Reserve raises interest rates, increasing the opportunity cost of staking in OverProtocol. Under these circumstances, the same capital might yield higher returns in alternative financial instruments. Therefore, even if OverProtocol maintains a consistent yield level, validators might prefer investing in other assets, leading to a decrease in deposits within OverProtocol. This situation illustrates how actual yield demand can diverge from our initial assumptions.

Irrespective of external factors, maintaining a specific deposit ratio is crucial for the security of OverProtocol. To ensure this, we have implemented a feedback mechanism that dynamically adjusts our yields. Modifying the yield either upwards or downwards serves as an incentive or disincentive for participation, thereby influencing deposit levels.

Feedback Mechanism

The feedback mechanism functions by assessing the discrepancy between the target and actual deposit ratios, subsequently fine-tuning the yields. The Validator Pending Queue\textit{Validator Pending Queue} comprises validators attempting to enter the system, while the Validator Exit Queue\textit{Validator Exit Queue} includes those trying to exit. The net demand difference, derived from the size disparity between these two queues, indicates the overall interest in becoming an OVER validator. By adding the original number of validators for the current epoch, we can calculate the number of validators for the next epoch as follows:

Validatornext=Validatorcurrent+Pending QueuesizeExit Queuesize\begin{align} \text{Validator}_{\text{next}} = \text{Validator}_{\text{current}} + \text{Pending Queue}_{\text{size}} - \text{Exit Queue}_{\text{size}} \end{align}

If the total deposit amount, inferred from Validatornext\text{Validator}_{\text{next}}, exceeds the target deposit amount for that timeframe, the yield decreases, and vice versa. To safeguard against attacks and prevent excessively high or low yield levels, we propose implementing upper and lower yield bounds. Additionally, the speed of feedback adjustment is a critical aspect. Denoting the feedback adjustment as f(t)f(t), its speed is defined as:

df(t)dt=kMaturity FactorScaling Factor\begin{align} \frac{df(t)}{dt} = k \cdot \text{Maturity Factor} \cdot \text{Scaling Factor} \end{align}

The Maturity Factor\textit{Maturity Factor} is introduced to steer the system towards a more stable and mature state. The system evaluates the current deposit level against the maximum target deposit amount, increasing the rate of feedback change proportionally to the discrepancy. In essence, the farther the system is from the maximum target, the faster the adjustments occur. The Scaling Factor\textit{Scaling Factor} enables the system to rapidly align with the target, where a larger discrepancy between the actual and target deposit amounts accelerates the feedback change rate.

To implement such a feedback mechanism, the system requires two key components: the Adaptive Validator Churn Limit\textit{Adaptive Validator Churn Limit} and The Issuance Reserve\textit{The Issuance Reserve}. The explanation follows.

Adaptive Validator Churn Limit

In a blockchain Proof of Stake (PoS) system, the 'churn limit' refers to the maximum number of validators permitted to enter or exit the network within a specific period. We observed that our feedback system fails to reach a stable status when the number of newly activated validators is equal to the number of exiting validators. To address this, we have implemented an Adaptive Validator Churn Limit\textit{Adaptive Validator Churn Limit} that adjusts based on current conditions. Specifically, if the number of active validators exceeds the target, the limit for exiting validators is set higher than that for incoming validators. Conversely, if the number of active validators falls below the target, the limit for incoming validators is increased beyond that for exiting ones. This approach effectively alters the number of active validators as needed and facilitates adjustments when the number of active validators is either above or below the target, thus promoting a more flexible and efficient system operation.

The Issuance Reserve

The primary function of the issuance reserve is to manage the allocation of additional rewards when needed. Specifically, the reserve is pre-allocated 200 million OVER and serves as a resource for the feedback system to augment rewards when necessary. If the system determines that more rewards should be distributed, the additional amount is provided from this reserve. However, no more than this pre-allocated amount will be issued. The management of the issuance reserve is handled at the protocol level, protecting it from risks such as account hacking and ensuring its use is strictly limited to the dynamic adjustment of yields.

- + \ No newline at end of file diff --git a/learn/key-features/tokenomics/overview.html b/learn/key-features/tokenomics/overview.html index 6af31aa..92331c6 100644 --- a/learn/key-features/tokenomics/overview.html +++ b/learn/key-features/tokenomics/overview.html @@ -4,13 +4,13 @@ Tokenomics Overview | OverProtocol Docs - +

Tokenomics Overview

Principles of Design

The OverProtocol is dedicated to crafting a robust tokenomics framework, guided by two fundamental principles throughout its design.

Firstly, the tokenomics should enhance the security of the blockchain. In Proof of Stake(PoS) systems, The higher the value of tokens protecting the network, the more resilient it becomes against potential attacks. Thus, the system must provide adequate incentives to attract a substantial number of validators who secure the network with their tokens.

Second, the tokenomics should emphasize stability, creating a dependable environment that fosters user engagement with the asset and its underlying network. Stability boosts user confidence and equips the system to handle challenges effectively. By being less vulnerable to rapid changes, the system gains the resilience to respond to external influences and facilitate recovery.

With these principles as our guide, we meticulously develop our tokenomics strategy, covering allocation, issuance, fees, yield, and other critical elements to ensure alignment with these core tenets. Let’s delve into each of these key components in detail.

OVER Token

The native token of OverProtocol is 'Over,' with the symbol 'OVER.' This is the primary currency required for participating in and utilizing the OverProtocol. While there are other tokens on OverProtocol, OVER is the most essential to the protocol’s operations. It facilitates transactions by covering gas fees and is crucial to network security. Users participate in the Proof of Stake (PoS) consensus by staking OVER, contributing to the network’s resilience and trustworthiness.

- + \ No newline at end of file diff --git a/operators.html b/operators.html index a2f8c56..1efbe92 100644 --- a/operators.html +++ b/operators.html @@ -4,13 +4,13 @@ Operator Guides | OverProtocol Docs - +

Operator Guides

Running your own node on the OverProtocol blockchain is not just about participating in the network; it’s about actively contributing to the stability and decentralization of the ecosystem. Nodes play a critical role in processing transactions and validating blocks, making the network more resilient and trustworthy. This guide provides a comprehensive overview of setting up your own node and becoming a validator in the OverProtocol ecosystem.

Benefits of Running Your Own Node

  • Increased Trust and Security: Operating your own node allows you to independently verify transactions without relying on third-party services.
  • Support for the Network: By running a node, you contribute to the network’s health and decentralization, reducing the risk of central points of failure.
  • Direct Participation in Consensus: As a validator, you play a part in the consensus process, influencing the network’s integrity and progression.
  • Potential Rewards: Validators who actively participate in consensus can earn rewards, incentivizing the maintenance and operation of the network. Also by running restoration node, you can help users restore expired accounts and receive additional rewards.

Step-by-Step Guide to Setting Up Your Node

  1. Check Hardware Requirements: Ensure you have the necessary hardware that meets the specifications required for running a node on OverProtocol.
  2. Software Installation: Download the latest version of OverNode, the OverProtocol node software. Then, follow the installation instructions specific to your operating system.
  3. Syncing the Blockchain: Before your node can start validating, it must sync with the existing blockchain data. This process can take several minutes to hours, depending on the network's size and your internet speed.
  4. Register as a Validator: Once your node is set up and fully synced, you need to register as a validator. This involves locking up a certain amount of the OVER tokens as a stake, signifying your commitment to the network’s integrity.
  5. Start Validating: With your node running and registered as a validator, you will begin to participate in the creation and validation of blocks. Monitor your node’s performance and participate in the OverProtocol blockchain consensus as required.

Maintaining Your Node

  • Regular Updates: Keep your node software updated to the latest version to ensure compatibility with network changes and enhancements.
  • Security Practices: Implement strong security practices to protect your node from unauthorized access and potential threats. This includes securing SSH access, and regularly updating your operating system and software.
  • Monitoring and Alerts: Set up monitoring tools to keep track of your node’s operation and health. Configure alerts for downtime or performance issues to quickly address potential problems.

Contributing to OverProtocol’s Ecosystem

Running your own node goes beyond technical setup and into active ecosystem participation. Engage with the community, provide feedback, and contribute to discussions about future upgrades and directions. By being an active participant, you help shape the evolution of OverProtocol.

- + \ No newline at end of file diff --git a/operators/faqs.html b/operators/faqs.html index e9efa0b..9bf57b2 100644 --- a/operators/faqs.html +++ b/operators/faqs.html @@ -4,13 +4,13 @@ FAQs | OverProtocol Docs - +

FAQs

1. What does a validator do?

OverProtocol utilizes Proof of Stake (PoS) to reach consensus on the blockchain. In this system, randomly selected validators propose, prove, and guarantee the validity of blocks.

Validators of OverProtocol contribute to the blockchain by participating in block validation, block creation, and synchronization proof, and receive rewards accordingly.

2. What is block attestation, block proposal, and sync-committee?

Block attestation, block proposal, and sync committee are roles that validators in OverProtocol must perform. All validators participate in block attestation, and a randomly selected group of validators participates in block proposal and sync-committee. Validators who participate in block proposal and sync-committee can get more rewards if they perform their roles well.

3. How can i run a validator?

If your are a OverNode user, you can start the validator application in the Validator menu. Follow the instructions on the screen to register as a validator. If you are choosing to run the client software yourself, refer to Operate Validators page.

You must stake 256 OVER(for testing) per validator, and you can apply for more validators depending on the OVER you have.

If you have completed the validator application through staking, it may take some time for the applied validator to be activated. The waiting time becomes longer as the number of validator applications from users increases.

Before validator activation, no separate rewards or penalties apply to validator operation. However, after the validator is activated, you must always keep the node running to receive rewards.

4. Validator activation takes a long time.

When staking for validator operation, a waiting time is required until the staking transaction is processed and validator registration is completed. Validator activation waiting time can be divided into two stages: primary and secondary.

  • Primary waiting: It is used to calculate the time it takes for the validator to be activated for about the first 2 hours. It is estimated to take about 2 hours, but the exact waiting time cannot be determined.

  • Secondary waiting: The exact waiting time until validator activation can be known and confirmed in the Validator menu. Once the validator is activated, you can participate in the network immediately.

In OBT #2, after successfully sending the staking transaction, depending on the network status and the number of validator operation applications, a waiting time of at least 2 hours to up to 3 days may occur.

If multiple users apply for validator operation, the secondary waiting time may increase significantly. Therefore, during this time, it is recommended to leave OverNode running in the background and keep the computer on.

If the node was turned off due to the waiting time, please make sure to turn on the node and complete synchronization to the completion state before the validator activation time. If the node is still off at the time of validator activation, you will immediately receive penalties.

5. I forgot the validator recovery phrase.

OverProtocol doesn't store any of user's passwords. If you forgot the validator Recovery phrase, you can't recover your access towards the active validator.

- + \ No newline at end of file diff --git a/operators/operate-restoration-client.html b/operators/operate-restoration-client.html index 16bbcf0..3318c5c 100644 --- a/operators/operate-restoration-client.html +++ b/operators/operate-restoration-client.html @@ -4,13 +4,13 @@ Operate Restoration Client | OverProtocol Docs - +

Operate Restoration Client

To restore an expired account, you need to retrieve the proof of historical state. This requires running an execution client that stores historical state data. By operating both the execution client and the restoration client, you can help users restore expired accounts and receive additional rewards.

How to run a restoration client

Restoration client is controlled using the command line. Here’s how to set it up:

restoration --help                                                                                                             
Usage of restoration:
-corsdomain string
Comma separated list of domains from which to accept cross origin requests (browser enforced) (default "*")
-ipc string
The ipc endpoint of a local geth node
-keystore string
Directory for the keystore (default = inside the datadir)
-minimum-reward string
Minimum reward for sending restoration transaction (default "1000000000000000000")
-passphrase string
Passphrase file for unlocking signer account
-port string
Server listening port (default ":32311")
-rpc string
The rpc endpoint of a local or remote geth node
-signer string
Signer address for signing restoration transaction and receiving reward
caution

The execution client must be synced with full sync mode and store an unlimited number of epochs.

$ geth --syncmode full --epochLimit 0
- + \ No newline at end of file diff --git a/operators/operate-validators.html b/operators/operate-validators.html index ef5705f..cd1c084 100644 --- a/operators/operate-validators.html +++ b/operators/operate-validators.html @@ -4,7 +4,7 @@ Operate Validators | OverProtocol Docs - + @@ -14,7 +14,7 @@ The execution layer's account needs 256 OVER per validator account it tries to enroll.

Then you should run the following-styled code in your machine to sender deposit transactions the with the validator keys generated in step 2. The deposit contract's address is set to 0x000000000000000000000000000000000000beef and the deposit contract ABI is set as the following link: [depositContractABI.json].

const Web3 = require('web3');
const fs = require('fs');
const path = require('path');
const web3 = new Web3('http://127.0.0.1:22000');

const depositContractAddress = '0x000000000000000000000000000000000000beef';
const depositContractABI = require('./depositContractABI.json').abi;
const args = process.argv.slice(2);

// Replace these with your own values
async function stake(privateKey) {
const account = web3.eth.accounts.privateKeyToAccount(privateKey);
let accountNonce = await web3.eth.getTransactionCount(account.address);
const stakingContract = new web3.eth.Contract(depositContractABI, depositContractAddress);
const amount = web3.utils.toWei('256', 'ether')

let depositDatas;
depositDatas = require('./deposit_data.json'); // The validator key you've generated from step 2.

for (let i = 0; i < depositDatas.length; i++) {
const encodedABI = stakingContract.methods.deposit(
'0x' + depositDatas[i].pubkey,
'0x' + depositDatas[i].withdrawal_credentials, // if it already contains the withdrawal_credentials
'0x' + depositDatas[i].signature,
'0x' + depositDatas[i].deposit_data_root
).encodeABI();
const tx = {
from: account.address,
to: depositContractAddress,
value: amount,
gas: 2000000,
data: encodedABI,
nonce: accountNonce + i
};

const signedTx = await web3.eth.accounts.signTransaction(tx, privateKey);
web3.eth.sendSignedTransaction(signedTx.rawTransaction);
}
}

If you've succeeded in registering your validator to the blockchain, you should now run your validator software. Follow steps 4 and 5.

4. Transfer Validator Keys

Go to the root folder of consensus client(chronos) and import the validator keys with the command similar to the following:

$ prysm.sh validator accounts import -keys-dir=<path/to/your/validator/keys>

5. Run your Validator

Run the following to run the validator on your node:

$ prysm.sh validator

More on Validator Activation

Activation Queue

Once your Execution Layer and Consensus Layer are synchronized and your deposit transaction successfully executed, your validator will enter the activation queue. This is a necessary step before becoming an active validator. Due to network protocols, the activation process can take 24 hours or more, depending on the queue. The system allows for only 900 new validators to join per day to maintain network stability and manage the rate of growth.

Activated

Upon activation, your validator will begin participating in the creation and validation of blocks. This active involvement in the network functions allows your validator to start earning staking rewards. These rewards are compensation for your contributions to network security and operability, incentivizing ongoing participation and support of the network's integrity.

Withdrawal Process (Quitting the validator status)

Initiating a Voluntary Exit

For users who decide to cease staking and wish to withdraw their entire balance, a "voluntary exit" process must be initiated. This involves signing and broadcasting a voluntary exit message using your validator keys. The process is facilitated by your validator client and must be submitted to your beacon node. Importantly, this action does not require any gas fees, as it is a part of the consensus layer's functionality. You will have to rely on the following-like command:

$ prysmctl validator exit --wallet-dir=<path/to/wallet> --beacon-rpc-provider=<127.0.0.1:4000>

Exiting Process

The time it takes for a validator to exit from staking can vary significantly depending on the number of other validators undergoing the same process simultaneously. After this period, your validator will no longer be eligible for validator duties, including block creation and voting.

Post-Exit Status

Once the exit process is complete, the validator's account status changes in several key ways:

  • No Longer Active: The account will no longer perform any network duties as a validator.
  • Ineligibility for Rewards: It ceases to earn staking rewards.
  • Removal of Stake: The staked OVER tokens are no longer considered "at stake."
- + \ No newline at end of file diff --git a/operators/run-a-node.html b/operators/run-a-node.html index 2409ea8..5c46a1b 100644 --- a/operators/run-a-node.html +++ b/operators/run-a-node.html @@ -4,7 +4,7 @@ Run a Node | OverProtocol Docs - + @@ -14,7 +14,7 @@ Access the official OverProtocol GitHub repository and clone it to your local machine.

OverProtocol Execution Client [Kairos]: The execution layer client handles the processing of transactions and the maintenance of the blockchain state. It must be fully synchronized with the OverProtocol network.

OverProtocol Consensus Client [Chronos]: This consensus client works in tandem with the execution layer to achieve network consensus on the current state of the blockchain. Synchronizing this client is crucial for participating in network validation.

  • Prerequisites: Make sure all required dependencies and development tools are installed on your machine. These are usually listed in the repository's README.

  • Compile the Source Code: Navigate to the cloned directory in your command line tool and run the build commands specified in the build documentation.

  • Configure Your Node: After building, configure your node’s settings, including network options and security measures. This may involve editing configuration files manually.

  • Run the Node: Execute the node software. You might need to use command line options to start it with specific parameters tailored to your needs.

  • Node Types

    OverProtocol supports several types of nodes, each serving distinct functions within the network:

    • Full Nodes: Primarily used for querying data and interacting with the blockchain, full nodes maintain only the Over Layer of the blockchain. Setting up a node with default configurations will typically result in a full node.
    • Archive Nodes: These nodes store the complete state of the blockchain from its genesis. Due to the extensive historical data they retain, archive nodes generally require significant disk space.
    • Validator Nodes: Essential for the security and integrity of the blockchain, validator nodes participate in proposing and voting on blocks. They play a critical role in maintaining the blockchain's consensus mechanism.

    Each node type is integral to the network’s functionality, offering different capabilities and requiring varying levels of resource commitment. Depending on your participation goals and available resources, you can choose the node type that best fits your needs in supporting and engaging with the OverProtocol ecosystem.

    Synchronization Modes

    Synchronization process is critical for ensuring that a node in the OverProtocol network is up-to-date with the latest blockchain state. This process involve downloading data from peers, verifying its integrity, and building a local blockchain database. Given the separation of data into the execution layer and the consensus layer in OverProtocol, each layer employs distinct synchronization strategies to manage data effectively.

    These synchronization modes provide different trade-offs between speed, disk usage, network bandwidth, and security. Choosing the right sync mode for a node depends on the node operator’s specific requirements, including their security preferences, hardware capabilities, and how quickly they need their node to be fully operational.

    Execution Layer Sync Modes

    In the execution layer, there are two primary synchronization modes to become a full node: Full Sync and Snap Sync. OverNode users can easily select the execution sync modes, upon blockchain data download.

    Full Sync:

    • This mode involves downloading all blocks, including headers, transactions, and receipts, from the genesis block onward.
    • It generates the state of the blockchain incrementally by executing every transactions.
    • This method minimizes trust as it verifies every transaction independently, providing the highest level of security.
    • Due to the comprehensive nature of the data processing involved, this sync can take days, depending on the number of transactions in the blockchain’s history.
    $ geth --syncmode full

    Snap Sync:

    • This mode starts from a more recent "trusted" checkpoint rather than the genesis block.
    • This mode leverages periodic snapshots of the blockchain state, allowing the node to regenerate necessary state data on demand rather than maintaining a complete historical state database.
    • It is the fastest synchronization strategy and is the default setting on networks.
    • This mode significantly reduces disk usage and network bandwidth requirements.
    $ geth --syncmode snap

    Becoming an Archive Node:

    There is an option to become an archive node. Currently, there is no option for OverNode users to become an archive node. Client software runners could become an archive node by running the execution client with the following tag:

    $ geth --gcmode archive

    If the combination is geth --syncmode full --gcmode archive then all blockchain data from the genesis block is written down in the database. If the combination is geth --syncmode snap --gcmode archive the blockchain data from the trusted checkpoint.

    Choose the Number of Epochs to Store:

    OverProtocol is lightweight because it only requires active and staged state data to progress blocks.

    You can use the geth --epochLimit 2 command (default) to minimize storage by retaining only active and staged data.

    You can use the geth --epochLimit 0 command (0 means unlimited) to store all inactive data in addition to active and staged data.

    Consensus Layer Sync Modes

    There are three ways to sync the consensus layer: initial sync, checkpoint sync. OverNodes users can only choose to sync consensus layer through checkpoint sync as it is set by default. The chronos client software runners can choose between the two sync modes.

    Initial sync:

    • This sync mode downloads the beacon chain data, if it has lower head information than its peers.
    • When bootstrapping a node, it has no beacon chain data, so it downloads all the beacon chain data starting from the genesis.

    Checkpoint sync (Initial sync from checkpoint):

    • This mode enhances the user experience by allowing consensus layer to sync from a recent weak subjectivity checkpoint instead of from the genesis block.
    • This approach drastically reduces the initial sync time.
    • The source of the checkpoint data is crucial and should be chosen with care, as the node will inherently trust the third party providing the data.
    • Append the following tags to enable the checkpoint sync
    $ chronos --checkpoint-sync-url value --genesis-beacon-api-url value

    What's Next

    Once your node is up, running and synced, the next step is to register and operate validators.This involves configuring your node to participate in the consensus process, enhancing the network's security and stability.

    For OverNode users this step is pretty much straight-forward. After the node is synced, jump in to the Staking tab to register as a validator.

    For advanced users running the client software from scratch follow register and operate validators section.

    - + \ No newline at end of file diff --git a/operators/system-requirements.html b/operators/system-requirements.html index d63dabb..c7e90e5 100644 --- a/operators/system-requirements.html +++ b/operators/system-requirements.html @@ -4,13 +4,13 @@ System Requirements | OverProtocol Docs - +

    System Requirements

    Environment

    When deciding how to deploy an OverProtocol node, you are presented with two primary options: running it on a local physical machine or using a cloud server. Each approach has distinct benefits and drawbacks, influenced by factors such as your technical expertise, budget, and priorities for privacy and control.

    OverProtocol recommends using a local machine to participate in the network. A censorship-resistant, decentralized network ideally should not depend on cloud providers. Operating your node on your own local hardware aligns with the decentralized ethos of blockchain technology.

    OverProtocol's node client can operate on various types of hardware, including personal computers, laptops, dedicated servers. While it's feasible to run the node client on your regular personal computer, using a dedicated machine specifically for your node can significantly boost its performance and enhance security.

    Requirements

    Although OverProtocol does not demand extensive computing power, maintaining a continuous connection to the blockchain network is essential. The system involves frequent data transfers and continuous reading and writing operations. Therefore, using higher-quality hardware and ensuring a stable internet connection can significantly enhance the performance of the client.

    Minimum Hardware Requirements

    To participate as a node in OverProtocol, the minimum hardware requirements are relatively modest. However participating in a blockchain system is input/output intensive. Therefore, securing a solid-state drive (SSD) is crucial for efficient data handling and quick access to blockchain records.

    • CPU: Dual-core or higher
    • Memory: 4GB RAM
    • Storage: SSD with at least 50GB available space
    • Network: 8MBit/sec download speed

    For an optimal experience and enhanced performance, particularly for validators who require more from their systems, the following specifications are recommended:

    • CPU: Fast CPU with 4 or more cores
    • Memory: 16GB RAM or more
    • Storage: SSD with at least 128GB available space
    • Network: 25+ MBit/s bandwidth

    By meeting or exceeding these recommended specifications, you can ensure that your node operates efficiently, contributes positively to the network, and minimizes the risk of downtime or performance issues.

    - + \ No newline at end of file