tx · 5Fquvgx8weY4n2UPtPBLWwkXcSTjf7sYAsBx5aza497h 3N54eKW5ZucDaRaGVUfzX8xRXv6Ve8M71tM: -0.01400000 Waves 2020.06.23 12:03 [1056080] smart account 3N54eKW5ZucDaRaGVUfzX8xRXv6Ve8M71tM > SELF 0.00000000 Waves
{ "type": 13, "id": "5Fquvgx8weY4n2UPtPBLWwkXcSTjf7sYAsBx5aza497h", "fee": 1400000, "feeAssetId": null, "timestamp": 1592903024779, "version": 1, "sender": "3N54eKW5ZucDaRaGVUfzX8xRXv6Ve8M71tM", "senderPublicKey": "FmnQ1LwTnauTS2BSrZivE1nSF1A9MY9hyYB72pyh5hw9", "proofs": [ "2x6YCD1jHZsJJh6PbvK9K5J32FCGaLX5qEDemd1yd1ZP8w8J71UkwZrp5AEPqEmSCEWwYmwgQAznRnYp6Az43ofH" ], "script": "base64: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", "chainId": 84, "height": 1056080, "spentComplexity": 0 } View: original | compacted Prev: 95stM5fJRWAfEb8us4NJefLES14XPQez2eSwfGXpABEv Next: AX5kXmqZ93zb7GiVCSLNtpZosLqJjdWNB9gS7u2t2M7H Diff:
Old | New | Differences | |
---|---|---|---|
7 | 7 | then throw("decode u8 error, decoding is finish") | |
8 | 8 | else { | |
9 | 9 | let x0 = take(drop(data, offset), 1) | |
10 | - | let x1 = toInt((base58'1111111' + x0), 0) | |
11 | - | if ((128 > x1)) | |
12 | - | then [x1, (offset + 1)] | |
13 | - | else [toInt((base58'1111111' + x0), 0), (offset + 1)] | |
10 | + | let x1 = toInt(x0, 0) | |
11 | + | [toInt((base58'1111111' + x0), 0), (offset + 1)] | |
14 | 12 | } | |
15 | 13 | ||
16 | 14 | ||
22 | 20 | let x0 = drop(data, offset) | |
23 | 21 | let x1 = take(x0, 1) | |
24 | 22 | let x2 = take(drop(x0, 1), 1) | |
25 | - | if ((decodeInt8(x2, 0)[0] >= 0)) | |
26 | - | then [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
27 | - | else [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
23 | + | [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
28 | 24 | } | |
29 | 25 | ||
30 | 26 | ||
38 | 34 | let x2 = take(drop(x0, 1), 1) | |
39 | 35 | let x3 = take(drop(x0, 2), 1) | |
40 | 36 | let x4 = take(drop(x0, 3), 1) | |
41 | - | if ((decodeInt8(x4, 0)[0] >= 0)) | |
42 | - | then [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
43 | - | else [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
37 | + | [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
44 | 38 | } | |
45 | 39 | ||
46 | 40 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func decodeInt8 (data,offset) = if ((1 > size(data))) | |
5 | 5 | then throw("decode u8 error, data must be at least 1 byte") | |
6 | 6 | else if ((offset > size(data))) | |
7 | 7 | then throw("decode u8 error, decoding is finish") | |
8 | 8 | else { | |
9 | 9 | let x0 = take(drop(data, offset), 1) | |
10 | - | let x1 = toInt((base58'1111111' + x0), 0) | |
11 | - | if ((128 > x1)) | |
12 | - | then [x1, (offset + 1)] | |
13 | - | else [toInt((base58'1111111' + x0), 0), (offset + 1)] | |
10 | + | let x1 = toInt(x0, 0) | |
11 | + | [toInt((base58'1111111' + x0), 0), (offset + 1)] | |
14 | 12 | } | |
15 | 13 | ||
16 | 14 | ||
17 | 15 | func decodeInt16 (data,offset) = if ((2 > size(data))) | |
18 | 16 | then throw("decode u16 error, data must be at least 2 bytes") | |
19 | 17 | else if ((offset > size(data))) | |
20 | 18 | then throw("decode u16 error, decoding is finish") | |
21 | 19 | else { | |
22 | 20 | let x0 = drop(data, offset) | |
23 | 21 | let x1 = take(x0, 1) | |
24 | 22 | let x2 = take(drop(x0, 1), 1) | |
25 | - | if ((decodeInt8(x2, 0)[0] >= 0)) | |
26 | - | then [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
27 | - | else [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
23 | + | [toInt(((base58'111111' + x2) + x1), 0), (offset + 2)] | |
28 | 24 | } | |
29 | 25 | ||
30 | 26 | ||
31 | 27 | func decodeInt32 (data,offset) = if ((4 > size(data))) | |
32 | 28 | then throw("decode u32 error, data must be at least 4 bytes") | |
33 | 29 | else if ((offset > size(data))) | |
34 | 30 | then throw("decode u32 error, decoding is finish") | |
35 | 31 | else { | |
36 | 32 | let x0 = drop(data, offset) | |
37 | 33 | let x1 = take(x0, 1) | |
38 | 34 | let x2 = take(drop(x0, 1), 1) | |
39 | 35 | let x3 = take(drop(x0, 2), 1) | |
40 | 36 | let x4 = take(drop(x0, 3), 1) | |
41 | - | if ((decodeInt8(x4, 0)[0] >= 0)) | |
42 | - | then [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
43 | - | else [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
37 | + | [toInt(((((base58'1111' + x4) + x3) + x2) + x1), 0), (offset + 4)] | |
44 | 38 | } | |
45 | 39 | ||
46 | 40 | ||
47 | 41 | func decodeInt64 (data,offset) = if ((8 > size(data))) | |
48 | 42 | then throw("decode u32 error, data must be at least 8 bytes") | |
49 | 43 | else if ((offset > size(data))) | |
50 | 44 | then throw("decode u32 error, decoding is finish") | |
51 | 45 | else { | |
52 | 46 | let x0 = drop(data, offset) | |
53 | 47 | let x1 = take(x0, 1) | |
54 | 48 | let x2 = take(drop(x0, 1), 1) | |
55 | 49 | let x3 = take(drop(x0, 2), 1) | |
56 | 50 | let x4 = take(drop(x0, 3), 1) | |
57 | 51 | let x5 = take(drop(x0, 4), 1) | |
58 | 52 | let x6 = take(drop(x0, 5), 1) | |
59 | 53 | let x7 = take(drop(x0, 6), 1) | |
60 | 54 | let x8 = take(drop(x0, 7), 1) | |
61 | 55 | [toInt((((((((x8 + x7) + x6) + x5) + x4) + x3) + x2) + x1), 0), (offset + 8)] | |
62 | 56 | } | |
63 | 57 | ||
64 | 58 | ||
65 | 59 | func decodeBool (data,offset) = { | |
66 | 60 | let decoded1 = decodeInt8(data, offset) | |
67 | 61 | [DataEntry("bool", (decoded1[0] != 0)), DataEntry("int", decoded1[1])] | |
68 | 62 | } | |
69 | 63 | ||
70 | 64 | ||
71 | 65 | func decodeBytes32 (data,offset) = if ((32 > size(data))) | |
72 | 66 | then throw("decode bytes32 error, data must be at least 32 bytes") | |
73 | 67 | else [DataEntry("byte_vector", take(drop(data, offset), 32)), DataEntry("int", (offset + 32))] | |
74 | 68 | ||
75 | 69 | ||
76 | 70 | func decodeBytes64 (data,offset) = if ((64 > size(data))) | |
77 | 71 | then throw("decode bytes64 error, data must be at least 64 bytes") | |
78 | 72 | else [DataEntry("byte_vector", take(drop(data, offset), 64)), DataEntry("int", (offset + 64))] | |
79 | 73 | ||
80 | 74 | ||
81 | 75 | func decodeBytes65 (data,offset) = if ((65 > size(data))) | |
82 | 76 | then throw("decode bytes65 error, data must be at least 65 bytes") | |
83 | 77 | else [DataEntry("byte_vector", take(drop(data, offset), 65)), DataEntry("int", (offset + 65))] | |
84 | 78 | ||
85 | 79 | ||
86 | 80 | func decodeBytes (data,offset) = { | |
87 | 81 | let decoded1 = decodeInt32(data, offset) | |
88 | 82 | let bytesSize = decoded1[0] | |
89 | 83 | let nextOffset = decoded1[1] | |
90 | 84 | [DataEntry("byte_vector", take(drop(data, nextOffset), bytesSize)), DataEntry("int", (nextOffset + bytesSize))] | |
91 | 85 | } | |
92 | 86 | ||
93 | 87 | ||
94 | 88 | func decodeString (data,offset) = { | |
95 | 89 | let decoded1 = decodeInt32(data, offset) | |
96 | 90 | let bytesSize = decoded1[0] | |
97 | 91 | let nextOffset = decoded1[1] | |
98 | 92 | [DataEntry("string", toUtf8String(take(drop(data, nextOffset), bytesSize))), DataEntry("int", (nextOffset + bytesSize))] | |
99 | 93 | } | |
100 | 94 | ||
101 | 95 | ||
102 | 96 | func getAsBool (tuple) = match tuple[0].value { | |
103 | 97 | case b: Boolean => | |
104 | 98 | b | |
105 | 99 | case _ => | |
106 | 100 | throw("not a Boolean") | |
107 | 101 | } | |
108 | 102 | ||
109 | 103 | ||
110 | 104 | func getAsByteVector (tuple) = match tuple[0].value { | |
111 | 105 | case bv: ByteVector => | |
112 | 106 | bv | |
113 | 107 | case _ => | |
114 | 108 | throw("not a ByteVector") | |
115 | 109 | } | |
116 | 110 | ||
117 | 111 | ||
118 | 112 | func getAsString (tuple) = match tuple[0].value { | |
119 | 113 | case s: String => | |
120 | 114 | s | |
121 | 115 | case _ => | |
122 | 116 | throw("not a String") | |
123 | 117 | } | |
124 | 118 | ||
125 | 119 | ||
126 | 120 | func getOffset (tuple) = match tuple[1].value { | |
127 | 121 | case i: Int => | |
128 | 122 | i | |
129 | 123 | case _ => | |
130 | 124 | throw("not a Int") | |
131 | 125 | } | |
132 | 126 | ||
133 | 127 | ||
134 | 128 | @Callable(contextObj) | |
135 | 129 | func testSaveString (data) = WriteSet([DataEntry("testSaveString", data)]) | |
136 | 130 | ||
137 | 131 | ||
138 | 132 | ||
139 | 133 | @Callable(contextObj) | |
140 | 134 | func relayAndVerify (data) = { | |
141 | 135 | let req1 = decodeInt64(data, 0) | |
142 | 136 | WriteSet([DataEntry(("temp" + "/clientId"), req1[0])]) | |
143 | 137 | } | |
144 | 138 | ||
145 | 139 |
github/deemru/w8io/169f3d6 36.22 ms ◑![]()