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

Pallet Fellowship #179

Closed
wants to merge 63 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
63 commits
Select commit Hold shift + click to select a range
71ba443
bump version, new template pallet
f-gate Jun 20, 2023
41811b3
fellowship pallet-skeleton
f-gate Jun 20, 2023
1daa8c7
add to fellowship, improv traits, documentation
f-gate Jun 21, 2023
a06b7e3
slash and leave fellowship
f-gate Jun 22, 2023
4c98000
progress
f-gate Jun 22, 2023
a78e438
remake ensurefellowship + add_candidate
f-gate Jun 26, 2023
276c354
fix
f-gate Jun 27, 2023
9578780
fix build
f-gate Jun 27, 2023
d6102f5
pending fellows extrinsic
f-gate Jun 27, 2023
97bb09b
add to fellowship after x blocks
f-gate Jun 27, 2023
3ac1ff5
mock
f-gate Jun 27, 2023
2d64d1e
fix
f-gate Jun 28, 2023
2604374
benchmark 1
f-gate Jun 28, 2023
644aabf
Merge branch 'main' of github.com:ImbueNetwork/imbue into pallet-fell…
f-gate Jul 14, 2023
a44a221
organisiation, distribute fees
f-gate Jul 17, 2023
60f546d
fix
f-gate Jul 19, 2023
f423545
loose coupling for projects
f-gate Jul 20, 2023
072b500
mega fixing
f-gate Jul 26, 2023
3c8f234
fix
f-gate Jul 26, 2023
932cd64
fail all the proposals tests
f-gate Jul 26, 2023
10b720d
tests :)
f-gate Jul 27, 2023
7639b9b
fmt
f-gate Jul 27, 2023
1b6f887
fellowship testing frame
f-gate Jul 27, 2023
3243999
role ranks, tests 1-6
f-gate Jul 27, 2023
6ff6ac7
implement the rank system in the pallet
f-gate Jul 27, 2023
6f9aafb
fmt
f-gate Jul 27, 2023
d0c404c
fix error return
f-gate Jul 28, 2023
5efe70c
fmt
f-gate Jul 28, 2023
24c0154
assoc type for deposit currency, test type alias, moar test
f-gate Jul 28, 2023
aeb6e0a
j keep testing
f-gate Aug 1, 2023
d5af853
ad infinitum
f-gate Aug 1, 2023
17006ba
fmt
f-gate Aug 3, 2023
6d49536
test
f-gate Aug 4, 2023
c4f8a7d
tests
f-gate Aug 5, 2023
a65aec8
basic tests done
f-gate Aug 7, 2023
5ac6727
fmt
f-gate Aug 7, 2023
9161cb2
finish impl
f-gate Aug 8, 2023
cc17dd3
fix mock add test
f-gate Aug 8, 2023
0fdc9d5
Merge branch 'main' of github.com:ImbueNetwork/imbue into pallet-fell…
f-gate Aug 8, 2023
32455ab
fix hook weight, tests, update dpenedancy version
f-gate Aug 8, 2023
2d23e9c
warning spring clean
f-gate Aug 8, 2023
b8b3e60
new into proposals function with config
f-gate Aug 10, 2023
67d8312
remove use of funding type for config refactor, fix build
f-gate Aug 10, 2023
19678a7
the beginings of the test refactor using config
f-gate Aug 11, 2023
ecef660
testing modifications
f-gate Aug 14, 2023
7a9fb56
updated test utils to match new format
f-gate Aug 19, 2023
367cc13
updated into proposals impl, new conversion for contributions
f-gate Aug 19, 2023
c328d78
trait definition, failing tests for new impls
f-gate Aug 19, 2023
638709f
fix convert to refunds, use from_rationsal
f-gate Aug 21, 2023
87a15bf
fix build but breaks all the test xd
f-gate Aug 21, 2023
d4b2223
fix that little err
f-gate Aug 21, 2023
2f0f9dc
todo files, more impl tests, removed unused config param
f-gate Aug 21, 2023
7bb94a9
remove the take from treasury idea and fmt
f-gate Aug 22, 2023
30cbe4b
add e2e test and more utils
f-gate Aug 22, 2023
1037698
on_initialise tests
f-gate Aug 22, 2023
7f040d1
and another one
f-gate Aug 22, 2023
657b380
weights
f-gate Aug 23, 2023
938e0ce
Merge branch 'main' of github.com:ImbueNetwork/imbue into pallet-fell…
f-gate Aug 23, 2023
443c6f6
remove TreasuryAccount, fix some benchmarks painfully
f-gate Aug 25, 2023
d51a826
add the correct weight fns to extrinsics
f-gate Aug 25, 2023
674e102
finally fixed the benchmarks
f-gate Aug 29, 2023
dda6a9f
fix up benchmarks
f-gate Aug 29, 2023
b193bac
benchmarks ready for testing
f-gate Aug 29, 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
Prev Previous commit
Next Next commit
fix convert to refunds, use from_rationsal
  • Loading branch information
f-gate committed Aug 21, 2023
commit 638709f3d6983e160bc7f446446530cd231deb6f
4 changes: 2 additions & 2 deletions pallets/proposals/src/impls.rs
Original file line number Diff line number Diff line change
Expand Up @@ -65,9 +65,9 @@ impl<T: Config> Pallet<T> {
.ok_or(Error::<T>::OnlyContributorsCanVote)?
.value;
let now = frame_system::Pallet::<T>::block_number();
let voters_bitmap_key = (project_key, RoundType::VotingRound, milestone_key);
let user_has_voted_key = (project_key, RoundType::VotingRound, milestone_key);

UserHasVoted::<T>::try_mutate(voters_bitmap_key, |votes| {
UserHasVoted::<T>::try_mutate(user_has_voted_key, |votes| {
ensure!(!votes.contains_key(&who), Error::<T>::VotesAreImmutable);
votes
.try_insert(who.clone(), approve_milestone)
Expand Down
34 changes: 13 additions & 21 deletions pallets/proposals/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ use pallet_fellowship::{traits::EnsureRole, Role};
use scale_info::TypeInfo;
use sp_arithmetic::per_things::Percent;
use sp_core::H256;
use sp_runtime::traits::{AccountIdConversion, Convert, Saturating, Zero};
use sp_runtime::traits::{AccountIdConversion, Convert, Saturating, Zero, One};
use sp_std::{collections::btree_map::*, convert::TryInto, prelude::*};
use xcm::latest::{MultiLocation};

Expand Down Expand Up @@ -74,6 +74,7 @@ pub mod pallet {
#[pallet::config]
pub trait Config:
frame_system::Config + pallet_identity::Config + pallet_timestamp::Config

{
/// Because this pallet emits events, it depends on the runtime's definition of an event.
type RuntimeEvent: From<Event<Self>> + IsType<<Self as frame_system::Config>::RuntimeEvent>;
Expand Down Expand Up @@ -461,7 +462,7 @@ pub mod pallet {
cancelled: false,
deposit_id,
refund_locations: refund_locations.try_into().map_err(|_|Error::<T>::TooManyRefundLocations)?,
jury.try_into().map_err(||Error::<T>::TooManyJuryMembers)?,
jury: jury.try_into().map_err(|_|Error::<T>::TooManyJuryMembers)?,
on_creation_funding,
};

Expand All @@ -479,23 +480,25 @@ pub mod pallet {
Ok(())
}

// TODO: TEST
/// SAFETY: Does no check on the bounds of the Map so ensure a bound before.
/// Assumes contributions are on the local chain.
fn convert_contributions_to_refund_locations(contributions: BTreeMap<AccountIdOf<T>, Contribution<BalanceOf<T>, BlockNumberFor<T>>>) -> Vec<(MultiLocation, Percent)> {
let sum_of_contributions = bounded_contributions
fn convert_contributions_to_refund_locations(contributions: &BTreeMap<AccountIdOf<T>, Contribution<BalanceOf<T>, BlockNumberFor<T>>>) -> Vec<(MultiLocation, Percent)> {
let sum_of_contributions = contributions
.values()
.fold(Default::default(), |acc: BalanceOf<T>, x| {
acc.saturating_add(x.value)
});

let mut sum_of_percents: Percent = Zero::zero();
let ret: Vec<(MultiLocation, Percent)> = contributions.iter().map(|c| {
let percent = Percent::from_parts((c.value / sum_of_contributions) as u8 * 100u8);
let percent = Percent::from_rational(c.1.value, sum_of_contributions);
sum_of_percents.saturating_add(percent);
// Since these are local we can use MultiLocation::Default;
(<MultiLocation as Default>::default(), percent)
});
}).collect::<Vec<(MultiLocation, Percent)>>();

if sum_of_perents != One::one() {
if sum_of_percents != One::one() {
// We are missing a part of the fund so take the remainder and use the treasury as the return address.
todo!()
}
Expand Down Expand Up @@ -583,7 +586,7 @@ pub struct Project<T: Config> {
/// Where do the refunds end up and what percent they get.
pub refund_locations: BoundedVec<(MultiLocation, Percent), T::MaximumContributorsPerProject>,
/// Who should deal with disputes.
pub jury: BoundedVec<AccountId, T::MaximumJurySize>,
pub jury: BoundedVec<AccountIdOf<T>, T::MaximumJurySize>,
/// When is the project funded and how is it taken.
pub on_creation_funding: FundingPath,
}
Expand All @@ -606,23 +609,12 @@ pub struct Whitelist<AccountId, Balance> {

#[derive(Encode, Decode, PartialEq, Eq, Clone, Debug, TypeInfo, MaxEncodedLen, Default)]
pub enum FundingPath {
#[default]
TakeFromReserved,
WaitForFunding,
}

impl Default for FundingPath {
fn default() -> Self {
Self::TakeFromReserved
}
}

impl Default for DisputeHandle {
fn default() -> Self {
Self::Fellowship
}
}

pub trait WeightInfoT {
pub trait WeightInfoT {
fn submit_milestone() -> Weight;
fn vote_on_milestone() -> Weight;
fn withdraw() -> Weight;
Expand Down
6 changes: 3 additions & 3 deletions pallets/proposals/src/traits.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
use crate::{AccountIdOf, BalanceOf, Contribution, ProposedMilestone, FundingPath, DisputeHandle};
use crate::{AccountIdOf, BalanceOf, Contribution, ProposedMilestone, FundingPath};
use common_types::{CurrencyId, FundingType, TreasuryOrigin, TreasuryOriginConverter};
use frame_support::{inherent::Vec, pallet_prelude::*, transactional, PalletId};
use orml_traits::XcmTransfer;
use orml_xtokens::Error;
use sp_core::H256;
use sp_runtime::traits::AccountIdConversion;
use sp_std::collections::btree_map::BTreeMap;
use sp_arithmetic::Percent;
use sp_arithmetic::{Percent, traits::AtLeast32BitUnsigned};
use xcm::latest::{MultiLocation, WeightLimit};


Expand All @@ -28,7 +28,7 @@ pub trait IntoProposal<AccountId, Balance: AtLeast32BitUnsigned, BlockNumber> {

/// Convert a btreemap of contributions to multilocations with the Here junction.
/// Use when the contributors are the refund locations.
fn convert_contributions_to_refund_locations(contributions: &BTreeMap<AccountId, Contribution<Balance, BlockNumber>>) -> Result<Vec<(MultiLocation, Percent)>, DispatchError>;
fn convert_contributions_to_refund_locations(contributions: &BTreeMap<AccountId, Contribution<Balance, BlockNumber>>) -> Vec<(MultiLocation, Percent)>;
}

pub trait RefundHandler<AccountId, Balance, CurrencyId> {
Expand Down