tx · GjNKi1PG2RNBCNwvQnYG8hY5R65nXmd6im3r3Yda6LNx
3MyV9Fm9cwW9W68VCGfPvejLujx7xVpJiKW: -0.01400000 Waves
2020.01.03 18:06 [837834] smart account 3MyV9Fm9cwW9W68VCGfPvejLujx7xVpJiKW > SELF 0.00000000 Waves
{
"type": 13,
"id": "GjNKi1PG2RNBCNwvQnYG8hY5R65nXmd6im3r3Yda6LNx",
"fee": 1400000,
"feeAssetId": null,
"timestamp": 1578063911299,
"version": 1,
"sender": "3MyV9Fm9cwW9W68VCGfPvejLujx7xVpJiKW",
"senderPublicKey": "8zVjiVAuhkkAyQsSHHvjkNNoN8WDKJAEBV5nSpiyyYWr",
"proofs": [
"eRDbLyJknXgrmxj6gyx2w9qh8ftpk8fTUJG7XgyjYnnQDkrresWYetQ7ufNRKQDxsqmCifKnobQY9a8hr5HkNco"
],
"script": "base64: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",
"chainId": 84,
"height": 837834,
"spentComplexity": 0
}
View: original | compacted
Prev: HykdfxjytxdV628ndwpVA5RgTrcpsQkjLkjeDXbBkQhA
Next: 6LJxxk9LVmZM637kDQsjgL9UbVmxwWaRtbYW1k4SSotp
Diff:
Old | New | | Differences |
---|
12 | 12 | | let euroId = base58'AsuWyM9MUUsMmWkK7jS48L3ky6gA1pxx7QtEYPbfLjAJ' |
---|
13 | 13 | | |
---|
14 | 14 | | @Callable(i) |
---|
15 | | - | func deposit (compeStart,id,num) = { |
---|
| 15 | + | func deposit (compeStart,id) = { |
---|
16 | 16 | | let pmt = extract(i.payment) |
---|
17 | 17 | | let paymentId = pmt.assetId |
---|
18 | 18 | | let currentKey = toBase58String(i.caller.bytes) |
---|
|
23 | 23 | | 0 |
---|
24 | 24 | | } |
---|
25 | 25 | | let newAmount = (currentAmount + pmt.amount) |
---|
26 | | - | WriteSet([DataEntry(((((id + "_") + num) + "_") + currentKey), newAmount), DataEntry(((((id + "_") + num) + "_compeStart_") + currentKey), compeStart)]) |
---|
| 26 | + | WriteSet([DataEntry(((id + "_") + currentKey), newAmount), DataEntry((((id + "_") + "_compeStart_") + currentKey), compeStart)]) |
---|
27 | 27 | | } |
---|
28 | 28 | | |
---|
29 | 29 | | |
---|
30 | 30 | | |
---|
31 | 31 | | @Callable(i) |
---|
32 | | - | func withdraw (amount,id,num) = { |
---|
| 32 | + | func withdraw (amount,id) = { |
---|
33 | 33 | | let currentKey = toBase58String(i.caller.bytes) |
---|
34 | | - | let compeStart = match getInteger(this, ((((id + "_") + num) + "_compeStart_") + currentKey)) { |
---|
| 34 | + | let compeStart = match getInteger(this, (((id + "_") + "_compeStart_") + currentKey)) { |
---|
35 | 35 | | case a: Int => |
---|
36 | 36 | | a |
---|
37 | 37 | | case _ => |
---|
38 | 38 | | 0 |
---|
39 | 39 | | } |
---|
40 | | - | let currentAmount = match getInteger(this, ((((id + "_") + num) + "_") + currentKey)) { |
---|
| 40 | + | let currentAmount = match getInteger(this, ((id + "_") + currentKey)) { |
---|
41 | 41 | | case a: Int => |
---|
42 | 42 | | a |
---|
43 | 43 | | case _ => |
---|
|
51 | 51 | | else if ((0 > newAmount)) |
---|
52 | 52 | | then throw("Not enough balance") |
---|
53 | 53 | | else if ((id == "EtV3CXQ4wqm28WPB1KaBv5B9ke2bpXRZMutYNEJUQcXm")) |
---|
54 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, par7Id)])) |
---|
| 54 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, par7Id)])) |
---|
55 | 55 | | else if ((id == "3KFXBGGLCjA5Z2DuW4Dq9fDDrHjJJP1ZEkaoajSzuKsC")) |
---|
56 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, usdnId)])) |
---|
| 56 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, usdnId)])) |
---|
57 | 57 | | else if ((id == "DWgwcZTMhSvnyYCoWLRUXXSH1RSkzThXLJhww9gwkqdn")) |
---|
58 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, btcId)])) |
---|
| 58 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, btcId)])) |
---|
59 | 59 | | else if ((id == "AsuWyM9MUUsMmWkK7jS48L3ky6gA1pxx7QtEYPbfLjAJ")) |
---|
60 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, euroId)])) |
---|
| 60 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, euroId)])) |
---|
61 | 61 | | else if ((id == "WAVES")) |
---|
62 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, unit)])) |
---|
| 62 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, unit)])) |
---|
63 | 63 | | else throw("Can't withdraw") |
---|
64 | 64 | | } |
---|
65 | 65 | | |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 3 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let dappAcountPubKey = base58'7DERSZYEoBTSwaTrN1ktwnx1Y5D46mSpMSayUNs8CmcK' |
---|
5 | 5 | | |
---|
6 | 6 | | let par7Id = base58'EtV3CXQ4wqm28WPB1KaBv5B9ke2bpXRZMutYNEJUQcXm' |
---|
7 | 7 | | |
---|
8 | 8 | | let usdnId = base58'3KFXBGGLCjA5Z2DuW4Dq9fDDrHjJJP1ZEkaoajSzuKsC' |
---|
9 | 9 | | |
---|
10 | 10 | | let btcId = base58'DWgwcZTMhSvnyYCoWLRUXXSH1RSkzThXLJhww9gwkqdn' |
---|
11 | 11 | | |
---|
12 | 12 | | let euroId = base58'AsuWyM9MUUsMmWkK7jS48L3ky6gA1pxx7QtEYPbfLjAJ' |
---|
13 | 13 | | |
---|
14 | 14 | | @Callable(i) |
---|
15 | | - | func deposit (compeStart,id,num) = { |
---|
| 15 | + | func deposit (compeStart,id) = { |
---|
16 | 16 | | let pmt = extract(i.payment) |
---|
17 | 17 | | let paymentId = pmt.assetId |
---|
18 | 18 | | let currentKey = toBase58String(i.caller.bytes) |
---|
19 | 19 | | let currentAmount = match getInteger(this, currentKey) { |
---|
20 | 20 | | case a: Int => |
---|
21 | 21 | | a |
---|
22 | 22 | | case _ => |
---|
23 | 23 | | 0 |
---|
24 | 24 | | } |
---|
25 | 25 | | let newAmount = (currentAmount + pmt.amount) |
---|
26 | | - | WriteSet([DataEntry(((((id + "_") + num) + "_") + currentKey), newAmount), DataEntry(((((id + "_") + num) + "_compeStart_") + currentKey), compeStart)]) |
---|
| 26 | + | WriteSet([DataEntry(((id + "_") + currentKey), newAmount), DataEntry((((id + "_") + "_compeStart_") + currentKey), compeStart)]) |
---|
27 | 27 | | } |
---|
28 | 28 | | |
---|
29 | 29 | | |
---|
30 | 30 | | |
---|
31 | 31 | | @Callable(i) |
---|
32 | | - | func withdraw (amount,id,num) = { |
---|
| 32 | + | func withdraw (amount,id) = { |
---|
33 | 33 | | let currentKey = toBase58String(i.caller.bytes) |
---|
34 | | - | let compeStart = match getInteger(this, ((((id + "_") + num) + "_compeStart_") + currentKey)) { |
---|
| 34 | + | let compeStart = match getInteger(this, (((id + "_") + "_compeStart_") + currentKey)) { |
---|
35 | 35 | | case a: Int => |
---|
36 | 36 | | a |
---|
37 | 37 | | case _ => |
---|
38 | 38 | | 0 |
---|
39 | 39 | | } |
---|
40 | | - | let currentAmount = match getInteger(this, ((((id + "_") + num) + "_") + currentKey)) { |
---|
| 40 | + | let currentAmount = match getInteger(this, ((id + "_") + currentKey)) { |
---|
41 | 41 | | case a: Int => |
---|
42 | 42 | | a |
---|
43 | 43 | | case _ => |
---|
44 | 44 | | 0 |
---|
45 | 45 | | } |
---|
46 | 46 | | let newAmount = (currentAmount - amount) |
---|
47 | 47 | | if ((lastBlock.timestamp > compeStart)) |
---|
48 | 48 | | then throw("Can't withdraw compe start") |
---|
49 | 49 | | else if ((0 > amount)) |
---|
50 | 50 | | then throw("Can't withdraw negative amount") |
---|
51 | 51 | | else if ((0 > newAmount)) |
---|
52 | 52 | | then throw("Not enough balance") |
---|
53 | 53 | | else if ((id == "EtV3CXQ4wqm28WPB1KaBv5B9ke2bpXRZMutYNEJUQcXm")) |
---|
54 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, par7Id)])) |
---|
| 54 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, par7Id)])) |
---|
55 | 55 | | else if ((id == "3KFXBGGLCjA5Z2DuW4Dq9fDDrHjJJP1ZEkaoajSzuKsC")) |
---|
56 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, usdnId)])) |
---|
| 56 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, usdnId)])) |
---|
57 | 57 | | else if ((id == "DWgwcZTMhSvnyYCoWLRUXXSH1RSkzThXLJhww9gwkqdn")) |
---|
58 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, btcId)])) |
---|
| 58 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, btcId)])) |
---|
59 | 59 | | else if ((id == "AsuWyM9MUUsMmWkK7jS48L3ky6gA1pxx7QtEYPbfLjAJ")) |
---|
60 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, euroId)])) |
---|
| 60 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, euroId)])) |
---|
61 | 61 | | else if ((id == "WAVES")) |
---|
62 | | - | then ScriptResult(WriteSet([DataEntry((id + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, unit)])) |
---|
| 62 | + | then ScriptResult(WriteSet([DataEntry(((id + "_") + currentKey), newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, unit)])) |
---|
63 | 63 | | else throw("Can't withdraw") |
---|
64 | 64 | | } |
---|
65 | 65 | | |
---|
66 | 66 | | |
---|
67 | 67 | | @Verifier(tx) |
---|
68 | 68 | | func verify () = match tx { |
---|
69 | 69 | | case ttx: TransferTransaction => |
---|
70 | 70 | | sigVerify(ttx.bodyBytes, ttx.proofs[0], ttx.senderPublicKey) |
---|
71 | 71 | | case stx: SetScriptTransaction => |
---|
72 | 72 | | sigVerify(stx.bodyBytes, stx.proofs[0], stx.senderPublicKey) |
---|
73 | 73 | | case _ => |
---|
74 | 74 | | true |
---|
75 | 75 | | } |
---|
76 | 76 | | |
---|