From 904fded3ac235e866625938e17b21c1c53fbb734 Mon Sep 17 00:00:00 2001 From: Thoralf-M <46689931+Thoralf-M@users.noreply.github.com> Date: Mon, 9 Oct 2023 20:12:10 +0200 Subject: [PATCH] Python: add Utils::transaction_id() (#1407) Co-authored-by: DaughterOfMars --- bindings/python/CHANGELOG.md | 6 ++++++ bindings/python/examples/exchange/1_create_account.py | 3 ++- bindings/python/iota_sdk/utils.py | 9 +++++++++ bindings/python/tests/test_offline.py | 6 ++++-- 4 files changed, 21 insertions(+), 3 deletions(-) diff --git a/bindings/python/CHANGELOG.md b/bindings/python/CHANGELOG.md index 8d701ef6b6..93da736851 100644 --- a/bindings/python/CHANGELOG.md +++ b/bindings/python/CHANGELOG.md @@ -19,6 +19,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Security --> +## 1.1.1 - 2023-MM-DD + +### Added + +- `Utils:transaction_id()`; + ## 1.1.0 - 2023-09-29 Stable release. diff --git a/bindings/python/examples/exchange/1_create_account.py b/bindings/python/examples/exchange/1_create_account.py index d7f4ae54dd..e6ec57fef0 100644 --- a/bindings/python/examples/exchange/1_create_account.py +++ b/bindings/python/examples/exchange/1_create_account.py @@ -14,7 +14,8 @@ # should not be done in production. load_dotenv() -for env_var in ['WALLET_DB_PATH', 'NODE_URL', 'STRONGHOLD_SNAPSHOT_PATH', 'STRONGHOLD_PASSWORD', 'MNEMONIC']: +for env_var in ['WALLET_DB_PATH', 'NODE_URL', + 'STRONGHOLD_SNAPSHOT_PATH', 'STRONGHOLD_PASSWORD', 'MNEMONIC']: if env_var not in os.environ: raise Exception(f'.env {env_var} is undefined, see .env.example') diff --git a/bindings/python/iota_sdk/utils.py b/bindings/python/iota_sdk/utils.py index aea2c52464..ee0a1f40e9 100644 --- a/bindings/python/iota_sdk/utils.py +++ b/bindings/python/iota_sdk/utils.py @@ -8,6 +8,7 @@ from iota_sdk.types.common import HexStr from iota_sdk.types.output_id import OutputId from iota_sdk.types.output import Output +from iota_sdk.types.payload import TransactionPayload from json import dumps, loads from typing import TYPE_CHECKING, List from dacite import from_dict @@ -176,6 +177,14 @@ def block_id(block: Block) -> HexStr: 'block': block.as_dict() }) + @staticmethod + def transaction_id(transaction_payload: TransactionPayload) -> HexStr: + """ Compute the transaction ID (Blake2b256 hash of the provided transaction payload) of a transaction payload. + """ + return _call_method('transactionId', { + 'payload': transaction_payload.as_dict() + }) + @staticmethod def hash_transaction_essence(essence) -> HexStr: """ Compute the hash of a transaction essence. diff --git a/bindings/python/tests/test_offline.py b/bindings/python/tests/test_offline.py index 4ae046a7ab..35b3942051 100644 --- a/bindings/python/tests/test_offline.py +++ b/bindings/python/tests/test_offline.py @@ -58,11 +58,13 @@ def test_output_id(self): transaction_id = '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c649' output_index = 42 output_id = OutputId(transaction_id, output_index) - assert repr(output_id) == '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6492a00' + assert repr( + output_id) == '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6492a00' new_output_id = OutputId.from_string( '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6492a00') - assert repr(new_output_id) == '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6492a00' + assert repr( + new_output_id) == '0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6492a00' assert new_output_id.transaction_id == transaction_id assert new_output_id.output_index == output_index