From 960845df2ac6b4474dcf3c80249447566e145f81 Mon Sep 17 00:00:00 2001 From: Mario Sarcevic Date: Wed, 30 Oct 2024 16:57:48 +0100 Subject: [PATCH 1/8] feat(tooling-sdk): TS SDK remove transactionEffectsV1 and rename transactionEffectsV2 to V1 [WiP] --- sdk/typescript/src/bcs/effects.ts | 23 ++----------------- .../src/transactions/ObjectCache.ts | 4 ++-- .../src/transactions/executor/caching.ts | 2 +- .../src/transactions/executor/parallel.ts | 8 +++---- .../src/transactions/executor/serial.ts | 8 +++---- 5 files changed, 13 insertions(+), 32 deletions(-) diff --git a/sdk/typescript/src/bcs/effects.ts b/sdk/typescript/src/bcs/effects.ts index 08cc8d8fe06..5c25d611bca 100644 --- a/sdk/typescript/src/bcs/effects.ts +++ b/sdk/typescript/src/bcs/effects.ts @@ -4,7 +4,7 @@ import { bcs } from '@iota/bcs'; -import { Address, ObjectDigest, IotaObjectRef } from './bcs.js'; +import { Address, ObjectDigest } from './bcs.js'; const PackageUpgradeError = bcs.enum('PackageUpgradeError', { UnableToFetchPackage: bcs.struct('UnableToFetchPackage', { packageId: Address }), @@ -132,24 +132,6 @@ const Owner = bcs.enum('Owner', { Immutable: null, }); -const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { - status: ExecutionStatus, - executedEpoch: bcs.u64(), - gasUsed: GasCostSummary, - modifiedAtVersions: bcs.vector(bcs.tuple([Address, bcs.u64()])), - sharedObjects: bcs.vector(IotaObjectRef), - transactionDigest: ObjectDigest, - created: bcs.vector(bcs.tuple([IotaObjectRef, Owner])), - mutated: bcs.vector(bcs.tuple([IotaObjectRef, Owner])), - unwrapped: bcs.vector(bcs.tuple([IotaObjectRef, Owner])), - deleted: bcs.vector(IotaObjectRef), - unwrappedThenDeleted: bcs.vector(IotaObjectRef), - wrapped: bcs.vector(IotaObjectRef), - gasObject: bcs.tuple([IotaObjectRef, Owner]), - eventsDigest: bcs.option(ObjectDigest), - dependencies: bcs.vector(ObjectDigest), -}); - const VersionDigest = bcs.tuple([bcs.u64(), ObjectDigest]); const ObjectIn = bcs.enum('ObjectIn', { @@ -183,7 +165,7 @@ const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { PerEpochConfig: null, }); -const TransactionEffectsV2 = bcs.struct('TransactionEffectsV2', { +const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { status: ExecutionStatus, executedEpoch: bcs.u64(), gasUsed: GasCostSummary, @@ -199,5 +181,4 @@ const TransactionEffectsV2 = bcs.struct('TransactionEffectsV2', { export const TransactionEffects = bcs.enum('TransactionEffects', { V1: TransactionEffectsV1, - V2: TransactionEffectsV2, }); diff --git a/sdk/typescript/src/transactions/ObjectCache.ts b/sdk/typescript/src/transactions/ObjectCache.ts index 6ce896a5d82..f33455d6304 100644 --- a/sdk/typescript/src/transactions/ObjectCache.ts +++ b/sdk/typescript/src/transactions/ObjectCache.ts @@ -267,11 +267,11 @@ export class ObjectCache { } async applyEffects(effects: typeof bcs.TransactionEffects.$inferType) { - if (!effects.V2) { + if (!effects.V1) { throw new Error(`Unsupported transaction effects version ${effects.$kind}`); } - const { lamportVersion, changedObjects } = effects.V2; + const { lamportVersion, changedObjects } = effects.V1; const deletedIds: string[] = []; const addedObjects: ObjectCacheEntry[] = []; diff --git a/sdk/typescript/src/transactions/executor/caching.ts b/sdk/typescript/src/transactions/executor/caching.ts index 6db0f214b1e..a57c342eabe 100644 --- a/sdk/typescript/src/transactions/executor/caching.ts +++ b/sdk/typescript/src/transactions/executor/caching.ts @@ -99,7 +99,7 @@ export class CachingTransactionExecutor { } async applyEffects(effects: typeof bcs.TransactionEffects.$inferType) { - this.#lastDigest = effects.V2?.transactionDigest ?? null; + this.#lastDigest = effects.V1?.transactionDigest ?? null; await this.cache.applyEffects(effects); } diff --git a/sdk/typescript/src/transactions/executor/parallel.ts b/sdk/typescript/src/transactions/executor/parallel.ts index 1d1e797f48f..36cf8455056 100644 --- a/sdk/typescript/src/transactions/executor/parallel.ts +++ b/sdk/typescript/src/transactions/executor/parallel.ts @@ -228,7 +228,7 @@ export class ParallelTransactionExecutor { const effects = bcs.TransactionEffects.parse(effectsBytes); const gasResult = getGasCoinFromEffects(effects); - const gasUsed = effects.V2?.gasUsed; + const gasUsed = effects.V1?.gasUsed; if (gasCoin && gasUsed && gasResult.owner === this.#signer.toIotaAddress()) { const totalUsed = @@ -428,14 +428,14 @@ export class ParallelTransactionExecutor { }); const effects = bcs.TransactionEffects.parse(Uint8Array.from(result.rawEffects!)); - effects.V2?.changedObjects.forEach(([id, { outputState }], i) => { - if (i === effects.V2?.gasObjectIndex || !outputState.ObjectWrite) { + effects.V1?.changedObjects.forEach(([id, { outputState }], i) => { + if (i === effects.V1?.gasObjectIndex || !outputState.ObjectWrite) { return; } this.#coinPool.push({ id, - version: effects.V2!.lamportVersion, + version: effects.V1!.lamportVersion, digest: outputState.ObjectWrite[0], balance: BigInt(this.#initialCoinBalance), }); diff --git a/sdk/typescript/src/transactions/executor/serial.ts b/sdk/typescript/src/transactions/executor/serial.ts index 8c0d92fef79..c11e6878b4c 100644 --- a/sdk/typescript/src/transactions/executor/serial.ts +++ b/sdk/typescript/src/transactions/executor/serial.ts @@ -41,7 +41,7 @@ export class SerialTransactionExecutor { } #cacheGasCoin = async (effects: typeof bcs.TransactionEffects.$inferType) => { - if (!effects.V2) { + if (!effects.V1) { return; } @@ -117,11 +117,11 @@ export class SerialTransactionExecutor { } export function getGasCoinFromEffects(effects: typeof bcs.TransactionEffects.$inferType) { - if (!effects.V2) { + if (!effects.V1) { throw new Error('Unexpected effects version'); } - const gasObjectChange = effects.V2.changedObjects[effects.V2.gasObjectIndex!]; + const gasObjectChange = effects.V1.changedObjects[effects.V1.gasObjectIndex!]; if (!gasObjectChange) { throw new Error('Gas object not found in effects'); @@ -139,7 +139,7 @@ export function getGasCoinFromEffects(effects: typeof bcs.TransactionEffects.$in ref: { objectId, digest, - version: effects.V2.lamportVersion, + version: effects.V1.lamportVersion, }, owner: owner.AddressOwner || owner.ObjectOwner!, }; From 8b0186d022dcf036c1791ac4b1ed285aa6fc0353 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bego=C3=B1a=20Alvarez?= Date: Thu, 31 Oct 2024 13:22:49 +0100 Subject: [PATCH 2/8] tmp --- .../src/mappers/transaction-block.ts | 377 +++++++++--------- 1 file changed, 180 insertions(+), 197 deletions(-) diff --git a/sdk/graphql-transport/src/mappers/transaction-block.ts b/sdk/graphql-transport/src/mappers/transaction-block.ts index 02f82f95c49..0726030b09f 100644 --- a/sdk/graphql-transport/src/mappers/transaction-block.ts +++ b/sdk/graphql-transport/src/mappers/transaction-block.ts @@ -351,250 +351,233 @@ const ADDRESS_ZERO = normalizeIotaAddress('0x0'); export function mapEffects(data: string): IotaTransactionBlockResponse['effects'] { const effects = bcs.TransactionEffects.parse(fromB64(data)); - let effectsV1 = effects.V1; - - if (effects.V2) { - const sharedObjects = effects.V2.unchangedSharedObjects.map(([id, sharedObject]) => { - switch (sharedObject.$kind) { - case 'ReadOnlyRoot': - return { - objectId: id, - version: Number(sharedObject.ReadOnlyRoot[0]) as unknown as string, - digest: sharedObject.ReadOnlyRoot[1], - }; - case 'MutateDeleted': - return { - objectId: id, - version: Number(sharedObject.MutateDeleted) as unknown as string, - digest: OBJECT_DIGEST_DELETED, - }; - case 'ReadDeleted': - return { - objectId: id, - version: Number(sharedObject.ReadDeleted) as unknown as string, - digest: OBJECT_DIGEST_DELETED, - }; - default: - throw new Error(`Unknown shared object type: ${sharedObject}`); - } - }); + // let effectsV1 = effects.V1; - effects.V2.changedObjects - .filter(([_id, change]) => change.inputState.Exist?.[1].Shared) - .forEach(([id, change]) => { - sharedObjects.push({ + const sharedObjects = effects.V1.unchangedSharedObjects.map(([id, sharedObject]) => { + switch (sharedObject.$kind) { + case 'ReadOnlyRoot': + return { objectId: id, - version: Number(change.inputState.Exist![0][0]) as unknown as string, - digest: change.inputState.Exist![0][1], - }); - }); - - const gasObject = - effects.V2.gasObjectIndex != null - ? effects.V2.changedObjects[effects.V2.gasObjectIndex] - : null; - - effectsV1 = { - status: effects.V2.status, - executedEpoch: effects.V2.executedEpoch, - gasUsed: effects.V2.gasUsed, - modifiedAtVersions: effects.V2.changedObjects - .filter(([_id, change]) => change.inputState.Exist) - .map(([id, change]) => [id, change.inputState.Exist![0][0]] as const), - sharedObjects, - transactionDigest: effects.V2.transactionDigest, - created: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.NotExist && - (change.outputState.ObjectWrite || change.outputState.PackageWrite) && - change.idOperation.Created, - ) - .map(([objectId, change]) => - change.outputState.PackageWrite - ? ([ - { - objectId, - version: Number( - change.outputState.PackageWrite[0], - ) as unknown as string, - digest: change.outputState.PackageWrite[1], - }, - { $kind: 'Immutable', Immutable: true }, - ] as const) - : ([ - { - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, - digest: change.outputState.ObjectWrite![0], - }, - change.outputState.ObjectWrite![1], - ] as const), - ), - mutated: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.Exist && - (change.outputState.ObjectWrite || change.outputState.PackageWrite), - ) - .map(([objectId, change]) => [ - change.outputState.PackageWrite - ? { - objectId, - version: Number( - change.outputState.PackageWrite[0], - ) as unknown as string, - digest: change.outputState.PackageWrite[1], - } - : { - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, - digest: change.outputState.ObjectWrite![0], - }, - change.outputState.ObjectWrite - ? change.outputState.ObjectWrite[1] - : { $kind: 'Immutable', Immutable: true }, - ]), - unwrapped: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.NotExist && - change.outputState.ObjectWrite && - change.idOperation.None, - ) - .map(([objectId, change]) => [ - { - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, - digest: change.outputState.ObjectWrite![0], - }, - change.outputState.ObjectWrite![1], - ]), - deleted: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.Exist && - change.outputState.NotExist && - change.idOperation.Deleted, - ) - .map(([objectId, _change]) => ({ - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, + version: Number(sharedObject.ReadOnlyRoot[0]) as unknown as string, + digest: sharedObject.ReadOnlyRoot[1], + }; + case 'MutateDeleted': + return { + objectId: id, + version: Number(sharedObject.MutateDeleted) as unknown as string, digest: OBJECT_DIGEST_DELETED, - })), - unwrappedThenDeleted: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.NotExist && - change.outputState.NotExist && - change.idOperation.Deleted, - ) - .map(([objectId, _change]) => ({ - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, + }; + case 'ReadDeleted': + return { + objectId: id, + version: Number(sharedObject.ReadDeleted) as unknown as string, digest: OBJECT_DIGEST_DELETED, - })), - wrapped: effects.V2.changedObjects - .filter( - ([_id, change]) => - change.inputState.Exist && - change.outputState.NotExist && - change.idOperation.None, - ) - .map(([objectId, _change]) => ({ - objectId, - version: Number(effects.V2.lamportVersion) as unknown as string, - digest: OBJECT_DIGEST_WRAPPED, - })), - gasObject: gasObject - ? [ - { - objectId: gasObject[0], - digest: gasObject[1].outputState.ObjectWrite![0], - version: Number(effects.V2.lamportVersion) as unknown as string, - }, - gasObject[1].outputState.ObjectWrite![1], - ] - : [ + }; + default: + throw new Error(`Unknown shared object type: ${sharedObject}`); + } + }); + + effects.V1.changedObjects + .filter(([_id, change]) => change.inputState.Exist?.[1].Shared) + .forEach(([id, change]) => { + sharedObjects.push({ + objectId: id, + version: Number(change.inputState.Exist![0][0]) as unknown as string, + digest: change.inputState.Exist![0][1], + }); + }); + + const modifiedAtVersions = effects.V1.changedObjects + .filter(([_id, change]) => change.inputState.Exist) + .map(([id, change]) => [id, change.inputState.Exist![0][0]] as const); + + const created = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.NotExist && + (change.outputState.ObjectWrite || change.outputState.PackageWrite) && + change.idOperation.Created, + ) + .map(([objectId, change]) => + change.outputState.PackageWrite + ? ([ { - objectId: ADDRESS_ZERO, - version: '0', - digest: OBJECT_DIGEST_ZERO, + objectId, + version: Number(change.outputState.PackageWrite[0]) as unknown as string, + digest: change.outputState.PackageWrite[1], }, + { $kind: 'Immutable', Immutable: true }, + ] as const) + : ([ { - $kind: 'AddressOwner', - AddressOwner: ADDRESS_ZERO, + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: change.outputState.ObjectWrite![0], }, - ], - eventsDigest: effects.V2.eventsDigest, - dependencies: effects.V2.dependencies, - }; - } + change.outputState.ObjectWrite![1], + ] as const), + ); - if (!effectsV1) { - throw new Error('Invalid effects'); - } + const mutated = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.Exist && + (change.outputState.ObjectWrite || change.outputState.PackageWrite), + ) + .map(([objectId, change]) => [ + change.outputState.PackageWrite + ? { + objectId, + version: Number(change.outputState.PackageWrite[0]) as unknown as string, + digest: change.outputState.PackageWrite[1], + } + : { + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: change.outputState.ObjectWrite![0], + }, + change.outputState.ObjectWrite + ? change.outputState.ObjectWrite[1] + : { $kind: 'Immutable', Immutable: true }, + ]); + const unwrapped = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.NotExist && + change.outputState.ObjectWrite && + change.idOperation.None, + ) + .map(([objectId, change]) => [ + { + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: change.outputState.ObjectWrite![0], + }, + change.outputState.ObjectWrite![1], + ]); + const deleted = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.Exist && + change.outputState.NotExist && + change.idOperation.Deleted, + ) + .map(([objectId, _change]) => ({ + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: OBJECT_DIGEST_DELETED, + })); + const unwrappedThenDeleted = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.NotExist && + change.outputState.NotExist && + change.idOperation.Deleted, + ) + .map(([objectId, _change]) => ({ + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: OBJECT_DIGEST_DELETED, + })); + + const wrapped = effects.V1.changedObjects + .filter( + ([_id, change]) => + change.inputState.Exist && change.outputState.NotExist && change.idOperation.None, + ) + .map(([objectId, _change]) => ({ + objectId, + version: Number(effects.V1.lamportVersion) as unknown as string, + digest: OBJECT_DIGEST_WRAPPED, + })); + + const gasObjectFromV1 = + effects.V1.gasObjectIndex != null + ? effects.V1.changedObjects[effects.V1.gasObjectIndex] + : null; + + const gasObject = gasObjectFromV1 + ? [ + { + objectId: gasObjectFromV1[0], + digest: gasObjectFromV1[1].outputState.ObjectWrite![0], + version: Number(effects.V1.lamportVersion) as unknown as string, + }, + gasObjectFromV1[1].outputState.ObjectWrite![1], + ] + : [ + { + objectId: ADDRESS_ZERO, + version: '0', + digest: OBJECT_DIGEST_ZERO, + }, + { + $kind: 'AddressOwner', + AddressOwner: ADDRESS_ZERO, + }, + ]; return { messageVersion: 'v1', - status: effectsV1.status.Success + status: effects.V1.status.Success ? { status: 'success', } : { status: 'failure', // TODO: we don't have the error message from bcs effects - error: effectsV1.status.$kind, + error: effects.V1.status.$kind, }, - executedEpoch: effectsV1.executedEpoch, - gasUsed: effectsV1.gasUsed, - modifiedAtVersions: effectsV1.modifiedAtVersions.map(([objectId, sequenceNumber]) => ({ + executedEpoch: effects.V1.executedEpoch, + gasUsed: effects.V1.gasUsed, + modifiedAtVersions: modifiedAtVersions.map(([objectId, sequenceNumber]) => ({ objectId, sequenceNumber, })), - ...(effectsV1.sharedObjects.length === 0 ? {} : { sharedObjects: effectsV1.sharedObjects }), - transactionDigest: effectsV1.transactionDigest, - ...(effectsV1.created.length === 0 + ...(sharedObjects.length === 0 ? {} : { sharedObjects }), + transactionDigest: effects.V1.transactionDigest, + ...(created.length === 0 ? {} : { - created: effectsV1.created.map(([reference, owner]) => ({ + created: created.map(([reference, owner]) => ({ reference, owner: mapEffectsOwner(owner), })), }), - ...(effectsV1.mutated.length === 0 + ...(mutated.length === 0 ? {} : { - mutated: effectsV1.mutated.map(([reference, owner]) => ({ + mutated: mutated.map(([reference, owner]) => ({ reference, owner: mapEffectsOwner(owner), })), }), - ...(effectsV1.unwrapped.length === 0 + ...(unwrapped.length === 0 ? {} : { unwrapped: - effectsV1.unwrapped.length === 0 + unwrapped.length === 0 ? undefined - : effectsV1.unwrapped.map(([reference, owner]) => ({ + : unwrapped.map(([reference, owner]) => ({ reference, owner: mapEffectsOwner(owner), })), }), - ...(effectsV1.deleted.length === 0 ? {} : { deleted: effectsV1.deleted }), - ...(effectsV1.unwrappedThenDeleted.length === 0 + ...(deleted.length === 0 ? {} : { deleted: deleted }), + ...(unwrappedThenDeleted.length === 0 ? {} - : { unwrappedThenDeleted: effectsV1.unwrappedThenDeleted }), - ...(effectsV1.wrapped.length === 0 ? {} : { wrapped: effectsV1.wrapped }), + : { unwrappedThenDeleted: unwrappedThenDeleted }), + ...(wrapped.length === 0 ? {} : { wrapped: wrapped }), gasObject: { - reference: effectsV1.gasObject[0], - owner: mapEffectsOwner(effectsV1.gasObject[1]), + reference: gasObject[0], + owner: mapEffectsOwner(gasObject[1]), }, - ...(effectsV1.eventsDigest ? { eventsDigest: effectsV1.eventsDigest } : {}), - dependencies: effectsV1.dependencies, + ...(effects.V1.eventsDigest ? { eventsDigest: effects.V1.eventsDigest } : {}), + dependencies: effects.V1.dependencies, }; - function mapEffectsOwner(owner: NonNullable['gasObject'][1]) { + function mapEffectsOwner(owner: NonNullable[1]) { if (owner.Immutable) { return 'Immutable'; } else if (owner.Shared) { From 2faf9f5c8d9a0c0f6ea7c23cf5282b52dd115eb3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bego=C3=B1a=20Alvarez?= Date: Thu, 31 Oct 2024 14:19:12 +0100 Subject: [PATCH 3/8] wip: no errors --- .../src/mappers/transaction-block.ts | 22 ++++++++----- sdk/typescript/src/bcs/effects.ts | 32 +++++++++---------- 2 files changed, 30 insertions(+), 24 deletions(-) diff --git a/sdk/graphql-transport/src/mappers/transaction-block.ts b/sdk/graphql-transport/src/mappers/transaction-block.ts index 0726030b09f..02a86e2d619 100644 --- a/sdk/graphql-transport/src/mappers/transaction-block.ts +++ b/sdk/graphql-transport/src/mappers/transaction-block.ts @@ -14,8 +14,10 @@ import type { IotaTransactionBlockResponse, IotaTransactionBlockResponseOptions, } from '@iota/iota-sdk/client'; +import type { IotaObjectRef } from '@iota/iota-sdk/client'; import { normalizeIotaAddress } from '@iota/iota-sdk/utils'; +import type { ObjectOut } from '@iota/iota-sdk/src/bcs/effects.js'; import type { Rpc_Transaction_FieldsFragment } from '../generated/queries.js'; import { toShortTypeString } from './util.js'; @@ -351,7 +353,11 @@ const ADDRESS_ZERO = normalizeIotaAddress('0x0'); export function mapEffects(data: string): IotaTransactionBlockResponse['effects'] { const effects = bcs.TransactionEffects.parse(fromB64(data)); - // let effectsV1 = effects.V1; + type Things = typeof ObjectOut; + + type Stuff = Things['$inferType']['ObjectWrite']; //Things['ObjectWrite']; + + type Caracola = Exclude[1]; const sharedObjects = effects.V1.unchangedSharedObjects.map(([id, sharedObject]) => { switch (sharedObject.$kind) { @@ -419,7 +425,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ] as const), ); - const mutated = effects.V1.changedObjects + const mutated: Array<[IotaObjectRef, Caracola]> = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.Exist && @@ -441,7 +447,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? change.outputState.ObjectWrite[1] : { $kind: 'Immutable', Immutable: true }, ]); - const unwrapped = effects.V1.changedObjects + const unwrapped: Array<[IotaObjectRef, Caracola]> = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.NotExist && @@ -456,7 +462,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' }, change.outputState.ObjectWrite![1], ]); - const deleted = effects.V1.changedObjects + const deleted: Array = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.Exist && @@ -497,7 +503,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? effects.V1.changedObjects[effects.V1.gasObjectIndex] : null; - const gasObject = gasObjectFromV1 + const gasObject: [IotaObjectRef, Caracola] = gasObjectFromV1 ? [ { objectId: gasObjectFromV1[0], @@ -550,7 +556,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' : { mutated: mutated.map(([reference, owner]) => ({ reference, - owner: mapEffectsOwner(owner), + owner: mapEffectsOwner(owner as Caracola), })), }), ...(unwrapped.length === 0 @@ -561,7 +567,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? undefined : unwrapped.map(([reference, owner]) => ({ reference, - owner: mapEffectsOwner(owner), + owner: mapEffectsOwner(owner as Caracola), })), }), ...(deleted.length === 0 ? {} : { deleted: deleted }), @@ -577,7 +583,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' dependencies: effects.V1.dependencies, }; - function mapEffectsOwner(owner: NonNullable[1]) { + function mapEffectsOwner(owner: NonNullable) { if (owner.Immutable) { return 'Immutable'; } else if (owner.Shared) { diff --git a/sdk/typescript/src/bcs/effects.ts b/sdk/typescript/src/bcs/effects.ts index 5c25d611bca..c19b2add487 100644 --- a/sdk/typescript/src/bcs/effects.ts +++ b/sdk/typescript/src/bcs/effects.ts @@ -6,7 +6,7 @@ import { bcs } from '@iota/bcs'; import { Address, ObjectDigest } from './bcs.js'; -const PackageUpgradeError = bcs.enum('PackageUpgradeError', { +export const PackageUpgradeError = bcs.enum('PackageUpgradeError', { UnableToFetchPackage: bcs.struct('UnableToFetchPackage', { packageId: Address }), NotAPackage: bcs.struct('NotAPackage', { objectId: Address }), IncompatibleUpgrade: null, @@ -18,18 +18,18 @@ const PackageUpgradeError = bcs.enum('PackageUpgradeError', { }), }); -const ModuleId = bcs.struct('ModuleId', { +export const ModuleId = bcs.struct('ModuleId', { address: Address, name: bcs.string(), }); -const MoveLocation = bcs.struct('MoveLocation', { +export const MoveLocation = bcs.struct('MoveLocation', { module: ModuleId, function: bcs.u16(), instruction: bcs.u16(), functionName: bcs.option(bcs.string()), }); -const CommandArgumentError = bcs.enum('CommandArgumentError', { +export const CommandArgumentError = bcs.enum('CommandArgumentError', { TypeMismatch: null, InvalidBCSBytes: null, InvalidUsageOfPureArg: null, @@ -47,12 +47,12 @@ const CommandArgumentError = bcs.enum('CommandArgumentError', { SharedObjectOperationNotAllowed: null, }); -const TypeArgumentError = bcs.enum('TypeArgumentError', { +export const TypeArgumentError = bcs.enum('TypeArgumentError', { TypeNotFound: null, ConstraintNotSatisfied: null, }); -const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { +export const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { InsufficientGas: null, InvalidGasObject: null, InvariantViolation: null, @@ -108,7 +108,7 @@ const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { InputObjectDeleted: null, }); -const ExecutionStatus = bcs.enum('ExecutionStatus', { +export const ExecutionStatus = bcs.enum('ExecutionStatus', { Success: null, Failed: bcs.struct('ExecutionFailed', { error: ExecutionFailureStatus, @@ -116,14 +116,14 @@ const ExecutionStatus = bcs.enum('ExecutionStatus', { }), }); -const GasCostSummary = bcs.struct('GasCostSummary', { +export const GasCostSummary = bcs.struct('GasCostSummary', { computationCost: bcs.u64(), storageCost: bcs.u64(), storageRebate: bcs.u64(), nonRefundableStorageFee: bcs.u64(), }); -const Owner = bcs.enum('Owner', { +export const Owner = bcs.enum('Owner', { AddressOwner: Address, ObjectOwner: Address, Shared: bcs.struct('Shared', { @@ -132,32 +132,32 @@ const Owner = bcs.enum('Owner', { Immutable: null, }); -const VersionDigest = bcs.tuple([bcs.u64(), ObjectDigest]); +export const VersionDigest = bcs.tuple([bcs.u64(), ObjectDigest]); -const ObjectIn = bcs.enum('ObjectIn', { +export const ObjectIn = bcs.enum('ObjectIn', { NotExist: null, Exist: bcs.tuple([VersionDigest, Owner]), }); -const ObjectOut = bcs.enum('ObjectOut', { +export const ObjectOut = bcs.enum('ObjectOut', { NotExist: null, ObjectWrite: bcs.tuple([ObjectDigest, Owner]), PackageWrite: VersionDigest, }); -const IDOperation = bcs.enum('IDOperation', { +export const IDOperation = bcs.enum('IDOperation', { None: null, Created: null, Deleted: null, }); -const EffectsObjectChange = bcs.struct('EffectsObjectChange', { +export const EffectsObjectChange = bcs.struct('EffectsObjectChange', { inputState: ObjectIn, outputState: ObjectOut, idOperation: IDOperation, }); -const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { +export const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { ReadOnlyRoot: VersionDigest, MutateDeleted: bcs.u64(), ReadDeleted: bcs.u64(), @@ -165,7 +165,7 @@ const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { PerEpochConfig: null, }); -const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { +export const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { status: ExecutionStatus, executedEpoch: bcs.u64(), gasUsed: GasCostSummary, From c8c933a78479ed49bab243a3fc77947ecdefa385 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bego=C3=B1a=20Alvarez?= Date: Thu, 31 Oct 2024 14:22:16 +0100 Subject: [PATCH 4/8] chore: cleanup code --- .../src/mappers/transaction-block.ts | 20 ++++++------- sdk/typescript/src/bcs/effects.ts | 28 +++++++++---------- 2 files changed, 22 insertions(+), 26 deletions(-) diff --git a/sdk/graphql-transport/src/mappers/transaction-block.ts b/sdk/graphql-transport/src/mappers/transaction-block.ts index 02a86e2d619..8cb552b09a6 100644 --- a/sdk/graphql-transport/src/mappers/transaction-block.ts +++ b/sdk/graphql-transport/src/mappers/transaction-block.ts @@ -353,11 +353,7 @@ const ADDRESS_ZERO = normalizeIotaAddress('0x0'); export function mapEffects(data: string): IotaTransactionBlockResponse['effects'] { const effects = bcs.TransactionEffects.parse(fromB64(data)); - type Things = typeof ObjectOut; - - type Stuff = Things['$inferType']['ObjectWrite']; //Things['ObjectWrite']; - - type Caracola = Exclude[1]; + type InferedOwner = Exclude<(typeof ObjectOut)['$inferType']['ObjectWrite'], undefined>[1]; const sharedObjects = effects.V1.unchangedSharedObjects.map(([id, sharedObject]) => { switch (sharedObject.$kind) { @@ -425,7 +421,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ] as const), ); - const mutated: Array<[IotaObjectRef, Caracola]> = effects.V1.changedObjects + const mutated: Array<[IotaObjectRef, InferedOwner]> = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.Exist && @@ -447,7 +443,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? change.outputState.ObjectWrite[1] : { $kind: 'Immutable', Immutable: true }, ]); - const unwrapped: Array<[IotaObjectRef, Caracola]> = effects.V1.changedObjects + const unwrapped: Array<[IotaObjectRef, InferedOwner]> = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.NotExist && @@ -462,7 +458,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' }, change.outputState.ObjectWrite![1], ]); - const deleted: Array = effects.V1.changedObjects + const deleted = effects.V1.changedObjects .filter( ([_id, change]) => change.inputState.Exist && @@ -503,7 +499,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? effects.V1.changedObjects[effects.V1.gasObjectIndex] : null; - const gasObject: [IotaObjectRef, Caracola] = gasObjectFromV1 + const gasObject: [IotaObjectRef, InferedOwner] = gasObjectFromV1 ? [ { objectId: gasObjectFromV1[0], @@ -556,7 +552,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' : { mutated: mutated.map(([reference, owner]) => ({ reference, - owner: mapEffectsOwner(owner as Caracola), + owner: mapEffectsOwner(owner as InferedOwner), })), }), ...(unwrapped.length === 0 @@ -567,7 +563,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? undefined : unwrapped.map(([reference, owner]) => ({ reference, - owner: mapEffectsOwner(owner as Caracola), + owner: mapEffectsOwner(owner as InferedOwner), })), }), ...(deleted.length === 0 ? {} : { deleted: deleted }), @@ -583,7 +579,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' dependencies: effects.V1.dependencies, }; - function mapEffectsOwner(owner: NonNullable) { + function mapEffectsOwner(owner: NonNullable) { if (owner.Immutable) { return 'Immutable'; } else if (owner.Shared) { diff --git a/sdk/typescript/src/bcs/effects.ts b/sdk/typescript/src/bcs/effects.ts index c19b2add487..a347442b4f0 100644 --- a/sdk/typescript/src/bcs/effects.ts +++ b/sdk/typescript/src/bcs/effects.ts @@ -6,7 +6,7 @@ import { bcs } from '@iota/bcs'; import { Address, ObjectDigest } from './bcs.js'; -export const PackageUpgradeError = bcs.enum('PackageUpgradeError', { +const PackageUpgradeError = bcs.enum('PackageUpgradeError', { UnableToFetchPackage: bcs.struct('UnableToFetchPackage', { packageId: Address }), NotAPackage: bcs.struct('NotAPackage', { objectId: Address }), IncompatibleUpgrade: null, @@ -18,18 +18,18 @@ export const PackageUpgradeError = bcs.enum('PackageUpgradeError', { }), }); -export const ModuleId = bcs.struct('ModuleId', { +const ModuleId = bcs.struct('ModuleId', { address: Address, name: bcs.string(), }); -export const MoveLocation = bcs.struct('MoveLocation', { +const MoveLocation = bcs.struct('MoveLocation', { module: ModuleId, function: bcs.u16(), instruction: bcs.u16(), functionName: bcs.option(bcs.string()), }); -export const CommandArgumentError = bcs.enum('CommandArgumentError', { +const CommandArgumentError = bcs.enum('CommandArgumentError', { TypeMismatch: null, InvalidBCSBytes: null, InvalidUsageOfPureArg: null, @@ -47,12 +47,12 @@ export const CommandArgumentError = bcs.enum('CommandArgumentError', { SharedObjectOperationNotAllowed: null, }); -export const TypeArgumentError = bcs.enum('TypeArgumentError', { +const TypeArgumentError = bcs.enum('TypeArgumentError', { TypeNotFound: null, ConstraintNotSatisfied: null, }); -export const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { +const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { InsufficientGas: null, InvalidGasObject: null, InvariantViolation: null, @@ -116,14 +116,14 @@ export const ExecutionStatus = bcs.enum('ExecutionStatus', { }), }); -export const GasCostSummary = bcs.struct('GasCostSummary', { +const GasCostSummary = bcs.struct('GasCostSummary', { computationCost: bcs.u64(), storageCost: bcs.u64(), storageRebate: bcs.u64(), nonRefundableStorageFee: bcs.u64(), }); -export const Owner = bcs.enum('Owner', { +const Owner = bcs.enum('Owner', { AddressOwner: Address, ObjectOwner: Address, Shared: bcs.struct('Shared', { @@ -132,9 +132,9 @@ export const Owner = bcs.enum('Owner', { Immutable: null, }); -export const VersionDigest = bcs.tuple([bcs.u64(), ObjectDigest]); +const VersionDigest = bcs.tuple([bcs.u64(), ObjectDigest]); -export const ObjectIn = bcs.enum('ObjectIn', { +const ObjectIn = bcs.enum('ObjectIn', { NotExist: null, Exist: bcs.tuple([VersionDigest, Owner]), }); @@ -145,19 +145,19 @@ export const ObjectOut = bcs.enum('ObjectOut', { PackageWrite: VersionDigest, }); -export const IDOperation = bcs.enum('IDOperation', { +const IDOperation = bcs.enum('IDOperation', { None: null, Created: null, Deleted: null, }); -export const EffectsObjectChange = bcs.struct('EffectsObjectChange', { +const EffectsObjectChange = bcs.struct('EffectsObjectChange', { inputState: ObjectIn, outputState: ObjectOut, idOperation: IDOperation, }); -export const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { +const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { ReadOnlyRoot: VersionDigest, MutateDeleted: bcs.u64(), ReadDeleted: bcs.u64(), @@ -165,7 +165,7 @@ export const UnchangedSharedKind = bcs.enum('UnchangedSharedKind', { PerEpochConfig: null, }); -export const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { +const TransactionEffectsV1 = bcs.struct('TransactionEffectsV1', { status: ExecutionStatus, executedEpoch: bcs.u64(), gasUsed: GasCostSummary, From fe51c933915043a589a572f87e89fb5f1406cfe6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bego=C3=B1a=20Alvarez?= Date: Thu, 31 Oct 2024 14:45:32 +0100 Subject: [PATCH 5/8] chore: rename remaining v2 effects to v1 in tests --- sdk/typescript/test/e2e/parallel-executor.test.ts | 4 ++-- sdk/typescript/test/e2e/serial-executor.test.ts | 10 +++++----- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/sdk/typescript/test/e2e/parallel-executor.test.ts b/sdk/typescript/test/e2e/parallel-executor.test.ts index 391f1819633..35cd2b08626 100644 --- a/sdk/typescript/test/e2e/parallel-executor.test.ts +++ b/sdk/typescript/test/e2e/parallel-executor.test.ts @@ -146,9 +146,9 @@ describe('ParallelTransactionExecutor', { retry: 3 }, () => { const result = await executor.executeTransaction(txb); const effects = bcs.TransactionEffects.fromBase64(result.effects); - const newCoinId = effects.V2?.changedObjects.find( + const newCoinId = effects.V1?.changedObjects.find( ([_id, { outputState }], index) => - index !== effects.V2.gasObjectIndex && outputState.ObjectWrite, + index !== effects.V1.gasObjectIndex && outputState.ObjectWrite, )?.[0]!; return newCoinId; diff --git a/sdk/typescript/test/e2e/serial-executor.test.ts b/sdk/typescript/test/e2e/serial-executor.test.ts index 89c48bd8cdf..ab2ba8b74df 100644 --- a/sdk/typescript/test/e2e/serial-executor.test.ts +++ b/sdk/typescript/test/e2e/serial-executor.test.ts @@ -46,9 +46,9 @@ describe('SerialExecutor', { retry: 3 }, () => { const effects = bcs.TransactionEffects.fromBase64(result.effects); - const newCoinId = effects.V2?.changedObjects.find( + const newCoinId = effects.V1?.changedObjects.find( ([_id, { outputState }], index) => - index !== effects.V2.gasObjectIndex && outputState.ObjectWrite, + index !== effects.V1.gasObjectIndex && outputState.ObjectWrite, )?.[0]!; expect(toolbox.client.getCoins).toHaveBeenCalledTimes(1); @@ -82,9 +82,9 @@ describe('SerialExecutor', { retry: 3 }, () => { await toolbox.client.waitForTransaction({ digest: result.digest }); - const newCoinId = effects.V2?.changedObjects.find( + const newCoinId = effects.V1?.changedObjects.find( ([_id, { outputState }], index) => - index !== effects.V2.gasObjectIndex && outputState.ObjectWrite, + index !== effects.V1.gasObjectIndex && outputState.ObjectWrite, )?.[0]!; expect(toolbox.client.getCoins).toHaveBeenCalledTimes(1); @@ -106,6 +106,6 @@ describe('SerialExecutor', { retry: 3 }, () => { const result2 = await executor.executeTransaction(txb3); expect(result2.digest).not.toEqual(result.digest); - expect(bcs.TransactionEffects.fromBase64(result2.effects).V2?.status.Success).toEqual(true); + expect(bcs.TransactionEffects.fromBase64(result2.effects).V1?.status.Success).toEqual(true); }); }); From bef5370988701d5ec812e514ea9785a2908211b3 Mon Sep 17 00:00:00 2001 From: Mario Sarcevic Date: Thu, 31 Oct 2024 15:13:28 +0100 Subject: [PATCH 6/8] feat(tooling-sdk): Minor formatting fix --- sdk/graphql-transport/src/mappers/transaction-block.ts | 3 +++ 1 file changed, 3 insertions(+) diff --git a/sdk/graphql-transport/src/mappers/transaction-block.ts b/sdk/graphql-transport/src/mappers/transaction-block.ts index 8cb552b09a6..f722709dc7e 100644 --- a/sdk/graphql-transport/src/mappers/transaction-block.ts +++ b/sdk/graphql-transport/src/mappers/transaction-block.ts @@ -443,6 +443,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' ? change.outputState.ObjectWrite[1] : { $kind: 'Immutable', Immutable: true }, ]); + const unwrapped: Array<[IotaObjectRef, InferedOwner]> = effects.V1.changedObjects .filter( ([_id, change]) => @@ -458,6 +459,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' }, change.outputState.ObjectWrite![1], ]); + const deleted = effects.V1.changedObjects .filter( ([_id, change]) => @@ -470,6 +472,7 @@ export function mapEffects(data: string): IotaTransactionBlockResponse['effects' version: Number(effects.V1.lamportVersion) as unknown as string, digest: OBJECT_DIGEST_DELETED, })); + const unwrappedThenDeleted = effects.V1.changedObjects .filter( ([_id, change]) => From fe380266c35ea32fd2ab6d2d2e597110b9cada50 Mon Sep 17 00:00:00 2001 From: Mario Sarcevic Date: Thu, 31 Oct 2024 15:13:47 +0100 Subject: [PATCH 7/8] feat(tooling-sdk): Fix dapp-kit test --- sdk/dapp-kit/test/hooks/useSignAndExecuteTransaction.test.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/dapp-kit/test/hooks/useSignAndExecuteTransaction.test.tsx b/sdk/dapp-kit/test/hooks/useSignAndExecuteTransaction.test.tsx index 73b348cc3fc..5cf63eb64b7 100644 --- a/sdk/dapp-kit/test/hooks/useSignAndExecuteTransaction.test.tsx +++ b/sdk/dapp-kit/test/hooks/useSignAndExecuteTransaction.test.tsx @@ -164,7 +164,7 @@ describe('useSignAndExecuteTransaction', () => { ]), ); const effectsBcs = bcs.TransactionEffects.serialize({ - V2: { + V1: { status: { Success: true, }, From 1781521989aea122810fc92c2dedfeaa4279fef4 Mon Sep 17 00:00:00 2001 From: Mario Sarcevic Date: Thu, 31 Oct 2024 15:26:47 +0100 Subject: [PATCH 8/8] feat(tooling-sdk): Remove unneeded export --- sdk/typescript/src/bcs/effects.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/typescript/src/bcs/effects.ts b/sdk/typescript/src/bcs/effects.ts index a347442b4f0..bb9f23c37c0 100644 --- a/sdk/typescript/src/bcs/effects.ts +++ b/sdk/typescript/src/bcs/effects.ts @@ -108,7 +108,7 @@ const ExecutionFailureStatus = bcs.enum('ExecutionFailureStatus', { InputObjectDeleted: null, }); -export const ExecutionStatus = bcs.enum('ExecutionStatus', { +const ExecutionStatus = bcs.enum('ExecutionStatus', { Success: null, Failed: bcs.struct('ExecutionFailed', { error: ExecutionFailureStatus,