tx · Be8kKnf3JyQ1j2DvdJHb2oaAYXHxfMudogcxUduWyTYZ 3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1: -0.01400000 Waves 2022.03.19 09:45 [1970483] smart account 3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1 > SELF 0.00000000 Waves
{ "type": 13, "id": "Be8kKnf3JyQ1j2DvdJHb2oaAYXHxfMudogcxUduWyTYZ", "fee": 1400000, "feeAssetId": null, "timestamp": 1647672378200, "version": 2, "chainId": 84, "sender": "3Mqzhyb3ayfeb2bnZzAthD1W8oKsNaw7on1", "senderPublicKey": "Ehngpik6DXwbcV8tpLbd3qBFjChSdW49YqyxinREgabT", "proofs": [ "3fz86DPW2jZD4PjnFf3Qip39BtSi5sMgTTNsbmS8bzVg5beVMq3ADvFXmuAfVTPdDZCvY7DVg9nXm4JcrNKGgDSb" ], "script": "base64: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Y2ggaGFzIG5vdCBiZWVuIHNldHRsZWQgWWV0LiBXYWl0IHVudGlsIHJvdW5kIGVuZCBhbmQgcmUtZW50ZXIgYWdhaW4uCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACAgAAAApUb3RhbF9UeG5zBQAAAAl0b3RhbHR4bnMJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgIAAAAPVG90YWxfVXNlclR4bnNfBQAAAApjdXJyZW50S2V5BQAAAA11c2VydG90YWx0eG5zCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACCQABLAAAAAICAAAAEUN1cnJlbnRfUm91bmRfT2ZfBQAAAApjdXJyZW50S2V5BQAAAA9nZXRjdXJyZW50cm91bmQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAAEsAAAAAgIAAAASRGVwb3NpdF9BbW91bnRfT2ZfBQAAAApjdXJyZW50S2V5CQAAZQAAAAIIBQAAAARwbXQxAAAABmFtb3VudAUAAAAHRGFwcEZlZQkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkAASwAAAACAgAAAA9Ob19PZl9EZXBvc2l0c18FAAAACmN1cnJlbnRLZXkFAAAAGFN1bXB1cG9mVXNlck5vT2ZEZXBvc2l0cwkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQABLAAAAAICAAAAEENsYWltX1N0YXR1c19PZl8FAAAACmN1cnJlbnRLZXkCAAAAB1BFTkRJTkcJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwUAAAARQ29sbGVjdEZlZUFkZHJlc3MFAAAAB0RhcHBGZWUFAAAAC3hVU0RBc3NldElEBQAAAANuaWwAAAABaQEAAAAFQ2xhaW0AAAAABAAAAApjdXJyZW50S2V5CQACWAAAAAEICAUAAAABaQAAAAZjYWxsZXIAAAAFYnl0ZXMEAAAADmZldGNodXNlcnJvdW5kCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACAgAAABFDdXJyZW50X1JvdW5kX09mXwUAAAAKY3VycmVudEtleQIAAABXWW91ciBBZGRy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", "height": 1970483, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: ANpTBJUMz6v5SvxB74dnyRMpg5rWwLrmMKxbnzWdSjyL Next: 4E3APTNNNj9hRuiEcwANsRnt7gWrkRmMnoDoU1gP78eG Diff:
Old | New | Differences | |
---|---|---|---|
62 | 62 | let fetchuserround = valueOrErrorMessage(getInteger(this, ("Current_Round_Of_" + currentKey)), "Your Address did not participated in any latest round Yet. Please Depoist again to WIN.") | |
63 | 63 | let getstartcapital = getIntegerValue(this, (toString(fetchuserround) + "_Start_Capital")) | |
64 | 64 | let getendcapital = getIntegerValue(this, (toString(fetchuserround) + "_End_Capital")) | |
65 | + | let getstatus = getStringValue(this, (toString(fetchuserround) + "_status")) | |
65 | 66 | let fetchuseramount = getIntegerValue(this, ("Deposit_Amount_Of_" + currentKey)) | |
66 | 67 | let fetchtotalusertxns = match getInteger(this, ("Total_UserTxns_" + currentKey)) { | |
67 | 68 | case a: Int => | |
72 | 73 | let usertotaltxns = (fetchtotalusertxns + 1) | |
73 | 74 | if ((0 >= fetchuserround)) | |
74 | 75 | then throw("You don't have any dues of Round to Claim.") | |
75 | - | 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)] | |
76 | + | else if ((getstatus == "Start")) | |
77 | + | then throw("Round has Just Started Yet results are Pending to Post.") | |
78 | + | else if ((getstatus == "Skipped")) | |
79 | + | then throw("Round results are Skipped.") | |
80 | + | 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)] | |
76 | 81 | } | |
77 | 82 | ||
78 | 83 |
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(("Current_Round_Of_" + currentKey), getcurrentround), IntegerEntry(("Deposit_Amount_Of_" + currentKey), (pmt1.amount - DappFee)), IntegerEntry(("No_Of_Deposits_" + currentKey), SumpupofUserNoOfDeposits), StringEntry(("Claim_Status_Of_" + currentKey), "PENDING"), 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 fetchuserround = valueOrErrorMessage(getInteger(this, ("Current_Round_Of_" + currentKey)), "Your Address did not participated in any latest round Yet. Please Depoist again to WIN.") | |
63 | 63 | let getstartcapital = getIntegerValue(this, (toString(fetchuserround) + "_Start_Capital")) | |
64 | 64 | let getendcapital = getIntegerValue(this, (toString(fetchuserround) + "_End_Capital")) | |
65 | + | let getstatus = getStringValue(this, (toString(fetchuserround) + "_status")) | |
65 | 66 | let fetchuseramount = getIntegerValue(this, ("Deposit_Amount_Of_" + currentKey)) | |
66 | 67 | let fetchtotalusertxns = match getInteger(this, ("Total_UserTxns_" + currentKey)) { | |
67 | 68 | case a: Int => | |
68 | 69 | a | |
69 | 70 | case _ => | |
70 | 71 | 0 | |
71 | 72 | } | |
72 | 73 | let usertotaltxns = (fetchtotalusertxns + 1) | |
73 | 74 | if ((0 >= fetchuserround)) | |
74 | 75 | then throw("You don't have any dues of Round to Claim.") | |
75 | - | 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)] | |
76 | + | else if ((getstatus == "Start")) | |
77 | + | then throw("Round has Just Started Yet results are Pending to Post.") | |
78 | + | else if ((getstatus == "Skipped")) | |
79 | + | then throw("Round results are Skipped.") | |
80 | + | 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)] | |
76 | 81 | } | |
77 | 82 | ||
78 | 83 | ||
79 | 84 | @Verifier(tx) | |
80 | 85 | func verify () = match tx { | |
81 | 86 | case _ => | |
82 | 87 | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
83 | 88 | } | |
84 | 89 |
github/deemru/w8io/026f985 30.57 ms ◑