tx · 8aw4WVhETjwd6BLpuao6iniqyqfXXNxqfDA3neFci2BB 3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1: -0.01400000 Waves 2022.03.18 15:10 [1969388] smart account 3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1 > SELF 0.00000000 Waves
{ "type": 13, "id": "8aw4WVhETjwd6BLpuao6iniqyqfXXNxqfDA3neFci2BB", "fee": 1400000, "feeAssetId": null, "timestamp": 1647605493573, "version": 2, "chainId": 84, "sender": "3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1", "senderPublicKey": "Ehngpik6DXwbcV8tpLbd3qBFjChSdW49YqyxinREgabT", "proofs": [ "2wj3D1vqYeK9FKomb9NhQu224pn1LkrGU6eRDgwu5P9XysJcdytH424nMJpkEsnvaxDQXveU1meATWEES3mJFdMq" ], "script": "base64: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Y2ggaGFzIG5vdCBiZWVuIHNldHRsZWQgWWV0LiBXYWl0IHVudGlsIHJvdW5kIGVuZCBhbmQgcmUtZW50ZXIgYWdhaW4uCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACAgAAAApUb3RhbF9UeG5zBQAAAAl0b3RhbHR4bnMJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgIAAAAPVG90YWxfVXNlclR4bnNfBQAAAApjdXJyZW50S2V5BQAAAA11c2VydG90YWx0eG5zCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAICAAAAEkRlcG9zaXRfQW1vdW50X09mXwUAAAAKY3VycmVudEtleQkAAGUAAAACCAUAAAAEcG10MQAAAAZhbW91bnQFAAAAB0RhcHBGZWUJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgIAAAARQ3VycmVudF9Sb3VuZF9PZl8FAAAACmN1cnJlbnRLZXkFAAAAD2dldGN1cnJlbnRyb3VuZAkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQABLAAAAAICAAAAEENsYWltX1N0YXR1c19PZl8FAAAACmN1cnJlbnRLZXkCAAAAB1BFTkRJTkcJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgIAAAAPTm9fT2ZfRGVwb3NpdHNfBQAAAApjdXJyZW50S2V5BQAAABhTdW1wdXBvZlVzZXJOb09mRGVwb3NpdHMJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwUAAAARQ29sbGVjdEZlZUFkZHJlc3MFAAAAB0RhcHBGZWUFAAAAC3hVU0RBc3NldElEBQAAAANuaWwAAAABaQEAAAAFQ2xhaW0AAAAABAAAAApjdXJyZW50S2V5CQACWAAAAAEICAUAAAABaQAAAAZjYWxsZXIAAAAFYnl0ZXMEAAAAEFVzZXJOb09mRGVwb3NpdHMJAQAAABFAZXh0ck5hdGl2ZSgxMDUwKQAAAAIFAAAABHRoaXMJAAEsAAAAAgIAAAAPTm9fT2ZfRGVwb3NpdHNfBQAAAApjdXJyZW50S2V5BAAAAA5mZXRjaHVzZXJyb3VuZAkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwkAASwAAAACAgAAABFDdXJyZW50X1JvdW5kX09mXwUAAAAKY3VycmVudEtleQQAAAAPZmV0Y2h1c2VyYW1vdW50CQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACBQAAAAR0aGlzCQABLAAAAAICAAAAEkRlcG9zaXRfQW1vdW50X09mXwUAAAAKY3VycmVudEtleQQAAAAPZ2V0c3RhcnRjYXBpdGFsCQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACBQAAAAR0aGlzCQABLAAAAAIJAAGkAAAAAQUAAAAOZmV0Y2h1c2Vycm91bmQCAAAADl9TdGFydF9DYXBpdGFsBAAAAA1nZXRlbmRjYXBpdGFsCQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACBQAAAAR0aGlzCQABLAAAAAIJAAGkAAAAAQUAAAAOZmV0Y2h1c2Vycm91bmQCAAAADF9FbmRfQ2FwaXRhbAQAAAAJZ2V0c3RhdHVzCQEAAAARQGV4dHJOYXRpdmUoMTA1MykAAAACBQAAAAR0aGlzCQABLAAAAAIJAAGkAAAAAQUAAAAOZmV0Y2h1c2Vycm91bmQCAAAAB19zdGF0dXMEAAAACmdldHJlc3VsdHMJAQAAABFAZXh0ck5hdGl2ZSgxMDUzKQAAAAIFAAAABHRoaXMJAAEsAAAAAgkAAaQAAAABBQAAAA5mZXRjaHVzZXJyb3VuZAIAAAALX21rdHJlc3VsdHMEAAAAEmZldGNodG90YWx1c2VydHhucwQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzCQABLAAAAAICAAAAD1RvdGFsX1VzZXJUeG5zXwUAAAAKY3VycmVudEtleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAABAAAAA11c2VydG90YWx0eG5zCQAAZAAAAAIFAAAAEmZldGNodG90YWx1c2VydHhucwAAAAAAAAAAAQMJAAAAAAAAAgUAAAAQVXNlck5vT2ZEZXBvc2l0cwAAAAAAAAAAAQkAAAIAAAABAgAAAIFZb3UgQWxyZWFkeSBwYXJ0aWNpcGF0ZWQgZm9yIGFuIFJvdW5kLCBXaGljaCBoYXMgbm90IGJlZW4gc2V0dGxlZCBZZXQuIFdhaXQgdW50aWwgcm91bmQgZW5kIHRoZW4gQ2xhaW0gYWZ0ZXIgdGhhdCByZS1lbnRlciBhZ2Fpbi4JAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAICAAAAClRvdGFsX1R4bnMFAAAACXRvdGFsdHhucwkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACAgAAAA9Ub3RhbF9Vc2VyVHhuc18FAAAACmN1cnJlbnRLZXkFAAAADXVzZXJ0b3RhbHR4bnMJAARMAAAAAgkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACAgAAABJEZXBvc2l0X0Ftb3VudF9PZl8FAAAACmN1cnJlbnRLZXkJAARMAAAAAgkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACAgAAABFDdXJyZW50X1JvdW5kX09mXwUAAAAKY3VycmVudEtleQkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQABLAAAAAICAAAAEENsYWltX1N0YXR1c19PZl8FAAAACmN1cnJlbnRLZXkCAAAABFBBSUQJAARMAAAAAgkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACAgAAAA9Ob19PZl9EZXBvc2l0c18FAAAACmN1cnJlbnRLZXkJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwgFAAAAAWkAAAAGY2FsbGVyBQAAAA9mZXRjaHVzZXJhbW91bnQFAAAAC3hVU0RBc3NldElEBQAAAANuaWwAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAABAAAAAckbWF0Y2gwBQAAAAJ0eAkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAIBQAAAAJ0eAAAAA9zZW5kZXJQdWJsaWNLZXnzSeja", "height": 1969388, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GJsxN57YA1PhiLYz7ST5geMHpTi7r2QJDgdpX5SYnroz Next: DPzBL7K1CHBVpykGi3SN4RQjBxjBG11NxvaX3E5uiWfh Diff:
Old | New | Differences | |
---|---|---|---|
74 | 74 | } | |
75 | 75 | let usertotaltxns = (fetchtotalusertxns + 1) | |
76 | 76 | if ((UserNoOfDeposits == 1)) | |
77 | - | then throw("You Already participated for an Round, Which has not been settled Yet. Wait until round end | |
77 | + | then throw("You Already participated for an Round, Which has not been settled Yet. Wait until round end then Claim after that re-enter again.") | |
78 | 78 | else [IntegerEntry("Total_Txns", totaltxns), IntegerEntry(("Total_UserTxns_" + currentKey), usertotaltxns), DeleteEntry(("Deposit_Amount_Of_" + currentKey)), DeleteEntry(("Current_Round_Of_" + currentKey)), StringEntry(("Claim_Status_Of_" + currentKey), "PAID"), DeleteEntry(("No_Of_Deposits_" + currentKey)), ScriptTransfer(i.caller, fetchuseramount, xUSDAssetID)] | |
79 | 79 | } | |
80 | 80 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 4 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let DappFee = 25000000 | |
5 | 5 | ||
6 | 6 | let getcurrentround = getIntegerValue(this, "current_round") | |
7 | 7 | ||
8 | 8 | let xUSDAssetID = base58'2PyngaPGAFjV9AVFXSQANwumY6FSY1cqZDBK8NsEGCup' | |
9 | 9 | ||
10 | 10 | let FAITHAssetID = base58'44Mq8KqUhM94t93MiBq3S22iiuGczMxpKmse5dBy2w5y' | |
11 | 11 | ||
12 | 12 | let CollectFeeAddress = addressFromPublicKey(base58'6Z73KxcX3sugpiStpSRXxKxTmWqCaLVwFeM6kwyiKVDR') | |
13 | 13 | ||
14 | 14 | let fetchtotaltxns = match getInteger(this, "Total_Txns") { | |
15 | 15 | case a: Int => | |
16 | 16 | a | |
17 | 17 | case _ => | |
18 | 18 | 0 | |
19 | 19 | } | |
20 | 20 | ||
21 | 21 | let totaltxns = (fetchtotaltxns + 1) | |
22 | 22 | ||
23 | 23 | @Callable(i) | |
24 | 24 | func Deposit () = { | |
25 | 25 | let pmt1 = if ((size(i.payments) == 1)) | |
26 | 26 | then i.payments[0] | |
27 | 27 | else throw((("No Payments Attached Please Attach " + toBase58String(xUSDAssetID)) + " Asset Only.")) | |
28 | 28 | let maxdepositamt = 1000000000000 | |
29 | 29 | let currentKey = toBase58String(i.caller.bytes) | |
30 | 30 | let fetchtotalusertxns = match getInteger(this, ("Total_UserTxns_" + currentKey)) { | |
31 | 31 | case a: Int => | |
32 | 32 | a | |
33 | 33 | case _ => | |
34 | 34 | 0 | |
35 | 35 | } | |
36 | 36 | let usertotaltxns = (fetchtotalusertxns + 1) | |
37 | 37 | let UserNoOfDeposits = match getInteger(this, ("No_Of_Deposits_" + currentKey)) { | |
38 | 38 | case a: Int => | |
39 | 39 | a | |
40 | 40 | case _ => | |
41 | 41 | 0 | |
42 | 42 | } | |
43 | 43 | let SumpupofUserNoOfDeposits = (UserNoOfDeposits + 1) | |
44 | 44 | if ((pmt1.assetId != xUSDAssetID)) | |
45 | 45 | then throw("Incorrect asset attached, please attach only xUSD AssetID.") | |
46 | 46 | else if ((499999999 >= pmt1.amount)) | |
47 | 47 | then throw("Please attach minimum 5 xUSD to deposit to enter round.") | |
48 | 48 | else if ((pmt1.amount > maxdepositamt)) | |
49 | 49 | then throw("Please attach correct amount in between [5-10000] xUSD.") | |
50 | 50 | else if ((size(i.payments) > 1)) | |
51 | 51 | then throw("Two assets attached, Kindly Attach only payment1 = xUSD with in [5-10000] xUSD Range.") | |
52 | 52 | else if ((UserNoOfDeposits == 1)) | |
53 | 53 | then throw("You Already participated for an Round, Which has not been settled Yet. Wait until round end and re-enter again.") | |
54 | 54 | else [IntegerEntry("Total_Txns", totaltxns), IntegerEntry(("Total_UserTxns_" + currentKey), usertotaltxns), IntegerEntry(("Deposit_Amount_Of_" + currentKey), (pmt1.amount - DappFee)), IntegerEntry(("Current_Round_Of_" + currentKey), getcurrentround), StringEntry(("Claim_Status_Of_" + currentKey), "PENDING"), IntegerEntry(("No_Of_Deposits_" + currentKey), SumpupofUserNoOfDeposits), ScriptTransfer(CollectFeeAddress, DappFee, xUSDAssetID)] | |
55 | 55 | } | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | ||
59 | 59 | @Callable(i) | |
60 | 60 | func Claim () = { | |
61 | 61 | let currentKey = toBase58String(i.caller.bytes) | |
62 | 62 | let UserNoOfDeposits = getIntegerValue(this, ("No_Of_Deposits_" + currentKey)) | |
63 | 63 | let fetchuserround = getIntegerValue(this, ("Current_Round_Of_" + currentKey)) | |
64 | 64 | let fetchuseramount = getIntegerValue(this, ("Deposit_Amount_Of_" + currentKey)) | |
65 | 65 | let getstartcapital = getIntegerValue(this, (toString(fetchuserround) + "_Start_Capital")) | |
66 | 66 | let getendcapital = getIntegerValue(this, (toString(fetchuserround) + "_End_Capital")) | |
67 | 67 | let getstatus = getStringValue(this, (toString(fetchuserround) + "_status")) | |
68 | 68 | let getresults = getStringValue(this, (toString(fetchuserround) + "_mktresults")) | |
69 | 69 | let fetchtotalusertxns = match getInteger(this, ("Total_UserTxns_" + currentKey)) { | |
70 | 70 | case a: Int => | |
71 | 71 | a | |
72 | 72 | case _ => | |
73 | 73 | 0 | |
74 | 74 | } | |
75 | 75 | let usertotaltxns = (fetchtotalusertxns + 1) | |
76 | 76 | if ((UserNoOfDeposits == 1)) | |
77 | - | then throw("You Already participated for an Round, Which has not been settled Yet. Wait until round end | |
77 | + | then throw("You Already participated for an Round, Which has not been settled Yet. Wait until round end then Claim after that re-enter again.") | |
78 | 78 | else [IntegerEntry("Total_Txns", totaltxns), IntegerEntry(("Total_UserTxns_" + currentKey), usertotaltxns), DeleteEntry(("Deposit_Amount_Of_" + currentKey)), DeleteEntry(("Current_Round_Of_" + currentKey)), StringEntry(("Claim_Status_Of_" + currentKey), "PAID"), DeleteEntry(("No_Of_Deposits_" + currentKey)), ScriptTransfer(i.caller, fetchuseramount, xUSDAssetID)] | |
79 | 79 | } | |
80 | 80 | ||
81 | 81 | ||
82 | 82 | @Verifier(tx) | |
83 | 83 | func verify () = match tx { | |
84 | 84 | case _ => | |
85 | 85 | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
86 | 86 | } | |
87 | 87 |
github/deemru/w8io/169f3d6 31.25 ms ◑