tx · 2dy9eoSBkKbCQCyhieho4LwJwRSZyyfHRW84GrK14DKD 3MpUPrEL1hyinuEbf6qKvChwqQNbnbGJp83: -0.01000000 Waves 2019.08.30 11:21 [653732] smart account 3MpUPrEL1hyinuEbf6qKvChwqQNbnbGJp83 > SELF 0.00000000 Waves
{ "type": 13, "id": "2dy9eoSBkKbCQCyhieho4LwJwRSZyyfHRW84GrK14DKD", "fee": 1000000, "feeAssetId": null, "timestamp": 1567153322260, "version": 1, "sender": "3MpUPrEL1hyinuEbf6qKvChwqQNbnbGJp83", "senderPublicKey": "GgC1LiazRChtAvcfVLSmeebtbmPhuwkxdpB55TsU4yYt", "proofs": [ "2qE4J77tdVUykvnDLcfbF3TvS91W69nVqvYLUy2ZXkeoEATpVaqtvrgSidgQi7bXe34sqPCEUmeRB7kxWFpyzpfG" ], "script": "base64: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", "chainId": 84, "height": 653732, "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 3 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let maxFee = 1000000 | |
5 | + | ||
6 | + | let minAmount = getIntegerValue(this, "config_min_amount") | |
7 | + | ||
8 | + | let acceptBetUntil = getIntegerValue(this, "config_bet_until") | |
9 | + | ||
10 | + | let tradeStart = getIntegerValue(this, "config_trade_start") | |
11 | + | ||
12 | + | let tradeEnd = getIntegerValue(this, "config_trade_end") | |
13 | + | ||
14 | + | let acceptAssets = [getStringValue(this, "config_asset_1"), getStringValue(this, "config_asset_2")] | |
15 | + | ||
16 | + | let tradeAccount = addressFromStringValue(getStringValue(this, "config_trade_account")) | |
17 | + | ||
18 | + | func repayFee (i,ws,address,amount,asset) = if ((i.fee > maxFee)) | |
19 | + | then throw("unreasonable large fee") | |
20 | + | else if ((i.feeAssetId != unit)) | |
21 | + | then throw("fee must be in WAVES") | |
22 | + | else ScriptResult(ws, TransferSet([ScriptTransfer(i.caller, i.fee, unit), ScriptTransfer(address, amount, asset)])) | |
23 | + | ||
24 | + | ||
25 | + | func assetMnemonic (assetId) = match assetId { | |
26 | + | case u: Unit => | |
27 | + | "WAVES" | |
28 | + | case b: ByteVector => | |
29 | + | toBase58String(b) | |
30 | + | case _ => | |
31 | + | throw() | |
32 | + | } | |
33 | + | ||
34 | + | ||
35 | + | func getIntDefault (key,default) = match getInteger(this, key) { | |
36 | + | case i: Int => | |
37 | + | i | |
38 | + | case _ => | |
39 | + | default | |
40 | + | } | |
41 | + | ||
42 | + | ||
43 | + | func getAssetBalance (assetId) = if ((assetId == "WAVES")) | |
44 | + | then wavesBalance(this) | |
45 | + | else assetBalance(this, extract(fromBase58String(assetId))) | |
46 | + | ||
47 | + | ||
48 | + | func getAssetIdFromMnemonic (assetId) = if ((assetId == "WAVES")) | |
49 | + | then unit | |
50 | + | else fromBase58String(assetId) | |
51 | + | ||
52 | + | ||
53 | + | @Callable(i) | |
54 | + | func letsTrade () = { | |
55 | + | let tradeStartedKey = "trade_started" | |
56 | + | if ((getBoolean(this, tradeStartedKey) == true)) | |
57 | + | then throw("Trades start already triggered") | |
58 | + | else if ((tradeStart > lastBlock.timestamp)) | |
59 | + | then throw("Trades no ready to start yet") | |
60 | + | else if ((lastBlock.timestamp > tradeEnd)) | |
61 | + | then throw("Trades finished") | |
62 | + | else if ((i.fee > maxFee)) | |
63 | + | then throw("unreasonable large fee") | |
64 | + | else if ((i.feeAssetId != unit)) | |
65 | + | then throw("fee must be in WAVES") | |
66 | + | else { | |
67 | + | let asset1Balance = (getAssetBalance(acceptAssets[0]) - minAmount) | |
68 | + | let asset2Balance = (getAssetBalance(acceptAssets[1]) - minAmount) | |
69 | + | if (if ((0 > asset1Balance)) | |
70 | + | then true | |
71 | + | else (0 > asset2Balance)) | |
72 | + | then throw("not enought bets to start trades") | |
73 | + | else ScriptResult(WriteSet([DataEntry(tradeStartedKey, true)]), TransferSet([ScriptTransfer(i.caller, i.fee, unit), ScriptTransfer(tradeAccount, asset1Balance, getAssetIdFromMnemonic(acceptAssets[0])), ScriptTransfer(tradeAccount, asset2Balance, getAssetIdFromMnemonic(acceptAssets[1]))])) | |
74 | + | } | |
75 | + | } | |
76 | + | ||
77 | + | ||
78 | + | ||
79 | + | @Callable(inv) | |
80 | + | func registerBetTx (tx) = { | |
81 | + | let txData = extract(transferTransactionById(fromBase58String(tx))) | |
82 | + | let owner = toBase58String(txData.sender.bytes) | |
83 | + | let asset = assetMnemonic(txData.assetId) | |
84 | + | let amount = txData.amount | |
85 | + | let txTimestamp = extract(blockInfoByHeight(extract(transactionHeightById(fromBase58String(tx))))).timestamp | |
86 | + | let betAmountKey = (((("bet_" + owner) + "_") + asset) + "_amount") | |
87 | + | let betTotalAmountKey = (("bet_total_" + asset) + "_amount") | |
88 | + | let betResultKey = (("tx_" + tx) + "_result") | |
89 | + | if ((txData.recipient != this)) | |
90 | + | then throw("invalid destination") | |
91 | + | else if (if ((asset != acceptAssets[0])) | |
92 | + | then (asset != acceptAssets[1]) | |
93 | + | else false) | |
94 | + | then throw("asset not accepted") | |
95 | + | else if (isDefined(getInteger(this, betResultKey))) | |
96 | + | then throw("tx already registered") | |
97 | + | else if ((minAmount > amount)) | |
98 | + | then throw(("min amount is " + toString(minAmount))) | |
99 | + | else if ((acceptBetUntil > txTimestamp)) | |
100 | + | then repayFee(inv, WriteSet([DataEntry(betResultKey, "accepted"), DataEntry(betAmountKey, (getIntDefault(betAmountKey, 0) + amount)), DataEntry(betTotalAmountKey, (getIntDefault(betTotalAmountKey, 0) + amount))]), inv.caller, 0, unit) | |
101 | + | else repayFee(inv, WriteSet([DataEntry(betResultKey, "returned")]), txData.sender, amount, txData.assetId) | |
102 | + | } | |
103 | + | ||
104 | + |
github/deemru/w8io/169f3d6 78.17 ms ◑![]()