tx · Gf3xSGK3xMVQCZGhxV2NWCCL3rWkCyhN2ZaZ5ZQZXWiC 3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr: -0.05000000 Waves 2020.03.30 07:16 [931684] smart account 3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr > SELF 0.00000000 Waves
{ "type": 13, "id": "Gf3xSGK3xMVQCZGhxV2NWCCL3rWkCyhN2ZaZ5ZQZXWiC", "fee": 5000000, "feeAssetId": null, "timestamp": 1585541702789, "version": 1, "sender": "3MtqLwWMkKYPCKTnEqVaErLLsQJgXs7bqnr", "senderPublicKey": "9oKyV5bddVGqz5B3JsNZ5BW8RTsyN1DTr5sftia2htBa", "proofs": [ "sP85KJHr48YyMQfX6L8pmQL2J1qfccqL1o4sQgAcP2QxkuC1SQWGwKB4TN1YZkhmtrsqyRWDDevQiDgZAfxMHHK" ], "script": "base64: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", "chainId": 84, "height": 931684, "spentComplexity": 0 } View: original | compacted Prev: F89EhQHH5NkZWoQHrRPMHqz3cJ3BhEdRau9rhvTJ4JTZ Next: 2ZFMtc4A2cnP3zxHtBPqTTchtGxP1b4bkxuC8EvHgmPA Diff:
Old | New | Differences | |
---|---|---|---|
41 | 41 | ||
42 | 42 | ||
43 | 43 | @Callable(i) | |
44 | - | func addNode (node) = { | |
45 | - | let senderAddr = toBase58String(i.caller.bytes) | |
44 | + | func addNode (node,status) = { | |
45 | + | let senderAddr = extract(toBase58String(i.caller.bytes)) | |
46 | 46 | let nodeSC = addressFromPublicKey(fromBase58String(node)) | |
47 | 47 | let ownerID = addNodeDetails(nodeSC, "owner") | |
48 | 48 | let nodeAsset = addNodeDetails(nodeSC, "asset") | |
56 | 56 | then throw("Propriedade incorreta") | |
57 | 57 | else if ((nodeAsset == NONE)) | |
58 | 58 | then throw("Inconsistencia de dados do node") | |
59 | - | else { | |
60 | - | let nodeDetails = addNodeDetails(nodeSC, "details") | |
61 | - | WriteSet([DataEntry(nodeAsset, node), DataEntry((node + "_nodeSC"), toString(nodeSC)), DataEntry((node + "_nodeDetails"), nodeDetails), DataEntry((node + "_nodeStatus"), "DISABLED")]) | |
62 | - | } | |
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 | + | } | |
63 | 69 | } | |
64 | 70 | ||
65 | 71 |
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 | - | func addNode (node) = { | |
45 | - | let senderAddr = toBase58String(i.caller.bytes) | |
44 | + | func addNode (node,status) = { | |
45 | + | let senderAddr = extract(toBase58String(i.caller.bytes)) | |
46 | 46 | let nodeSC = addressFromPublicKey(fromBase58String(node)) | |
47 | 47 | let ownerID = addNodeDetails(nodeSC, "owner") | |
48 | 48 | let nodeAsset = addNodeDetails(nodeSC, "asset") | |
49 | 49 | if ((senderAddr != toString(this))) | |
50 | 50 | then throw("Operação não autorizada") | |
51 | 51 | else if ((ownerID == NONE)) | |
52 | 52 | then throw("Propriedade não identificada") | |
53 | 53 | else if (if ((ownerID != OWNER)) | |
54 | 54 | then (MULTIOWNER == false) | |
55 | 55 | else false) | |
56 | 56 | then throw("Propriedade incorreta") | |
57 | 57 | else if ((nodeAsset == NONE)) | |
58 | 58 | then throw("Inconsistencia de dados do node") | |
59 | - | else { | |
60 | - | let nodeDetails = addNodeDetails(nodeSC, "details") | |
61 | - | WriteSet([DataEntry(nodeAsset, node), DataEntry((node + "_nodeSC"), toString(nodeSC)), DataEntry((node + "_nodeDetails"), nodeDetails), DataEntry((node + "_nodeStatus"), "DISABLED")]) | |
62 | - | } | |
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 | + | } | |
63 | 69 | } | |
64 | 70 | ||
65 | 71 |
github/deemru/w8io/169f3d6 30.88 ms ◑![]()