* Add network name display instead of chainID * Add display of correct ticker along with network * Add FTM * Clang-format * Add comment in python script * Rename SIZE_MAX to MAX_SIZE * Change %u to %d in printf * Remove needless PIC * Update comment about get_chain_id() * Update example script to follow EIP155 * Remove unused PIC calls * Add whitespace between ticker and amount when using EIP155 * Remove decimal config per network, set back 18 everywhere * Adapt u32_from_BE to swith cases * Remove chainid from signTx.py * Switch to switch in stead of if in get_chain_id * Revert "Remove chainid from signTx.py" This reverts commit 454e09f280ec3e3ec1c7d7cc0027247ef4390088. * Change Ethereum chainid to 1 * Rename chainid_step to network_step * Adapt finalizeParsing to new chainid for Ethereum * Update snapshots * clang-format * Fix network display logic for clones * Fix tests * Add clone tests Co-authored-by: TamtamHero <10632523+TamtamHero@users.noreply.github.com>
76 lines
2.3 KiB
Python
Executable File
76 lines
2.3 KiB
Python
Executable File
#!/usr/bin/env python
|
|
"""
|
|
*******************************************************************************
|
|
* Ledger Ethereum App
|
|
* (c) 2016-2019 Ledger
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
********************************************************************************
|
|
"""
|
|
|
|
from rlp.sedes import big_endian_int, binary, Binary
|
|
from rlp import Serializable
|
|
|
|
try:
|
|
from Crypto.Hash import keccak
|
|
def sha3_256(x): return keccak.new(digest_bits=256, data=x.encode()).digest()
|
|
except:
|
|
import sha3 as _sha3
|
|
def sha3_256(x): return _sha3.sha3_256(x).digest()
|
|
|
|
address = Binary.fixed_length(20, allow_empty=True)
|
|
|
|
def sha3(seed):
|
|
return sha3_256(str(seed))
|
|
|
|
|
|
class Transaction(Serializable):
|
|
fields = [
|
|
('nonce', big_endian_int),
|
|
('gasprice', big_endian_int),
|
|
('startgas', big_endian_int),
|
|
('to', address),
|
|
('value', big_endian_int),
|
|
('data', binary),
|
|
('v', big_endian_int),
|
|
('r', big_endian_int),
|
|
('s', big_endian_int),
|
|
]
|
|
|
|
def __init__(self, nonce, gasprice, startgas, to, value, data, v=0, r=0, s=0):
|
|
super(Transaction, self).__init__(
|
|
nonce, gasprice, startgas, to, value, data, v, r, s)
|
|
|
|
class UnsignedTransaction(Serializable):
|
|
fields = [
|
|
('nonce', big_endian_int),
|
|
('gasprice', big_endian_int),
|
|
('startgas', big_endian_int),
|
|
('to', address),
|
|
('value', big_endian_int),
|
|
('data', binary),
|
|
('chainid', big_endian_int),
|
|
('dummy1', big_endian_int),
|
|
('dummy2', big_endian_int),
|
|
]
|
|
|
|
def unsigned_tx_from_tx(tx):
|
|
return UnsignedTransaction(
|
|
nonce=tx.nonce,
|
|
gasprice=tx.gasprice,
|
|
startgas=tx.startgas,
|
|
to=tx.to,
|
|
value=tx.value,
|
|
data=tx.data,
|
|
)
|