mirror of https://github.com/status-im/nim-abc.git
Add convenience method for signing transaction
This commit is contained in:
parent
1a0a96705b
commit
b0babf9962
|
@ -67,6 +67,9 @@ func toBytes*(transaction: Transaction): seq[byte] =
|
|||
func hash*(transaction: Transaction): TxHash =
|
||||
TxHash(sha256.digest(transaction.toBytes))
|
||||
|
||||
func sign*(key: PrivateKey, transaction: var Transaction) =
|
||||
transaction.add(key.sign(transaction.hash.toBytes))
|
||||
|
||||
func hasValidSignature*(transaction: Transaction): bool =
|
||||
if transaction.inputs.len == 0:
|
||||
return false
|
||||
|
|
|
@ -55,6 +55,12 @@ suite "Transactions":
|
|||
transaction.add(sig2)
|
||||
check transaction.signature == aggregate(sig1, sig2)
|
||||
|
||||
test "transaction can be signed by a private key":
|
||||
let key = PrivateKey.example
|
||||
var transaction = Transaction.example
|
||||
key.sign(transaction)
|
||||
check transaction.signature == key.sign(transaction.hash.toBytes)
|
||||
|
||||
test "transaction signature can be checked for validity":
|
||||
let genesis = !Transaction.init({alice: 32.u256, bob: 10.u256})
|
||||
check not genesis.hasValidSignature()
|
||||
|
|
Loading…
Reference in New Issue