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/python: Lint sdk develop #1411

Merged
merged 33 commits into from
Oct 25, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
d6c1094
moved pylint to root
Sep 22, 2023
2cda124
feat/Python: Add pylint to code (#1315)
Sep 26, 2023
0fc60ef
fixes for develop
Oct 9, 2023
ec15a13
reverts
Oct 9, 2023
2f33cab
lint
Oct 9, 2023
d2a5c36
reverted range
Oct 9, 2023
98b227c
Merge branch 'develop' into python/lint-sdk-develop
Oct 10, 2023
f0373c2
docs
Oct 10, 2023
ced83ec
format
Oct 10, 2023
7dd98a2
comment
Oct 16, 2023
82ba977
Merge branch 'develop' into python/lint-sdk-develop
Oct 16, 2023
bb6f51b
some more doc fix
Oct 16, 2023
638af66
todo comment on disable
Oct 16, 2023
3eb78af
changed docs
Oct 17, 2023
b42e24e
Update bindings/python/iota_sdk/wallet/account.py
thibault-martinez Oct 18, 2023
10840f8
Merge branch 'develop' into python/lint-sdk-develop
Oct 23, 2023
c82ee5e
2 review comments
Oct 23, 2023
c9db213
format
Oct 23, 2023
55711e8
Merge branch 'python/lint-sdk-develop' of https://github.com/kwek20/i…
Oct 23, 2023
97f5cb2
pep again?
Oct 23, 2023
1daed17
fmt x2
Oct 23, 2023
906ab30
final lints
Oct 23, 2023
00a3bf1
Merge branch 'develop' into python/lint-sdk-develop
Oct 23, 2023
e1f17a8
removed test
Oct 23, 2023
353ac73
review
Oct 24, 2023
d45e6a0
revert
Oct 24, 2023
990eb3a
1 more
Oct 24, 2023
3a6fe27
Merge branch 'develop' into python/lint-sdk-develop
thibault-martinez Oct 24, 2023
fbb069f
Update bindings/python/iota_sdk/types/unlock.py
thibault-martinez Oct 25, 2023
37b02bf
Update bindings/python/iota_sdk/types/irc_30.py
thibault-martinez Oct 25, 2023
3acc008
Merge branch 'develop' into python/lint-sdk-develop
thibault-martinez Oct 25, 2023
bd72347
changelog
Oct 25, 2023
50e66e4
Merge branch 'python/lint-sdk-develop' of https://github.com/kwek20/i…
Oct 25, 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
5 changes: 5 additions & 0 deletions .github/workflows/bindings-python.yml
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,11 @@ jobs:
sudo apt-get update
sudo apt-get install libudev-dev libusb-1.0-0-dev

- name: Run linter for iota_sdk
if: ${{ startsWith(matrix.os, 'ubuntu-latest') }}
working-directory: bindings/python
run: tox -e lint-sdk

- name: Run linter for examples
if: ${{ startsWith(matrix.os, 'ubuntu-latest') }}
working-directory: bindings/python
Expand Down
10 changes: 8 additions & 2 deletions bindings/python/.pylintrc
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,12 @@ disable=missing-module-docstring,
invalid-name, # files that starts with number
duplicate-code,
consider-using-with,
consider-using-f-string

fixme, # TODOS
too-many-instance-attributes,
too-many-arguments,
too-many-public-methods,
too-few-public-methods,
too-many-locals

[TYPECHECK]
generated-members=from_dict,to_dict,to_json # Made from @json
5 changes: 5 additions & 0 deletions bindings/python/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- `Utils:transaction_id()`;
- `py.typed` file to the package;

### Fixed

- `Range` type instead of `range` method in `GenerateAddressesOptions` init;
- `Dict` type instead of `dict` method in `Irc27Metadata` init;

## 1.1.0 - 2023-09-29

Stable release.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,9 @@

for i, output_data in enumerate(outputs):
print(f'OUTPUT #{i}')
print(
'- address: {}\n- amount: {}\n- native tokens: {}'.format(
Utils.hex_to_bech32(output_data.address.pubKeyHash, 'rms'),
output_data.output.amount,
output_data.output.nativeTokens
)
)
print(f'- address: #{Utils.hex_to_bech32(output_data.address.pubKeyHash, "rms")}')
print(f'- amount: #{output_data.output.amount}')
print(f'- native tokens: #{output_data.output.nativeTokens}')

print('Sending consolidation transaction...')

Expand All @@ -66,10 +62,6 @@
print('Outputs AFTER consolidation:')
for i, output_data in enumerate(outputs):
print(f'OUTPUT #{i}')
print(
'- address: {}\n- amount: {}\n- native tokens: {}'.format(
Utils.hex_to_bech32(output_data.address.pubKeyHash, 'rms'),
output_data.output.amount,
output_data.output.nativeTokens
)
)
print(f'- address: #{Utils.hex_to_bech32(output_data.address.pubKeyHash, "rms")}')
print(f'- amount: #{output_data.output.amount}')
print(f'- native tokens: #{output_data.output.nativeTokens}')
4 changes: 2 additions & 2 deletions bindings/python/iota_sdk/__init__.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
# Copyright 2023 IOTA Stiftung
# SPDX-License-Identifier: Apache-2.0

from .iota_sdk import *
from .client.client import Client, NodeIndexerAPI, ClientError
from .client._high_level_api import GenerateAddressesOptions, GenerateAddressOptions
from .external import *
from .utils import Utils
from .wallet.wallet import Wallet, Account
from .wallet.common import WalletError
from .wallet.sync_options import AccountSyncOptions, AliasSyncOptions, NftSyncOptions, SyncOptions
from .wallet.sync_options import AccountSyncOptions, NftSyncOptions, AliasSyncOptions, SyncOptions
from .secret_manager.secret_manager import *
from .prefix_hex import *
from .types.address import *
Expand Down
40 changes: 32 additions & 8 deletions bindings/python/iota_sdk/client/_high_level_api.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
# Copyright 2023 IOTA Stiftung
# SPDX-License-Identifier: Apache-2.0

from iota_sdk.secret_manager.secret_manager import LedgerNanoSecretManager, MnemonicSecretManager, StrongholdSecretManager, SeedSecretManager
from typing import List, Optional, Union
from abc import ABCMeta, abstractmethod
from dacite import from_dict
from iota_sdk.types.block import Block
from iota_sdk.types.common import HexStr
from iota_sdk.types.common import CoinType, HexStr
from iota_sdk.types.output import OutputWithMetadata
from iota_sdk.types.output_id import OutputId
from iota_sdk.types.common import CoinType
from typing import List, Optional, Union
from dacite import from_dict
from iota_sdk.secret_manager.secret_manager import LedgerNanoSecretManager, MnemonicSecretManager, StrongholdSecretManager, SeedSecretManager


class Range:
Expand Down Expand Up @@ -50,8 +50,9 @@ class GenerateAddressesOptions():
options: An instance of `GenerateAddressOptions`.
"""

# pylint: disable=redefined-builtin
def __init__(self, coinType: CoinType,
range: range,
range: Range,
thibault-martinez marked this conversation as resolved.
Show resolved Hide resolved
bech32Hrp: str,
accountIndex: Optional[int] = None,
options: Optional[GenerateAddressOptions] = None):
Expand All @@ -65,12 +66,14 @@ def __init__(self, coinType: CoinType,
options: An instance of `GenerateAddressOptions`.
"""
self.coinType = coinType
self.range = Range(range.start, range.stop)
self.range = range
self.bech32Hrp = bech32Hrp
self.accountIndex = accountIndex
self.options = options

def as_dict(self):
"""Converts this object to a dict.
"""
config = {k: v for k, v in self.__dict__.items() if v is not None}

config["range"] = config["range"].__dict__
Expand All @@ -79,10 +82,31 @@ def as_dict(self):
return config


class HighLevelAPI():
class HighLevelAPI(metaclass=ABCMeta):
"""High level API.
"""

@abstractmethod
def _call_method(self, name, data=None):
"""
Sends a message to the Rust library and returns the response.
It is abstract here as its implementation is located in `client.py`, which is a composite class.

Arguments:

* `name`: The `name` parameter is a string that represents the name of the method to be called.
It is used to identify the specific method to be executed in the Rust library.
* `data`: The `data` parameter is an optional parameter that represents additional data to be
sent along with the method call. It is a dictionary that contains key-value pairs of data. If
the `data` parameter is provided, it will be included in the `message` dictionary as the 'data'
key.

Returns:

The method returns either the payload from the JSON response or the entire response if there is
no payload.
"""

def get_outputs(
self, output_ids: List[OutputId]) -> List[OutputWithMetadata]:
"""Fetch OutputWithMetadata from provided OutputIds (requests are sent in parallel).
Expand Down
29 changes: 26 additions & 3 deletions bindings/python/iota_sdk/client/_node_core_api.py
Original file line number Diff line number Diff line change
@@ -1,21 +1,44 @@
# Copyright 2023 IOTA Stiftung
# SPDX-License-Identifier: Apache-2.0

from typing import List, Union
from abc import ABCMeta, abstractmethod
from dacite import from_dict

from iota_sdk.types.block import Block, BlockMetadata
from iota_sdk.types.common import HexStr
from iota_sdk.types.node_info import NodeInfo, NodeInfoWrapper
from iota_sdk.types.output import OutputWithMetadata, OutputMetadata
from iota_sdk.types.output_id import OutputId
from iota_sdk.types.payload import MilestonePayload
from iota_sdk.types.utxo_changes import UtxoChanges
from typing import List, Union
from dacite import from_dict


class NodeCoreAPI():
class NodeCoreAPI(metaclass=ABCMeta):
"""Node core API.
"""

@abstractmethod
def _call_method(self, name, data=None):
"""
Sends a message to the Rust library and returns the response.
It is abstract here as its implementation is located in `client.py`, which is a composite class.

Arguments:

* `name`: The `name` parameter is a string that represents the name of the method to be called.
It is used to identify the specific method to be executed in the Rust library.
* `data`: The `data` parameter is an optional parameter that represents additional data to be
sent along with the method call. It is a dictionary that contains key-value pairs of data. If
the `data` parameter is provided, it will be included in the `message` dictionary as the 'data'
key.

Returns:

The method returns either the payload from the JSON response or the entire response if there is
no payload.
"""

def get_health(self, url: str):
""" Get node health.

Expand Down
Loading