1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-15 01:40:57 +00:00

common: skip deprecated fields during generation; deprecate overwintered field in Zcash

This commit is contained in:
Tomas Susanka 2020-06-30 07:43:01 +00:00
parent 64cfe48f54
commit ca3dd2bfb9
12 changed files with 24 additions and 32 deletions

View File

@ -130,7 +130,7 @@ message SignTx {
optional uint32 version = 4 [default=1]; // transaction version optional uint32 version = 4 [default=1]; // transaction version
optional uint32 lock_time = 5 [default=0]; // transaction lock_time optional uint32 lock_time = 5 [default=0]; // transaction lock_time
optional uint32 expiry = 6; // only for Decred and Zcash optional uint32 expiry = 6; // only for Decred and Zcash
// optional bool overwintered = 7; // deprecated - only for Zcash optional bool _overwintered = 7 [deprecated=true]; // deprecated in 2.3.2, the field is not needed as it can be derived from `version`
optional uint32 version_group_id = 8; // only for Zcash, nVersionGroupId optional uint32 version_group_id = 8; // only for Zcash, nVersionGroupId
optional uint32 timestamp = 9; // only for Peercoin optional uint32 timestamp = 9; // only for Peercoin
optional uint32 branch_id = 10; // only for Zcash, BRANCH_ID optional uint32 branch_id = 10; // only for Zcash, BRANCH_ID
@ -196,7 +196,7 @@ message TxAck {
optional bytes extra_data = 8; // only for Dash, Zcash optional bytes extra_data = 8; // only for Dash, Zcash
optional uint32 extra_data_len = 9; // only for Dash, Zcash optional uint32 extra_data_len = 9; // only for Dash, Zcash
optional uint32 expiry = 10; // only for Decred and Zcash optional uint32 expiry = 10; // only for Decred and Zcash
// optional bool overwintered = 11; // deprecated - only for Zcash optional bool _overwintered = 11 [deprecated=true]; // Zcash only; deprecated in 2.3.2, the field is not needed, it can be derived from `version`
optional uint32 version_group_id = 12; // only for Zcash, nVersionGroupId optional uint32 version_group_id = 12; // only for Zcash, nVersionGroupId
optional uint32 timestamp = 13; // only for Peercoin optional uint32 timestamp = 13; // only for Peercoin
optional uint32 branch_id = 14; // only for Zcash, BRANCH_ID optional uint32 branch_id = 14; // only for Zcash, BRANCH_ID

View File

@ -44,7 +44,7 @@ message EthereumGetAddress {
* @end * @end
*/ */
message EthereumAddress { message EthereumAddress {
optional bytes old_address = 1 [deprecated=true]; // trezor <1.8.0, <2.1.0 - raw bytes of Ethereum address optional bytes _old_address = 1 [deprecated=true]; // trezor <1.8.0, <2.1.0 - raw bytes of Ethereum address
optional string address = 2; // Ethereum address as hex-encoded string optional string address = 2; // Ethereum address as hex-encoded string
} }

View File

@ -265,7 +265,7 @@ class Descriptor:
yield " }" yield " }"
# fmt: on # fmt: on
def process_message(self, message): def process_message(self, message, include_deprecated=False):
logging.debug("Processing message {}".format(message.name)) logging.debug("Processing message {}".format(message.name))
msg_id = self.message_types.get(message.name) msg_id = self.message_types.get(message.name)
@ -273,6 +273,8 @@ class Descriptor:
yield self.protobuf_import + " as p" yield self.protobuf_import + " as p"
fields = [ProtoField.from_field(self, field) for field in message.field] fields = [ProtoField.from_field(self, field) for field in message.field]
if not include_deprecated:
fields = [field for field in fields if not field.orig.options.deprecated]
yield from self.process_subtype_imports(fields) yield from self.process_subtype_imports(fields)
@ -331,9 +333,9 @@ class Descriptor:
self.enum_types[enum.name][value.name] = value.number self.enum_types[enum.name][value.name] = value.number
yield f"{name} = {value.number} # type: Literal[{value.number}]" yield f"{name} = {value.number} # type: Literal[{value.number}]"
def process_messages(self, messages): def process_messages(self, messages, include_deprecated=False):
for message in sorted(messages, key=lambda m: m.name): for message in sorted(messages, key=lambda m: m.name):
self.write_to_file(message.name, self.process_message(message)) self.write_to_file(message.name, self.process_message(message, include_deprecated))
def process_enums(self, enums): def process_enums(self, enums):
for enum in sorted(enums, key=lambda e: e.name): for enum in sorted(enums, key=lambda e: e.name):
@ -358,10 +360,10 @@ class Descriptor:
for enum in sorted(self.enums, key=lambda m: m.name): for enum in sorted(self.enums, key=lambda m: m.name):
init_py.write("from . import {}\n".format(enum.name)) init_py.write("from . import {}\n".format(enum.name))
def write_classes(self, out_dir, init_py=True): def write_classes(self, out_dir, init_py=True, include_deprecated=False):
self.out_dir = out_dir self.out_dir = out_dir
self.process_enums(self.enums) self.process_enums(self.enums)
self.process_messages(self.messages) self.process_messages(self.messages, include_deprecated)
if init_py: if init_py:
self.write_init_py() self.write_init_py()
@ -376,6 +378,7 @@ if __name__ == "__main__":
parser.add_argument("--message-type", default="MessageType", help="Name of enum with message IDs") parser.add_argument("--message-type", default="MessageType", help="Name of enum with message IDs")
parser.add_argument("-I", "--protoc-include", action="append", help="protoc include path") parser.add_argument("-I", "--protoc-include", action="append", help="protoc include path")
parser.add_argument("-v", "--verbose", action="store_true", help="Print debug messages") parser.add_argument("-v", "--verbose", action="store_true", help="Print debug messages")
parser.add_argument("-d", "--include-deprecated", action="store_true", help="Include deprecated fields")
# fmt: on # fmt: on
args = parser.parse_args() args = parser.parse_args()
@ -387,7 +390,7 @@ if __name__ == "__main__":
descriptor = Descriptor(descriptor_proto, args.message_type, args.protobuf_module) descriptor = Descriptor(descriptor_proto, args.message_type, args.protobuf_module)
with tempfile.TemporaryDirectory() as tmpdir: with tempfile.TemporaryDirectory() as tmpdir:
descriptor.write_classes(tmpdir, not args.no_init_py) descriptor.write_classes(tmpdir, not args.no_init_py, args.include_deprecated)
for filename in os.listdir(args.out_dir): for filename in os.listdir(args.out_dir):
pathname = os.path.join(args.out_dir, filename) pathname = os.path.join(args.out_dir, filename)

View File

@ -14,6 +14,7 @@ _Most likely to be released on July 1st._
- Dedicated `initialized` field in storage. - Dedicated `initialized` field in storage.
### Deprecated ### Deprecated
- Deprecate `Overwintered` field in `SignTx` and `TxAck`.
### Removed ### Removed

View File

@ -15,15 +15,12 @@ class EthereumAddress(p.MessageType):
def __init__( def __init__(
self, self,
old_address: bytes = None,
address: str = None, address: str = None,
) -> None: ) -> None:
self.old_address = old_address
self.address = address self.address = address
@classmethod @classmethod
def get_fields(cls) -> Dict: def get_fields(cls) -> Dict:
return { return {
1: ('old_address', p.BytesType, 0),
2: ('address', p.UnicodeType, 0), 2: ('address', p.UnicodeType, 0),
} }

View File

@ -16,17 +16,14 @@ class PassphraseAck(p.MessageType):
def __init__( def __init__(
self, self,
passphrase: str = None, passphrase: str = None,
_state: bytes = None,
on_device: bool = None, on_device: bool = None,
) -> None: ) -> None:
self.passphrase = passphrase self.passphrase = passphrase
self._state = _state
self.on_device = on_device self.on_device = on_device
@classmethod @classmethod
def get_fields(cls) -> Dict: def get_fields(cls) -> Dict:
return { return {
1: ('passphrase', p.UnicodeType, 0), 1: ('passphrase', p.UnicodeType, 0),
2: ('_state', p.BytesType, 0),
3: ('on_device', p.BoolType, 0), 3: ('on_device', p.BoolType, 0),
} }

View File

@ -12,15 +12,3 @@ if __debug__:
class PassphraseRequest(p.MessageType): class PassphraseRequest(p.MessageType):
MESSAGE_WIRE_TYPE = 41 MESSAGE_WIRE_TYPE = 41
def __init__(
self,
_on_device: bool = None,
) -> None:
self._on_device = _on_device
@classmethod
def get_fields(cls) -> Dict:
return {
1: ('_on_device', p.BoolType, 0),
}

View File

@ -24,6 +24,6 @@ EthereumMessageSignature.signature max_size:65
EthereumGetAddress.address_n max_count:8 EthereumGetAddress.address_n max_count:8
EthereumGetPublicKey.address_n max_count:8 EthereumGetPublicKey.address_n max_count:8
EthereumAddress.old_address max_size:20 EthereumAddress._old_address max_size:20
EthereumAddress.address max_size:43 EthereumAddress.address max_size:43
EthereumPublicKey.xpub max_size:113 EthereumPublicKey.xpub max_size:113

View File

@ -15,15 +15,15 @@ class EthereumAddress(p.MessageType):
def __init__( def __init__(
self, self,
old_address: bytes = None, _old_address: bytes = None,
address: str = None, address: str = None,
) -> None: ) -> None:
self.old_address = old_address self._old_address = _old_address
self.address = address self.address = address
@classmethod @classmethod
def get_fields(cls) -> Dict: def get_fields(cls) -> Dict:
return { return {
1: ('old_address', p.BytesType, 0), 1: ('_old_address', p.BytesType, 0),
2: ('address', p.UnicodeType, 0), 2: ('address', p.UnicodeType, 0),
} }

View File

@ -21,6 +21,7 @@ class SignTx(p.MessageType):
version: int = None, version: int = None,
lock_time: int = None, lock_time: int = None,
expiry: int = None, expiry: int = None,
_overwintered: bool = None,
version_group_id: int = None, version_group_id: int = None,
timestamp: int = None, timestamp: int = None,
branch_id: int = None, branch_id: int = None,
@ -31,6 +32,7 @@ class SignTx(p.MessageType):
self.version = version self.version = version
self.lock_time = lock_time self.lock_time = lock_time
self.expiry = expiry self.expiry = expiry
self._overwintered = _overwintered
self.version_group_id = version_group_id self.version_group_id = version_group_id
self.timestamp = timestamp self.timestamp = timestamp
self.branch_id = branch_id self.branch_id = branch_id
@ -44,6 +46,7 @@ class SignTx(p.MessageType):
4: ('version', p.UVarintType, 0), # default=1 4: ('version', p.UVarintType, 0), # default=1
5: ('lock_time', p.UVarintType, 0), # default=0 5: ('lock_time', p.UVarintType, 0), # default=0
6: ('expiry', p.UVarintType, 0), 6: ('expiry', p.UVarintType, 0),
7: ('_overwintered', p.BoolType, 0),
8: ('version_group_id', p.UVarintType, 0), 8: ('version_group_id', p.UVarintType, 0),
9: ('timestamp', p.UVarintType, 0), 9: ('timestamp', p.UVarintType, 0),
10: ('branch_id', p.UVarintType, 0), 10: ('branch_id', p.UVarintType, 0),

View File

@ -28,6 +28,7 @@ class TransactionType(p.MessageType):
extra_data: bytes = None, extra_data: bytes = None,
extra_data_len: int = None, extra_data_len: int = None,
expiry: int = None, expiry: int = None,
_overwintered: bool = None,
version_group_id: int = None, version_group_id: int = None,
timestamp: int = None, timestamp: int = None,
branch_id: int = None, branch_id: int = None,
@ -42,6 +43,7 @@ class TransactionType(p.MessageType):
self.extra_data = extra_data self.extra_data = extra_data
self.extra_data_len = extra_data_len self.extra_data_len = extra_data_len
self.expiry = expiry self.expiry = expiry
self._overwintered = _overwintered
self.version_group_id = version_group_id self.version_group_id = version_group_id
self.timestamp = timestamp self.timestamp = timestamp
self.branch_id = branch_id self.branch_id = branch_id
@ -59,6 +61,7 @@ class TransactionType(p.MessageType):
8: ('extra_data', p.BytesType, 0), 8: ('extra_data', p.BytesType, 0),
9: ('extra_data_len', p.UVarintType, 0), 9: ('extra_data_len', p.UVarintType, 0),
10: ('expiry', p.UVarintType, 0), 10: ('expiry', p.UVarintType, 0),
11: ('_overwintered', p.BoolType, 0),
12: ('version_group_id', p.UVarintType, 0), 12: ('version_group_id', p.UVarintType, 0),
13: ('timestamp', p.UVarintType, 0), 13: ('timestamp', p.UVarintType, 0),
14: ('branch_id', p.UVarintType, 0), 14: ('branch_id', p.UVarintType, 0),

View File

@ -114,6 +114,6 @@ else
fi fi
$func core/src/trezor/messages "$CORE_PROTOBUF_SOURCES" "$CORE_MESSAGES_IGNORE" TRUE --no-init-py $func core/src/trezor/messages "$CORE_PROTOBUF_SOURCES" "$CORE_MESSAGES_IGNORE" TRUE --no-init-py
$func python/src/trezorlib/messages "$PYTHON_PROTOBUF_SOURCES" "$PYTHON_MESSAGES_IGNORE" FALSE -P ..protobuf $func python/src/trezorlib/messages "$PYTHON_PROTOBUF_SOURCES" "$PYTHON_MESSAGES_IGNORE" FALSE --include-deprecated -P ..protobuf
exit $RETURN exit $RETURN