tx · 2dCeUxEaAS6P4kXi7CV86QC4Lvw5f3L3tq5gPKoTCooK

3N4bdnbamh2f9A7E6msaiZFGvWy6k9eHKhB:  -0.01000000 Waves

2019.08.29 17:38 [652632] smart account 3N4bdnbamh2f9A7E6msaiZFGvWy6k9eHKhB > SELF 0.00000000 Waves

{ "type": 13, "id": "2dCeUxEaAS6P4kXi7CV86QC4Lvw5f3L3tq5gPKoTCooK", "fee": 1000000, "feeAssetId": null, "timestamp": 1567089504111, "version": 1, "sender": "3N4bdnbamh2f9A7E6msaiZFGvWy6k9eHKhB", "senderPublicKey": "92DyW7euuajmGUCwZAUgqyzYzH2qqhzpSjvdMYMQUx7c", "proofs": [ "51tH1i2E2cvEoH1ARVbMsMRF7ZeXeFeDu5GRSreU8ZfSeMgpnkTjPsNLG3cEEvqjr8sAJmU7bJ3nSNz9NXjJZdYV" ], "script": "base64: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", "chainId": 84, "height": 652632, "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
OldNewDifferences
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/03bedc9 
16.91 ms