From bfdea5da079f52a2fd12b9dac1de440d710b86ff Mon Sep 17 00:00:00 2001 From: Timur Guskov Date: Wed, 18 Oct 2023 13:12:49 +0300 Subject: [PATCH] feature: added new instructions to transfer domain ownerhsip and revoke permissions Signed-off-by: Timur Guskov --- .../iroha2/transaction/Instructions.kt | 36 +++++++++++++++++++ .../iroha2/transaction/TransactionBuilder.kt | 11 ++++++ 2 files changed, 47 insertions(+) diff --git a/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/Instructions.kt b/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/Instructions.kt index 0417ec972..91d270f6c 100644 --- a/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/Instructions.kt +++ b/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/Instructions.kt @@ -444,6 +444,18 @@ object Instructions { ), ) + /** + * Transfer domain ownership. + */ + fun transferDomainOwnership(sourceId: AccountId, value: IdBox.DomainId, destinationId: AccountId) = + InstructionBox.Transfer( + TransferBox( + sourceId = IdBox.AccountId(sourceId).evaluatesTo(), + `object` = Value.Id(value).evaluatesTo(), + destinationId = IdBox.AccountId(destinationId).evaluatesTo(), + ), + ) + /** * Evaluate one instruction if a [condition] is met and another one otherwise. */ @@ -480,6 +492,30 @@ object Instructions { } } + /** + * Revoke an account the [Permissions.CanSetKeyValueInUserAccount] permission + */ + fun revokeSetKeyValueAccount(accountId: AccountId, target: AccountId): InstructionBox { + return revokeSome(IdBox.AccountId(target)) { + PermissionToken( + definitionId = Permissions.CanSetKeyValueInUserAccount.type, + payload = accountId.asJsonString().asStringWithJson(), + ) + } + } + + /** + * Revoke an account the [Permissions.CanSetKeyValueInDomain] permission + */ + fun revokeSetKeyValueDomain(domainId: DomainId, target: AccountId): InstructionBox { + return revokeSome(IdBox.AccountId(target)) { + PermissionToken( + definitionId = Permissions.CanSetKeyValueInDomain.type, + payload = domainId.asJsonString().asStringWithJson(), + ) + } + } + /** * Revoke an account a given role. */ diff --git a/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/TransactionBuilder.kt b/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/TransactionBuilder.kt index ffa3f91c5..fa6ff6156 100644 --- a/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/TransactionBuilder.kt +++ b/modules/client/src/main/kotlin/jp/co/soramitsu/iroha2/transaction/TransactionBuilder.kt @@ -13,6 +13,7 @@ import jp.co.soramitsu.iroha2.generated.AssetValue import jp.co.soramitsu.iroha2.generated.AssetValueType import jp.co.soramitsu.iroha2.generated.DomainId import jp.co.soramitsu.iroha2.generated.Executable +import jp.co.soramitsu.iroha2.generated.IdBox import jp.co.soramitsu.iroha2.generated.InstructionBox import jp.co.soramitsu.iroha2.generated.IpfsPath import jp.co.soramitsu.iroha2.generated.Metadata @@ -393,6 +394,10 @@ class TransactionBuilder(builder: TransactionBuilder.() -> Unit = {}) { instructions.value.add(Instructions.transferAsset(sourceId, value, destinationId)) } + fun transferDomain(sourceId: AccountId, value: IdBox.DomainId, destinationId: AccountId) = this.apply { + instructions.value.add(Instructions.transferDomainOwnership(sourceId, value, destinationId)) + } + fun `if`(condition: Boolean, then: InstructionBox, otherwise: InstructionBox) = this.apply { instructions.value.add(Instructions.`if`(condition, then, otherwise)) } @@ -412,6 +417,12 @@ class TransactionBuilder(builder: TransactionBuilder.() -> Unit = {}) { fun revokeSetKeyValueAsset(assetId: AssetId, target: AccountId) = this.apply { instructions.value.add(Instructions.revokeSetKeyValueAsset(assetId, target)) } + fun revokeSetKeyValueAccount(accountId: AccountId, target: AccountId) = + this.apply { instructions.value.add(Instructions.revokeSetKeyValueAccount(accountId, target)) } + + fun revokeSetKeyValueDomain(domainId: DomainId, target: AccountId) = + this.apply { instructions.value.add(Instructions.revokeSetKeyValueDomain(domainId, target)) } + fun revokeRole( roleId: RoleId, accountId: AccountId,