From de46558c33c1d841057f3c4e342bb81ca146f62b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marin=20Ver=C5=A1i=C4=87?= Date: Thu, 10 Oct 2024 07:17:48 +0200 Subject: [PATCH] refactor!: rename JsonString to JsonValue MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Marin Veršić --- crates/iroha/tests/integration/permissions.rs | 8 +-- .../integration/queries/smart_contract.rs | 2 +- crates/iroha/tests/integration/roles.rs | 4 +- .../tests/integration/transfer_domain.rs | 10 +-- .../integration/triggers/time_trigger.rs | 4 +- crates/iroha_cli/src/main.rs | 14 ++-- crates/iroha_codec/src/main.rs | 2 +- crates/iroha_core/src/query/store.rs | 4 +- .../src/smartcontracts/isi/account.rs | 4 +- .../src/smartcontracts/isi/asset.rs | 4 +- .../src/smartcontracts/isi/domain.rs | 6 +- .../src/smartcontracts/isi/query.rs | 38 +++++------ .../src/smartcontracts/isi/triggers/mod.rs | 4 +- .../src/smartcontracts/isi/world.rs | 4 +- .../src/events/data/events.rs | 6 +- .../src/events/execute_trigger.rs | 4 +- crates/iroha_data_model/src/executor.rs | 6 +- crates/iroha_data_model/src/isi.rs | 24 +++---- crates/iroha_data_model/src/metadata.rs | 12 ++-- crates/iroha_data_model/src/parameter.rs | 8 +-- crates/iroha_data_model/src/permission.rs | 8 +-- crates/iroha_data_model/src/query/mod.rs | 14 ++-- crates/iroha_kagami/src/genesis/generate.rs | 2 +- crates/iroha_primitives/src/json.rs | 64 +++++++++---------- crates/iroha_schema_gen/src/lib.rs | 6 +- docs/source/references/schema.json | 44 ++++++------- .../src/complex_isi.rs | 6 +- .../src/mint_rose_args.rs | 10 +-- .../src/multisig.rs | 16 ++--- .../src/simple_isi.rs | 6 +- wasm_samples/multisig/src/lib.rs | 6 +- wasm_samples/multisig_register/src/lib.rs | 2 +- .../query_assets_and_save_cursor/src/lib.rs | 2 +- 33 files changed, 176 insertions(+), 178 deletions(-) diff --git a/crates/iroha/tests/integration/permissions.rs b/crates/iroha/tests/integration/permissions.rs index a9ec6759f99..49149c393e7 100644 --- a/crates/iroha/tests/integration/permissions.rs +++ b/crates/iroha/tests/integration/permissions.rs @@ -261,7 +261,7 @@ fn permissions_differ_not_only_by_names() { .submit_blocking(SetKeyValue::asset( mouse_hat_id, "color".parse().expect("Valid"), - "red".parse::().expect("Valid"), + "red".parse::().expect("Valid"), )) .expect("Failed to modify Mouse's hats"); @@ -270,7 +270,7 @@ fn permissions_differ_not_only_by_names() { let set_shoes_color = SetKeyValue::asset( mouse_shoes_id.clone(), "color".parse().expect("Valid"), - "yellow".parse::().expect("Valid"), + "yellow".parse::().expect("Valid"), ); let _err = client .submit_blocking(set_shoes_color.clone()) @@ -318,7 +318,7 @@ fn stored_vs_granted_permission_payload() -> Result<()> { .expect("Failed to register mouse"); // Allow alice to mint mouse asset and mint initial value - let value_json = JsonString::from_string_unchecked(format!( + let value_json = JsonValue::from_string_unchecked(format!( // NOTE: Permissions is created explicitly as a json string to introduce additional whitespace // This way, if the executor compares permissions just as JSON strings, the test will fail r##"{{ "asset" : "xor#wonderland#{mouse_id}" }}"## @@ -341,7 +341,7 @@ fn stored_vs_granted_permission_payload() -> Result<()> { let set_key_value = SetKeyValue::asset( mouse_asset, "color".parse()?, - "red".parse::().expect("Valid"), + "red".parse::().expect("Valid"), ); iroha .submit_blocking(set_key_value) diff --git a/crates/iroha/tests/integration/queries/smart_contract.rs b/crates/iroha/tests/integration/queries/smart_contract.rs index f3435977f3a..3c1a605c3e1 100644 --- a/crates/iroha/tests/integration/queries/smart_contract.rs +++ b/crates/iroha/tests/integration/queries/smart_contract.rs @@ -17,7 +17,7 @@ fn live_query_is_dropped_after_smart_contract_end() -> Result<()> { ); client.submit_transaction_blocking(&transaction)?; - let metadata_value: JsonString = client.query_single(FindAccountMetadata::new( + let metadata_value: JsonValue = client.query_single(FindAccountMetadata::new( client.account.clone(), "cursor".parse().unwrap(), ))?; diff --git a/crates/iroha/tests/integration/roles.rs b/crates/iroha/tests/integration/roles.rs index 7a7a6ddf763..ec0bb59f4e8 100644 --- a/crates/iroha/tests/integration/roles.rs +++ b/crates/iroha/tests/integration/roles.rs @@ -65,7 +65,7 @@ fn register_and_grant_role_for_metadata_access() -> Result<()> { let set_key_value = SetKeyValue::account( mouse_id, "key".parse::()?, - "value".parse::()?, + "value".parse::()?, ); test_client.submit_blocking(set_key_value)?; @@ -222,7 +222,7 @@ fn grant_revoke_role_permissions() -> Result<()> { let set_key_value = SetKeyValue::account( mouse_id.clone(), "key".parse()?, - "value".parse::()?, + "value".parse::()?, ); let can_set_key_value_in_mouse = CanModifyAccountMetadata { account: mouse_id.clone(), diff --git a/crates/iroha/tests/integration/transfer_domain.rs b/crates/iroha/tests/integration/transfer_domain.rs index 8854b6a627b..c4c3d0d345a 100644 --- a/crates/iroha/tests/integration/transfer_domain.rs +++ b/crates/iroha/tests/integration/transfer_domain.rs @@ -13,7 +13,7 @@ use iroha_executor_data_model::permission::{ trigger::CanUnregisterTrigger, }; use iroha_genesis::GenesisBlock; -use iroha_primitives::json::JsonString; +use iroha_primitives::json::JsonValue; use iroha_test_network::{Peer as TestPeer, *}; use iroha_test_samples::{gen_account_in, ALICE_ID, BOB_ID, SAMPLE_GENESIS_ACCOUNT_ID}; use tokio::runtime::Runtime; @@ -74,7 +74,7 @@ fn domain_owner_domain_permissions() -> Result<()> { // check that "alice@wonderland" as owner of domain can edit metadata in her domain let key: Name = "key".parse()?; - let value = JsonString::new("value"); + let value = JsonValue::new("value"); test_client.submit_blocking(SetKeyValue::domain(kingdom_id.clone(), key.clone(), value))?; test_client.submit_blocking(RemoveKeyValue::domain(kingdom_id.clone(), key))?; @@ -111,7 +111,7 @@ fn domain_owner_account_permissions() -> Result<()> { // check that "alice@wonderland" as owner of domain can edit metadata of account in her domain let key: Name = "key".parse()?; - let value = JsonString::new("value"); + let value = JsonValue::new("value"); test_client.submit_blocking(SetKeyValue::account( mad_hatter_id.clone(), key.clone(), @@ -177,7 +177,7 @@ fn domain_owner_asset_definition_permissions() -> Result<()> { // check that "alice@wonderland" as owner of domain can edit metadata of asset definition in her domain let key: Name = "key".parse()?; - let value = JsonString::new("value"); + let value = JsonValue::new("value"); test_client.submit_blocking(SetKeyValue::asset_definition( coin_id.clone(), key.clone(), @@ -249,7 +249,7 @@ fn domain_owner_asset_permissions() -> Result<()> { // check that "alice@wonderland" as owner of domain can edit metadata of store asset in her domain let key: Name = "key".parse()?; - let value = JsonString::new("value"); + let value = JsonValue::new("value"); let bob_store_id = AssetId::new(store_id, bob_id.clone()); test_client.submit_blocking(SetKeyValue::asset(bob_store_id.clone(), key.clone(), value))?; test_client.submit_blocking(RemoveKeyValue::asset(bob_store_id.clone(), key))?; diff --git a/crates/iroha/tests/integration/triggers/time_trigger.rs b/crates/iroha/tests/integration/triggers/time_trigger.rs index c70778f176d..99b01902d80 100644 --- a/crates/iroha/tests/integration/triggers/time_trigger.rs +++ b/crates/iroha/tests/integration/triggers/time_trigger.rs @@ -121,7 +121,7 @@ fn pre_commit_trigger_should_be_executed() -> Result<()> { let sample_isi = SetKeyValue::account( account_id.clone(), "key".parse::()?, - "value".parse::()?, + "value".parse::()?, ); test_client.submit(sample_isi)?; } @@ -251,7 +251,7 @@ fn submit_sample_isi_on_every_block_commit( let sample_isi = SetKeyValue::account( account_id.clone(), "key".parse::()?, - JsonString::new("value"), + JsonValue::new("value"), ); test_client.submit(sample_isi)?; } diff --git a/crates/iroha_cli/src/main.rs b/crates/iroha_cli/src/main.rs index 48d7367e516..e022718fd30 100644 --- a/crates/iroha_cli/src/main.rs +++ b/crates/iroha_cli/src/main.rs @@ -11,7 +11,7 @@ use erased_serde::Serialize; use error_stack::{fmt::ColorMode, IntoReportCompat, ResultExt}; use eyre::{eyre, Error, Result, WrapErr}; use iroha::{client::Client, config::Config, data_model::prelude::*}; -use iroha_primitives::{addr::SocketAddr, json::JsonString}; +use iroha_primitives::{addr::SocketAddr, json::JsonValue}; use thiserror::Error; /// Re-usable clap `--metadata ` (`-m`) argument. @@ -58,7 +58,7 @@ pub struct MetadataValueArg { /// Booleans: false/true /// Objects: e.g. {"Vec":[{"String":"a"},{"String":"b"}]} #[arg(short, long)] - value: JsonString, + value: JsonValue, } impl FromStr for MetadataValueArg { @@ -66,7 +66,7 @@ impl FromStr for MetadataValueArg { fn from_str(s: &str) -> Result { Ok(MetadataValueArg { - value: JsonString::from_str(s)?, + value: JsonValue::from_str(s)?, }) } } @@ -1212,12 +1212,12 @@ mod tests { } // Boolean values - case!("true", JsonString::new(true)); - case!("false", JsonString::new(false)); + case!("true", JsonValue::new(true)); + case!("false", JsonValue::new(false)); // Numeric values - case!("\"123\"", JsonString::new(numeric!(123))); - case!("\"123.0\"", JsonString::new(numeric!(123.0))); + case!("\"123\"", JsonValue::new(numeric!(123))); + case!("\"123.0\"", JsonValue::new(numeric!(123.0))); // JSON Value let json_str = r#"{"Vec":[{"String":"a"},{"String":"b"}]}"#; diff --git a/crates/iroha_codec/src/main.rs b/crates/iroha_codec/src/main.rs index 2e7367e50ed..9f37a8a4966 100644 --- a/crates/iroha_codec/src/main.rs +++ b/crates/iroha_codec/src/main.rs @@ -313,7 +313,7 @@ mod tests { let mut metadata = Metadata::default(); metadata.insert( "hat".parse().expect("Valid"), - "white".parse::().expect("Valid"), + "white".parse::().expect("Valid"), ); let account = Account::new(ALICE_ID.clone()).with_metadata(metadata); diff --git a/crates/iroha_core/src/query/store.rs b/crates/iroha_core/src/query/store.rs index fb5e38dc81f..aa021857f70 100644 --- a/crates/iroha_core/src/query/store.rs +++ b/crates/iroha_core/src/query/store.rs @@ -329,7 +329,7 @@ mod tests { permission::Permission, query::parameters::{FetchSize, Pagination, QueryParams, Sorting}, }; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use iroha_test_samples::ALICE_ID; use nonzero_ext::nonzero; @@ -355,7 +355,7 @@ mod tests { // it's not important which type we use here, just to test the flow let query_output = - (0..100).map(|_| Permission::new(String::default(), JsonString::from(false))); + (0..100).map(|_| Permission::new(String::default(), JsonValue::from(false))); let query_output = crate::smartcontracts::query::apply_query_postprocessing( query_output, &query_params, diff --git a/crates/iroha_core/src/smartcontracts/isi/account.rs b/crates/iroha_core/src/smartcontracts/isi/account.rs index ab5c769a145..056609cdf6a 100644 --- a/crates/iroha_core/src/smartcontracts/isi/account.rs +++ b/crates/iroha_core/src/smartcontracts/isi/account.rs @@ -453,7 +453,7 @@ pub mod query { }, }, }; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use super::*; use crate::{smartcontracts::ValidQuery, state::StateReadOnly}; @@ -508,7 +508,7 @@ pub mod query { impl ValidSingularQuery for FindAccountMetadata { #[metrics(+"find_account_key_value_by_id_and_key")] - fn execute(&self, state_ro: &impl StateReadOnly) -> Result { + fn execute(&self, state_ro: &impl StateReadOnly) -> Result { let id = &self.id; let key = &self.key; iroha_logger::trace!(%id, %key); diff --git a/crates/iroha_core/src/smartcontracts/isi/asset.rs b/crates/iroha_core/src/smartcontracts/isi/asset.rs index 4051e099bf9..b864e851bc9 100644 --- a/crates/iroha_core/src/smartcontracts/isi/asset.rs +++ b/crates/iroha_core/src/smartcontracts/isi/asset.rs @@ -433,7 +433,7 @@ pub mod query { }, }, }; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use super::*; use crate::{smartcontracts::ValidQuery, state::StateReadOnly}; @@ -495,7 +495,7 @@ pub mod query { impl ValidSingularQuery for FindAssetMetadata { #[metrics(+"find_asset_key_value_by_id_and_key")] - fn execute(&self, state_ro: &impl StateReadOnly) -> Result { + fn execute(&self, state_ro: &impl StateReadOnly) -> Result { let id = &self.id; let key = &self.key; let asset = state_ro.world().asset(id).map_err(|asset_err| { diff --git a/crates/iroha_core/src/smartcontracts/isi/domain.rs b/crates/iroha_core/src/smartcontracts/isi/domain.rs index 550de8a2d20..46ae246c3a7 100644 --- a/crates/iroha_core/src/smartcontracts/isi/domain.rs +++ b/crates/iroha_core/src/smartcontracts/isi/domain.rs @@ -388,7 +388,7 @@ pub mod query { predicate::{predicate_atoms::domain::DomainPredicateBox, CompoundPredicate}, }, }; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use super::*; use crate::{smartcontracts::ValidQuery, state::StateReadOnly}; @@ -410,7 +410,7 @@ pub mod query { impl ValidSingularQuery for FindDomainMetadata { #[metrics(+"find_domain_key_value_by_id_and_key")] - fn execute(&self, state_ro: &impl StateReadOnly) -> Result { + fn execute(&self, state_ro: &impl StateReadOnly) -> Result { let id = &self.id; let key = &self.key; iroha_logger::trace!(%id, %key); @@ -424,7 +424,7 @@ pub mod query { impl ValidSingularQuery for FindAssetDefinitionMetadata { #[metrics(+"find_asset_definition_key_value_by_id_and_key")] - fn execute(&self, state_ro: &impl StateReadOnly) -> Result { + fn execute(&self, state_ro: &impl StateReadOnly) -> Result { let id = &self.id; let key = &self.key; iroha_logger::trace!(%id, %key); diff --git a/crates/iroha_core/src/smartcontracts/isi/query.rs b/crates/iroha_core/src/smartcontracts/isi/query.rs index 2c6d60a4dd6..60a6cc101e0 100644 --- a/crates/iroha_core/src/smartcontracts/isi/query.rs +++ b/crates/iroha_core/src/smartcontracts/isi/query.rs @@ -26,29 +26,29 @@ pub trait SortableQueryOutput { /// Get the sorting key for the output, from metadata /// /// If the type doesn't have metadata or metadata key doesn't exist - return None - fn get_metadata_sorting_key(&self, key: &Name) -> Option; + fn get_metadata_sorting_key(&self, key: &Name) -> Option; } impl SortableQueryOutput for Account { - fn get_metadata_sorting_key(&self, key: &Name) -> Option { + fn get_metadata_sorting_key(&self, key: &Name) -> Option { self.metadata.get(key).cloned() } } impl SortableQueryOutput for Domain { - fn get_metadata_sorting_key(&self, key: &Name) -> Option { + fn get_metadata_sorting_key(&self, key: &Name) -> Option { self.metadata.get(key).cloned() } } impl SortableQueryOutput for AssetDefinition { - fn get_metadata_sorting_key(&self, key: &Name) -> Option { + fn get_metadata_sorting_key(&self, key: &Name) -> Option { self.metadata.get(key).cloned() } } impl SortableQueryOutput for Asset { - fn get_metadata_sorting_key(&self, key: &Name) -> Option { + fn get_metadata_sorting_key(&self, key: &Name) -> Option { match &self.value { AssetValue::Numeric(_) => None, AssetValue::Store(metadata) => metadata.get(key).cloned(), @@ -57,55 +57,55 @@ impl SortableQueryOutput for Asset { } impl SortableQueryOutput for Role { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for RoleId { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for TransactionQueryOutput { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for Peer { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for Permission { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for Trigger { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for TriggerId { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for iroha_data_model::block::SignedBlock { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } impl SortableQueryOutput for iroha_data_model::block::BlockHeader { - fn get_metadata_sorting_key(&self, _key: &Name) -> Option { + fn get_metadata_sorting_key(&self, _key: &Name) -> Option { None } } @@ -138,7 +138,7 @@ where // sort & paginate, erase the iterator with QueryBatchedErasedIterator let output = if let Some(key) = &sorting.sort_by_metadata_key { // if sorting was requested, we need to retrieve all the results first - let mut pairs: Vec<(Option, I::Item)> = iter + let mut pairs: Vec<(Option, I::Item)> = iter .map(|value| { let key = value.get_metadata_sorting_key(key); (key, value) @@ -340,7 +340,7 @@ impl ValidQueryRequest { mod tests { use iroha_crypto::{Hash, KeyPair}; use iroha_data_model::query::predicate::CompoundPredicate; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use iroha_test_samples::{gen_account_in, ALICE_ID, ALICE_KEYPAIR}; use nonzero_ext::nonzero; use tokio::test; @@ -475,7 +475,7 @@ mod tests { let asset_definition_id = "rose#wonderland".parse()?; let asset_id = AssetId::new(asset_definition_id, ALICE_ID.clone()); let bytes = FindAssetMetadata::new(asset_id, "Bytes".parse()?).execute(&state.view())?; - assert_eq!(JsonString::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); + assert_eq!(JsonValue::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); Ok(()) } @@ -487,7 +487,7 @@ mod tests { let bytes = FindAccountMetadata::new(ALICE_ID.clone(), "Bytes".parse()?).execute(&state.view())?; - assert_eq!(JsonString::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); + assert_eq!(JsonValue::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); Ok(()) } @@ -684,7 +684,7 @@ mod tests { let domain_id = "wonderland".parse()?; let key = "Bytes".parse()?; let bytes = FindDomainMetadata::new(domain_id, key).execute(&state.view())?; - assert_eq!(JsonString::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); + assert_eq!(JsonValue::from(vec![1_u32, 2_u32, 3_u32,]), bytes,); Ok(()) } } diff --git a/crates/iroha_core/src/smartcontracts/isi/triggers/mod.rs b/crates/iroha_core/src/smartcontracts/isi/triggers/mod.rs index 10942d54c75..14bdb339ac4 100644 --- a/crates/iroha_core/src/smartcontracts/isi/triggers/mod.rs +++ b/crates/iroha_core/src/smartcontracts/isi/triggers/mod.rs @@ -329,7 +329,7 @@ pub mod query { }, trigger::{Trigger, TriggerId}, }; - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use super::*; use crate::{ @@ -380,7 +380,7 @@ pub mod query { impl ValidSingularQuery for FindTriggerMetadata { #[metrics(+"find_trigger_key_value_by_id_and_key")] - fn execute(&self, state_ro: &impl StateReadOnly) -> Result { + fn execute(&self, state_ro: &impl StateReadOnly) -> Result { let id = &self.id; let key = &self.key; iroha_logger::trace!(%id, %key); diff --git a/crates/iroha_core/src/smartcontracts/isi/world.rs b/crates/iroha_core/src/smartcontracts/isi/world.rs index a36443dc243..e3e43042085 100644 --- a/crates/iroha_core/src/smartcontracts/isi/world.rs +++ b/crates/iroha_core/src/smartcontracts/isi/world.rs @@ -25,7 +25,7 @@ pub mod isi { query::error::FindError, Level, }; - use iroha_primitives::{json::JsonString, unique_vec::PushResult}; + use iroha_primitives::{json::JsonValue, unique_vec::PushResult}; use super::*; @@ -356,7 +356,7 @@ pub mod isi { CustomParameter { id: next.id.clone(), - payload: JsonString::default(), + payload: JsonValue::default(), } }); diff --git a/crates/iroha_data_model/src/events/data/events.rs b/crates/iroha_data_model/src/events/data/events.rs index 92a841a0e61..823eae88933 100644 --- a/crates/iroha_data_model/src/events/data/events.rs +++ b/crates/iroha_data_model/src/events/data/events.rs @@ -3,7 +3,7 @@ use getset::Getters; use iroha_data_model_derive::{model, EventSet, HasOrigin}; -use iroha_primitives::{json::JsonString, numeric::Numeric}; +use iroha_primitives::{json::JsonValue, numeric::Numeric}; pub use self::model::*; use super::*; @@ -60,7 +60,7 @@ mod model { pub struct MetadataChanged { pub target: Id, pub key: Name, - pub value: JsonString, + pub value: JsonValue, } /// Event @@ -653,7 +653,7 @@ impl MetadataChanged { } /// Getter for `value` - pub fn value(&self) -> &JsonString { + pub fn value(&self) -> &JsonValue { &self.value } } diff --git a/crates/iroha_data_model/src/events/execute_trigger.rs b/crates/iroha_data_model/src/events/execute_trigger.rs index 66bd26885bb..ef170fbc4b9 100644 --- a/crates/iroha_data_model/src/events/execute_trigger.rs +++ b/crates/iroha_data_model/src/events/execute_trigger.rs @@ -35,7 +35,7 @@ mod model { pub authority: AccountId, /// Args to pass for trigger execution #[getset(skip)] - pub args: JsonString, + pub args: JsonValue, } /// Filter for trigger execution [`Event`] @@ -64,7 +64,7 @@ mod model { impl ExecuteTriggerEvent { /// Args to pass for trigger execution - pub fn args(&self) -> &JsonString { + pub fn args(&self) -> &JsonValue { &self.args } } diff --git a/crates/iroha_data_model/src/executor.rs b/crates/iroha_data_model/src/executor.rs index f03775cbe50..071f3531bdb 100644 --- a/crates/iroha_data_model/src/executor.rs +++ b/crates/iroha_data_model/src/executor.rs @@ -6,7 +6,7 @@ use alloc::{collections::BTreeSet, format, string::String, vec::Vec}; use std::collections::BTreeSet; use iroha_data_model_derive::model; -use iroha_primitives::json::JsonString; +use iroha_primitives::json::JsonValue; use iroha_schema::{Ident, IntoSchema}; pub use self::model::*; @@ -89,7 +89,7 @@ mod model { /// Ids of permission tokens supported by the executor. pub permissions: BTreeSet, /// Schema of executor defined data types (instructions, parameters, permissions) - pub schema: JsonString, + pub schema: JsonValue, } // TODO: Client doesn't need structures defined inside this macro. When dynamic linking is @@ -105,7 +105,7 @@ impl ExecutorDataModel { } /// Getter - pub fn schema(&self) -> &JsonString { + pub fn schema(&self) -> &JsonValue { &self.schema } } diff --git a/crates/iroha_data_model/src/isi.rs b/crates/iroha_data_model/src/isi.rs index 891f17f2f8d..1b9ea4b6a1b 100644 --- a/crates/iroha_data_model/src/isi.rs +++ b/crates/iroha_data_model/src/isi.rs @@ -189,7 +189,7 @@ impl BuiltInInstruction for InstructionBox { } mod transparent { - use iroha_primitives::json::JsonString; + use iroha_primitives::json::JsonValue; use super::*; use crate::{account::NewAccount, domain::NewDomain, metadata::Metadata}; @@ -270,13 +270,13 @@ mod transparent { /// Key. pub key: Name, /// Value. - pub value: JsonString, + pub value: JsonValue, } } impl SetKeyValue { /// Constructs a new [`SetKeyValue`] for a [`Domain`] with the given `key` and `value`. - pub fn domain(domain_id: DomainId, key: Name, value: impl Into) -> Self { + pub fn domain(domain_id: DomainId, key: Name, value: impl Into) -> Self { Self { object: domain_id, key, @@ -287,7 +287,7 @@ mod transparent { impl SetKeyValue { /// Constructs a new [`SetKeyValue`] for an [`Account`] with the given `key` and `value`. - pub fn account(account_id: AccountId, key: Name, value: impl Into) -> Self { + pub fn account(account_id: AccountId, key: Name, value: impl Into) -> Self { Self { object: account_id, key, @@ -301,7 +301,7 @@ mod transparent { pub fn asset_definition( asset_definition_id: AssetDefinitionId, key: Name, - value: impl Into, + value: impl Into, ) -> Self { Self { object: asset_definition_id, @@ -313,7 +313,7 @@ mod transparent { impl SetKeyValue { /// Constructs a new [`SetKeyValue`] for an [`Asset`] with the given `key` and `value`. - pub fn asset(asset_id: AssetId, key: Name, value: impl Into) -> Self { + pub fn asset(asset_id: AssetId, key: Name, value: impl Into) -> Self { Self { object: asset_id, key, @@ -324,7 +324,7 @@ mod transparent { impl SetKeyValue { /// Constructs a new [`SetKeyValue`] for a [`Trigger`] with the given `key` and `value`. - pub fn trigger(trigger_id: TriggerId, key: Name, value: impl Into) -> Self { + pub fn trigger(trigger_id: TriggerId, key: Name, value: impl Into) -> Self { Self { object: trigger_id, key, @@ -919,7 +919,7 @@ mod transparent { /// Id of a trigger to execute pub trigger: TriggerId, /// Arguments to trigger execution - pub args: JsonString, + pub args: JsonValue, } } @@ -928,14 +928,14 @@ mod transparent { pub fn new(trigger: TriggerId) -> Self { Self { trigger, - args: JsonString::default(), + args: JsonValue::default(), } } /// Add trigger execution args #[must_use] pub fn with_args(mut self, args: &T) -> Self { - self.args = JsonString::new(args); + self.args = JsonValue::new(args); self } } @@ -981,13 +981,13 @@ mod transparent { #[display(fmt = "CUSTOM({payload})")] pub struct CustomInstruction { /// Custom payload - pub payload: JsonString, + pub payload: JsonValue, } } impl CustomInstruction { /// Constructor - pub fn new(payload: impl Into) -> Self { + pub fn new(payload: impl Into) -> Self { Self { payload: payload.into(), } diff --git a/crates/iroha_data_model/src/metadata.rs b/crates/iroha_data_model/src/metadata.rs index 998212f6fbe..186173f1189 100644 --- a/crates/iroha_data_model/src/metadata.rs +++ b/crates/iroha_data_model/src/metadata.rs @@ -7,7 +7,7 @@ use core::borrow::Borrow; use std::collections::BTreeMap; use iroha_data_model_derive::model; -use iroha_primitives::json::JsonString; +use iroha_primitives::json::JsonValue; pub use self::model::*; use crate::prelude::Name; @@ -46,7 +46,7 @@ mod model { #[serde(transparent)] #[display(fmt = "Metadata")] #[allow(clippy::multiple_inherent_impl)] - pub struct Metadata(pub(super) BTreeMap); + pub struct Metadata(pub(super) BTreeMap); } impl Metadata { @@ -56,13 +56,13 @@ impl Metadata { } /// Iterate over key/value pairs stored in the internal map. - pub fn iter(&self) -> impl ExactSizeIterator { + pub fn iter(&self) -> impl ExactSizeIterator { self.0.iter() } /// Get the `Some(&Value)` associated to `key`. Return `None` if not found. #[inline] - pub fn get(&self, key: &K) -> Option<&JsonString> + pub fn get(&self, key: &K) -> Option<&JsonValue> where Name: Borrow, { @@ -71,7 +71,7 @@ impl Metadata { /// Insert [`Value`] under the given key. Returns `Some(value)` /// if the value was already present, `None` otherwise. - pub fn insert(&mut self, key: Name, value: impl Into) -> Option { + pub fn insert(&mut self, key: Name, value: impl Into) -> Option { self.0.insert(key, value.into()) } } @@ -82,7 +82,7 @@ impl Metadata { /// `Some(value)` at the key if the key was previously in the /// map, else `None`. #[inline] - pub fn remove(&mut self, key: &K) -> Option + pub fn remove(&mut self, key: &K) -> Option where Name: Borrow, { diff --git a/crates/iroha_data_model/src/parameter.rs b/crates/iroha_data_model/src/parameter.rs index 320bb86ae66..302fc3ea42f 100644 --- a/crates/iroha_data_model/src/parameter.rs +++ b/crates/iroha_data_model/src/parameter.rs @@ -6,7 +6,7 @@ use core::{num::NonZeroU64, time::Duration}; use std::collections::btree_map; use iroha_data_model_derive::model; -use iroha_primitives::json::JsonString; +use iroha_primitives::json::JsonValue; pub use self::model::*; use crate::{name::Name, Identifiable}; @@ -232,7 +232,7 @@ mod model { /// /// It is JSON-encoded, and its structure must correspond to the structure of /// the type defined in [`crate::executor::ExecutorDataModel`]. - pub payload: JsonString, + pub payload: JsonValue, } /// Set of all current blockchain parameter values @@ -577,7 +577,7 @@ impl CustomParameterId { impl CustomParameter { /// Constructor - pub fn new(id: CustomParameterId, payload: impl Into) -> Self { + pub fn new(id: CustomParameterId, payload: impl Into) -> Self { Self { id, payload: payload.into(), @@ -586,7 +586,7 @@ impl CustomParameter { /// Getter // TODO: derive with getset once FFI impl is fixed - pub fn payload(&self) -> &JsonString { + pub fn payload(&self) -> &JsonValue { &self.payload } } diff --git a/crates/iroha_data_model/src/permission.rs b/crates/iroha_data_model/src/permission.rs index 04bab19588e..3e811e9f69d 100644 --- a/crates/iroha_data_model/src/permission.rs +++ b/crates/iroha_data_model/src/permission.rs @@ -5,7 +5,7 @@ use alloc::{collections::BTreeSet, format, string::String, vec::Vec}; use std::collections::BTreeSet; use iroha_data_model_derive::model; -use iroha_primitives::json::JsonString; +use iroha_primitives::json::JsonValue; use iroha_schema::{Ident, IntoSchema}; pub use self::model::*; @@ -45,13 +45,13 @@ mod model { /// /// It is JSON-encoded, and its structure must correspond to the structure of /// the type defined in [`crate::executor::ExecutorDataModel`]. - pub payload: JsonString, + pub payload: JsonValue, } } impl Permission { /// Constructor - pub fn new(name: Ident, payload: impl Into) -> Self { + pub fn new(name: Ident, payload: impl Into) -> Self { Self { name, payload: payload.into(), @@ -65,7 +65,7 @@ impl Permission { /// Getter // TODO: derive with getset once FFI impl is fixed - pub fn payload(&self) -> &JsonString { + pub fn payload(&self) -> &JsonValue { &self.payload } } diff --git a/crates/iroha_data_model/src/query/mod.rs b/crates/iroha_data_model/src/query/mod.rs index 40d0f3970b4..18693869359 100644 --- a/crates/iroha_data_model/src/query/mod.rs +++ b/crates/iroha_data_model/src/query/mod.rs @@ -9,7 +9,7 @@ use derive_more::Constructor; use iroha_crypto::{PublicKey, SignatureOf}; use iroha_data_model_derive::model; use iroha_macro::FromVariant; -use iroha_primitives::{json::JsonString, numeric::Numeric}; +use iroha_primitives::{json::JsonValue, numeric::Numeric}; use iroha_schema::IntoSchema; use iroha_version::prelude::*; use parameters::{ForwardCursor, QueryParams}; @@ -150,7 +150,7 @@ mod model { pub enum SingularQueryOutputBox { Numeric(Numeric), ExecutorDataModel(crate::executor::ExecutorDataModel), - JsonString(JsonString), + Json(JsonValue), Trigger(crate::trigger::Trigger), Parameters(Parameters), Transaction(TransactionQueryOutput), @@ -570,13 +570,13 @@ impl_iter_queries! { } impl_singular_queries! { - FindAccountMetadata => JsonString, + FindAccountMetadata => JsonValue, FindAssetQuantityById => Numeric, - FindAssetMetadata => JsonString, - FindAssetDefinitionMetadata => JsonString, - FindDomainMetadata => JsonString, + FindAssetMetadata => JsonValue, + FindAssetDefinitionMetadata => JsonValue, + FindDomainMetadata => JsonValue, FindParameters => crate::parameter::Parameters, - FindTriggerMetadata => JsonString, + FindTriggerMetadata => JsonValue, FindExecutorDataModel => crate::executor::ExecutorDataModel, } diff --git a/crates/iroha_kagami/src/genesis/generate.rs b/crates/iroha_kagami/src/genesis/generate.rs index 54edb6e4a7b..880a6eba1b0 100644 --- a/crates/iroha_kagami/src/genesis/generate.rs +++ b/crates/iroha_kagami/src/genesis/generate.rs @@ -90,7 +90,7 @@ pub fn generate_default( ) -> color_eyre::Result { let genesis_account_id = AccountId::new(GENESIS_DOMAIN_ID.clone(), genesis_public_key); let mut meta = Metadata::default(); - meta.insert("key".parse()?, JsonString::new("value")); + meta.insert("key".parse()?, JsonValue::new("value")); let mut builder = builder .domain_with_metadata("wonderland".parse()?, meta.clone()) diff --git a/crates/iroha_primitives/src/json.rs b/crates/iroha_primitives/src/json.rs index f36be4d5f92..cfa6dadce5e 100644 --- a/crates/iroha_primitives/src/json.rs +++ b/crates/iroha_primitives/src/json.rs @@ -20,13 +20,13 @@ use parity_scale_codec::{Decode, Encode}; use serde::{de::DeserializeOwned, Deserialize, Serialize}; use serde_json::Value; -/// A valid `JsonString` that consists of valid String of Json type +/// A valid `JsonValue` that consists of valid String of Json type #[derive(Debug, Display, Clone, PartialOrd, PartialEq, Ord, Eq, IntoSchema, Encode, Decode)] #[display(fmt = "{_0}")] -pub struct JsonString(String); +pub struct JsonValue(String); -impl JsonString { - /// Constructs [`JsonString`] +impl JsonValue { + /// Constructs [`Self`] /// # Errors /// /// - Serialization can fail if T's implementation of Serialize decides to fail, @@ -36,7 +36,7 @@ impl JsonString { candidate::JsonCandidate::new(payload).try_into().unwrap() } - /// Tries cast [`JsonString`] to any value. + /// Tries cast [`Self`] to any value. /// /// # Errors /// - if invalid representation of `T` @@ -51,13 +51,13 @@ impl JsonString { Self(value) } - /// Getter for [`JsonString`] + /// Getter for [`Self`] pub fn get(&self) -> &String { &self.0 } } -impl<'de> serde::de::Deserialize<'de> for JsonString { +impl<'de> serde::de::Deserialize<'de> for JsonValue { fn deserialize(deserializer: D) -> Result where D: serde::Deserializer<'de>, @@ -67,7 +67,7 @@ impl<'de> serde::de::Deserialize<'de> for JsonString { } } -impl serde::ser::Serialize for JsonString { +impl serde::ser::Serialize for JsonValue { fn serialize(&self, serializer: S) -> Result where S: serde::Serializer, @@ -77,77 +77,77 @@ impl serde::ser::Serialize for JsonString { } } -impl From<&Value> for JsonString { +impl From<&Value> for JsonValue { fn from(value: &Value) -> Self { - JsonString(value.to_string()) + JsonValue(value.to_string()) } } -impl From for JsonString { +impl From for JsonValue { fn from(value: Value) -> Self { - JsonString(value.to_string()) + JsonValue(value.to_string()) } } -impl From for JsonString { +impl From for JsonValue { fn from(value: u32) -> Self { - JsonString::new(value) + JsonValue::new(value) } } -impl From for JsonString { +impl From for JsonValue { fn from(value: u64) -> Self { - JsonString::new(value) + JsonValue::new(value) } } -impl From for JsonString { +impl From for JsonValue { fn from(value: f64) -> Self { - JsonString::new(value) + JsonValue::new(value) } } -impl From for JsonString { +impl From for JsonValue { fn from(value: bool) -> Self { - JsonString::new(value) + JsonValue::new(value) } } -impl From<&str> for JsonString { +impl From<&str> for JsonValue { fn from(value: &str) -> Self { - value.parse::().expect("Impossible error") + value.parse::().expect("Impossible error") } } -impl + Serialize> From> for JsonString { +impl + Serialize> From> for JsonValue { fn from(value: Vec) -> Self { - JsonString::new(value) + JsonValue::new(value) } } /// Removes extra spaces from object if `&str` is an object -impl FromStr for JsonString { +impl FromStr for JsonValue { type Err = serde_json::Error; fn from_str(s: &str) -> Result { if let Ok(value) = serde_json::from_str::(s) { - Ok(JsonString(value.to_string())) + Ok(JsonValue(value.to_string())) } else { let json_formatted_string = serde_json::to_string(s)?; let value: Value = serde_json::from_str(&json_formatted_string)?; - Ok(JsonString(value.to_string())) + Ok(JsonValue(value.to_string())) } } } -impl Default for JsonString { +impl Default for JsonValue { fn default() -> Self { // NOTE: empty string isn't valid JSON Self("null".to_string()) } } -impl AsRef for JsonString { +impl AsRef for JsonValue { fn as_ref(&self) -> &str { &self.0 } @@ -156,8 +156,6 @@ impl AsRef for JsonString { mod candidate { use super::*; - /// A candidate for a valid `JsonString`. - /// Is used for generalizing ser/de any types to `JsonString` and vise versa #[derive(Serialize, Deserialize, Clone)] pub(super) struct JsonCandidate(T); @@ -167,10 +165,10 @@ mod candidate { } } - impl TryFrom> for JsonString { + impl TryFrom> for JsonValue { type Error = serde_json::Error; fn try_from(value: JsonCandidate) -> Result { - Ok(JsonString(serde_json::to_string(&value.0)?)) + Ok(JsonValue(serde_json::to_string(&value.0)?)) } } } diff --git a/crates/iroha_schema_gen/src/lib.rs b/crates/iroha_schema_gen/src/lib.rs index fca63e6721e..a373e870c7d 100644 --- a/crates/iroha_schema_gen/src/lib.rs +++ b/crates/iroha_schema_gen/src/lib.rs @@ -158,7 +158,7 @@ types!( Box>, Box, BTreeMap, - BTreeMap, + BTreeMap, BTreeSet, BTreeSet, BurnBox, @@ -279,7 +279,7 @@ types!( QueryWithFilter, QueryWithFilter, QueryWithParams, - JsonString, + JsonValue, Level, Log, MathError, @@ -552,7 +552,7 @@ pub mod complete_data_model { addr::{Ipv4Addr, Ipv6Addr, SocketAddr, SocketAddrHost, SocketAddrV4, SocketAddrV6}, const_vec::ConstVec, conststr::ConstString, - json::JsonString, + json::JsonValue, }; pub use iroha_schema::Compact; } diff --git a/docs/source/references/schema.json b/docs/source/references/schema.json index 40709192242..a1f460792dd 100644 --- a/docs/source/references/schema.json +++ b/docs/source/references/schema.json @@ -1359,7 +1359,7 @@ "Struct": [ { "name": "payload", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -1371,7 +1371,7 @@ }, { "name": "payload", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -1699,7 +1699,7 @@ }, { "name": "args", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -1715,7 +1715,7 @@ }, { "name": "args", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -1768,7 +1768,7 @@ }, { "name": "schema", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2336,7 +2336,7 @@ "IpfsPath": "String", "Ipv4Addr": "Array", "Ipv6Addr": "Array", - "JsonString": "String", + "JsonValue": "String", "Level": { "Enum": [ { @@ -2409,7 +2409,7 @@ "MerkleTree": { "Vec": "HashOf" }, - "Metadata": "SortedMap", + "Metadata": "SortedMap", "MetadataChanged": { "Struct": [ { @@ -2422,7 +2422,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2438,7 +2438,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2454,7 +2454,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2470,7 +2470,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2486,7 +2486,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -2882,7 +2882,7 @@ }, { "name": "payload", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -3825,7 +3825,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -3841,7 +3841,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -3857,7 +3857,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -3873,7 +3873,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -3889,7 +3889,7 @@ }, { "name": "value", - "type": "JsonString" + "type": "JsonValue" } ] }, @@ -4077,9 +4077,9 @@ "type": "ExecutorDataModel" }, { - "tag": "JsonString", + "tag": "Json", "discriminant": 2, - "type": "JsonString" + "type": "JsonValue" }, { "tag": "Trigger", @@ -4190,10 +4190,10 @@ "value": "CustomParameter" } }, - "SortedMap": { + "SortedMap": { "Map": { "key": "Name", - "value": "JsonString" + "value": "JsonValue" } }, "SortedVec": { diff --git a/wasm_samples/executor_custom_data_model/src/complex_isi.rs b/wasm_samples/executor_custom_data_model/src/complex_isi.rs index 6c358abe770..f6327068233 100644 --- a/wasm_samples/executor_custom_data_model/src/complex_isi.rs +++ b/wasm_samples/executor_custom_data_model/src/complex_isi.rs @@ -12,7 +12,7 @@ mod isi { use iroha_data_model::{ isi::{CustomInstruction, Instruction, InstructionBox}, - prelude::JsonString, + prelude::JsonValue, }; use iroha_schema::IntoSchema; use serde::{Deserialize, Serialize}; @@ -69,10 +69,10 @@ mod isi { } } - impl TryFrom<&JsonString> for CustomInstructionExpr { + impl TryFrom<&JsonValue> for CustomInstructionExpr { type Error = serde_json::Error; - fn try_from(payload: &JsonString) -> serde_json::Result { + fn try_from(payload: &JsonValue) -> serde_json::Result { serde_json::from_str::(payload.as_ref()) } } diff --git a/wasm_samples/executor_custom_data_model/src/mint_rose_args.rs b/wasm_samples/executor_custom_data_model/src/mint_rose_args.rs index 501c3810bf0..9ecbd3d16d9 100644 --- a/wasm_samples/executor_custom_data_model/src/mint_rose_args.rs +++ b/wasm_samples/executor_custom_data_model/src/mint_rose_args.rs @@ -1,6 +1,6 @@ //! Arguments to mint rose with args trigger -use iroha_data_model::prelude::JsonString; +use iroha_data_model::prelude::JsonValue; use serde::{Deserialize, Serialize}; /// Arguments to mint rose with args trigger @@ -10,16 +10,16 @@ pub struct MintRoseArgs { pub val: u32, } -impl From for JsonString { +impl From for JsonValue { fn from(details: MintRoseArgs) -> Self { - JsonString::new(details) + JsonValue::new(details) } } -impl TryFrom<&JsonString> for MintRoseArgs { +impl TryFrom<&JsonValue> for MintRoseArgs { type Error = serde_json::Error; - fn try_from(payload: &JsonString) -> serde_json::Result { + fn try_from(payload: &JsonValue) -> serde_json::Result { serde_json::from_str::(payload.as_ref()) } } diff --git a/wasm_samples/executor_custom_data_model/src/multisig.rs b/wasm_samples/executor_custom_data_model/src/multisig.rs index 5a42c2494bd..8a40fc55e70 100644 --- a/wasm_samples/executor_custom_data_model/src/multisig.rs +++ b/wasm_samples/executor_custom_data_model/src/multisig.rs @@ -23,30 +23,30 @@ pub enum MultisigArgs { Vote(HashOf>), } -impl From for JsonString { +impl From for JsonValue { fn from(details: MultisigRegisterArgs) -> Self { - JsonString::new(details) + JsonValue::new(details) } } -impl TryFrom<&JsonString> for MultisigRegisterArgs { +impl TryFrom<&JsonValue> for MultisigRegisterArgs { type Error = serde_json::Error; - fn try_from(payload: &JsonString) -> serde_json::Result { + fn try_from(payload: &JsonValue) -> serde_json::Result { serde_json::from_str::(payload.as_ref()) } } -impl From for JsonString { +impl From for JsonValue { fn from(details: MultisigArgs) -> Self { - JsonString::new(details) + JsonValue::new(details) } } -impl TryFrom<&JsonString> for MultisigArgs { +impl TryFrom<&JsonValue> for MultisigArgs { type Error = serde_json::Error; - fn try_from(payload: &JsonString) -> serde_json::Result { + fn try_from(payload: &JsonValue) -> serde_json::Result { serde_json::from_str::(payload.as_ref()) } } diff --git a/wasm_samples/executor_custom_data_model/src/simple_isi.rs b/wasm_samples/executor_custom_data_model/src/simple_isi.rs index e89200fee18..f5bafea4fee 100644 --- a/wasm_samples/executor_custom_data_model/src/simple_isi.rs +++ b/wasm_samples/executor_custom_data_model/src/simple_isi.rs @@ -6,7 +6,7 @@ use alloc::{format, string::String, vec::Vec}; use iroha_data_model::{ asset::AssetDefinitionId, isi::{CustomInstruction, Instruction, InstructionBox}, - prelude::{JsonString, Numeric}, + prelude::{JsonValue, Numeric}, }; use iroha_schema::IntoSchema; use serde::{Deserialize, Serialize}; @@ -53,10 +53,10 @@ impl From for InstructionBox { } } -impl TryFrom<&JsonString> for CustomInstructionBox { +impl TryFrom<&JsonValue> for CustomInstructionBox { type Error = serde_json::Error; - fn try_from(payload: &JsonString) -> serde_json::Result { + fn try_from(payload: &JsonValue) -> serde_json::Result { serde_json::from_str::(payload.as_ref()) } } diff --git a/wasm_samples/multisig/src/lib.rs b/wasm_samples/multisig/src/lib.rs index 646a79b9e19..db772e2c9a2 100644 --- a/wasm_samples/multisig/src/lib.rs +++ b/wasm_samples/multisig/src/lib.rs @@ -55,14 +55,14 @@ fn main(host: Iroha, context: Context) { host.submit(&SetKeyValue::trigger( trigger_id.clone(), instructions_metadata_key.clone(), - JsonString::new(&instructions), + JsonValue::new(&instructions), )) .dbg_unwrap(); host.submit(&SetKeyValue::trigger( trigger_id.clone(), votes_metadata_key.clone(), - JsonString::new(&votes), + JsonValue::new(&votes), )) .dbg_unwrap(); @@ -83,7 +83,7 @@ fn main(host: Iroha, context: Context) { host.submit(&SetKeyValue::trigger( trigger_id.clone(), votes_metadata_key.clone(), - JsonString::new(&votes), + JsonValue::new(&votes), )) .dbg_unwrap(); diff --git a/wasm_samples/multisig_register/src/lib.rs b/wasm_samples/multisig_register/src/lib.rs index dc097485829..08b27e42056 100644 --- a/wasm_samples/multisig_register/src/lib.rs +++ b/wasm_samples/multisig_register/src/lib.rs @@ -83,7 +83,7 @@ fn main(host: Iroha, context: Context) { host.submit(&SetKeyValue::trigger( trigger_id, "signatories".parse().unwrap(), - JsonString::new(&args.signatories), + JsonValue::new(&args.signatories), )) .dbg_unwrap(); diff --git a/wasm_samples/query_assets_and_save_cursor/src/lib.rs b/wasm_samples/query_assets_and_save_cursor/src/lib.rs index d7a8784680d..81ab1a299cd 100644 --- a/wasm_samples/query_assets_and_save_cursor/src/lib.rs +++ b/wasm_samples/query_assets_and_save_cursor/src/lib.rs @@ -51,7 +51,7 @@ fn main(host: Iroha, context: Context) { host.submit(&SetKeyValue::account( context.authority, "cursor".parse().unwrap(), - JsonString::new(asset_cursor.cursor), + JsonValue::new(asset_cursor.cursor), )) .dbg_expect("Failed to save cursor to the owner's metadata"); }