From a574097676642fe853bbde31b849efaee701f18b Mon Sep 17 00:00:00 2001 From: Amiya Behera Date: Wed, 5 Jun 2024 11:16:32 +0530 Subject: [PATCH] wonlost --- custom-pallets/project-tips/src/lib.rs | 28 +++++++--- .../schelling-game-shared/src/extras.rs | 55 +++++++++++++++++++ .../schelling-game-shared/src/lib.rs | 2 +- .../schelling-game-shared/src/types.rs | 12 ++++ 4 files changed, 89 insertions(+), 8 deletions(-) diff --git a/custom-pallets/project-tips/src/lib.rs b/custom-pallets/project-tips/src/lib.rs index eac2657..888d77b 100644 --- a/custom-pallets/project-tips/src/lib.rs +++ b/custom-pallets/project-tips/src/lib.rs @@ -374,16 +374,30 @@ use super::*; #[pallet::call_index(8)] #[pallet::weight(0)] - pub fn get_incentives(origin: OriginFor, project_id: ProjectId) -> DispatchResult { + pub fn add_incentive_count( + origin: OriginFor, + project_id: ProjectId + + ) -> DispatchResult { let who = ensure_signed(origin)?; let block_number = Self::get_block_number_of_schelling_game(project_id)?; - let key = SumTreeName::ProjectTips { project_id, block_number: block_number.clone() }; - - let phase_data = Self::get_phase_data(); - T::SchellingGameSharedSource::get_incentives_two_choice_helper_link( - key, phase_data, who, - )?; + // let key = SumTreeName::ProjectTips { project_id, block_number: block_number.clone() }; Ok(()) + } + + // #[pallet::call_index(8)] + // #[pallet::weight(0)] + // pub fn get_incentives(origin: OriginFor, project_id: ProjectId) -> DispatchResult { + // let who = ensure_signed(origin)?; + // let block_number = Self::get_block_number_of_schelling_game(project_id)?; + // let key = SumTreeName::ProjectTips { project_id, block_number: block_number.clone() }; + + // let phase_data = Self::get_phase_data(); + // T::SchellingGameSharedSource::get_incentives_two_choice_helper_link( + // key, phase_data, who, + // )?; + // Ok(()) + // } } } diff --git a/custom-pallets/schelling-game-shared/src/extras.rs b/custom-pallets/schelling-game-shared/src/extras.rs index d4b7466..41275f2 100644 --- a/custom-pallets/schelling-game-shared/src/extras.rs +++ b/custom-pallets/schelling-game-shared/src/extras.rs @@ -614,6 +614,61 @@ impl Pallet { Ok(()) } + + pub(super) fn get_result_of_juror( + key: SumTreeNameType, + who: AccountIdOf + ) -> Result { + match >::get(&key) { + Some(period) => { + ensure!(period == Period::Execution, Error::::PeriodDontMatch); + }, + None => Err(Error::::PeriodDoesNotExists)?, + } + + let drawn_juror = >::get(&key); + + let who_commit_vote = >::get(&key, &who); + match who_commit_vote { + Some(commit_struct) => { + let vote_option = commit_struct.revealed_vote; + match vote_option { + Some(vote) => { + let decision_count: (u64, u64) = >::get(&key); + let winning_decision = Self::get_winning_decision(decision_count); + if let Ok(_) = drawn_juror.binary_search_by(|(c, _)| c.cmp(&who.clone())) { + match winning_decision { + WinningDecision::WinnerYes => match vote { + RevealedVote::Yes => { + Ok(WonLost::Won) + }, + RevealedVote::No => { + Ok(WonLost::Lost) + }, + }, + WinningDecision::WinnerNo => match vote { + RevealedVote::Yes => { + Ok(WonLost::Lost) + }, + RevealedVote::No => { + Ok(WonLost::Won) + }, + }, + WinningDecision::Draw => { + Ok(WonLost::Lost) + }, + } + } else { + Err(Error::::StakeDoesNotExists)? + } + }, + None => Err(Error::::VoteNotRevealed)?, + } + }, + None => Err(Error::::CommitDoesNotExists)?, + } + } + pub(super) fn getting_incentives_draw( key: SumTreeNameType, who: AccountIdOf, diff --git a/custom-pallets/schelling-game-shared/src/lib.rs b/custom-pallets/schelling-game-shared/src/lib.rs index 0497c02..a50c507 100644 --- a/custom-pallets/schelling-game-shared/src/lib.rs +++ b/custom-pallets/schelling-game-shared/src/lib.rs @@ -24,7 +24,7 @@ pub mod types; use crate::types::{ CommitVote, Period, PhaseData, RangePoint, RevealedVote, SchellingGameType, ScoreCommitVote, - VoteStatus, WinningDecision, + VoteStatus, WinningDecision, WonLost }; use frame_support::pallet_prelude::*; use frame_system::pallet_prelude::*; diff --git a/custom-pallets/schelling-game-shared/src/types.rs b/custom-pallets/schelling-game-shared/src/types.rs index 9a67bb5..329282e 100644 --- a/custom-pallets/schelling-game-shared/src/types.rs +++ b/custom-pallets/schelling-game-shared/src/types.rs @@ -86,6 +86,18 @@ pub enum WinningDecision { Draw, } + +#[derive(PartialEq, Eq, PartialOrd, Ord, Clone, Encode, Decode, MaxEncodedLen, TypeInfo)] +#[cfg_attr(feature = "std", derive(Debug))] +pub enum WonLost { + Won, + Lost, + Draw, +} + + + + #[derive(PartialEq, Eq, PartialOrd, Ord, Clone, Encode, Decode, MaxEncodedLen, TypeInfo)] #[cfg_attr(feature = "std", derive(Debug))] pub struct ScoreCommitVote {