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

feat(examples): add p/moul/udao/... packages #2963

Draft
wants to merge 23 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions examples/gno.land/p/moul/udao/gno.mod
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
module gno.land/p/moul/udao
77 changes: 77 additions & 0 deletions examples/gno.land/p/moul/udao/udao.gno
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
// Package udao defines minimal interfaces for Decentralized Autonomous Organizations (DAOs).
// It intentionally does not expose members and votes, as these details are implementation-specific.
// Instead, it focuses on providing an external view of proposals and their statuses,
// which is what non-members and non-voters typically care about.
//
// The package is designed to allow for composable DAO patterns, enabling flexible
// and modular implementations of various DAO structures and behaviors.
package udao

// DAO defines a minimal interface for a Decentralized Autonomous Organization
// from an external point of view, hiding the internal details of members and voting.
type DAO interface {
// Propose submits a new proposal to the DAO
Propose(proposal Proposal) (uint64, error)

// GetProposalStatus retrieves the current status and metrics of a specific proposal
GetProposalStatus(proposalID uint64) (ProposalStatus, error)

// Execute attempts to execute a proposal if it has passed
Execute(proposalID uint64) error

// GetProposal retrieves the details of a specific proposal
GetProposal(proposalID uint64) (Proposal, error)

// XXX: find a smart way to list proposals
// // ListProposalss retrieves a list of Proposals with pagination and optional filters
// ListDAOs(offset, limit int, filters ...ProposalFilter) ([]DAO, error)
moul marked this conversation as resolved.
Show resolved Hide resolved
}

// Proposal defines the interface for a DAO proposal
type Proposal interface {
Title() string
Body() string
Constraints() []Constraint
}

// ProposalStatus represents the current status and metrics of a proposal
type ProposalStatus struct {
// status
State ProposalState

// metrics
YayPercentage float64
moul marked this conversation as resolved.
Show resolved Hide resolved
NayPercentage float64
NonVoterPercentage float64
moul marked this conversation as resolved.
Show resolved Hide resolved
// XXX: other metrics?
}

// ProposalState represents the current state of a proposal
type ProposalState int

const (
Pending ProposalState = iota
Active
Passed
Rejected
Executed
Expired // XXX: better name for when it's expired but not because of time?
moul marked this conversation as resolved.
Show resolved Hide resolved
)

// Constraint defines an interface for proposal constraints
type Constraint interface {
Validate() (bool, string)
Description() string
}

// ValidateConstraints checks if all constraints of a proposal are met
func ValidateConstraints(p Proposal) (bool, []string) {
var unmetReasons []string
for _, constraint := range p.Constraints() {
valid, reason := constraint.Validate()
if !valid {
unmetReasons = append(unmetReasons, reason)
}
}
return len(unmetReasons) == 0, unmetReasons
}
Loading