tx · 5YRwzc76CwfwLe5ZBhz19hH1zLofBxkJ9ohLtL6Y7Lgq

3N4rfXV9DbA9Kbngt5qpNXuziAaBRmCrbHZ:  -0.01400000 Waves

2019.08.09 17:57 [623594] smart account 3N4rfXV9DbA9Kbngt5qpNXuziAaBRmCrbHZ > SELF 0.00000000 Waves

{ "type": 13, "id": "5YRwzc76CwfwLe5ZBhz19hH1zLofBxkJ9ohLtL6Y7Lgq", "fee": 1400000, "feeAssetId": null, "timestamp": 1565362544886, "version": 1, "sender": "3N4rfXV9DbA9Kbngt5qpNXuziAaBRmCrbHZ", "senderPublicKey": "7dgeV8sSzVnj9GqLdFXQktfdiQjrFcWTgDPeQwbs1kyK", "proofs": [ "27mKZypy86qXnr4zoAso9AxehAq6APp5fsMHkRvbAtDo1LLCmccz1smBdkZLJjaASLZrdYNuoTZsbHgpPCa7st8w" ], "script": "base64:AAIDAAAAAAAAAAAAAAAeAAAAAAROT05FAgAAAARub25lAQAAAA5nZXROdW1iZXJCeUtleQAAAAEAAAADa2V5BAAAAAckbWF0Y2gwCQAEGgAAAAIFAAAABHRoaXMFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAAAQAAAAtnZXRTdHJCeUtleQAAAAEAAAADa2V5BAAAAAckbWF0Y2gwCQAEHQAAAAIFAAAABHRoaXMFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAGU3RyaW5nBAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhBQAAAAROT05FAAAAABFBY2NvdW50QmFsYW5jZUtleQIAAAAIYmFsYW5jZV8AAAAAEE5ldXRyaW5vUHJpY2VLZXkCAAAACm51c2RfcHJpY2UAAAAADEJvbmRDb3VudEtleQIAAAAKYm9uZF9jb3VudAAAAAAMQm9uZFByaWNlS2V5AgAAAApib25kX3ByaWNlAAAAAAxCb25kQmxvY2tLZXkCAAAACmJvbmRfYmxvY2sAAAAADEJvbmRPd25lcktleQIAAAAKYm9uZF9vd25lcgAAAAAKQm9uZFN0YXR1cwIAAAALYm9uZF9zdGF0dXMBAAAAFGdldEFjY291bnRCYWxhbmNlS2V5AAAAAQAAAAdhY2NvdW50CQABLAAAAAIFAAAAEUFjY291bnRCYWxhbmNlS2V5BQAAAAdhY2NvdW50AQAAABFnZXRBY2NvdW50QmFsYW5jZQAAAAEAAAAHYWNjb3VudAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQkBAAAAFGdldEFjY291bnRCYWxhbmNlS2V5AAAAAQUAAAAHYWNjb3VudAEAAAAQZ2V0TmV1dHJpbm9QcmljZQAAAAAJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEFAAAAEE5ldXRyaW5vUHJpY2VLZXkBAAAADGdldEJvbmRDb3VudAAAAAAJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEFAAAADEJvbmRDb3VudEtleQEAAAAMZ2V0Qm9uZFByaWNlAAAAAAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQUAAAAMQm9uZFByaWNlS2V5AQAAAA1nZXRCb25kU3RhdHVzAAAAAAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQUAAAAMQm9uZFByaWNlS2V5AQAAABFnZXRCb25kT3JkZXJCbG9jawAAAAAJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEFAAAADEJvbmRCbG9ja0tleQEAAAAMZ2V0Qm9uZE93bmVyAAAAAAkBAAAAC2dldFN0ckJ5S2V5AAAAAQUAAAAMQm9uZE93bmVyS2V5AAAAAAdXYXZlbGV0AAAAAAAF9eEAAAAAAA9FeHBpcmVCb25kT3JkZXIAAAAAAAAAAAoAAAAAD0V4Y2VjdXRlZFN0YXR1cwIAAAAJZXhjZWN1dGVkAAAAABVOZXV0cmlub0Fzc2V0SWRTdHJpbmcCAAAAAAAAAAAPTmV1dHJpbm9Bc3NldElkCQABmwAAAAEFAAAAFU5ldXRyaW5vQXNzZXRJZFN0cmluZwAAAAARQm9uZEFzc2V0SWRTdHJpbmcCAAAAAAAAAAALQm9uZEFzc2V0SWQJAAGbAAAAAQUAAAAVTmV1dHJpbm9Bc3NldElkU3RyaW5nAAAAAAxOZXV0cmlub05hbWUCAAAADE5ldXRyaW5vLVVTRAAAAAAOTmV1dHJpbm9TeW1ib2wCAAAABU4tVVNEAAAAABBNaW5pbWFsQm9uZE9yZGVyCQAAaAAAAAIAAAAAAAAAAAoFAAAAB1dhdmVsZXQBAAAACWdldFN1cHBseQAAAAAJAAPrAAAAAgUAAAAEdGhpcwUAAAAPTmV1dHJpbm9Bc3NldElkAQAAAApnZXRSZXNlcnZlAAAAAAkBAAAADHdhdmVzQmFsYW5jZQAAAAEFAAAABHRoaXMAAAAEAAAAAWkBAAAAD3NldEN1dXJlbnRQcmljZQAAAAEAAAAFcHJpY2UJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAEE5ldXRyaW5vUHJpY2VLZXkFAAAABmhlaWdodAUAAAADbmlsAAAAAWkBAAAAE3N3YXBXYXZlc1RvTmV1dHJpbm8AAAAABAAAAAVwcmljZQkBAAAAEGdldE5ldXRyaW5vUHJpY2UAAAAABAAAAANwbXQJAQAAAAdleHRyYWN0AAAAAQgFAAAAAWkAAAAHcGF5bWVudAMJAQAAAAlp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", "chainId": 84, "height": 623594, "spentComplexity": 0 } View: original | compacted Prev: A1eQxdHJWDMk1ycB8rBsCyuSFQbDxCtEDCirxtNocxev Next: EMEAQV9TDB4reNLYGusGYLuZxscr4i61J4ULHL1yNyrU Diff:
OldNewDifferences
6363
6464 let ExcecutedStatus = "excecuted"
6565
66-let NeutrinoAssetIdString = "4LFQD5CQHi7fpUqNaCyAbaoXPNRuvvdPL6tD7xubtUr4"
66+let NeutrinoAssetIdString = ""
6767
6868 let NeutrinoAssetId = toBytes(NeutrinoAssetIdString)
6969
8181
8282
8383 func getReserve () = wavesBalance(this)
84+
85+
86+@Callable(i)
87+func setCuurentPrice (price) = WriteSet([DataEntry(NeutrinoPriceKey, height)])
88+
8489
8590
8691 @Callable(i)
110115 TransferSet([ScriptTransfer(addressFromStringValue(account), amount, NeutrinoAssetId)])
111116 }
112117 }
113-
114-
115-
116-@Callable(i)
117-func setCurrentPrice (price) = WriteSet([DataEntry(BondPriceKey, price)])
118118
119119
120120
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 3 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let NONE = "none"
55
66 func getNumberByKey (key) = match getInteger(this, key) {
77 case a: Int =>
88 a
99 case _ =>
1010 0
1111 }
1212
1313
1414 func getStrByKey (key) = match getString(this, key) {
1515 case a: String =>
1616 a
1717 case _ =>
1818 NONE
1919 }
2020
2121
2222 let AccountBalanceKey = "balance_"
2323
2424 let NeutrinoPriceKey = "nusd_price"
2525
2626 let BondCountKey = "bond_count"
2727
2828 let BondPriceKey = "bond_price"
2929
3030 let BondBlockKey = "bond_block"
3131
3232 let BondOwnerKey = "bond_owner"
3333
3434 let BondStatus = "bond_status"
3535
3636 func getAccountBalanceKey (account) = (AccountBalanceKey + account)
3737
3838
3939 func getAccountBalance (account) = getNumberByKey(getAccountBalanceKey(account))
4040
4141
4242 func getNeutrinoPrice () = getNumberByKey(NeutrinoPriceKey)
4343
4444
4545 func getBondCount () = getNumberByKey(BondCountKey)
4646
4747
4848 func getBondPrice () = getNumberByKey(BondPriceKey)
4949
5050
5151 func getBondStatus () = getNumberByKey(BondPriceKey)
5252
5353
5454 func getBondOrderBlock () = getNumberByKey(BondBlockKey)
5555
5656
5757 func getBondOwner () = getStrByKey(BondOwnerKey)
5858
5959
6060 let Wavelet = 100000000
6161
6262 let ExpireBondOrder = 10
6363
6464 let ExcecutedStatus = "excecuted"
6565
66-let NeutrinoAssetIdString = "4LFQD5CQHi7fpUqNaCyAbaoXPNRuvvdPL6tD7xubtUr4"
66+let NeutrinoAssetIdString = ""
6767
6868 let NeutrinoAssetId = toBytes(NeutrinoAssetIdString)
6969
7070 let BondAssetIdString = ""
7171
7272 let BondAssetId = toBytes(NeutrinoAssetIdString)
7373
7474 let NeutrinoName = "Neutrino-USD"
7575
7676 let NeutrinoSymbol = "N-USD"
7777
7878 let MinimalBondOrder = (10 * Wavelet)
7979
8080 func getSupply () = assetBalance(this, NeutrinoAssetId)
8181
8282
8383 func getReserve () = wavesBalance(this)
84+
85+
86+@Callable(i)
87+func setCuurentPrice (price) = WriteSet([DataEntry(NeutrinoPriceKey, height)])
88+
8489
8590
8691 @Callable(i)
8792 func swapWavesToNeutrino () = {
8893 let price = getNeutrinoPrice()
8994 let pmt = extract(i.payment)
9095 if (isDefined(pmt.assetId))
9196 then throw("can use waves only at the moment")
9297 else {
9398 let account = toBase58String(i.caller.bytes)
9499 let amount = (pmt.amount * price)
95100 TransferSet([ScriptTransfer(addressFromStringValue(account), amount, NeutrinoAssetId)])
96101 }
97102 }
98103
99104
100105
101106 @Callable(i)
102107 func swapNeutrinoToWaves () = {
103108 let price = getNeutrinoPrice()
104109 let pmt = extract(i.payment)
105110 if ((pmt.assetId == NeutrinoAssetId))
106111 then throw("can use neutrino only at the moment")
107112 else {
108113 let account = toBase58String(i.caller.bytes)
109114 let amount = (pmt.amount / price)
110115 TransferSet([ScriptTransfer(addressFromStringValue(account), amount, NeutrinoAssetId)])
111116 }
112117 }
113-
114-
115-
116-@Callable(i)
117-func setCurrentPrice (price) = WriteSet([DataEntry(BondPriceKey, price)])
118118
119119
120120
121121 @Callable(i)
122122 func setBondOrder (price) = {
123123 let priceNeutrino = getNeutrinoPrice()
124124 let reserve = getReserve()
125125 let supply = getSupply()
126126 let deficit = ((supply / priceNeutrino) - reserve)
127127 let pmt = extract(i.payment)
128128 let boudBlock = getBondOrderBlock()
129129 if (isDefined(pmt.assetId))
130130 then throw("can use waves only at the moment")
131131 else if ((deficit == pmt.amount))
132132 then throw("amount does not cover deficit")
133133 else if ((boudBlock == 0))
134134 then if ((MinimalBondOrder > deficit))
135135 then throw("bond not generated")
136136 else {
137137 let amount = (pmt.amount / price)
138138 ScriptResult(WriteSet([DataEntry(BondBlockKey, height), DataEntry(BondPriceKey, price), DataEntry(BondOwnerKey, toString(i.caller)), DataEntry(BondCountKey, (pmt.amount / price))]), TransferSet([ScriptTransfer(i.caller, amount, NeutrinoAssetId)]))
139139 }
140140 else if (((boudBlock + ExpireBondOrder) > height))
141141 then throw("TODO")
142142 else {
143143 let lastPrice = getBondPrice()
144144 let lastCount = getBondCount()
145145 if ((lastPrice >= price))
146146 then throw("bond not generated")
147147 else ScriptResult(WriteSet([DataEntry(BondPriceKey, price), DataEntry(BondOwnerKey, toString(i.caller)), DataEntry(BondCountKey, (pmt.amount / price))]), TransferSet([ScriptTransfer(addressFromStringValue(getBondOwner()), (lastCount * lastPrice), NeutrinoAssetId)]))
148148 }
149149 }
150150
151151

github/deemru/w8io/169f3d6 
35.31 ms