Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Balances clarification #23

Open
rogercoll opened this issue Feb 25, 2021 · 1 comment
Open

Balances clarification #23

rogercoll opened this issue Feb 25, 2021 · 1 comment

Comments

@rogercoll
Copy link

rogercoll commented Feb 25, 2021

Hi,

I was checking your code regarding the smart contracts part and I would like to clarify an important aspect to fully understand it.

In the optimistic-roll-in implementation smart contract (opritmistic-roll-in.sol) there are different maps in order to maintain the state and balances the participants, indeed the following two:

  mapping(address => bytes32) public account_states;
  mapping(address => uint256) public balances;

Could you provide more information on what is stored in each of them? The balances one seems to handle the amount of ethers of each key (address) but I am not able to see where the balance amount is updated.

In addition, does the actual merkle tree root state saved in the smart contract?

Finally, when calling the initialize() function that calls the initialize_state() function of the some-logic-contract.sol the deposited ethers are not saved in the account_states, neither the balances map. What happens with this deposit?

Best regards,

@deluca-mike
Copy link
Contributor

deluca-mike commented Apr 12, 2021

@rogercoll So sorry I didn't see this earlier. My bad.

Could you provide more information on what is stored in each of them?

balances holds the bonded and accrued ETH of each participant, which can be slashed if they are proven fraudulent, and accumulates when they prove someone else fraudulent.
account_states is the state hash for each account, which includes the calldata merkle root, current state, and last time.

does the actual merkle tree root state saved in the smart contract?

First, see https://github.com/circle-free/bouncy for a better example of usage (however, slightly outdated).
As for the question, as per above, the merkle root is hashed with the current state and last time and stored as the value in the account_states, keyed to that account.
There is no need for the underlying logic contract to store user state, as it is stored here and always passed in as an argument to the logic contract's functions.

As for the sent ETH when calling initialize, the contact applies the minimum necessary as a bond, which does get saved as part of the user's balance, and forwards the remainder, if any, to the logic contract. This allow the logic contract to make decisions based on how much it is receiving after the bond amount is taken into account.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants