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

Fix challange app #96

Merged
merged 53 commits into from
Oct 19, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
1109dde
replace duration enum
CyberHoward Sep 30, 2023
a772ced
formatting
CyberHoward Sep 30, 2023
a796e6e
small refactor
Buckram123 Oct 4, 2023
ae2ec4a
remove check_ins
Buckram123 Oct 4, 2023
d49b08b
voting object
Buckram123 Oct 4, 2023
3c6a914
update voting
Buckram123 Oct 4, 2023
5179336
add vote error
Buckram123 Oct 5, 2023
a2266f8
fix challenge status
Buckram123 Oct 5, 2023
068c486
challenge execute methods
Buckram123 Oct 5, 2023
84477e8
add expiration for voting
Buckram123 Oct 5, 2023
3b2847b
veto period start after votes counted
Buckram123 Oct 6, 2023
8034615
integrate voting in challenge
Buckram123 Oct 6, 2023
c99cb0b
fix remove voters
Buckram123 Oct 6, 2023
de5bc2a
add veto action
Buckram123 Oct 6, 2023
366738d
update queries
Buckram123 Oct 6, 2023
c2a33e5
add comments
Buckram123 Oct 9, 2023
3cb78f3
fix existing tests
Buckram123 Oct 9, 2023
ec77cdd
add challenge id to the response
Buckram123 Oct 9, 2023
42995db
format
Buckram123 Oct 9, 2023
a058198
previous votes
Buckram123 Oct 9, 2023
88b657b
wasm can't deserialize map
Buckram123 Oct 10, 2023
0dda5ca
fix friends
Buckram123 Oct 10, 2023
576dc2b
bugfix
Buckram123 Oct 10, 2023
9118043
rename to proposals, where it fits
Buckram123 Oct 10, 2023
f3f642a
add votes query
Buckram123 Oct 10, 2023
dc39dec
cast vote as abstract account
Buckram123 Oct 10, 2023
86bf03b
add veto tests
Buckram123 Oct 11, 2023
9c8f4a6
format
Buckram123 Oct 11, 2023
34e488c
add limits
Buckram123 Oct 11, 2023
0d8e64d
Doc-comment for SimpleVoting
Buckram123 Oct 11, 2023
fbd0c9c
clippy
Buckram123 Oct 11, 2023
3f10572
Bump challenge to 0.2.0
adairrr Oct 11, 2023
b00aee8
add validation, make description optional
Buckram123 Oct 12, 2023
497a74a
format
Buckram123 Oct 12, 2023
2ca5d81
duplicate addrs fix
Buckram123 Oct 13, 2023
2adb059
update proposal initiation and veto
Buckram123 Oct 16, 2023
8f1af63
update tests/fix bugs
Buckram123 Oct 17, 2023
b279cfe
clippy fixes
Buckram123 Oct 17, 2023
41df9bb
add readme for the challenge
Buckram123 Oct 17, 2023
ebf2919
small edit in readme
Buckram123 Oct 17, 2023
08100cc
Merge branch 'main' into fix/challange_app
Buckram123 Oct 17, 2023
cf953e3
Merge remote-tracking branch 'origin' into fix/challange_app
Buckram123 Oct 17, 2023
7da4b22
voting tests and fixes
Buckram123 Oct 18, 2023
4a4b40b
update challenge to the new simple_voting
Buckram123 Oct 18, 2023
1a3816f
add active_proposal to ChallengeEntryResponse
Buckram123 Oct 18, 2023
9c12138
update schema
Buckram123 Oct 18, 2023
a9b0627
update voting readme
Buckram123 Oct 18, 2023
c39bede
redundant take(1)
Buckram123 Oct 19, 2023
b341aa8
add proposal lifecylce
CyberHoward Oct 19, 2023
a474d75
formatting
CyberHoward Oct 19, 2023
ea40e6f
update proposal lifecylce
CyberHoward Oct 19, 2023
231da31
complete proposal lifecycle
CyberHoward Oct 19, 2023
d1d5df7
fix beta clippy
CyberHoward Oct 19, 2023
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 framework/packages/abstract-core/src/objects/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ pub mod paged_map;
pub mod price_source;
pub mod time_weighted_average;
pub mod validation;
pub mod voting;

pub use account::{AccountId, ABSTRACT_ACCOUNT_ID};
pub use ans_asset::AnsAsset;
Expand Down
203 changes: 203 additions & 0 deletions framework/packages/abstract-core/src/objects/voting.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,203 @@
use crate::AbstractResult;
use cosmwasm_std::{ensure, Addr, Decimal, Env, StdError, StdResult, Storage};
use cw_storage_plus::{Bound, Item, Map};
use cw_utils::Duration;

pub const DEFAULT_LIMIT: u64 = 25;
pub type VoteId = u64;

/// Simple voting helper
pub struct SimpleVoting<'a> {
vote_id: Item<'a, VoteId>,
votes: Map<'a, (VoteId, &'a Addr), Option<Vote>>,
vote_config: Item<'a, VoteConfig>,
}

impl<'a> SimpleVoting<'a> {
pub const fn new(id_key: &'a str, vote_config_key: &'a str, votes_key: &'a str) -> Self {
Self {
vote_id: Item::new(id_key),
votes: Map::new(votes_key),
vote_config: Item::new(vote_config_key),
}
}

pub fn instantiate(
&self,
store: &mut dyn Storage,
vote_config: &VoteConfig,
) -> AbstractResult<()> {
self.vote_id.save(store, &VoteId::default())?;
self.vote_config.save(store, vote_config)?;
Ok(())
}

pub fn new_vote(
&self,
store: &mut dyn Storage,
initial_voters: &[Addr],
) -> AbstractResult<VoteId> {
let vote_id = self
.vote_id
.update(store, |id| AbstractResult::Ok(id + 1))?
// to start from zero
- 1;

for voter in initial_voters {
self.votes.save(store, (vote_id, voter), &None);
}
Ok(vote_id)
}

pub fn cast_vote(
&self,
store: &mut dyn Storage,
vote_id: VoteId,
voter: &Addr,
vote: Vote,
new_voter: bool,
) -> AbstractResult<()> {
match new_voter {
true => {
// Need to check it's existing vote id
let current_vote_id = self.vote_id.load(store)?;
ensure!(
current_vote_id <= vote_id,
crate::AbstractError::Std(StdError::generic_err(
"There are no vote by this id"
))
);
self.votes.save(store, (vote_id, voter), &Some(vote))?;
}
false => {
self.votes.update(
store,
(vote_id, voter),
|previous_vote| match previous_vote {
// We allow re-voting
Some(_v) => Ok(Some(vote)),
None => Err(StdError::generic_err("This user is not allowed to vote")),
},
)?;
}
}
Ok(())
}

pub fn count_votes(&self, store: &mut dyn Storage, vote_id: VoteId) -> AbstractResult<()> {
Ok(())
}

pub fn add_voters(
&self,
store: &mut dyn Storage,
vote_id: VoteId,
new_voters: &[Addr],
) -> AbstractResult<()> {
// Check it's existing vote id
let current_vote_id = self.vote_id.load(store)?;
ensure!(
current_vote_id <= vote_id,
crate::AbstractError::Std(StdError::generic_err("There are no vote by this id"))
);

for voter in new_voters {
// Don't override already existing vote
self.votes.update(store, (vote_id, voter), |v| match v {
Some(v) => AbstractResult::Ok(v),
None => AbstractResult::Ok(None),
})?;
}
Ok(())
}

pub fn remove_voters(
&self,
store: &mut dyn Storage,
vote_id: VoteId,
removed_voters: &[Addr],
) -> AbstractResult<()> {
for voter in removed_voters {
self.votes.remove(store, (vote_id, voter));
}
Ok(())
}

pub fn load_vote(
&self,
store: &dyn Storage,
vote_id: VoteId,
voter: &Addr,
) -> AbstractResult<Option<Vote>> {
self.votes.load(store, (vote_id, voter)).map_err(Into::into)
}

// TODO: do we want pagination on this?
// I guess no, because if we can't load all votes in one tx means we can't count it
// so maybe another TODO: Figure out max len for it
Buckram123 marked this conversation as resolved.
Show resolved Hide resolved
pub fn votes_for_id(
&self,
store: &dyn Storage,
vote_id: VoteId,
) -> AbstractResult<Vec<(Addr, Option<Vote>)>> {
let votes = self
.votes
.prefix(vote_id)
.range(store, None, None, cosmwasm_std::Order::Ascending)
.collect::<StdResult<_>>()?;
Ok(votes)
}

pub fn query_list(
&self,
store: &dyn Storage,
start_after: Option<(VoteId, &Addr)>,
limit: Option<u64>,
) -> AbstractResult<Vec<((VoteId, Addr), Option<Vote>)>> {
let min = start_after.map(Bound::exclusive);
let limit = limit.unwrap_or(DEFAULT_LIMIT);
let votes = self
.votes
.range(store, min, None, cosmwasm_std::Order::Ascending)
.take(limit as usize)
.collect::<StdResult<_>>()?;
Ok(votes)
}
}

#[cosmwasm_schema::cw_serde]
pub struct Vote {
pub vote: bool,
pub memo: Option<String>,
}

#[cosmwasm_schema::cw_serde]
pub struct VoteConfig {
pub threshold: Threshold,
pub veto_duration: Duration,
}

#[cosmwasm_schema::cw_serde]
pub enum Threshold {
Majority {},
Percentage(Decimal),
}

impl Threshold {
/// Asserts that the 0.0 < percent <= 1.0
fn validate_percentage(&self) -> StdResult<()> {
if let Threshold::Percentage(percent) = self {
if percent.is_zero() {
Err(StdError::generic_err("Threshold can't be 0%"))
} else if *percent > Decimal::one() {
Err(StdError::generic_err(
"Not possible to reach >100% threshold",
))
} else {
Ok(())
}
} else {
Ok(())
}
}
}
2 changes: 0 additions & 2 deletions modules/contracts/apps/challenge/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,6 @@ abstract-core = { workspace = true }
abstract-app = { workspace = true }
abstract-sdk = { workspace = true }

chrono = { workspace = true, default-features = false }

# Dependencies for interface
abstract-interface = { workspace = true, optional = true }
cw-orch = { workspace = true, optional = true }
Expand Down
7 changes: 5 additions & 2 deletions modules/contracts/apps/challenge/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ pub enum AppError {
#[error("{0}")]
DappError(#[from] AbstractAppError),

#[error("Resource not found")]
NotFound {},
#[error("Challenge not found")]
ChallengeNotFound {},

#[error("Already checked in")]
AlreadyCheckedIn {},
Expand All @@ -46,4 +46,7 @@ pub enum AppError {

#[error("The check in status is not correct for this action")]
WrongCheckInStatus {},

#[error("No friends found for the challenge")]
ZeroFriends {},
}
Loading