2019-03-19 00:34:01 +01:00
|
|
|
from binascii import unhexlify
|
|
|
|
|
2019-12-31 21:30:13 +01:00
|
|
|
from lbry.testcase import AsyncioTestCase
|
2020-01-03 07:55:19 +01:00
|
|
|
from lbry.wallet.constants import CENT, NULL_HASH32
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2020-01-03 04:18:49 +01:00
|
|
|
from lbry.wallet import Ledger, Database, Headers, Transaction, Input, Output
|
2019-06-21 03:02:58 +02:00
|
|
|
from lbry.schema.claim import Claim
|
2019-03-20 06:46:23 +01:00
|
|
|
|
|
|
|
|
|
|
|
def get_output(amount=CENT, pubkey_hash=NULL_HASH32):
|
|
|
|
return Transaction() \
|
|
|
|
.add_outputs([Output.pay_pubkey_hash(amount, pubkey_hash)]) \
|
|
|
|
.outputs[0]
|
|
|
|
|
|
|
|
|
|
|
|
def get_input():
|
|
|
|
return Input.spend(get_output())
|
|
|
|
|
|
|
|
|
|
|
|
def get_tx():
|
|
|
|
return Transaction().add_inputs([get_input()])
|
|
|
|
|
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def get_channel(claim_name='@foo'):
|
2019-06-13 02:25:32 +02:00
|
|
|
channel_txo = Output.pay_claim_name_pubkey_hash(CENT, claim_name, Claim(), b'abc')
|
2020-05-11 20:10:34 +02:00
|
|
|
await channel_txo.generate_channel_private_key()
|
2019-06-13 02:25:32 +02:00
|
|
|
get_tx().add_outputs([channel_txo])
|
|
|
|
return channel_txo
|
|
|
|
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2019-06-13 02:25:32 +02:00
|
|
|
def get_stream(claim_name='foo'):
|
|
|
|
stream_txo = Output.pay_claim_name_pubkey_hash(CENT, claim_name, Claim(), b'abc')
|
|
|
|
get_tx().add_outputs([stream_txo])
|
|
|
|
return stream_txo
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2019-06-13 02:25:32 +02:00
|
|
|
|
|
|
|
class TestSigningAndValidatingClaim(AsyncioTestCase):
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def test_successful_create_sign_and_validate(self):
|
|
|
|
channel = await get_channel()
|
2019-06-13 02:25:32 +02:00
|
|
|
stream = get_stream()
|
2019-03-20 06:46:23 +01:00
|
|
|
stream.sign(channel)
|
|
|
|
self.assertTrue(stream.is_signed_by(channel))
|
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def test_fail_to_validate_on_wrong_channel(self):
|
2019-06-13 02:25:32 +02:00
|
|
|
stream = get_stream()
|
2020-05-11 20:10:34 +02:00
|
|
|
stream.sign(await get_channel())
|
|
|
|
self.assertFalse(stream.is_signed_by(await get_channel()))
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def test_fail_to_validate_altered_claim(self):
|
|
|
|
channel = await get_channel()
|
2019-06-13 02:25:32 +02:00
|
|
|
stream = get_stream()
|
2019-03-20 06:46:23 +01:00
|
|
|
stream.sign(channel)
|
|
|
|
self.assertTrue(stream.is_signed_by(channel))
|
|
|
|
stream.claim.stream.title = 'hello'
|
2019-05-05 04:15:25 +02:00
|
|
|
self.assertFalse(stream.is_signed_by(channel))
|
2019-03-20 06:46:23 +01:00
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def test_valid_private_key_for_cert(self):
|
|
|
|
channel = await get_channel()
|
2019-03-20 06:46:23 +01:00
|
|
|
self.assertTrue(channel.is_channel_private_key(channel.private_key))
|
|
|
|
|
2020-05-11 20:10:34 +02:00
|
|
|
async def test_fail_to_load_wrong_private_key_for_cert(self):
|
|
|
|
channel = await get_channel()
|
|
|
|
self.assertFalse(channel.is_channel_private_key((await get_channel()).private_key))
|
2019-03-19 00:34:01 +01:00
|
|
|
|
|
|
|
|
2019-03-20 06:46:23 +01:00
|
|
|
class TestValidatingOldSignatures(AsyncioTestCase):
|
2019-03-19 00:34:01 +01:00
|
|
|
|
|
|
|
def test_signed_claim_made_by_ytsync(self):
|
|
|
|
stream_tx = Transaction(unhexlify(
|
|
|
|
b'0100000001eb2a756e15bde95db3d2ae4a6e9b2796a699087890644607b5b04a5f15b67062010000006a4'
|
|
|
|
b'7304402206444b920bd318a07d9b982e30eb66245fdaaa6c9866e1f6e5900161d9b0ffd70022036464714'
|
|
|
|
b'4f1830898a2042aa0d6cef95a243799cc6e36630a58d411e2f9111f00121029b15f9a00a7c3f21b10bd4b'
|
|
|
|
b'98ab23a9e895bd9160e21f71317862bf55fbbc89effffffff0240420f0000000000fd1503b52268657265'
|
|
|
|
b'2d6172652d352d726561736f6e732d692d6e657874636c6f75642d746c674dd302080110011aee0408011'
|
|
|
|
b'2a604080410011a2b4865726520617265203520526561736f6e73204920e29da4efb88f204e657874636c'
|
|
|
|
b'6f7564207c20544c4722920346696e64206f7574206d6f72652061626f7574204e657874636c6f75643a2'
|
|
|
|
b'068747470733a2f2f6e657874636c6f75642e636f6d2f0a0a596f752063616e2066696e64206d65206f6e'
|
|
|
|
b'20746865736520736f6369616c733a0a202a20466f72756d733a2068747470733a2f2f666f72756d2e686'
|
|
|
|
b'5617679656c656d656e742e696f2f0a202a20506f64636173743a2068747470733a2f2f6f6666746f7069'
|
|
|
|
b'63616c2e6e65740a202a2050617472656f6e3a2068747470733a2f2f70617472656f6e2e636f6d2f74686'
|
|
|
|
b'56c696e757867616d65720a202a204d657263683a2068747470733a2f2f746565737072696e672e636f6d'
|
|
|
|
b'2f73746f7265732f6f6666696369616c2d6c696e75782d67616d65720a202a205477697463683a2068747'
|
|
|
|
b'470733a2f2f7477697463682e74762f786f6e64616b0a202a20547769747465723a2068747470733a2f2f'
|
|
|
|
b'747769747465722e636f6d2f7468656c696e757867616d65720a0a2e2e2e0a68747470733a2f2f7777772'
|
|
|
|
b'e796f75747562652e636f6d2f77617463683f763d4672546442434f535f66632a0f546865204c696e7578'
|
|
|
|
b'2047616d6572321c436f7079726967687465642028636f6e7461637420617574686f722938004a2968747'
|
|
|
|
b'470733a2f2f6265726b2e6e696e6a612f7468756d626e61696c732f4672546442434f535f666352005a00'
|
|
|
|
b'1a41080110011a30040e8ac6e89c061f982528c23ad33829fd7146435bf7a4cc22f0bff70c4fe0b91fd36'
|
|
|
|
b'da9a375e3e1c171db825bf5d1f32209766964656f2f6d70342a5c080110031a4062b2dd4c45e364030fbf'
|
|
|
|
b'ad1a6fefff695ebf20ea33a5381b947753e2a0ca359989a5cc7d15e5392a0d354c0b68498382b2701b22c'
|
|
|
|
b'03beb8dcb91089031b871e72214feb61536c007cdf4faeeaab4876cb397feaf6b516d7576a914f4f43f6f'
|
|
|
|
b'7a472bbf27fa3630329f771135fc445788ac86ff0600000000001976a914cef0fe3eeaf04416f0c3ff3e7'
|
|
|
|
b'8a598a081e70ee788ac00000000'
|
|
|
|
))
|
|
|
|
stream = stream_tx.outputs[0]
|
|
|
|
|
|
|
|
channel_tx = Transaction(unhexlify(
|
|
|
|
b'010000000192a1e1e3f66b8ca05a021cfa5fb6645ebc066b46639ccc9b3781fa588a88da65010000006a4'
|
|
|
|
b'7304402206be09a355f6abea8a10b5512180cd258460b42d516b5149431ffa3230a02533a0220325e83c6'
|
|
|
|
b'176b295d633b18aad67adb4ad766d13152536ac04583f86d14645c9901210269c63bc8bac8143ef02f972'
|
|
|
|
b'4a4ab35b12bdfa65ee1ad8c0db3d6511407a4cc2effffffff0240420f000000000091b50e405468654c69'
|
|
|
|
b'6e757847616d65724c6408011002225e0801100322583056301006072a8648ce3d020106052b8104000a0'
|
|
|
|
b'34200043878b1edd4a1373149909ef03f4339f6da9c2bd2214c040fd2e530463ffe66098eca14fc70b50f'
|
|
|
|
b'f3aefd106049a815f595ed5a13eda7419ad78d9ed7ae473f176d7576a914994dad5f21c384ff526749b87'
|
|
|
|
b'6d9d017d257b69888ac00dd6d00000000001976a914979202508a44f0e8290cea80787c76f98728845388'
|
|
|
|
b'ac00000000'
|
|
|
|
))
|
|
|
|
channel = channel_tx.outputs[0]
|
|
|
|
|
2020-01-03 04:18:49 +01:00
|
|
|
ledger = Ledger({
|
|
|
|
'db': Database(':memory:'),
|
|
|
|
'headers': Headers(':memory:')
|
2019-03-19 00:34:01 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
self.assertTrue(stream.is_signed_by(channel, ledger))
|