-
Notifications
You must be signed in to change notification settings - Fork 39
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
feat(sdk): implement document transfers in WASM DPP #2406
base: v2.0-dev
Are you sure you want to change the base?
Changes from all commits
3b511ce
d3383a1
fae5915
fd48355
e17f1a1
5fd4329
10998f7
fbe5dbc
8f79b69
9925a68
e8defe8
1f0f7c6
43cc7f1
cf99fe6
44df2e6
5894a7f
d7d5d90
2131f00
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,33 @@ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
import { Identity, ExtendedDocument } from '@dashevo/wasm-dpp'; | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
import { Platform } from '../../Platform'; | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
import broadcastStateTransition from '../../broadcastStateTransition'; | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
import { signStateTransition } from '../../signStateTransition'; | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
/** | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* Transfer document in the platform | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* @param {Platform} this - bound instance class | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* @param {ExtendedDocument} document - document from the DAPI | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* @param {Identifier} receiver - identifier of the document recipient ownership | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
* @param {Identifier} sender - identifier of the document owner | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
*/ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
export async function transfer( | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
this: Platform, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
document: ExtendedDocument, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
receiver: Identity, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sender: Identity, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
): Promise<any> { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
this.logger.debug(`[Document#transfer] Transfer document ${document.getId().toString()} from ${sender.getId().toString} to {${receiver.getId().toString()}`); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
await this.initialize(); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
const identityContractNonce = await this.nonceManager | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
.bumpIdentityContractNonce(sender.getId(), document.getDataContractId()); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
const documentsBatchTransition = document | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
.createTransferStateTransition(receiver.getId(), BigInt(identityContractNonce)); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
await signStateTransition(this, documentsBatchTransition, sender, 1); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
await broadcastStateTransition(this, documentsBatchTransition); | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Comment on lines
+13
to
+30
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🛠️ Refactor suggestion Add input validation for required parameters The function should validate its input parameters before proceeding with the transfer operation. export async function transfer(
this: Platform,
document: ExtendedDocument,
receiver: Identity,
sender: Identity,
): Promise<any> {
+ if (!document || !receiver || !sender) {
+ throw new Error('Document, receiver, and sender are required parameters');
+ }
+
+ if (sender.getId().equals(receiver.getId())) {
+ throw new Error('Sender and receiver cannot be the same identity');
+ }
+
this.logger.debug(`[Document#transfer] Transfer document ${document.getId().toString()}... 📝 Committable suggestion
Suggested change
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
export default transfer; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,8 @@ | ||
use dpp::document::{ | ||
DocumentV0Getters, DocumentV0Setters, ExtendedDocument, EXTENDED_DOCUMENT_IDENTIFIER_FIELDS, | ||
}; | ||
use dpp::document::{DocumentV0Getters, DocumentV0Setters, ExtendedDocument, EXTENDED_DOCUMENT_IDENTIFIER_FIELDS}; | ||
use serde_json::Value as JsonValue; | ||
|
||
use dpp::platform_value::{Bytes32, Value}; | ||
use dpp::prelude::{Identifier, Revision, TimestampMillis}; | ||
use dpp::prelude::{Identifier, IdentityNonce, Revision, TimestampMillis, UserFeeIncrease}; | ||
Check warning on line 5 in packages/wasm-dpp/src/document/extended_document.rs GitHub Actions / Rust packages (wasm-dpp) / Lintingunused import: `UserFeeIncrease`
|
||
|
||
use dpp::util::json_value::JsonValueExt; | ||
|
||
|
@@ -16,12 +14,15 @@ | |
use serde::{Deserialize, Serialize}; | ||
use std::convert::TryInto; | ||
use wasm_bindgen::prelude::*; | ||
use dpp::state_transition::documents_batch_transition::document_transition::DocumentTransferTransition; | ||
use dpp::state_transition::documents_batch_transition::{DocumentsBatchTransition, DocumentsBatchTransitionV0}; | ||
|
||
use crate::buffer::Buffer; | ||
use crate::data_contract::DataContractWasm; | ||
#[allow(deprecated)] // BinaryType is unsed in unused code below | ||
use crate::document::BinaryType; | ||
use crate::document::{ConversionOptions, DocumentWasm}; | ||
use crate::document_batch_transition::DocumentsBatchTransitionWasm; | ||
use crate::errors::RustConversionError; | ||
use crate::identifier::{identifier_from_js_value, IdentifierWrapper}; | ||
use crate::lodash::lodash_set; | ||
|
@@ -235,6 +236,33 @@ | |
.set_created_at(ts.map(|t| t.get_time() as TimestampMillis)); | ||
} | ||
|
||
#[wasm_bindgen(js_name=createTransferStateTransition)] | ||
pub fn create_transfer_state_transition(&mut self, recipient: IdentifierWrapper, identity_contract_nonce: IdentityNonce) -> DocumentsBatchTransitionWasm { | ||
let mut cloned_document = self.0.document().clone(); | ||
|
||
cloned_document.set_revision(Some(cloned_document.revision().unwrap() + 1)); | ||
|
||
let transfer_transition = DocumentTransferTransition::from_document( | ||
cloned_document, | ||
self.0.document_type().unwrap(), | ||
identity_contract_nonce, | ||
recipient.into(), | ||
PlatformVersion::latest(), | ||
None, | ||
None, | ||
).unwrap(); | ||
|
||
let documents_batch_transition: DocumentsBatchTransition = DocumentsBatchTransitionV0 { | ||
owner_id: self.0.owner_id(), | ||
transitions: vec![transfer_transition.into()], | ||
user_fee_increase: Default::default(), | ||
signature_public_key_id: Default::default(), | ||
signature: Default::default(), | ||
}.into(); | ||
|
||
documents_batch_transition.into() | ||
} | ||
Comment on lines
+239
to
+264
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Check for None revision before incrementing. let mut cloned_document = self.0.document().clone();
- cloned_document.set_revision(Some(cloned_document.revision().unwrap() + 1));
+ if let Some(current_revision) = cloned_document.revision() {
+ cloned_document.set_revision(Some(current_revision + 1));
+ } else {
+ // Decide how to handle the absence of a revision, e.g., return an error or set a default revision
+ return Err(JsValue::from_str("Document is missing a revision"));
+ }
|
||
|
||
#[wasm_bindgen(js_name=setUpdatedAt)] | ||
pub fn set_updated_at(&mut self, ts: Option<js_sys::Date>) { | ||
self.0 | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
use wasm_bindgen::prelude::wasm_bindgen; | ||
use dpp::state_transition::documents_batch_transition::document_transition::DocumentTransferTransition; | ||
|
||
#[wasm_bindgen(js_name=DocumentTransferTransition)] | ||
#[derive(Debug, Clone)] | ||
pub struct DocumentTransferTransitionWasm { | ||
inner: DocumentTransferTransition, | ||
} | ||
|
||
impl From<DocumentTransferTransition> for DocumentTransferTransitionWasm { | ||
fn from(v: DocumentTransferTransition) -> Self { | ||
Self { inner: v } | ||
} | ||
} | ||
|
||
impl From<DocumentTransferTransitionWasm> for DocumentTransferTransition { | ||
fn from(v: DocumentTransferTransitionWasm) -> Self { | ||
v.inner | ||
} | ||
} | ||
|
||
#[wasm_bindgen(js_class=DocumentTransferTransition)] | ||
Check warning on line 22 in packages/wasm-dpp/src/document/state_transition/document_batch_transition/document_transition/document_transfer_transition.rs GitHub Actions / Rust packages (wasm-dpp) / Lintingunused variable: `js_class`
|
||
impl DocumentTransferTransitionWasm { | ||
} | ||
|
||
impl DocumentTransferTransitionWasm { | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Add error handling for external calls
The function makes several external calls without proper error handling, which could lead to unhandled rejections.
📝 Committable suggestion