tx · HvLzWnEnbnRDiLrf1iULerbBK5oahJMGfe6fqZgUJf64
3MvYrCuZcSEEpaonJMECNuAgua1N1pP4QLv: -0.01400000 Waves
2019.11.08 12:46 [755815] smart account 3MvYrCuZcSEEpaonJMECNuAgua1N1pP4QLv > SELF 0.00000000 Waves
{
"type": 13,
"id": "HvLzWnEnbnRDiLrf1iULerbBK5oahJMGfe6fqZgUJf64",
"fee": 1400000,
"feeAssetId": null,
"timestamp": 1573206439691,
"version": 1,
"sender": "3MvYrCuZcSEEpaonJMECNuAgua1N1pP4QLv",
"senderPublicKey": "8M3Q3Umd3j8Awzm99M79fM53H8ciKVWraTxGrf9qktxT",
"proofs": [
"23VeuuA4KAxf1mBq9tqz5cyoFZD13MM8zRadcRWbW8gcZW9Jtpmbmx9nyaPM32bZBg55rS2XUF8xpcoSUdXPxknN"
],
"script": "base64:AAIDAAAAAAAAAAgIARIECgICCAAAAAIBAAAADHRvQnl0ZVZlY3RvcgAAAAEAAAACYnYEAAAAByRtYXRjaDAFAAAAAmJ2AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAApCeXRlVmVjdG9yBAAAAANidjAFAAAAByRtYXRjaDAFAAAAA2J2MAkAAAIAAAABAgAAABNCeXRlVmVjdG9yIGV4cGVjdGVkAQAAAAhhc1N0cmluZwAAAAEAAAACYnYEAAAAByRtYXRjaDAFAAAAAmJ2AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAZTdHJpbmcEAAAAA2J2MAUAAAAHJG1hdGNoMAUAAAADYnYwCQAAAgAAAAECAAAAE0J5dGVWZWN0b3IgZXhwZWN0ZWQAAAABAAAAAWkBAAAAB3JlZ1VzZXIAAAACAAAACnVzZXJQdWJLZXkAAAAHbWVzc2FnZQkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkAASwAAAACAgAAAAt1c2VyUHViS2V5XwkAAlgAAAABBQAAAAp1c2VyUHViS2V5BQAAAAp1c2VyUHViS2V5CQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACAgAAAAdtZXNzYWdlBQAAAAdtZXNzYWdlBQAAAANuaWwAAAABAAAAAnR4AQAAAAh2ZXJpZmllcgAAAAAEAAAAByRtYXRjaDAFAAAAAnR4AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAABdJbnZva2VTY3JpcHRUcmFuc2FjdGlvbgQAAAADaW52BQAAAAckbWF0Y2gwAwkAAAAAAAACCAUAAAADaW52AAAACGZ1bmN0aW9uAgAAAAdyZWdVc2VyCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAAkAAlkAAAABCQEAAAAIYXNTdHJpbmcAAAABCQABkQAAAAIIBQAAAANpbnYAAAAEYXJncwAAAAAAAAAAAAkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAIBQAAAAJ0eAAAAA9zZW5kZXJQdWJsaWNLZXkJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAAACAUAAAACdHgAAAAPc2VuZGVyUHVibGljS2V5XHL+9g==",
"chainId": 84,
"height": 755815,
"spentComplexity": 0
}
View: original | compacted
Prev: BHjNFo7kcdE4qHjMro3YiHcaYWkcLyCYa8zbHJnaML5t
Next: 65FSLcRGS9dwGoQN4CS8TDR9hDBwpsaA35AuDfZwrGqB
Diff:
Old | New | | Differences |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | func toByteVector (bv) = match bv { |
---|
5 | 5 | | case bv0: ByteVector => |
---|
| 6 | + | bv0 |
---|
| 7 | + | case _ => |
---|
| 8 | + | throw("ByteVector expected") |
---|
| 9 | + | } |
---|
| 10 | + | |
---|
| 11 | + | |
---|
| 12 | + | func asString (bv) = match bv { |
---|
| 13 | + | case bv0: String => |
---|
6 | 14 | | bv0 |
---|
7 | 15 | | case _ => |
---|
8 | 16 | | throw("ByteVector expected") |
---|
|
17 | 25 | | func verifier () = match tx { |
---|
18 | 26 | | case inv: InvokeScriptTransaction => |
---|
19 | 27 | | if ((inv.function == "regUser")) |
---|
20 | | - | then sigVerify(tx.bodyBytes, tx.proofs[0], toByteVector(inv.args[0])) |
---|
| 28 | + | then sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(asString(inv.args[0]))) |
---|
21 | 29 | | else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) |
---|
22 | 30 | | case _ => |
---|
23 | 31 | | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 3 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | func toByteVector (bv) = match bv { |
---|
5 | 5 | | case bv0: ByteVector => |
---|
| 6 | + | bv0 |
---|
| 7 | + | case _ => |
---|
| 8 | + | throw("ByteVector expected") |
---|
| 9 | + | } |
---|
| 10 | + | |
---|
| 11 | + | |
---|
| 12 | + | func asString (bv) = match bv { |
---|
| 13 | + | case bv0: String => |
---|
6 | 14 | | bv0 |
---|
7 | 15 | | case _ => |
---|
8 | 16 | | throw("ByteVector expected") |
---|
9 | 17 | | } |
---|
10 | 18 | | |
---|
11 | 19 | | |
---|
12 | 20 | | @Callable(i) |
---|
13 | 21 | | func regUser (userPubKey,message) = WriteSet([DataEntry(("userPubKey_" + toBase58String(userPubKey)), userPubKey), DataEntry("message", message)]) |
---|
14 | 22 | | |
---|
15 | 23 | | |
---|
16 | 24 | | @Verifier(tx) |
---|
17 | 25 | | func verifier () = match tx { |
---|
18 | 26 | | case inv: InvokeScriptTransaction => |
---|
19 | 27 | | if ((inv.function == "regUser")) |
---|
20 | | - | then sigVerify(tx.bodyBytes, tx.proofs[0], toByteVector(inv.args[0])) |
---|
| 28 | + | then sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(asString(inv.args[0]))) |
---|
21 | 29 | | else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) |
---|
22 | 30 | | case _ => |
---|
23 | 31 | | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) |
---|
24 | 32 | | } |
---|
25 | 33 | | |
---|