tx · C9buh742L4KUj9LS7258uCdqAQZwuYhzESiFbHpFTkG
3N6SCyR13XotwN2hqizWvqxz8mrHLc53pfZ: -0.14000000 Waves
2018.12.10 17:22 [398709] smart account 3N6SCyR13XotwN2hqizWvqxz8mrHLc53pfZ > SELF 0.00000000 Waves
{
"type": 13,
"id": "C9buh742L4KUj9LS7258uCdqAQZwuYhzESiFbHpFTkG",
"fee": 14000000,
"feeAssetId": null,
"timestamp": 1544451811877,
"version": 1,
"sender": "3N6SCyR13XotwN2hqizWvqxz8mrHLc53pfZ",
"senderPublicKey": "7vRLZahSi6vPoFqv7sHCnPwWdLMibPshpbiazZ7Mr2Xq",
"proofs": [
"65f75qTStFgdNzM8tnQAeqAyFw59vQoMJgrsUVmb7ECmF5NeM4W6w7NBu7JxZeS33f8kXx91AFKL93GjVLpqdXod"
],
"script": "base64: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",
"chainId": 84,
"height": 398709,
"spentComplexity": 0
}
View: original | compacted
Prev: B2ikEo5Gy8ufgaqJmQVBk9mE9ujdis2NN7v6m4p886tP
Next: DjdAkH7hxS7bPfQX8BEktXq8dvNcaKSDCuJJEAzMcRpC
Diff:
Old | New | | Differences |
---|
6 | 6 | | case s: SetScriptTransaction => |
---|
7 | 7 | | sigVerify(s.bodyBytes, s.proofs[0], tokenomicaPubKey) |
---|
8 | 8 | | case t: TransferTransaction => |
---|
9 | | - | let limit = extract(getInteger(this, toBase58String(t.sender.bytes))) |
---|
| 9 | + | let limit = extract(getInteger(this, "limit")) |
---|
10 | 10 | | if (if (if ((limit >= t.amount)) |
---|
11 | 11 | | then isDefined(t.assetId) |
---|
12 | 12 | | else false) |
---|
|
15 | 15 | | then sigVerify(t.bodyBytes, t.proofs[0], tx.senderPublicKey) |
---|
16 | 16 | | else false |
---|
17 | 17 | | case m: MassTransferTransaction => |
---|
18 | | - | let limit = extract(getInteger(this, toBase58String(m.sender.bytes))) |
---|
| 18 | + | let limit = extract(getInteger(this, "limit")) |
---|
19 | 19 | | if (if ((limit >= m.totalAmount)) |
---|
20 | 20 | | then isDefined(m.assetId) |
---|
21 | 21 | | else false) |
---|
22 | 22 | | then sigVerify(m.bodyBytes, m.proofs[0], tx.senderPublicKey) |
---|
23 | 23 | | else false |
---|
24 | 24 | | case e: ExchangeTransaction => |
---|
25 | | - | let limit = extract(getInteger(this, toBase58String(e.sender.bytes))) |
---|
| 25 | + | let limit = extract(getInteger(this, "limit")) |
---|
26 | 26 | | if (if (if (!(isDefined(e.sellOrder.assetPair.amountAsset))) |
---|
27 | 27 | | then (limit >= e.buyOrder.amount) |
---|
28 | 28 | | else false) |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 1 #-} |
---|
2 | 2 | | {-# CONTENT_TYPE EXPRESSION #-} |
---|
3 | 3 | | let tokenomicaPubKey = base58'7dkSgXFv9EpYi3C3JK76wJTkciBsVPZ1xE5fVAMB6AD9' |
---|
4 | 4 | | let this = extract(tx.sender) |
---|
5 | 5 | | match tx { |
---|
6 | 6 | | case s: SetScriptTransaction => |
---|
7 | 7 | | sigVerify(s.bodyBytes, s.proofs[0], tokenomicaPubKey) |
---|
8 | 8 | | case t: TransferTransaction => |
---|
9 | | - | let limit = extract(getInteger(this, toBase58String(t.sender.bytes))) |
---|
| 9 | + | let limit = extract(getInteger(this, "limit")) |
---|
10 | 10 | | if (if (if ((limit >= t.amount)) |
---|
11 | 11 | | then isDefined(t.assetId) |
---|
12 | 12 | | else false) |
---|
13 | 13 | | then ((t.amount % 2) == 0) |
---|
14 | 14 | | else false) |
---|
15 | 15 | | then sigVerify(t.bodyBytes, t.proofs[0], tx.senderPublicKey) |
---|
16 | 16 | | else false |
---|
17 | 17 | | case m: MassTransferTransaction => |
---|
18 | | - | let limit = extract(getInteger(this, toBase58String(m.sender.bytes))) |
---|
| 18 | + | let limit = extract(getInteger(this, "limit")) |
---|
19 | 19 | | if (if ((limit >= m.totalAmount)) |
---|
20 | 20 | | then isDefined(m.assetId) |
---|
21 | 21 | | else false) |
---|
22 | 22 | | then sigVerify(m.bodyBytes, m.proofs[0], tx.senderPublicKey) |
---|
23 | 23 | | else false |
---|
24 | 24 | | case e: ExchangeTransaction => |
---|
25 | | - | let limit = extract(getInteger(this, toBase58String(e.sender.bytes))) |
---|
| 25 | + | let limit = extract(getInteger(this, "limit")) |
---|
26 | 26 | | if (if (if (!(isDefined(e.sellOrder.assetPair.amountAsset))) |
---|
27 | 27 | | then (limit >= e.buyOrder.amount) |
---|
28 | 28 | | else false) |
---|
29 | 29 | | then true |
---|
30 | 30 | | else if (!(isDefined(e.sellOrder.assetPair.priceAsset))) |
---|
31 | 31 | | then (limit >= e.sellOrder.amount) |
---|
32 | 32 | | else false) |
---|
33 | 33 | | then sigVerify(e.bodyBytes, e.proofs[0], tx.senderPublicKey) |
---|
34 | 34 | | else false |
---|
35 | 35 | | case d: DataTransaction => |
---|
36 | 36 | | sigVerify(d.bodyBytes, d.proofs[0], tokenomicaPubKey) |
---|
37 | 37 | | case _ => |
---|
38 | 38 | | false |
---|
39 | 39 | | } |
---|