Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
2dd0619
Squashed commit of the following:
QuantumExplorer Mar 17, 2025
ca2a8fe
feat(sdk): get identity by non-unique pubkey hashes
lklimek Mar 10, 2025
21113f4
Squashed commit of the following:
QuantumExplorer Mar 17, 2025
09afcb6
feat(sdk): get identity by non-unique pubkey hashes
lklimek Mar 10, 2025
cd34fd0
test: initial version of framework and some first tests
lklimek Mar 17, 2025
2c338d6
WIP
lklimek Mar 18, 2025
938fea9
chore: test decreasing distribution
lklimek Mar 20, 2025
4a42235
chore: remove duplicate code
lklimek Mar 20, 2025
27bad8d
chore: self-review
lklimek Mar 20, 2025
53576a1
WIP
lklimek Mar 21, 2025
91de94c
chore: check entropy of random distribution
lklimek Mar 24, 2025
3dc1c9b
wip
lklimek Mar 25, 2025
a9cbf97
chore: wip
lklimek Mar 26, 2025
3adc24c
chore(Dockerfile): snapshots_enabled = true
lklimek Mar 27, 2025
b84b54b
Revert "chore(Dockerfile): snapshots_enabled = true"
lklimek Mar 27, 2025
1061b52
test: Polynomial
lklimek Apr 3, 2025
fe48a9e
test: Logarithmic
lklimek Apr 4, 2025
9045516
test: InvertedLogarithmic
lklimek Apr 4, 2025
488bd31
Merge branch 'v2.0-dev' into feat/getIdentitiesByPublicKeyHashes2
QuantumExplorer Apr 10, 2025
ed2d855
Merge branch 'feat/getIdentitiesByPublicKeyHashes2' of github.com:das…
QuantumExplorer Apr 10, 2025
2fe0e71
clean up
QuantumExplorer Apr 10, 2025
8606de3
Merge branch 'v2.0-dev' into feat/getIdentitiesByPublicKeyHashes2
QuantumExplorer Apr 16, 2025
9178c06
Merge branch 'v2.0-dev' into feat/getIdentitiesByPublicKeyHashes2
QuantumExplorer Apr 17, 2025
c5e1de2
fmt
QuantumExplorer Apr 17, 2025
160d771
fmt
QuantumExplorer Apr 17, 2025
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
41 changes: 0 additions & 41 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 5 additions & 1 deletion packages/dapi-grpc/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ fn configure_platform(mut platform: MappingConfig) -> MappingConfig {
// Derive features for versioned messages
//
// "GetConsensusParamsRequest" is excluded as this message does not support proofs
const VERSIONED_REQUESTS: [&str; 40] = [
const VERSIONED_REQUESTS: [&str; 41] = [
"GetDataContractHistoryRequest",
"GetDataContractRequest",
"GetDataContractsRequest",
Expand All @@ -85,6 +85,7 @@ fn configure_platform(mut platform: MappingConfig) -> MappingConfig {
"GetIdentityContractNonceRequest",
"GetIdentityBalanceAndRevisionRequest",
"GetIdentityBalanceRequest",
"GetIdentityByNonUniquePublicKeyHashRequest",
"GetIdentityByPublicKeyHashRequest",
"GetIdentityKeysRequest",
"GetIdentityRequest",
Expand Down Expand Up @@ -120,6 +121,9 @@ fn configure_platform(mut platform: MappingConfig) -> MappingConfig {
// - "GetConsensusParamsResponse"
// - "GetStatusResponse"
//
// The following responses are excluded as they need custom proof handling:
// - "GetIdentityByNonUniquePublicKeyHashResponse"
//
// "GetEvonodesProposedEpochBlocksResponse" is used for 2 Requests
const VERSIONED_RESPONSES: [&str; 39] = [
"GetDataContractHistoryResponse",
Expand Down
31 changes: 31 additions & 0 deletions packages/dapi-grpc/protos/platform/v0/platform.proto
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ service Platform {
rpc getDocuments(GetDocumentsRequest) returns (GetDocumentsResponse);
rpc getIdentityByPublicKeyHash(GetIdentityByPublicKeyHashRequest)
returns (GetIdentityByPublicKeyHashResponse);
rpc getIdentityByNonUniquePublicKeyHash(GetIdentityByNonUniquePublicKeyHashRequest)
returns (GetIdentityByNonUniquePublicKeyHashResponse);
rpc waitForStateTransitionResult(WaitForStateTransitionResultRequest)
returns (WaitForStateTransitionResultResponse);
rpc getConsensusParams(GetConsensusParamsRequest)
Expand Down Expand Up @@ -592,6 +594,35 @@ message GetIdentityByPublicKeyHashResponse {
oneof version { GetIdentityByPublicKeyHashResponseV0 v0 = 1; }
}

message GetIdentityByNonUniquePublicKeyHashRequest {
message GetIdentityByNonUniquePublicKeyHashRequestV0 {
bytes public_key_hash = 1;
optional bytes start_after = 2; // Give one result after a previous result
bool prove = 3;
}
oneof version { GetIdentityByNonUniquePublicKeyHashRequestV0 v0 = 1; }
}

message GetIdentityByNonUniquePublicKeyHashResponse {
message GetIdentityByNonUniquePublicKeyHashResponseV0 {
message IdentityResponse {
optional bytes identity = 1;
}

message IdentityProvedResponse {
Proof grovedb_identity_public_key_hash_proof = 1;
optional bytes identity_proof_bytes = 2; // A hack, we return 2 proofs
}
oneof result {
IdentityResponse identity = 1;
IdentityProvedResponse proof = 2;
}

ResponseMetadata metadata = 3; // Metadata about the blockchain state
}
oneof version { GetIdentityByNonUniquePublicKeyHashResponseV0 v0 = 1; }
}

message WaitForStateTransitionResultRequest {
message WaitForStateTransitionResultRequestV0 {
bytes state_transition_hash =
Expand Down
9 changes: 9 additions & 0 deletions packages/rs-dapi-client/src/transport/grpc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -490,6 +490,15 @@ impl_transport_request_grpc!(
get_status
);

// rpc getIdentityByNonUniquePublicKeyHash(GetIdentityByNonUniquePublicKeyHashRequest) returns (GetIdentityByNonUniquePublicKeyHashResponse);
impl_transport_request_grpc!(
platform_proto::GetIdentityByNonUniquePublicKeyHashRequest,
platform_proto::GetIdentityByNonUniquePublicKeyHashResponse,
PlatformGrpcClient,
RequestSettings::default(),
get_identity_by_non_unique_public_key_hash
);

// rpc getIdentityTokenBalances(GetIdentityTokenBalancesRequest) returns (GetIdentityTokenBalancesResponse);
impl_transport_request_grpc!(
platform_proto::GetIdentityTokenBalancesRequest,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ use crate::state_transition::StateTransition;
use crate::tokens::emergency_action::TokenEmergencyAction;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::token_payment_info::TokenPaymentInfo;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::token_pricing_schedule::TokenPricingSchedule;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::{PrivateEncryptedNote, SharedEncryptedNote};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ use crate::state_transition::batch_transition::accessors::DocumentsBatchTransiti
use crate::state_transition::StateTransition;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::emergency_action::TokenEmergencyAction;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::token_pricing_schedule::TokenPricingSchedule;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::{PrivateEncryptedNote, SharedEncryptedNote};
Expand Down
Original file line number Diff line number Diff line change
@@ -1,21 +1,27 @@
#[cfg(feature = "state-transition-signing")]
use crate::fee::Credits;
#[cfg(feature = "state-transition-signing")]
use crate::identity::signer::Signer;
#[cfg(feature = "state-transition-signing")]
use crate::identity::SecurityLevel;
#[cfg(feature = "state-transition-signing")]
use crate::prelude::IdentityNonce;
#[cfg(feature = "state-transition-signing")]
use crate::prelude::IdentityPublicKey;
#[cfg(feature = "state-transition-signing")]
use crate::prelude::UserFeeIncrease;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::batched_transition::BatchedTransition;
use crate::state_transition::batch_transition::{BatchTransitionV1, TokenDirectPurchaseTransition, TokenSetPriceForDirectPurchaseTransition};
use crate::state_transition::batch_transition::BatchTransitionV1;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::{TokenDirectPurchaseTransition, TokenSetPriceForDirectPurchaseTransition};
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::{TokenClaimTransition, TokenBurnTransition, TokenConfigUpdateTransition, TokenDestroyFrozenFundsTransition, TokenEmergencyActionTransition, TokenFreezeTransition, TokenMintTransition, TokenTransferTransition, TokenUnfreezeTransition};
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::BatchTransition;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::StateTransition;
#[cfg(feature = "state-transition-signing")]
use crate::ProtocolError;
#[cfg(feature = "state-transition-signing")]
use platform_value::Identifier;
Expand Down Expand Up @@ -48,13 +54,15 @@ use crate::state_transition::batch_transition::token_claim_transition::TokenClai
use crate::state_transition::batch_transition::token_config_update_transition::TokenConfigUpdateTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_destroy_frozen_funds_transition::TokenDestroyFrozenFundsTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_direct_purchase_transition::TokenDirectPurchaseTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_emergency_action_transition::TokenEmergencyActionTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_freeze_transition::TokenFreezeTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_mint_transition::TokenMintTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_set_price_for_direct_purchase_transition::TokenSetPriceForDirectPurchaseTransitionV0;
#[cfg(feature = "state-transition-signing")]
use crate::state_transition::batch_transition::token_transfer_transition::TokenTransferTransitionV0;
Expand All @@ -64,6 +72,7 @@ use crate::state_transition::batch_transition::token_unfreeze_transition::TokenU
use crate::tokens::emergency_action::TokenEmergencyAction;
#[cfg(feature = "state-transition-signing")]
use crate::tokens::{PrivateEncryptedNote, SharedEncryptedNote};
#[cfg(feature = "state-transition-signing")]
use crate::tokens::token_pricing_schedule::TokenPricingSchedule;

impl DocumentsBatchTransitionMethodsV1 for BatchTransitionV1 {
Expand Down
2 changes: 1 addition & 1 deletion packages/rs-drive-abci/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -103,10 +103,10 @@ assert_matches = "1.5.0"
drive-abci = { path = ".", features = ["testing-config", "mocks"] }
bls-signatures = { git = "https://github.com/dashpay/bls-signatures", tag = "1.3.3" }
mockall = { version = "0.13" }

# For tests of grovedb verify
rocksdb = { version = "0.23.0" }
integer-encoding = { version = "4.0.0" }
serial_test = { version = "3.2.0" }

[features]
default = []
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -153,14 +153,20 @@ impl<C> Platform<C> {
transaction: TransactionArg,
platform_version: &PlatformVersion,
) -> Result<(), Error> {
let mut rng = StdRng::seed_from_u64(0u64);
let non_unique_key =
IdentityPublicKey::random_voting_key_with_rng(11, &mut rng, platform_version)?;

for id in [IDENTITY_ID_1, IDENTITY_ID_2, IDENTITY_ID_3] {
// Create identity without keys
let mut identity = Identity::create_basic_identity(id, platform_version)?;

// Generate keys
let seed = id.to_buffer()[0];
let mut rng = StdRng::seed_from_u64(seed as u64);
let keys = IdentityPublicKey::main_keys_with_random_authentication_keys_with_private_keys_with_rng(3, &mut rng, platform_version)?;
let mut keys = IdentityPublicKey::main_keys_with_random_authentication_keys_with_private_keys_with_rng(3, &mut rng, platform_version)?;
// every identity has the same non-unique key
keys.push(non_unique_key.clone());

for (key, private_key) in keys.iter() {
let private_key = hex::encode(private_key);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
use crate::error::query::QueryError;
use crate::error::Error;
use crate::platform_types::platform::Platform;
use crate::platform_types::platform_state::PlatformState;
use crate::query::QueryValidationResult;
use dapi_grpc::platform::v0::get_identity_by_non_unique_public_key_hash_request::Version as RequestVersion;
use dapi_grpc::platform::v0::get_identity_by_non_unique_public_key_hash_response::Version as ResponseVersion;
use dapi_grpc::platform::v0::{
GetIdentityByNonUniquePublicKeyHashRequest, GetIdentityByNonUniquePublicKeyHashResponse,
};
use dpp::version::PlatformVersion;

mod v0;

impl<C> Platform<C> {
/// Querying of an identity by a public key hash
pub fn query_identity_by_non_unique_public_key_hash(
&self,
GetIdentityByNonUniquePublicKeyHashRequest { version }: GetIdentityByNonUniquePublicKeyHashRequest,
platform_state: &PlatformState,
platform_version: &PlatformVersion,
) -> Result<QueryValidationResult<GetIdentityByNonUniquePublicKeyHashResponse>, Error> {
let Some(version) = version else {
return Ok(QueryValidationResult::new_with_error(
QueryError::DecodingError(
"could not decode identity by public key non unique hash query".to_string(),
),
));
};

let feature_version_bounds = &platform_version
.drive_abci
.query
.identity_based_queries
.identity_by_non_unique_public_key_hash;

let feature_version = match &version {
RequestVersion::V0(_) => 0,
};

if !feature_version_bounds.check_version(feature_version) {
return Ok(QueryValidationResult::new_with_error(
QueryError::UnsupportedQueryVersion(
"identity_by_non_unique_public_key_hash".to_string(),
feature_version_bounds.min_version,
feature_version_bounds.max_version,
platform_version.protocol_version,
feature_version,
),
));
}

match version {
RequestVersion::V0(request_v0) => {
let request = self.query_identity_by_non_unique_public_key_hash_v0(
request_v0,
platform_state,
platform_version,
)?;

Ok(
request.map(|response_v0| GetIdentityByNonUniquePublicKeyHashResponse {
version: Some(ResponseVersion::V0(response_v0)),
}),
)
}
}
}
}
Loading
Loading