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

Add and use Epoch- and SlotIndex #1347

Merged
merged 4 commits into from
Sep 29, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
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
2 changes: 2 additions & 0 deletions bindings/python/iota_sdk/types/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
from dataclasses_json import DataClassJsonMixin, dataclass_json, LetterCase, Undefined

HexStr = NewType("HexStr", str)
EpochIndex = NewType("EpochIndex", int)
SlotIndex = NewType("SlotIndex", int)


def json(cls):
Expand Down
8 changes: 4 additions & 4 deletions bindings/python/iota_sdk/types/essence.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

from dataclasses import dataclass, field

from iota_sdk.types.common import HexStr, json
from iota_sdk.types.common import HexStr, json, SlotIndex
from iota_sdk.types.mana import ManaAllotment
# TODO: Add missing output types in #1174
# pylint: disable=no-name-in-module
Expand Down Expand Up @@ -54,11 +54,11 @@ class RegularTransactionEssence(TransactionEssence):
payload: An optional tagged data payload
"""
network_id: str
# TODO: Replace with a proper SlotIndex type
creation_slot: HexStr
creation_slot: SlotIndex
inputs: List[UtxoInput]
inputs_commitment: HexStr
outputs: List[Union[BasicOutput, AccountOutput, FoundryOutput, NftOutput, DelegationOutput]]
outputs: List[Union[BasicOutput, AccountOutput,
FoundryOutput, NftOutput, DelegationOutput]]
context_inputs: Optional[List[Union[CommitmentContextInput,
BlockIssuanceCreditContextInput, RewardContextInput]]] = None
allotments: Optional[List[ManaAllotment]] = None
Expand Down
11 changes: 4 additions & 7 deletions bindings/python/iota_sdk/types/feature.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
from dataclasses import dataclass, field

from iota_sdk.types.address import Ed25519Address, AccountAddress, NFTAddress
from iota_sdk.types.common import HexStr, json
from iota_sdk.types.common import EpochIndex, HexStr, json, SlotIndex


class FeatureType(IntEnum):
Expand Down Expand Up @@ -97,8 +97,7 @@ class BlockIssuer(Feature):
expiry_slot: The slot index at which the Block Issuer Feature expires and can be removed.
public_keys: The Block Issuer Keys.
"""
# TODO Replace with a proper SlotIndex type
expiry_slot: str
expiry_slot: SlotIndex
# TODO Replace with a list of PublicKey types
public_keys: List[HexStr]
type: int = field(
Expand All @@ -119,10 +118,8 @@ class StakingFeature(Feature):
"""
staked_amount: str
fixed_cost: str
# TODO Replace with an EpochIndex type
start_epoch: HexStr
# TODO Replace with an EpochIndex type
end_epoch: HexStr
start_epoch: EpochIndex
end_epoch: EpochIndex
type: int = field(
default_factory=lambda: int(
FeatureType.Staking),
Expand Down
34 changes: 14 additions & 20 deletions bindings/python/iota_sdk/types/node_info.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
from __future__ import annotations
from dataclasses import dataclass
from typing import List, Optional
from iota_sdk.types.common import HexStr, json
from iota_sdk.types.common import EpochIndex, HexStr, json, SlotIndex


@json
Expand All @@ -22,22 +22,18 @@ class NodeInfoStatus:
latest_finalized_slot: The index of the latest finalized slot.
latest_accepted_block_slot: The slot index of the latest accepted block.
latest_confirmed_block_slot: The slot index of the latest confirmed block.
pruning_epoch: The index of the slot before which the tangle history is pruned.
pruning_epoch: The index of the epoch before which the tangle history is pruned.
"""
is_healthy: bool
accepted_tangle_time: str
relative_accepted_tangle_time: str
confirmed_tangle_time: str
relative_confirmed_tangle_time: str
latest_commitment_id: HexStr
# TODO Replace with a proper SlotIndex type
latest_finalized_slot: str
# TODO Replace with a proper SlotIndex type
latest_accepted_block_slot: str
# TODO Replace with a proper SlotIndex type
latest_confirmed_block_slot: str
# TODO Replace with a proper SlotIndex type
pruning_epoch: str
latest_finalized_slot: SlotIndex
latest_accepted_block_slot: SlotIndex
latest_confirmed_block_slot: SlotIndex
pruning_epoch: EpochIndex


@json
Expand Down Expand Up @@ -214,15 +210,13 @@ class ProtocolParameters:
slot_duration_in_seconds: int
slots_per_epoch_exponent: int
mana_structure: ManaStructure
staking_unbonding_period: str
staking_unbonding_period: EpochIndex
validation_blocks_per_slot: int
punishment_epochs: str
staking_unbonding_period: str
thibault-martinez marked this conversation as resolved.
Show resolved Hide resolved
liveness_threshold: str
min_committable_age: str
max_committable_age: str
# TODO Replace with a proper SlotIndex type
epoch_nearing_threshold: str
punishment_epochs: EpochIndex
liveness_threshold: SlotIndex
min_committable_age: SlotIndex
max_committable_age: SlotIndex
epoch_nearing_threshold: SlotIndex
congestion_control_parameters: CongestionControlParameters
version_signaling: VersionSignaling

Expand All @@ -236,7 +230,7 @@ class ProtocolParametersResponse:
start_epoch: The start epoch of the set of protocol parameters.
parameters: The protocol parameters.
"""
start_epoch: str
start_epoch: EpochIndex
parameters: ProtocolParameters


Expand All @@ -255,9 +249,9 @@ class NodeInfoBaseToken:
name: str
ticker_symbol: str
unit: str
subunit: Optional[str] = None
decimals: int
use_metric_prefix: bool
subunit: Optional[str] = None


@json
Expand Down