mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-19 03:40:59 +00:00
common/messages: Add credential management message.
This commit is contained in:
parent
d1f36f42c0
commit
091053507d
@ -17,6 +17,8 @@ for fn in sorted(glob(os.path.join(MYDIR, "messages-*.proto"))):
|
||||
continue
|
||||
if prefix == "Nem":
|
||||
prefix = "NEM"
|
||||
elif prefix == "Webauthn":
|
||||
prefix = "WebAuthn"
|
||||
for line in f:
|
||||
line = line.strip().split(" ")
|
||||
if line[0] not in ["enum", "message"]:
|
||||
|
56
common/protob/messages-webauthn.proto
Normal file
56
common/protob/messages-webauthn.proto
Normal file
@ -0,0 +1,56 @@
|
||||
syntax = "proto2";
|
||||
package hw.trezor.messages.webauthn;
|
||||
|
||||
// Sugar for easier handling in Java
|
||||
option java_package = "com.satoshilabs.trezor.lib.protobuf";
|
||||
option java_outer_classname = "TrezorMessageWebAuthn";
|
||||
|
||||
/**
|
||||
* Request: List resident credentials
|
||||
* @start
|
||||
* @next WebAuthnCredentials
|
||||
* @next Failure
|
||||
*/
|
||||
message WebAuthnListResidentCredentials {
|
||||
}
|
||||
|
||||
/**
|
||||
* Request: Add resident credential
|
||||
* @start
|
||||
* @next Success
|
||||
* @next Failure
|
||||
*/
|
||||
message WebAuthnAddResidentCredential {
|
||||
optional bytes credential_id = 1;
|
||||
}
|
||||
|
||||
/**
|
||||
* Request: Remove resident credential
|
||||
* @start
|
||||
* @next Success
|
||||
* @next Failure
|
||||
*/
|
||||
message WebAuthnRemoveResidentCredential {
|
||||
optional uint32 index = 1;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Response: Resident credential list
|
||||
* @start
|
||||
* @next end
|
||||
*/
|
||||
message WebAuthnCredentials {
|
||||
repeated WebAuthnCredential credentials = 1;
|
||||
message WebAuthnCredential {
|
||||
optional uint32 index = 1;
|
||||
optional bytes id = 2;
|
||||
optional string rp_id = 3;
|
||||
optional string rp_name = 4;
|
||||
optional bytes user_id = 5;
|
||||
optional string user_name = 6;
|
||||
optional string user_display_name = 7;
|
||||
optional uint32 creation_time = 8;
|
||||
optional bool hmac_secret = 9;
|
||||
}
|
||||
}
|
@ -237,4 +237,10 @@ enum MessageType {
|
||||
MessageType_BinanceOrderMsg = 707 [(wire_in) = true];
|
||||
MessageType_BinanceCancelMsg = 708 [(wire_in) = true];
|
||||
MessageType_BinanceSignedTx = 709 [(wire_out) = true];
|
||||
|
||||
// WebAuthn
|
||||
MessageType_WebAuthnListResidentCredentials = 800 [(wire_in) = true];
|
||||
MessageType_WebAuthnCredentials = 801 [(wire_out) = true];
|
||||
MessageType_WebAuthnAddResidentCredential = 802 [(wire_in) = true];
|
||||
MessageType_WebAuthnRemoveResidentCredential = 803 [(wire_in) = true];
|
||||
}
|
||||
|
@ -180,3 +180,7 @@ if not utils.BITCOIN_ONLY:
|
||||
BinanceOrderMsg = 707
|
||||
BinanceCancelMsg = 708
|
||||
BinanceSignedTx = 709
|
||||
WebAuthnListResidentCredentials = 800
|
||||
WebAuthnCredentials = 801
|
||||
WebAuthnAddResidentCredential = 802
|
||||
WebAuthnRemoveResidentCredential = 803
|
||||
|
26
core/src/trezor/messages/WebAuthnAddResidentCredential.py
Normal file
26
core/src/trezor/messages/WebAuthnAddResidentCredential.py
Normal file
@ -0,0 +1,26 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnAddResidentCredential(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 802
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
credential_id: bytes = None,
|
||||
) -> None:
|
||||
self.credential_id = credential_id
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('credential_id', p.BytesType, 0),
|
||||
}
|
49
core/src/trezor/messages/WebAuthnCredential.py
Normal file
49
core/src/trezor/messages/WebAuthnCredential.py
Normal file
@ -0,0 +1,49 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnCredential(p.MessageType):
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
index: int = None,
|
||||
id: bytes = None,
|
||||
rp_id: str = None,
|
||||
rp_name: str = None,
|
||||
user_id: bytes = None,
|
||||
user_name: str = None,
|
||||
user_display_name: str = None,
|
||||
creation_time: int = None,
|
||||
hmac_secret: bool = None,
|
||||
) -> None:
|
||||
self.index = index
|
||||
self.id = id
|
||||
self.rp_id = rp_id
|
||||
self.rp_name = rp_name
|
||||
self.user_id = user_id
|
||||
self.user_name = user_name
|
||||
self.user_display_name = user_display_name
|
||||
self.creation_time = creation_time
|
||||
self.hmac_secret = hmac_secret
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('index', p.UVarintType, 0),
|
||||
2: ('id', p.BytesType, 0),
|
||||
3: ('rp_id', p.UnicodeType, 0),
|
||||
4: ('rp_name', p.UnicodeType, 0),
|
||||
5: ('user_id', p.BytesType, 0),
|
||||
6: ('user_name', p.UnicodeType, 0),
|
||||
7: ('user_display_name', p.UnicodeType, 0),
|
||||
8: ('creation_time', p.UVarintType, 0),
|
||||
9: ('hmac_secret', p.BoolType, 0),
|
||||
}
|
28
core/src/trezor/messages/WebAuthnCredentials.py
Normal file
28
core/src/trezor/messages/WebAuthnCredentials.py
Normal file
@ -0,0 +1,28 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
import protobuf as p
|
||||
|
||||
from .WebAuthnCredential import WebAuthnCredential
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnCredentials(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 801
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
credentials: List[WebAuthnCredential] = None,
|
||||
) -> None:
|
||||
self.credentials = credentials if credentials is not None else []
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('credentials', WebAuthnCredential, p.FLAG_REPEATED),
|
||||
}
|
14
core/src/trezor/messages/WebAuthnListResidentCredentials.py
Normal file
14
core/src/trezor/messages/WebAuthnListResidentCredentials.py
Normal file
@ -0,0 +1,14 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnListResidentCredentials(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 800
|
26
core/src/trezor/messages/WebAuthnRemoveResidentCredential.py
Normal file
26
core/src/trezor/messages/WebAuthnRemoveResidentCredential.py
Normal file
@ -0,0 +1,26 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnRemoveResidentCredential(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 803
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
index: int = None,
|
||||
) -> None:
|
||||
self.index = index
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('index', p.UVarintType, 0),
|
||||
}
|
@ -2,7 +2,7 @@ ifneq ($(V),1)
|
||||
Q := @
|
||||
endif
|
||||
|
||||
SKIPPED_MESSAGES := Binance Cardano DebugMonero Eos Monero Ontology Ripple Tezos
|
||||
SKIPPED_MESSAGES := Binance Cardano DebugMonero Eos Monero Ontology Ripple Tezos WebAuthn
|
||||
|
||||
ifeq ($(BITCOIN_ONLY), 1)
|
||||
SKIPPED_MESSAGES += Ethereum Lisk NEM Stellar
|
||||
|
@ -177,3 +177,7 @@ BinanceTransferMsg = 706
|
||||
BinanceOrderMsg = 707
|
||||
BinanceCancelMsg = 708
|
||||
BinanceSignedTx = 709
|
||||
WebAuthnListResidentCredentials = 800
|
||||
WebAuthnCredentials = 801
|
||||
WebAuthnAddResidentCredential = 802
|
||||
WebAuthnRemoveResidentCredential = 803
|
||||
|
@ -0,0 +1,26 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
from .. import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnAddResidentCredential(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 802
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
credential_id: bytes = None,
|
||||
) -> None:
|
||||
self.credential_id = credential_id
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('credential_id', p.BytesType, 0),
|
||||
}
|
49
python/src/trezorlib/messages/WebAuthnCredential.py
Normal file
49
python/src/trezorlib/messages/WebAuthnCredential.py
Normal file
@ -0,0 +1,49 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
from .. import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnCredential(p.MessageType):
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
index: int = None,
|
||||
id: bytes = None,
|
||||
rp_id: str = None,
|
||||
rp_name: str = None,
|
||||
user_id: bytes = None,
|
||||
user_name: str = None,
|
||||
user_display_name: str = None,
|
||||
creation_time: int = None,
|
||||
hmac_secret: bool = None,
|
||||
) -> None:
|
||||
self.index = index
|
||||
self.id = id
|
||||
self.rp_id = rp_id
|
||||
self.rp_name = rp_name
|
||||
self.user_id = user_id
|
||||
self.user_name = user_name
|
||||
self.user_display_name = user_display_name
|
||||
self.creation_time = creation_time
|
||||
self.hmac_secret = hmac_secret
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('index', p.UVarintType, 0),
|
||||
2: ('id', p.BytesType, 0),
|
||||
3: ('rp_id', p.UnicodeType, 0),
|
||||
4: ('rp_name', p.UnicodeType, 0),
|
||||
5: ('user_id', p.BytesType, 0),
|
||||
6: ('user_name', p.UnicodeType, 0),
|
||||
7: ('user_display_name', p.UnicodeType, 0),
|
||||
8: ('creation_time', p.UVarintType, 0),
|
||||
9: ('hmac_secret', p.BoolType, 0),
|
||||
}
|
28
python/src/trezorlib/messages/WebAuthnCredentials.py
Normal file
28
python/src/trezorlib/messages/WebAuthnCredentials.py
Normal file
@ -0,0 +1,28 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
from .. import protobuf as p
|
||||
|
||||
from .WebAuthnCredential import WebAuthnCredential
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnCredentials(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 801
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
credentials: List[WebAuthnCredential] = None,
|
||||
) -> None:
|
||||
self.credentials = credentials if credentials is not None else []
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('credentials', WebAuthnCredential, p.FLAG_REPEATED),
|
||||
}
|
@ -0,0 +1,14 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
from .. import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnListResidentCredentials(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 800
|
@ -0,0 +1,26 @@
|
||||
# Automatically generated by pb2py
|
||||
# fmt: off
|
||||
from .. import protobuf as p
|
||||
|
||||
if __debug__:
|
||||
try:
|
||||
from typing import Dict, List, Optional
|
||||
from typing_extensions import Literal # noqa: F401
|
||||
except ImportError:
|
||||
Dict, List, Optional = None, None, None # type: ignore
|
||||
|
||||
|
||||
class WebAuthnRemoveResidentCredential(p.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 803
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
index: int = None,
|
||||
) -> None:
|
||||
self.index = index
|
||||
|
||||
@classmethod
|
||||
def get_fields(cls) -> Dict:
|
||||
return {
|
||||
1: ('index', p.UVarintType, 0),
|
||||
}
|
@ -247,6 +247,11 @@ from .TxRequest import TxRequest
|
||||
from .TxRequestDetailsType import TxRequestDetailsType
|
||||
from .TxRequestSerializedType import TxRequestSerializedType
|
||||
from .VerifyMessage import VerifyMessage
|
||||
from .WebAuthnAddResidentCredential import WebAuthnAddResidentCredential
|
||||
from .WebAuthnCredential import WebAuthnCredential
|
||||
from .WebAuthnCredentials import WebAuthnCredentials
|
||||
from .WebAuthnListResidentCredentials import WebAuthnListResidentCredentials
|
||||
from .WebAuthnRemoveResidentCredential import WebAuthnRemoveResidentCredential
|
||||
from .WipeDevice import WipeDevice
|
||||
from .WordAck import WordAck
|
||||
from .WordRequest import WordRequest
|
||||
|
@ -20,6 +20,7 @@ CORE_PROTOBUF_SOURCES="\
|
||||
$PROTOB/messages-ripple.proto \
|
||||
$PROTOB/messages-stellar.proto \
|
||||
$PROTOB/messages-tezos.proto \
|
||||
$PROTOB/messages-webauthn.proto \
|
||||
"
|
||||
|
||||
PYTHON_PROTOBUF_SOURCES=$PROTOB/*.proto
|
||||
@ -72,7 +73,7 @@ do_rebuild() {
|
||||
sed -i "3ifrom trezor import utils\n" "$DESTDIR"/Capability.py
|
||||
sed -i "3ifrom trezor import utils\n" "$DESTDIR"/MessageType.py
|
||||
sed -i "/^EthereumGetPublicKey/iif not utils.BITCOIN_ONLY:" "$DESTDIR"/MessageType.py
|
||||
for altcoin in Ethereum NEM Lisk Tezos Stellar Cardano Ripple Monero DebugMonero Eos Binance; do
|
||||
for altcoin in Ethereum NEM Lisk Tezos Stellar Cardano Ripple Monero DebugMonero Eos Binance WebAuthn; do
|
||||
sed -i "s:^$altcoin: $altcoin:" "$DESTDIR"/Capability.py
|
||||
sed -i "s:^$altcoin: $altcoin:" "$DESTDIR"/MessageType.py
|
||||
done
|
||||
|
Loading…
Reference in New Issue
Block a user