1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 20:11:00 +00:00

common/messages: Add credential management message.

This commit is contained in:
Andrew Kozlik 2019-09-01 22:54:34 +02:00
parent d1f36f42c0
commit 091053507d
18 changed files with 366 additions and 2 deletions

View File

@ -17,6 +17,8 @@ for fn in sorted(glob(os.path.join(MYDIR, "messages-*.proto"))):
continue continue
if prefix == "Nem": if prefix == "Nem":
prefix = "NEM" prefix = "NEM"
elif prefix == "Webauthn":
prefix = "WebAuthn"
for line in f: for line in f:
line = line.strip().split(" ") line = line.strip().split(" ")
if line[0] not in ["enum", "message"]: if line[0] not in ["enum", "message"]:

View 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;
}
}

View File

@ -237,4 +237,10 @@ enum MessageType {
MessageType_BinanceOrderMsg = 707 [(wire_in) = true]; MessageType_BinanceOrderMsg = 707 [(wire_in) = true];
MessageType_BinanceCancelMsg = 708 [(wire_in) = true]; MessageType_BinanceCancelMsg = 708 [(wire_in) = true];
MessageType_BinanceSignedTx = 709 [(wire_out) = 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];
} }

View File

@ -180,3 +180,7 @@ if not utils.BITCOIN_ONLY:
BinanceOrderMsg = 707 BinanceOrderMsg = 707
BinanceCancelMsg = 708 BinanceCancelMsg = 708
BinanceSignedTx = 709 BinanceSignedTx = 709
WebAuthnListResidentCredentials = 800
WebAuthnCredentials = 801
WebAuthnAddResidentCredential = 802
WebAuthnRemoveResidentCredential = 803

View 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),
}

View 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),
}

View 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),
}

View 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

View 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),
}

View File

@ -2,7 +2,7 @@ ifneq ($(V),1)
Q := @ Q := @
endif 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) ifeq ($(BITCOIN_ONLY), 1)
SKIPPED_MESSAGES += Ethereum Lisk NEM Stellar SKIPPED_MESSAGES += Ethereum Lisk NEM Stellar

View File

@ -177,3 +177,7 @@ BinanceTransferMsg = 706
BinanceOrderMsg = 707 BinanceOrderMsg = 707
BinanceCancelMsg = 708 BinanceCancelMsg = 708
BinanceSignedTx = 709 BinanceSignedTx = 709
WebAuthnListResidentCredentials = 800
WebAuthnCredentials = 801
WebAuthnAddResidentCredential = 802
WebAuthnRemoveResidentCredential = 803

View File

@ -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),
}

View 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),
}

View 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),
}

View File

@ -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

View File

@ -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),
}

View File

@ -247,6 +247,11 @@ from .TxRequest import TxRequest
from .TxRequestDetailsType import TxRequestDetailsType from .TxRequestDetailsType import TxRequestDetailsType
from .TxRequestSerializedType import TxRequestSerializedType from .TxRequestSerializedType import TxRequestSerializedType
from .VerifyMessage import VerifyMessage 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 .WipeDevice import WipeDevice
from .WordAck import WordAck from .WordAck import WordAck
from .WordRequest import WordRequest from .WordRequest import WordRequest

View File

@ -20,6 +20,7 @@ CORE_PROTOBUF_SOURCES="\
$PROTOB/messages-ripple.proto \ $PROTOB/messages-ripple.proto \
$PROTOB/messages-stellar.proto \ $PROTOB/messages-stellar.proto \
$PROTOB/messages-tezos.proto \ $PROTOB/messages-tezos.proto \
$PROTOB/messages-webauthn.proto \
" "
PYTHON_PROTOBUF_SOURCES=$PROTOB/*.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"/Capability.py
sed -i "3ifrom trezor import utils\n" "$DESTDIR"/MessageType.py sed -i "3ifrom trezor import utils\n" "$DESTDIR"/MessageType.py
sed -i "/^EthereumGetPublicKey/iif not utils.BITCOIN_ONLY:" "$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"/Capability.py
sed -i "s:^$altcoin: $altcoin:" "$DESTDIR"/MessageType.py sed -i "s:^$altcoin: $altcoin:" "$DESTDIR"/MessageType.py
done done