Skip to content
AdamScislowicz edited this page Jun 28, 2016 · 13 revisions

Ethereum Governance Phase 1

Target Proof-of-Concept Date: 2016/07/02
Target Deployment Date: 2016/07/09

Summary: Phase 1 Will enable the submission of propositions which can then be efficiently explored and signalled upon. Signals can be negative or positive. Ethereum account holders will be able to create signalling accounts which can then hold positions against propositions creating a signal level proportional to the account balance. Anyone can then browse the current state of propositions and their respective signal levels over time. Ethereum users who have associated an account with the Signal contract will be able to see a short-list of just the propositions they are tracking and/or holding an active position in or browse the entire active list sorted by date or magnitude of signal (positive signal + |negative signal|).

Contracts

Contract: Proposition

Data Model

  • Propositions
    • string title : short summary of the proposition
    • string text : complete proposition text
    • bool active : true if proposition is still active
    • address proposer : ethereum address used to submit the proposition
    • uint256 deposit : qty. of ether deposited

Actions

  • submitProposition(title, text, deposit)
  • deactivateProposition(propId)
  • getNumPropositions()
  • getProposition(propId)
  • TODO have way to transfer deposits

Events

  • PropositionSubmitted(proposer, title, text, deposit)
  • PropositionDeactivated(propId)

Upgrade Path

  • A new version of the proposition contract will upon instantiation, in its constructor, call this version of the proposition contract in order to migrate all necessary data in an auditable way.

Contract: Signal

Data Model

  • SignalAccounts
    • account sigAcct
    • mapping uint -> propId
    • uint numPropositions
    • mapping propId -> weight (where weight is between -10 and 10)

Actions

  • openSignalAccount(sigAcct, deposit)
  • closeSignalAccount(sigAcct) // deposit is returned
  • * setPosition(sigAcct, propId, weight) * getPosition(sigAcct, propId) * clearPosition(sigAcct, propId) * getMappedPositions(sigAcct)

Events

  • SignalAccountOpened(sigAcct, deposit)
  • SignalAccountClosed(sigAcct)
  • SignalAccountSetPosition(sigAcct, propId, weight)

Upgrade Path

  • A new version of the signal contract will upon instantiation, in its constructor, call this version of the signal contract in order to migrate all necessary data in an auditable way.

Browser Context

State

The first time a browser visits the site, it will construct the current state of all propositions and signals via interfacing with an ethereum node instance. Once the initial state is reproduced updates will be received via events. The browser local state data model used by the User Interface will be a JOIN of the data available in the Propositions contract and the Signal contract as defined below (in the Data Model subsection). Note the negative and positive signal histograms are tracked separately rather than interfering with each other. Otherwise equal positive and negative sentiment would look like no interest.

Data Model

  • Propositions
    • string title : short summary of the proposition
    • string text : complete proposition text
    • address proposer : ethereum address used to submit the proposition
    • uint256 deposit : qty. of ether deposited
    • mapping acct -> weight
    • uint256 negSignal[Nintervals] // histogram
    • uint256 posSignal[Nintervals] // histogram

User Interface

User Interfaces

  • Submit a proposal
  • List proposals (can sort by age of proposal and/or show only proposals where (you have an active position or are tracking))
    • Show voting stats (signal) and meta-data (age of proposal)
    • Add a position
    • Withdraw a position
    • Update position (withdraw then add)

Issues

Notes

  • The browser local data model histograms should be deterministic, that is every browser should produce the exact same histograms. This means that the account balance and weight values will be scraped from the blockchain appropriately from events and balances using the blocks time stamps.
Clone this wiki locally