tx · 2ZFMtc4A2cnP3zxHtBPqTTchtGxP1b4bkxuC8EvHgmPA 3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr: -0.05000000 Waves 2020.03.30 07:26 [931694] smart account 3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr > SELF 0.00000000 Waves
{ "type": 13, "id": "2ZFMtc4A2cnP3zxHtBPqTTchtGxP1b4bkxuC8EvHgmPA", "fee": 5000000, "feeAssetId": null, "timestamp": 1585542429079, "version": 1, "sender": "3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr", "senderPublicKey": "9oKyV5bddVGqz5B3JsNZ5BW8RTsyN1DTr5sftia2htBa", "proofs": [ "2fhqbJ8GEiednMvPMKRfNCWgLJNtxaq49HNv8RwPDHe1b6RT8XRr6xtzFBr9DU9XNKuGJoMgmv6xCDFDREZ5BrGn" ], "script": "base64:AAIDAAAAAAAAAAgIARIECgIICAAAAAYAAAAABE5PTkUCAAAABG5vbmUAAAAABU9XTkVSAgAAAAhCSVROT0RFUwAAAAAKTVVMVElPV05FUgcBAAAADmdldE51bWJlckJ5S2V5AAAAAQAAAANrZXkEAAAAA251bQQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAANrZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAABYQUAAAAHJG1hdGNoMAUAAAABYQAAAAAAAAAAAAUAAAADbnVtAQAAAAtnZXRTdHJCeUtleQAAAAEAAAADa2V5BAAAAANzdHIEAAAAByRtYXRjaDAJAAQdAAAAAgUAAAAEdGhpcwUAAAADa2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAZTdHJpbmcEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEFAAAABE5PTkUFAAAAA3N0cgEAAAAOYWRkTm9kZURldGFpbHMAAAACAAAABGFkZHIAAAADa2V5BAAAAANzdHIEAAAAByRtYXRjaDAJAAQdAAAAAgUAAAAEYWRkcgUAAAADa2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAZTdHJpbmcEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEFAAAABE5PTkUFAAAAA3N0cgAAAAEAAAABaQEAAAAHYWRkTm9kZQAAAAIAAAAEbm9kZQAAAAZzdGF0dXMEAAAACnNlbmRlckFkZHIJAAJYAAAAAQgIBQAAAAFpAAAABmNhbGxlcgAAAAVieXRlcwMJAQAAAAIhPQAAAAIJAQAAABFhZGRyZXNzRnJvbVN0cmluZwAAAAEFAAAACnNlbmRlckFkZHIFAAAABHRoaXMJAAACAAAAAQIAAAAaT3BlcmHDp8OjbyBuw6NvIGF1dG9yaXphZGEDCQAAAAAAAAIJAQAAABFhZGRyZXNzRnJvbVN0cmluZwAAAAEFAAAACnNlbmRlckFkZHIFAAAABHRoaXMJAAACAAAAAQIAAAAdIDIgT3BlcmHDp8OjbyBuw6NvIGF1dG9yaXphZGEJAQAAAAhXcml0ZVNldAAAAAEFAAAAA25pbAAAAAA9UodM", "chainId": 84, "height": 931694, "spentComplexity": 0 } View: original | compacted Prev: Gf3xSGK3xMVQCZGhxV2NWCCL3rWkCyhN2ZaZ5ZQZXWiC Next: HcDUc6akWrpZJNZrkQjkv9T1LXz4fRj9dtpYs5LNG7NB Diff:
Old | New | Differences | |
---|---|---|---|
42 | 42 | ||
43 | 43 | @Callable(i) | |
44 | 44 | func addNode (node,status) = { | |
45 | - | let senderAddr = extract(toBase58String(i.caller.bytes)) | |
46 | - | let nodeSC = addressFromPublicKey(fromBase58String(node)) | |
47 | - | let ownerID = addNodeDetails(nodeSC, "owner") | |
48 | - | let nodeAsset = addNodeDetails(nodeSC, "asset") | |
49 | - | if ((senderAddr != toString(this))) | |
45 | + | let senderAddr = toBase58String(i.caller.bytes) | |
46 | + | if ((addressFromString(senderAddr) != this)) | |
50 | 47 | then throw("Operação não autorizada") | |
51 | - | else if ((ownerID == NONE)) | |
52 | - | then throw("Propriedade não identificada") | |
53 | - | else if (if ((ownerID != OWNER)) | |
54 | - | then (MULTIOWNER == false) | |
55 | - | else false) | |
56 | - | then throw("Propriedade incorreta") | |
57 | - | else if ((nodeAsset == NONE)) | |
58 | - | then throw("Inconsistencia de dados do node") | |
59 | - | else if (if (if ((status != "ENABLED")) | |
60 | - | then true | |
61 | - | else (status != "DISABLED")) | |
62 | - | then true | |
63 | - | else (status != "NEW")) | |
64 | - | then throw("Status operacional inexistente") | |
65 | - | else { | |
66 | - | let nodeDetails = addNodeDetails(nodeSC, "details") | |
67 | - | WriteSet([DataEntry(nodeAsset, node), DataEntry((node + "_nodeSC"), toString(nodeSC)), DataEntry((node + "_nodeDetails"), nodeDetails), DataEntry((node + "_nodeStatus"), status)]) | |
68 | - | } | |
48 | + | else if ((addressFromString(senderAddr) == this)) | |
49 | + | then throw(" 2 Operação não autorizada") | |
50 | + | else WriteSet(nil) | |
69 | 51 | } | |
70 | 52 | ||
71 | 53 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let NONE = "none" | |
5 | 5 | ||
6 | 6 | let OWNER = "BITNODES" | |
7 | 7 | ||
8 | 8 | let MULTIOWNER = false | |
9 | 9 | ||
10 | 10 | func getNumberByKey (key) = { | |
11 | 11 | let num = match getInteger(this, key) { | |
12 | 12 | case a: Int => | |
13 | 13 | a | |
14 | 14 | case _ => | |
15 | 15 | 0 | |
16 | 16 | } | |
17 | 17 | num | |
18 | 18 | } | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | func getStrByKey (key) = { | |
22 | 22 | let str = match getString(this, key) { | |
23 | 23 | case a: String => | |
24 | 24 | a | |
25 | 25 | case _ => | |
26 | 26 | NONE | |
27 | 27 | } | |
28 | 28 | str | |
29 | 29 | } | |
30 | 30 | ||
31 | 31 | ||
32 | 32 | func addNodeDetails (addr,key) = { | |
33 | 33 | let str = match getString(addr, key) { | |
34 | 34 | case a: String => | |
35 | 35 | a | |
36 | 36 | case _ => | |
37 | 37 | NONE | |
38 | 38 | } | |
39 | 39 | str | |
40 | 40 | } | |
41 | 41 | ||
42 | 42 | ||
43 | 43 | @Callable(i) | |
44 | 44 | func addNode (node,status) = { | |
45 | - | let senderAddr = extract(toBase58String(i.caller.bytes)) | |
46 | - | let nodeSC = addressFromPublicKey(fromBase58String(node)) | |
47 | - | let ownerID = addNodeDetails(nodeSC, "owner") | |
48 | - | let nodeAsset = addNodeDetails(nodeSC, "asset") | |
49 | - | if ((senderAddr != toString(this))) | |
45 | + | let senderAddr = toBase58String(i.caller.bytes) | |
46 | + | if ((addressFromString(senderAddr) != this)) | |
50 | 47 | then throw("Operação não autorizada") | |
51 | - | else if ((ownerID == NONE)) | |
52 | - | then throw("Propriedade não identificada") | |
53 | - | else if (if ((ownerID != OWNER)) | |
54 | - | then (MULTIOWNER == false) | |
55 | - | else false) | |
56 | - | then throw("Propriedade incorreta") | |
57 | - | else if ((nodeAsset == NONE)) | |
58 | - | then throw("Inconsistencia de dados do node") | |
59 | - | else if (if (if ((status != "ENABLED")) | |
60 | - | then true | |
61 | - | else (status != "DISABLED")) | |
62 | - | then true | |
63 | - | else (status != "NEW")) | |
64 | - | then throw("Status operacional inexistente") | |
65 | - | else { | |
66 | - | let nodeDetails = addNodeDetails(nodeSC, "details") | |
67 | - | WriteSet([DataEntry(nodeAsset, node), DataEntry((node + "_nodeSC"), toString(nodeSC)), DataEntry((node + "_nodeDetails"), nodeDetails), DataEntry((node + "_nodeStatus"), status)]) | |
68 | - | } | |
48 | + | else if ((addressFromString(senderAddr) == this)) | |
49 | + | then throw(" 2 Operação não autorizada") | |
50 | + | else WriteSet(nil) | |
69 | 51 | } | |
70 | 52 | ||
71 | 53 |
github/deemru/w8io/169f3d6 30.65 ms ◑![]()