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

Add work score trait and impls #1235

Merged
merged 60 commits into from
Nov 27, 2023
Merged
Changes from 1 commit
Commits
Show all changes
60 commits
Select commit Hold shift + click to select a range
80a2eda
add workscore calc
Alex6323 Sep 15, 2023
f7cffb6
Merge branch '2.0' into feat/workscore
Alex6323 Sep 15, 2023
29843e5
fix merge
Alex6323 Sep 15, 2023
5da94e4
finish calculations
Alex6323 Sep 19, 2023
9d8d0cd
nits
Alex6323 Sep 20, 2023
5cd1d54
merge import
Alex6323 Sep 20, 2023
8ade41a
Merge branch '2.0' into feat/workscore; Add WorkScore trait;
Alex6323 Sep 20, 2023
00ddccf
nits
Alex6323 Sep 20, 2023
cca95f3
Merge branch '2.0' into feat/workscore
Alex6323 Sep 20, 2023
ab3b9fe
rename trait fn
Alex6323 Oct 8, 2023
25f183c
Merge branch '2.0' into feat/workscore
Alex6323 Oct 9, 2023
830ff47
update work score computations
Alex6323 Oct 9, 2023
6306da5
nit
Alex6323 Oct 9, 2023
7e8a204
move work score types into own module
Alex6323 Oct 9, 2023
f917fd9
add and impl mana cost fn
Alex6323 Oct 9, 2023
1ee7870
PR suggestions 1
Alex6323 Oct 10, 2023
9b64653
Merge branch '2.0' into feat/workscore
Alex6323 Nov 6, 2023
7fe6244
Merge branch '2.0' into feat/workscore
Alex6323 Nov 6, 2023
8789e80
is_signature
Alex6323 Nov 9, 2023
0797c70
remove todo
Alex6323 Nov 9, 2023
1766d74
Merge branch '2.0' into feat/workscore
Alex6323 Nov 9, 2023
363a153
Merge branch 'upstream/2.0' into feat/workscore
Alex6323 Nov 20, 2023
fac3fd2
review 1
Alex6323 Nov 20, 2023
4665f7f
Merge branch '2.0' into feat/workscore
Alex6323 Nov 20, 2023
7aaae7d
review 2
Alex6323 Nov 20, 2023
d7929c6
review 3
Alex6323 Nov 20, 2023
ecf08e3
fix copyright year
Alex6323 Nov 20, 2023
7098d84
Merge branch '2.0' into feat/workscore
Alex6323 Nov 20, 2023
05edd44
Merge branch '2.0' into feat/workscore
Alex6323 Nov 20, 2023
15bfd4f
Merge branch '2.0' into feat/workscore
thibault-martinez Nov 21, 2023
711c35b
StorageScore :heart: WorkScore
Alex6323 Nov 21, 2023
8d6b744
Fix def_is_as_opt panic message (#1659)
thibault-martinez Nov 21, 2023
5f8e14f
Remove native tokens from AnchorOutput (#1660)
thibault-martinez Nov 21, 2023
21217b9
Python: add multi address (#1658)
Alex6323 Nov 21, 2023
e449156
fmt
Alex6323 Nov 21, 2023
f48a8cf
align + more impls
Alex6323 Nov 21, 2023
dc921e8
Merge branch '2.0' into feat/workscore
Alex6323 Nov 21, 2023
913a5b6
nit
Alex6323 Nov 21, 2023
87d56af
default impl for all features
Alex6323 Nov 22, 2023
9861038
default impl for all unlocks
Alex6323 Nov 22, 2023
d778512
self
Alex6323 Nov 22, 2023
751935c
Merge branch '2.0' into feat/workscore
Alex6323 Nov 22, 2023
620598b
Merge branch '2.0' into feat/workscore
thibault-martinez Nov 22, 2023
5d3d1e0
rm WorkScore impl for NativeTokens type
Alex6323 Nov 23, 2023
d23fb61
review suggestions
Alex6323 Nov 23, 2023
2fad332
align and improve
Alex6323 Nov 24, 2023
52dc638
cleanup
Alex6323 Nov 24, 2023
dfe23e9
Merge branch '2.0' into feat/workscore
Alex6323 Nov 24, 2023
01906c0
cleanup 2
Alex6323 Nov 24, 2023
3a303e0
forward work score in NativeTokenFeature
Alex6323 Nov 24, 2023
3fa452a
cleanup 3
Alex6323 Nov 24, 2023
d002ed1
forward 2
Alex6323 Nov 24, 2023
f5ee525
let's see if we're faster than thibault
Alex6323 Nov 24, 2023
f19d7dc
unnecessary import
Alex6323 Nov 24, 2023
80d2f38
underscore
Alex6323 Nov 24, 2023
34a0b99
Merge branch '2.0' into feat/workscore
Alex6323 Nov 24, 2023
787067c
final touches
Alex6323 Nov 24, 2023
ab6501e
remove todo
Alex6323 Nov 24, 2023
9f751e0
rm mana_cost fn from work score trait
Alex6323 Nov 27, 2023
80d982c
Merge branch '2.0' into feat/workscore
Alex6323 Nov 27, 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
Merge branch 'upstream/2.0' into feat/workscore
Alex6323 committed Nov 20, 2023
commit 363a153c53fb797b3cd3183a9b262a876c48f438
4 changes: 2 additions & 2 deletions sdk/src/types/block/address/multi.rs
Original file line number Diff line number Diff line change
@@ -30,8 +30,8 @@ pub struct WeightedAddress {
impl WeightedAddress {
/// Creates a new [`WeightedAddress`].
pub fn new(address: Address, weight: u8) -> Result<Self, Error> {
verify_address::<true>(&address, &())?;
verify_weight::<true>(&weight, &())?;
verify_address::<true>(&address)?;
verify_weight::<true>(&weight)?;

Ok(Self { address, weight })
}
24 changes: 11 additions & 13 deletions sdk/src/types/block/core/basic.rs
Original file line number Diff line number Diff line change
@@ -154,7 +154,7 @@ impl BasicBlockBody {
}
}

impl WorkScore for BasicBlock {
impl WorkScore for BasicBlockBody {
fn work_score(&self, work_score_params: WorkScoreParameters) -> u32 {
let payload_score = self
.payload
@@ -165,18 +165,16 @@ impl WorkScore for BasicBlock {
}
}

impl Packable for BasicBlock {
type UnpackError = Error;
type UnpackVisitor = ProtocolParameters;

fn pack<P: Packer>(&self, packer: &mut P) -> Result<(), P::Error> {
self.strong_parents.pack(packer)?;
self.weak_parents.pack(packer)?;
self.shallow_like_parents.pack(packer)?;
self.payload.pack(packer)?;
self.max_burned_mana.pack(packer)?;

Ok(())
fn verify_basic_block_body<const VERIFY: bool>(
basic_block_body: &BasicBlockBody,
_: &ProtocolParameters,
) -> Result<(), Error> {
if VERIFY {
verify_parents_sets(
&basic_block_body.strong_parents,
&basic_block_body.weak_parents,
&basic_block_body.shallow_like_parents,
)?;
}

Ok(())
10 changes: 5 additions & 5 deletions sdk/src/types/block/core/block.rs
Original file line number Diff line number Diff line change
@@ -15,7 +15,7 @@ use packable::{

use crate::types::block::{
block_id::{BlockHash, BlockId},
core::{BasicBlock, ValidationBlock},
core::{BasicBlockBody, ValidationBlockBody},
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
signature::Signature,
slot::{SlotCommitmentId, SlotIndex},
@@ -290,15 +290,15 @@ impl Block {
}
}

impl WorkScore for SignedBlock {
impl WorkScore for Block {
fn work_score(&self, work_score_params: WorkScoreParameters) -> u32 {
let block_score = self.block.work_score(work_score_params);
let body_score = self.body.work_score(work_score_params);
let signature_score = self.signature.work_score(work_score_params);
block_score + signature_score
body_score + signature_score
}
}

impl Packable for SignedBlock {
impl Packable for Block {
type UnpackError = Error;
type UnpackVisitor = ProtocolParameters;

33 changes: 1 addition & 32 deletions sdk/src/types/block/core/mod.rs
Original file line number Diff line number Diff line change
@@ -103,7 +103,7 @@ impl BlockBody {
}
}

impl WorkScore for Block {
impl WorkScore for BlockBody {
fn work_score(&self, work_score_params: WorkScoreParameters) -> u32 {
match self {
Self::Basic(basic) => basic.work_score(work_score_params),
@@ -112,37 +112,6 @@ impl WorkScore for Block {
}
}

impl Packable for Block {
type UnpackError = Error;
type UnpackVisitor = ProtocolParameters;

fn pack<P: Packer>(&self, packer: &mut P) -> Result<(), P::Error> {
match self {
Self::Basic(block) => {
BasicBlock::KIND.pack(packer)?;
block.pack(packer)
}
Self::Validation(block) => {
ValidationBlock::KIND.pack(packer)?;
block.pack(packer)
}
}?;

Ok(())
}

fn unpack<U: Unpacker, const VERIFY: bool>(
unpacker: &mut U,
visitor: &Self::UnpackVisitor,
) -> Result<Self, UnpackError<Self::UnpackError, U::Error>> {
Ok(match u8::unpack::<_, VERIFY>(unpacker, &()).coerce()? {
BasicBlock::KIND => Self::from(BasicBlock::unpack::<_, VERIFY>(unpacker, visitor).coerce()?),
ValidationBlock::KIND => Self::from(ValidationBlock::unpack::<_, VERIFY>(unpacker, visitor).coerce()?),
k => return Err(UnpackError::Packable(Error::InvalidBlockKind(k))),
})
}
}

#[cfg(feature = "serde")]
pub(crate) mod dto {
use alloc::format;
2 changes: 1 addition & 1 deletion sdk/src/types/block/core/validation.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@
use packable::Packable;

use crate::types::block::{
core::{parent::verify_parents_sets, Block, Parents},
core::{parent::verify_parents_sets, BlockBody, Parents},
protocol::{ProtocolParameters, ProtocolParametersHash, WorkScore, WorkScoreParameters},
thibault-martinez marked this conversation as resolved.
Show resolved Hide resolved
Error,
};
5 changes: 4 additions & 1 deletion sdk/src/types/block/error.rs
Original file line number Diff line number Diff line change
@@ -21,7 +21,10 @@ use crate::types::block::{
AccountId, AnchorId, ChainId, MetadataFeatureLength, NativeTokenCount, NftId, OutputIndex, StateMetadataLength,
TagFeatureLength,
},
payload::{ContextInputCount, InputCount, OutputCount, TagLength, TaggedDataLength},
payload::{
tagged_data::{TagLength, TaggedDataLength},
ContextInputCount, InputCount, OutputCount,
},
protocol::ProtocolParametersHash,
unlock::{UnlockCount, UnlockIndex, UnlocksCount},
};
41 changes: 22 additions & 19 deletions sdk/src/types/block/output/account.rs
Original file line number Diff line number Diff line change
@@ -11,25 +11,16 @@ use packable::{
Packable, PackableExt,
};

use crate::types::{
block::{
address::{AccountAddress, Address},
output::{
feature::{verify_allowed_features, Feature, FeatureFlags, Features},
unlock_condition::{
verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions,
},
verify_output_amount_min, verify_output_amount_packable, ChainId, NativeToken, NativeTokens, Output,
OutputBuilderAmount, OutputId, Rent, RentStructure, StateTransitionError, StateTransitionVerifier,
},
payload::signed_transaction::TransactionCapabilityFlag,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
use crate::types::block::{
address::{AccountAddress, Address},
output::{
feature::{verify_allowed_features, Feature, FeatureFlags, Features},
unlock_condition::{verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions},
ChainId, MinimumOutputAmount, Output, OutputBuilderAmount, OutputId, StateTransitionError,
StateTransitionVerifier, StorageScore, StorageScoreParameters,
},
payload::signed_transaction::TransactionCapabilityFlag,
protocol::ProtocolParameters,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
@@ -502,13 +493,25 @@ impl StateTransitionVerifier for AccountOutput {

impl WorkScore for AccountOutput {
fn work_score(&self, work_score_params: WorkScoreParameters) -> u32 {
let native_tokens_score = self.native_tokens().work_score(work_score_params);
let features_score = self.features().work_score(work_score_params);
let immutable_features_score = self.immutable_features().work_score(work_score_params);
work_score_params.output() + native_tokens_score + features_score + immutable_features_score
work_score_params.output() + features_score + immutable_features_score
}
}

impl StorageScore for AccountOutput {
fn storage_score(&self, params: StorageScoreParameters) -> u64 {
params.output_offset()
// Type byte
+ (1 + self.packed_len() as u64) * params.data_factor() as u64
+ self.unlock_conditions.storage_score(params)
+ self.features.storage_score(params)
+ self.immutable_features.storage_score(params)
}
}

impl MinimumOutputAmount for AccountOutput {}

impl Packable for AccountOutput {
type UnpackError = Error;
type UnpackVisitor = ProtocolParameters;
25 changes: 8 additions & 17 deletions sdk/src/types/block/output/anchor.rs
Original file line number Diff line number Diff line change
@@ -13,25 +13,16 @@ use packable::{
Packable, PackableExt,
};

use crate::types::{
block::{
address::{Address, AnchorAddress},
output::{
feature::{verify_allowed_features, Feature, FeatureFlags, Features},
unlock_condition::{
verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions,
},
verify_output_amount_min, verify_output_amount_packable, ChainId, NativeToken, NativeTokens, Output,
OutputBuilderAmount, OutputId, Rent, RentStructure, StateTransitionError, StateTransitionVerifier,
},
payload::signed_transaction::TransactionCapabilityFlag,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
use crate::types::block::{
address::{Address, AnchorAddress},
output::{
feature::{verify_allowed_features, Feature, FeatureFlags, Features},
unlock_condition::{verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions},
ChainId, MinimumOutputAmount, NativeToken, NativeTokens, Output, OutputBuilderAmount, OutputId,
StateTransitionError, StateTransitionVerifier, StorageScore, StorageScoreParameters,
},
payload::signed_transaction::TransactionCapabilityFlag,
protocol::ProtocolParameters,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
22 changes: 15 additions & 7 deletions sdk/src/types/block/output/basic.rs
Original file line number Diff line number Diff line change
@@ -13,12 +13,9 @@ use crate::types::block::{
verify_allowed_unlock_conditions, AddressUnlockCondition, StorageDepositReturnUnlockCondition,
UnlockCondition, UnlockConditionFlags, UnlockConditions,
},
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
MinimumOutputAmount, NativeToken, Output, OutputBuilderAmount, OutputId, StorageScore, StorageScoreParameters,
},
protocol::ProtocolParameters,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
unlock::Unlock,
Error,
@@ -363,12 +360,23 @@ impl BasicOutput {

impl WorkScore for BasicOutput {
fn work_score(&self, work_score_params: WorkScoreParameters) -> u32 {
let native_tokens_score = self.native_tokens().work_score(work_score_params);
let features_score = self.features().work_score(work_score_params);
work_score_params.output() + native_tokens_score + features_score
work_score_params.output() + features_score
}
}

impl StorageScore for BasicOutput {
fn storage_score(&self, params: StorageScoreParameters) -> u64 {
params.output_offset()
// Type byte
+ (1 + self.packed_len() as u64) * params.data_factor() as u64
+ self.unlock_conditions.storage_score(params)
+ self.features.storage_score(params)
}
}

impl MinimumOutputAmount for BasicOutput {}

fn verify_unlock_conditions<const VERIFY: bool>(unlock_conditions: &UnlockConditions) -> Result<(), Error> {
if VERIFY {
if unlock_conditions.address().is_none() {
37 changes: 20 additions & 17 deletions sdk/src/types/block/output/delegation.rs
Original file line number Diff line number Diff line change
@@ -5,24 +5,15 @@ use alloc::collections::BTreeSet;

use packable::{Packable, PackableExt};

use crate::types::{
block::{
address::{AccountAddress, Address},
output::{
chain_id::ChainId,
unlock_condition::{
verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions,
},
verify_output_amount_min, verify_output_amount_packable, Output, OutputBuilderAmount, OutputId, Rent,
RentStructure, StateTransitionError, StateTransitionVerifier,
},
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
slot::EpochIndex,
unlock::Unlock,
Error,
use crate::types::block::{
address::{AccountAddress, Address},
output::{
chain_id::ChainId,
unlock_condition::{verify_allowed_unlock_conditions, UnlockCondition, UnlockConditionFlags, UnlockConditions},
MinimumOutputAmount, Output, OutputBuilderAmount, OutputId, StateTransitionError, StateTransitionVerifier,
StorageScore, StorageScoreParameters,
},
protocol::ProtocolParameters,
protocol::{ProtocolParameters, WorkScore, WorkScoreParameters},
semantic::{SemanticValidationContext, TransactionFailureReason},
slot::EpochIndex,
unlock::Unlock,
@@ -395,6 +386,18 @@ impl WorkScore for DelegationOutput {
}
}

impl StorageScore for DelegationOutput {
fn storage_score(&self, params: StorageScoreParameters) -> u64 {
params.output_offset()
// Type byte
+ (1 + self.packed_len() as u64) * params.data_factor() as u64
+ params.delegation_offset()
+ self.unlock_conditions.storage_score(params)
}
}

impl MinimumOutputAmount for DelegationOutput {}

fn verify_validator_address<const VERIFY: bool>(validator_address: &AccountAddress) -> Result<(), Error> {
if VERIFY && validator_address.is_null() {
Err(Error::NullDelegationValidatorId)
9 changes: 8 additions & 1 deletion sdk/src/types/block/output/feature/mod.rs
Original file line number Diff line number Diff line change
@@ -31,7 +31,7 @@ pub use self::{
tag::TagFeature,
};
use crate::types::block::{
create_bitflags,
output::{StorageScore, StorageScoreParameters},
protocol::{WorkScore, WorkScoreParameters},
Error,
};
@@ -262,13 +262,20 @@ impl WorkScore for Features {
self.iter()
.map(|f| match f {
Feature::BlockIssuer(_) => work_score_params.block_issuer(),
Feature::NativeToken(_) => work_score_params.native_token(),
Feature::Staking(_) => work_score_params.staking(),
_ => 0,
thibault-martinez marked this conversation as resolved.
Show resolved Hide resolved
})
.sum::<u32>()
}
}

impl StorageScore for Features {
fn storage_score(&self, params: StorageScoreParameters) -> u64 {
self.iter().map(|f| f.storage_score(params)).sum::<u64>()
}
}

#[inline]
fn verify_unique_sorted<const VERIFY: bool>(features: &[Feature]) -> Result<(), Error> {
if VERIFY && !is_unique_sorted(features.iter().map(Feature::kind)) {
Loading
You are viewing a condensed version of this merge commit. You can view the full changes here.