def test_ecdh(self): self.setup_mnemonic_nopin_nopassphrase() # URI : gpg://Satoshi Nakamoto <*****@*****.**> identity = proto.IdentityType( proto="gpg", user="", host="Satoshi Nakamoto <*****@*****.**>", port="", path="", index=0, ) peer_public_key = bytes.fromhex( "0407f2c6e5becf3213c1d07df0cfbe8e39f70a8c643df7575e5c56859ec52c45ca950499c019719dae0fda04248d851e52cf9d66eeb211d89a77be40de22b6c89d" ) result = misc.get_ecdh_session_key( self.client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="secp256k1", ) assert ( result.session_key.hex() == "0495e5d8c9e5cc09e7cf4908774f52decb381ce97f2fc9ba56e959c13f03f9f47a03dd151cbc908bc1db84d46e2c33e7bbb9daddc800f985244c924fd64adf6647" ) peer_public_key = bytes.fromhex( "04811a6c2bd2a547d0dd84747297fec47719e7c3f9b0024f027c2b237be99aac39a9230acbd163d0cb1524a0f5ea4bfed6058cec6f18368f72a12aa0c4d083ff64" ) result = misc.get_ecdh_session_key( self.client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="nist256p1", ) assert ( result.session_key.hex() == "046d1f5c48af2cf2c57076ac2c9d7808db2086f614cb7b8107119ff2c6270cd209749809efe0196f01a0cc633788cef1f4a2bd650c99570d06962f923fca6d8fdf" ) peer_public_key = bytes.fromhex( "40a8cf4b6a64c4314e80f15a8ea55812bd735fbb365936a48b2d78807b575fa17a" ) result = misc.get_ecdh_session_key( self.client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="curve25519", ) assert ( result.session_key.hex() == "04e24516669e0b7d3d72e5129fddd07b6644c30915f5c8b7f1f62324afb3624311" )
def test_ecdh(client): identity = messages.IdentityType( proto="gpg", user="", host="Satoshi Nakamoto <*****@*****.**>", port="", path="", index=0, ) peer_public_key = bytes.fromhex( "0407f2c6e5becf3213c1d07df0cfbe8e39f70a8c643df7575e5c56859ec52c45ca950499c019719dae0fda04248d851e52cf9d66eeb211d89a77be40de22b6c89d" ) result = misc.get_ecdh_session_key( client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="secp256k1", ) assert ( result.session_key.hex() == "0495e5d8c9e5cc09e7cf4908774f52decb381ce97f2fc9ba56e959c13f03f9f47a03dd151cbc908bc1db84d46e2c33e7bbb9daddc800f985244c924fd64adf6647" ) assert (result.public_key.hex( ) == "02a3b34db999f994aa91accb7b73ecafe0ce8ce228e17a45525ccbf73feeb7c809") peer_public_key = bytes.fromhex( "04811a6c2bd2a547d0dd84747297fec47719e7c3f9b0024f027c2b237be99aac39a9230acbd163d0cb1524a0f5ea4bfed6058cec6f18368f72a12aa0c4d083ff64" ) result = misc.get_ecdh_session_key( client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="nist256p1", ) assert ( result.session_key.hex() == "046d1f5c48af2cf2c57076ac2c9d7808db2086f614cb7b8107119ff2c6270cd209749809efe0196f01a0cc633788cef1f4a2bd650c99570d06962f923fca6d8fdf" ) assert (result.public_key.hex( ) == "03fda61bc6e6be9b1dd99f7f9d04836d1bf2a6ea2426095210c8ce65091b09000a") peer_public_key = bytes.fromhex( "40a8cf4b6a64c4314e80f15a8ea55812bd735fbb365936a48b2d78807b575fa17a") result = misc.get_ecdh_session_key( client, identity=identity, peer_public_key=peer_public_key, ecdsa_curve_name="curve25519", ) assert (result.session_key.hex( ) == "04e24516669e0b7d3d72e5129fddd07b6644c30915f5c8b7f1f62324afb3624311") assert (result.public_key.hex( ) == "019753a0738c55c7ba7c17dd4a9a975ce9b0d2b62e8a1ecef4a76767fad99d3c71")
def test_sign(self): self.setup_mnemonic_nopin_nopassphrase() hidden = bytes.fromhex( "cd8552569d6e4509266ef137584d1e62c7579b5b8ed69bbafa4b864c6521e7c2") visual = "2015-03-23 17:39:22" # URI : https://[email protected]/login # hash : d0e2389d4c8394a9f3e32de01104bf6e8db2d9e2bb0905d60fffa5a18fd696db # path : m/2147483661/2637750992/2845082444/3761103859/4005495825 identity = proto.IdentityType( proto="https", user="******", host="bitcoin.org", port="", path="/login", index=0, ) sig = misc.sign_identity(self.client, identity, hidden, visual) assert sig.address == "17F17smBTX9VTZA9Mj8LM5QGYNZnmziCjL" assert ( sig.public_key.hex() == "023a472219ad3327b07c18273717bb3a40b39b743756bf287fbd5fa9d263237f45" ) assert ( sig.signature.hex() == "20f2d1a42d08c3a362be49275c3ffeeaa415fc040971985548b9f910812237bb41770bf2c8d488428799fbb7e52c11f1a3404011375e4080e077e0e42ab7a5ba02" ) # URI : ftp://[email protected]:2323/pub # hash : 79a6b53831c6ff224fb283587adc4ebae8fb0d734734a46c876838f52dff53f3 # path : m/2147483661/3098912377/2734671409/3632509519/3125730426 identity = proto.IdentityType( proto="ftp", user="******", host="bitcoin.org", port="2323", path="/pub", index=3, ) sig = misc.sign_identity(self.client, identity, hidden, visual) assert sig.address == "1KAr6r5qF2kADL8bAaRQBjGKYEGxn9WrbS" assert ( sig.public_key.hex() == "0266cf12d2ba381c5fd797da0d64f59c07a6f1b034ad276cca6bf2729e92b20d9c" ) assert ( sig.signature.hex() == "20bbd12dc657d534fc0f7e40186e22c447e0866a016f654f380adffa9a84e9faf412a1bb0ae908296537838cf91145e77da08681c63d07b7dca40728b9e6cb17cf" ) # URI : ssh://[email protected] # hash : 5fa612f558a1a3b1fb7f010b2ea0a25cb02520a0ffa202ce74a92fc6145da5f3 # path : m/2147483661/4111640159/2980290904/2332131323/3701645358 identity = proto.IdentityType(proto="ssh", user="******", host="bitcoin.org", port="", path="", index=47) sig = misc.sign_identity(self.client, identity, hidden, visual, ecdsa_curve_name="nist256p1") assert sig.address is None assert ( sig.public_key.hex() == "0373f21a3da3d0e96fc2189f81dd826658c3d76b2d55bd1da349bc6c3573b13ae4" ) assert ( sig.signature.hex() == "005122cebabb852cdd32103b602662afa88e54c0c0c1b38d7099c64dcd49efe908288114e66ed2d8c82f23a70b769a4db723173ec53840c08aafb840d3f09a18d3" ) # URI : ssh://[email protected] # hash : 5fa612f558a1a3b1fb7f010b2ea0a25cb02520a0ffa202ce74a92fc6145da5f3 # path : m/2147483661/4111640159/2980290904/2332131323/3701645358 identity = proto.IdentityType(proto="ssh", user="******", host="bitcoin.org", port="", path="", index=47) sig = misc.sign_identity(self.client, identity, hidden, visual, ecdsa_curve_name="ed25519") assert sig.address is None assert ( sig.public_key.hex() == "000fac2a491e0f5b871dc48288a4cae551bac5cb0ed19df0764d6e721ec5fade18" ) assert ( sig.signature.hex() == "00f05e5085e666429de397c70a081932654369619c0bd2a6579ea6c1ef2af112ef79998d6c862a16b932d44b1ac1b83c8cbcd0fbda228274fde9e0d0ca6e9cb709" )