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

feat!: identity funding with asset lock special transactions #1510

Merged
merged 56 commits into from
Nov 1, 2023
Merged
Show file tree
Hide file tree
Changes from 26 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
eb98957
refactor: use OutPoint instead of Bytes36
shumkov Oct 18, 2023
c34ba46
chore: get outpoint from payload
shumkov Oct 18, 2023
6bf1220
test: send asset lock transaction
shumkov Oct 19, 2023
45abe20
fix: incorrect output for chain asset lock proof
shumkov Oct 19, 2023
ca1637c
fix: compilation errors in wasm-dpp
shumkov Oct 19, 2023
dff21bc
chore: add asset lock transaction validation
shumkov Oct 19, 2023
ffc0c95
fix(wasm-dpp): compilation error typo
markin-io Oct 19, 2023
3ea2c2f
chore: update dashcore-lib to v0.20.10
markin-io Oct 19, 2023
e5d6377
feat(sdk): create asset lock transaction
markin-io Oct 19, 2023
f85971d
fix: add missing dashcore dependency
markin-io Oct 19, 2023
6306d15
fix(wasm-dpp): test
markin-io Oct 19, 2023
b8c2542
chore: verify state transition signature
shumkov Oct 19, 2023
0f3a473
Merge remote-tracking branch 'origin/feat/process-asset-locks' into f…
shumkov Oct 19, 2023
1c4bbef
fix: hash signature verification
shumkov Oct 19, 2023
5526306
fix: public key signature validation result is ignored
shumkov Oct 19, 2023
7e5ddf1
fix(wasm-dpp): compilation
markin-io Oct 19, 2023
c19a4b8
chore: asset lock proof structure validation
shumkov Oct 19, 2023
7e60430
Merge remote-tracking branch 'origin/feat/process-asset-locks' into f…
shumkov Oct 19, 2023
a200f5b
chore: some missing files
shumkov Oct 19, 2023
55c7bf2
chore: validate state
shumkov Oct 19, 2023
a31ef00
test: fix check_tx tests
shumkov Oct 19, 2023
37eb3a8
chore: set genesis block info
shumkov Oct 19, 2023
8de6b70
test: add verify_instant_lock mock
shumkov Oct 19, 2023
ef38440
style: remove unused import
shumkov Oct 19, 2023
b7d8afc
chore: remove asset lock proof type
shumkov Oct 20, 2023
fbf540d
docs: add docs for asset lock proofs
shumkov Oct 20, 2023
2a4dce1
test: fix fixture
shumkov Oct 20, 2023
ab8d56c
chore: move core expensive operations to very end
shumkov Oct 20, 2023
b157214
fix: action is not required for idenity create and topup
shumkov Oct 20, 2023
e272666
test: fix JS tests
shumkov Oct 20, 2023
b9af33a
test(wasm-dpp): fix asset lock proof tests
markin-io Oct 20, 2023
aaa5368
test(wasm-dpp): fix asset lock proof
markin-io Oct 20, 2023
ef7b753
refactor: use Bytes36 in Drive
shumkov Oct 20, 2023
0d74cf0
fix: CheckCreditPoolDiffForBlock for block failed with bad-cbtx-asse…
shumkov Oct 27, 2023
b53e1f8
Merge branch 'v1.0-dev' into feat/process-asset-locks
shumkov Oct 28, 2023
dfa80fd
fix: can't fetch asset transaction for chain asset lock proof
shumkov Oct 28, 2023
446c0bc
chore: throw JsError in create_instant_asset_lock_proof
shumkov Oct 29, 2023
9dc085f
chore: add log level in test suite config
shumkov Oct 29, 2023
558b1e6
docs: fix ensureFileMountExistsFactory js docs
shumkov Oct 29, 2023
8ea1bdd
chore: temporary use old chain locks
shumkov Oct 29, 2023
a9fa944
chore: handle a right getrawtransaction response
shumkov Oct 29, 2023
c4d74ac
fix: instant lock signature verification
shumkov Oct 29, 2023
b82c18f
chore: remove $ form consensus error messages
shumkov Oct 30, 2023
2de9ee4
fix: invalid getOutPointBuffer
shumkov Oct 30, 2023
5c7ae92
fix: internal error with chain asset lock proof
shumkov Oct 30, 2023
fc08fe1
tests: enabled identity test suite tests
shumkov Oct 30, 2023
cf39d6a
Merge branch 'v1.0-dev' into feat/process-asset-locks
shumkov Oct 30, 2023
4e0eeb6
refactor: init information to genesis block info
shumkov Oct 30, 2023
7b73a06
fix: identity create balance validation
shumkov Oct 30, 2023
6b0e0d4
test: fix wasm-dpp tests
shumkov Oct 31, 2023
078459a
Merge branch 'v1.0-dev' into feat/process-asset-locks
shumkov Oct 31, 2023
f4eb7d1
chore: fix migrations
shumkov Oct 31, 2023
bad0450
tests: disable migration tests
shumkov Oct 31, 2023
6905a64
chore: switch to instant locks version 1
shumkov Oct 31, 2023
58c381f
Merge branch 'v1.0-dev' into feat/process-asset-locks
shumkov Oct 31, 2023
b222dcb
style: fix linter
shumkov Oct 31, 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
26 changes: 13 additions & 13 deletions .pnp.cjs

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

Binary file not shown.
Binary file not shown.
6 changes: 3 additions & 3 deletions Cargo.lock

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

2 changes: 1 addition & 1 deletion packages/bench-suite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
"lint": "eslint ."
},
"dependencies": {
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dpns-contract": "workspace:*",
"@dashevo/dpp": "workspace:*",
"@dashevo/wallet-lib": "workspace:*",
Expand Down
2 changes: 1 addition & 1 deletion packages/dapi/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
"dependencies": {
"@dashevo/bls": "~1.2.9",
"@dashevo/dapi-grpc": "workspace:*",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dashd-rpc": "^18.2.0",
"@dashevo/dpp": "workspace:*",
"@dashevo/grpc-common": "workspace:*",
Expand Down
2 changes: 1 addition & 1 deletion packages/dash-spv/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
"dependencies": {
"@dashevo/dark-gravity-wave": "^1.1.1",
"@dashevo/dash-util": "^2.0.3",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"levelup": "^4.4.0",
"memdown": "^5.1.0",
"wasm-x11-hash": "~0.0.2"
Expand Down
2 changes: 1 addition & 1 deletion packages/dashmate/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@
"homepage": "https://github.com/dashevo/dashmate#readme",
"dependencies": {
"@dashevo/bls": "~1.2.9",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dashd-rpc": "^18.2.0",
"@dashevo/dashpay-contract": "workspace:*",
"@dashevo/docker-compose": "^0.24.4",
Expand Down
2 changes: 1 addition & 1 deletion packages/js-dapi-client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
"dependencies": {
"@dashevo/dapi-grpc": "workspace:*",
"@dashevo/dash-spv": "workspace:*",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dpp": "workspace:*",
"@dashevo/grpc-common": "workspace:*",
"@dashevo/wasm-dpp": "workspace:*",
Expand Down
2 changes: 1 addition & 1 deletion packages/js-dash-sdk/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@
"@dashevo/bls": "~1.2.9",
"@dashevo/dapi-client": "workspace:*",
"@dashevo/dapi-grpc": "workspace:*",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dashpay-contract": "workspace:*",
"@dashevo/dpns-contract": "workspace:*",
"@dashevo/dpp": "workspace:*",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import { PrivateKey, Transaction } from '@dashevo/dashcore-lib';
import {
PrivateKey, Transaction, Script, Address, Opcode,
} from '@dashevo/dashcore-lib';
import { utils } from '@dashevo/wallet-lib';
import { Platform } from './Platform';

Expand Down Expand Up @@ -44,11 +46,35 @@ export async function createAssetLockTransaction(

const selection = utils.coinSelection(utxos, [output]);

const realOutput = {
satoshis: output.satoshis,
script: Script
.buildPublicKeyHashOut(Address.fromString(identityAddress, this.client.network)).toString(),
};

const payload = Transaction.Payload.AssetLockPayload.fromJSON({
version: 1,
creditOutputs: [{
satoshis: realOutput.satoshis,
script: realOutput.script,
}],
});

lockTransaction
// @ts-ignore
.setType(Transaction.TYPES.TRANSACTION_ASSET_LOCK)
.from(selection.utxos)
// eslint-disable-next-line
.addBurnOutput(output.satoshis, assetLockOneTimePublicKey._getID())
.change(changeAddress);
// eslint-disable-next-line
.addOutput(
new Transaction.Output({
satoshis: realOutput.satoshis,
// @ts-ignore
script: new Script().add(Opcode.OP_RETURN).add(Buffer.alloc(0)),
}),
)
.change(changeAddress)
// @ts-ignore
.setExtraPayload(payload);

const utxoAddresses = selection.utxos.map((utxo: any) => utxo.address.toString());

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ export default async function register(
const { identity, identityCreateTransition, identityIndex } = await this.identities.utils
.createIdentityCreateTransition(assetLockProof, assetLockPrivateKey);

this.logger.silly(`[Identity#register] Created IdentityCreateTransition with asset lock tx "${assetLockTransaction.hash}"`);
this.logger.silly(`[Identity#register] Created IdentityCreateTransition with identity id "${identity.getId()}" using asset lock tx "${assetLockTransaction.hash}" `);

// Skipping validation because it's already done in createIdentityCreateTransition
await broadcastStateTransition(this, identityCreateTransition, {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,6 @@ export async function register(this: Platform,
const [label] = nameLabels;
const normalizedLabel = convertToHomographSafeChars(label);

console.log('Label', label, 'normalized', normalizedLabel);

const preorderSalt = crypto.randomBytes(32);

const isSecondLevelDomain = normalizedParentDomainName.length > 0;
Expand Down
2 changes: 1 addition & 1 deletion packages/js-dpp/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@
"dependencies": {
"@apidevtools/json-schema-ref-parser": "^8.0.0",
"@dashevo/bls": "~1.2.9",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dashpay-contract": "workspace:*",
"@dashevo/dpns-contract": "workspace:*",
"@dashevo/feature-flags-contract": "workspace:*",
Expand Down
2 changes: 1 addition & 1 deletion packages/platform-test-suite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
"homepage": "https://github.com/dashevo/platform-test-suite#readme",
"dependencies": {
"@dashevo/dapi-client": "workspace:*",
"@dashevo/dashcore-lib": "~0.20.9",
"@dashevo/dashcore-lib": "~0.20.10",
"@dashevo/dpns-contract": "workspace:*",
"@dashevo/dpp": "workspace:*",
"@dashevo/feature-flags-contract": "workspace:*",
Expand Down
13 changes: 11 additions & 2 deletions packages/rs-dpp/src/errors/protocol_error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@ use crate::state_transition::errors::{
StateTransitionError, StateTransitionIsNotSignedError, WrongPublicKeyPurposeError,
};
use crate::{
CompatibleProtocolVersionIsNotDefinedError, DashPlatformProtocolInitError, NonConsensusError,
SerdeParsingError,
CompatibleProtocolVersionIsNotDefinedError, DashPlatformProtocolInitError,
InvalidVectorSizeError, NonConsensusError, SerdeParsingError,
};

use dashcore::consensus::encode::Error as DashCoreError;
Expand Down Expand Up @@ -207,6 +207,9 @@ pub enum ProtocolError {

#[error("critical corrupted credits code execution: {0}")]
CriticalCorruptedCreditsCodeExecution(String),

#[error(transparent)]
InvalidVectorSizeError(InvalidVectorSizeError),
}

impl From<&str> for ProtocolError {
Expand Down Expand Up @@ -244,3 +247,9 @@ impl From<DashPlatformProtocolInitError> for ProtocolError {
ProtocolError::Generic(e.to_string())
}
}

impl From<InvalidVectorSizeError> for ProtocolError {
fn from(err: InvalidVectorSizeError) -> Self {
Self::InvalidVectorSizeError(err)
}
}
1 change: 1 addition & 0 deletions packages/rs-dpp/src/identity/identity_factory.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use crate::identity::state_transition::asset_lock_proof::chain::ChainAssetLockProof;
use crate::identity::state_transition::asset_lock_proof::{AssetLockProof, InstantAssetLockProof};
use crate::identity::state_transition::AssetLockProved;
#[cfg(all(feature = "state-transitions", feature = "client"))]
use crate::identity::{IdentityV0, TimestampMillis};

Expand Down
Original file line number Diff line number Diff line change
@@ -1,20 +1,25 @@
use platform_value::{Bytes36, Value};
use serde::{Deserialize, Serialize};
use ::serde::{Deserialize, Serialize};
use platform_value::Value;
use std::convert::TryFrom;

use crate::{
errors::NonConsensusError, identifier::Identifier, util::hash::hash_to_vec,
util::vec::vec_to_array, ProtocolError,
identifier::Identifier, util::hash::hash_to_vec, util::vec::vec_to_array, ProtocolError,
};
pub use bincode::{Decode, Encode};
use dashcore::consensus::Encodable;
use dashcore::OutPoint;

#[derive(Clone, PartialEq, Eq, Debug, Serialize, Deserialize, Encode, Decode)]
/// Instant Asset Lock Proof is a part of Identity Create and Identity Topup
/// transitions. It is a proof that specific output of dash is locked in credits
/// pull and the transitions can mint credits and populate identity's balance.
/// To prove that the output is locked, a height where transaction was chain locked is provided.
#[derive(Clone, PartialEq, Eq, Debug, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ChainAssetLockProof {
#[serde(rename = "type")]
asset_lock_type: u8,
/// Core height on which the asset lock transaction was chain locked or higher
pub core_chain_locked_height: u32,
pub out_point: Bytes36,
/// A reference to Asset Lock Special Transaction ID and output index in the payload
pub out_point: OutPoint,
}

impl TryFrom<Value> for ChainAssetLockProof {
Expand All @@ -34,21 +39,23 @@ impl ChainAssetLockProof {

pub fn new(core_chain_locked_height: u32, out_point: [u8; 36]) -> Self {
Self {
// TODO: change to const
asset_lock_type: 1,
core_chain_locked_height,
out_point: Bytes36::new(out_point),
out_point: OutPoint::from(out_point),
}
}

/// Get proof type
pub fn asset_lock_type() -> u8 {
1
}

/// Create identifier
pub fn create_identifier(&self) -> Result<Identifier, NonConsensusError> {
let array = vec_to_array(hash_to_vec(self.out_point.as_slice()).as_ref())?;
Ok(Identifier::new(array))
pub fn create_identifier(&self) -> Result<Identifier, ProtocolError> {
let mut outpoint_bytes = Vec::new();

self.out_point
.consensus_encode(&mut outpoint_bytes)
.map_err(|e| ProtocolError::EncodingError(e.to_string()))?;

let hash = hash_to_vec(&outpoint_bytes);

let hash_array = vec_to_array(&hash)?;

Ok(Identifier::new(hash_array))
}
}
Original file line number Diff line number Diff line change
@@ -1,3 +1,2 @@
pub use chain_asset_lock_proof::*;

mod chain_asset_lock_proof;
Loading
Loading