mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-17 10:51:00 +00:00
feat(cardano): add preprod and preview testnets
This commit is contained in:
parent
ec83d0187f
commit
51a8e18c8d
@ -1,9 +1,14 @@
|
||||
# https://book.world.dev.cardano.org/environments.html
|
||||
MAINNET = 764824073
|
||||
TESTNET = 1097911063
|
||||
TESTNET_PREPROD = 1
|
||||
TESTNET_PREVIEW = 2
|
||||
TESTNET_LEGACY = 1097911063
|
||||
|
||||
NAMES = {
|
||||
MAINNET: "Mainnet",
|
||||
TESTNET: "Testnet",
|
||||
TESTNET_PREPROD: "Preprod Testnet",
|
||||
TESTNET_PREVIEW: "Preview Testnet",
|
||||
TESTNET_LEGACY: "Legacy Testnet",
|
||||
}
|
||||
|
||||
|
||||
|
@ -290,7 +290,7 @@ class TestCardanoAddress(unittest.TestCase):
|
||||
address_type=CardanoAddressType.BYRON,
|
||||
address_n=[0x80000000 | 44, 0x80000000 | 1815, 0x80000000, 0, i],
|
||||
)
|
||||
address = derive_human_readable(self.keychain, address_parameters, protocol_magics.TESTNET, 0)
|
||||
address = derive_human_readable(self.keychain, address_parameters, protocol_magics.TESTNET_LEGACY, 0)
|
||||
self.assertEqual(expected, address)
|
||||
|
||||
def test_derive_address(self):
|
||||
|
@ -38,7 +38,12 @@ if TYPE_CHECKING:
|
||||
from .client import TrezorClient
|
||||
from .protobuf import MessageType
|
||||
|
||||
PROTOCOL_MAGICS = {"mainnet": 764824073, "testnet": 1097911063}
|
||||
PROTOCOL_MAGICS = {
|
||||
"mainnet": 764824073,
|
||||
"testnet_preprod": 1,
|
||||
"testnet_preview": 2,
|
||||
"testnet_legacy": 1097911063,
|
||||
}
|
||||
NETWORK_IDS = {"mainnet": 1, "testnet": 0}
|
||||
|
||||
MAX_CHUNK_SIZE = 1024
|
||||
|
@ -27,6 +27,12 @@ if TYPE_CHECKING:
|
||||
|
||||
PATH_HELP = "BIP-32 path to key, e.g. m/44'/1815'/0'/0/0"
|
||||
|
||||
TESTNET_CHOICES = {
|
||||
"preprod": "testnet_preprod",
|
||||
"preview": "testnet_preview",
|
||||
"legacy": "testnet_legacy",
|
||||
}
|
||||
|
||||
|
||||
@click.group(name="cardano")
|
||||
def cli() -> None:
|
||||
@ -46,7 +52,7 @@ def cli() -> None:
|
||||
"-p", "--protocol-magic", type=int, default=cardano.PROTOCOL_MAGICS["mainnet"]
|
||||
)
|
||||
@click.option("-N", "--network-id", type=int, default=cardano.NETWORK_IDS["mainnet"])
|
||||
@click.option("-t", "--testnet", is_flag=True)
|
||||
@click.option("-t", "--testnet", type=ChoiceType(TESTNET_CHOICES))
|
||||
@click.option(
|
||||
"-D",
|
||||
"--derivation-type",
|
||||
@ -61,7 +67,7 @@ def sign_tx(
|
||||
signing_mode: messages.CardanoTxSigningMode,
|
||||
protocol_magic: int,
|
||||
network_id: int,
|
||||
testnet: bool,
|
||||
testnet: str,
|
||||
derivation_type: messages.CardanoDerivationType,
|
||||
include_network_id: bool,
|
||||
) -> cardano.SignTxResponse:
|
||||
@ -69,7 +75,7 @@ def sign_tx(
|
||||
transaction = json.load(file)
|
||||
|
||||
if testnet:
|
||||
protocol_magic = cardano.PROTOCOL_MAGICS["testnet"]
|
||||
protocol_magic = cardano.PROTOCOL_MAGICS[testnet]
|
||||
network_id = cardano.NETWORK_IDS["testnet"]
|
||||
|
||||
inputs = [cardano.parse_input(input) for input in transaction["inputs"]]
|
||||
@ -185,7 +191,7 @@ def sign_tx(
|
||||
"-p", "--protocol-magic", type=int, default=cardano.PROTOCOL_MAGICS["mainnet"]
|
||||
)
|
||||
@click.option("-N", "--network-id", type=int, default=cardano.NETWORK_IDS["mainnet"])
|
||||
@click.option("-e", "--testnet", is_flag=True)
|
||||
@click.option("-e", "--testnet", type=ChoiceType(TESTNET_CHOICES))
|
||||
@click.option(
|
||||
"-D",
|
||||
"--derivation-type",
|
||||
@ -207,7 +213,7 @@ def get_address(
|
||||
protocol_magic: int,
|
||||
network_id: int,
|
||||
show_display: bool,
|
||||
testnet: bool,
|
||||
testnet: str,
|
||||
derivation_type: messages.CardanoDerivationType,
|
||||
) -> str:
|
||||
"""
|
||||
@ -225,7 +231,7 @@ def get_address(
|
||||
Byron, enterprise and reward addresses only require the general parameters.
|
||||
"""
|
||||
if testnet:
|
||||
protocol_magic = cardano.PROTOCOL_MAGICS["testnet"]
|
||||
protocol_magic = cardano.PROTOCOL_MAGICS[testnet]
|
||||
network_id = cardano.NETWORK_IDS["testnet"]
|
||||
|
||||
staking_key_hash_bytes = cardano.parse_optional_bytes(staking_key_hash)
|
||||
|
Loading…
Reference in New Issue
Block a user