2022.10.03 16:19 [3321691] smart account 3PH2KWQ4aPVZQo27CKYvA3wtLFpocJ9oSxR > SELF 0.00000000 Waves

{ "type": 13, "id": "E3JMSBMmE7RB8LzNaGjEsr282UVShjUXDBZ1cDKdg8KW", "fee": 500000, "feeAssetId": null, "timestamp": 1664803168448, "version": 2, "chainId": 87, "sender": "3PH2KWQ4aPVZQo27CKYvA3wtLFpocJ9oSxR", "senderPublicKey": "F2oYoje2nsMBbUbhBJwpyE7Xdc5HsMi7BmkNW22i7Syi", "proofs": [ "5g7wpzV93NCRopEExZiavbbFbYAF7UYpDjB8JjtCtDZVScmd9EqpNDdVx8DsJNKJbmSPyjvBhAhKDy29FHK9rSCP" ], "script": "base64:AAIFAAAAAAAAAA8IAhIFCgMIAQgSBAoCCAEAAAAUAAAAAAhDb3Vyc2VJZAAAAAAAAAAAAAAAAAAQYmFja2VuZFB1YmxpY0tleQEAAAAgWfw+o16bck5csjvuo75l3fBL85OUGiBdbOKUSjbPGWIAAAAAC1VzZG5Bc3NldElkAQAAACC2JinDBPXOU5GkDkt1JC9kjFGx+t+vVCm9SNIdKrKq0QAAAAAKVXNkbkFtb3VudAAAAAAAAIlUQAAAAAAMV2F2ZXNBc3NldElkBQAAAAR1bml0AAAAAAlXWEFzc2V0SWQBAAAAIJMBHKupx24lV85mnnG2vapr+DzoWAsq7tmgTrs83BSxAAAAAAxWaXJlc0Fzc2V0SWQBAAAAILja4jcBYnBfmqhbshkMvQ/DZa91BrZYLd0Hk1ap3amXAAAAAAtTd29wQXNzZXRJZAEAAAAgy5Y+heb1k1ZPj3mDERR4TyZ+jN5UknzW4a3AXGioruwAAAAACkVHR0Fzc2V0SWQBAAAAIKOff08jclHRLOIhkmKITQwL8+oiboHVr/wLkxfObbHJAAAAABBXYXZlc1Bvb2xBZGRyZXNzAQAAABoBV6ugnY67/HaJPzVO8b2xSyoDl1hFH8eK8wAAAAANV3hQb29sQWRkcmVzcwEAAAAaAVfDBNALfMDi9acVJgY8J+21U7PKg5/T8uAAAAAADkVnZ1Bvb2xBZGRyZXNzAQAAABoBV4t2U7r2KHVlbgNLn7re08lgIxh5/Y2jTQAAAAAPU3dvcFBvb2xBZGRyZXNzAQAAABoBVwH+Ys39xeSIPYQt+A3ojmN8bZkuAYsCxwAAAAAQVmlyZXNQb29sQWRkcmVzcwEAAAAaAVew4FH4tSpSwo45u5VAIXMd1a7Eo/y/lMoBAAAADWtleVVzZXJDb3Vyc2UAAAACAAAAB2FkZHJlc3MAAAAIY291cnNlSWQJAAEsAAAAAgkAASwAAAACBQAAAAdhZGRyZXNzAgAAAAhfY291cnNlXwkAAaQAAAABBQAAAAhDb3Vyc2VJZAEAAAAPa2V5VXNlclJld2FyZGVkAAAAAgAAAAdhZGRyZXNzAAAACGNvdXJzZUlkCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAAdhZGRyZXNzAgAAAAhfY291cnNlXwkAAaQAAAABBQAAAAhDb3Vyc2VJZAIAAAAJX3Jld2FyZGVkAQAAABJnZXRUb2tlbkVxdWl2YWxlbnQAAAACAAAAC3Bvb2xBZGRyZXNzAAAABmFtb3VudAQAAAANYXNzZXRBQmFsYW5jZQkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgkBAAAAB0FkZHJlc3MAAAABBQAAAAtwb29sQWRkcmVzcwIAAAAPQV9hc3NldF9iYWxhbmNlBAAAAA1hc3NldEJCYWxhbmNlCQEAAAARQGV4dHJOYXRpdmUoMTA1MCkAAAACCQEAAAAHQWRkcmVzcwAAAAEFAAAAC3Bvb2xBZGRyZXNzAgAAAA9CX2Fzc2V0X2JhbGFuY2UJAABrAAAAAwUAAAANYXNzZXRBQmFsYW5jZQUAAAAGYW1vdW50BQAAAA1hc3NldEJCYWxhbmNlAQAAABBjYWxjdWxhdGVSZXdhcmRzAAAAAAQAAAASd2F2ZXNCYWxhbmNlQmVmb3JlCAkAA+8AAAABBQAAAAR0aGlzAAAAB3JlZ3VsYXIDCQAAAAAAAAIFAAAAEndhdmVzQmFsYW5jZUJlZm9yZQUAAAASd2F2ZXNCYWxhbmNlQmVmb3JlBAAAAA1leGNoYW5nZVdhdmVzCQAD/AAAAAQJAQAAAAdBZGRyZXNzAAAAAQUAAAAQV2F2ZXNQb29sQWRkcmVzcwIAAAAIZXhjaGFuZ2UJAARMAAAAAgAAAAAAAAAAAQUAAAADbmlsCQAETAAAAAIJAQAAAA9BdHRhY2hlZFBheW1lbnQAAAACBQAAAAtVc2RuQXNzZXRJZAAAAAAAAD0JAAUAAAADbmlsAwkAAAAAAAACBQAAAA1leGNoYW5nZVdhdmVzBQAAAA1leGNoYW5nZVdhdmVzBAAAABF3YXZlc0JhbGFuY2VBZnRlcggJAAPvAAAAAQUAAAAEdGhpcwAAAAdyZWd1bGFyAwkAAAAAAAACBQAAABF3YXZlc0JhbGFuY2VBZnRlcgUAAAARd2F2ZXNCYWxhbmNlQWZ0ZXIEAAAAC3dhdmVzQW1vdW50CQAAZQAAAAIFAAAAEXdhdmVzQmFsYW5jZUFmdGVyBQAAABJ3YXZlc0JhbGFuY2VCZWZvcmUEAAAAEGVnZ0JhbGFuY2VCZWZvcmUJAAPwAAAAAgUAAAAEdGhpcwUAAAAKRUdHQXNzZXRJZAMJAAAAAAAAAgUAAAAQZWdnQmFsYW5jZUJlZm9yZQUAAAAQZWdnQmFsYW5jZUJlZm9yZQQAAAALZXhjaGFuZ2VFZ2cJAAP8AAAABAkBAAAAB0FkZHJlc3MAAAABBQAAAA5FZ2dQb29sQWRkcmVzcwIAAAAIZXhjaGFuZ2UJAARMAAAAAgAAAAAAAAAAAQUAAAADbmlsCQAETAAAAAIJAQAAAA9BdHRhY2hlZFBheW1lbnQAAAACBQAAAAtVc2RuQXNzZXRJZAAAAAAAAD0JAAUAAAADbmlsAwkAAAAAAAACBQAAAAtleGNoYW5nZUVnZwUAAAALZXhjaGFuZ2VFZ2cEAAAAD2VnZ0JhbGFuY2VBZnRlcgkAA/AAAAACBQAAAAR0aGlzBQAAAApFR0dBc3NldElkAwkAAAAAAAACBQAAAA9lZ2dCYWxhbmNlQWZ0ZXIFAAAAD2VnZ0JhbGFuY2VBZnRlcgQAAAAJZWdnQW1vdW50CQAAZQAAAAIFAAAAD2VnZ0JhbGFuY2VBZnRlcgUAAAAQZWdnQmFsYW5jZUJlZm9yZQQAAAAKc3dvcEFtb3VudAkBAAAAEmdldFRva2VuRXF1aXZhbGVudAAAAAIFAAAAD1N3b3BQb29sQWRkcmVzcwAAAAAAAD0JAAQAAAAId3hBbW91bnQJAQAAABJnZXRUb2tlbkVxdWl2YWxlbnQAAAACBQAAAA1XeFBvb2xBZGRyZXNzAAAAAAAAPQkABAAAAAt2aXJlc0Ftb3VudAkBAAAAEmdldFRva2VuRXF1aXZhbGVudAAAAAIFAAAAEFZpcmVzUG9vbEFkZHJlc3MAAAAAAAA9CQAJAARMAAAAAgkBAAAAC1N0cmluZ0VudHJ5AAAAAgIAAAAHX19kZWJ1ZwkABLkAAAACCQAETAAAAAIJAAGkAAAAAQUAAAALd2F2ZXNBbW91bnQJAARMAAAAAgkAAaQAAAABBQAAAAllZ2dBbW91bnQJAARMAAAAAgkAAaQAAAABBQAAAApzd29wQW1vdW50CQAETAAAAAIJAAGkAAAAAQUAAAAId3hBbW91bnQJAARMAAAAAgkAAaQAAAABBQAAAAt2aXJlc0Ftb3VudAUAAAADbmlsAgAAAAQgfHwgBQAAAANuaWwJAAACAAAAAQIAAAAkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQAAAgAAAAECAAAAJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAAIAAAABAgAAACRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAACAAAAAQIAAAAkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQAAAgAAAAECAAAAJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAAIAAAABAgAAACRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAAAAFmdldFVzZXJBbHJlYWR5RmluaXNoZWQAAAACAAAADWNhbGxlckFkZHJlc3MAAAAIY291cnNlSWQEAAAAC2tVc2VyQ291cnNlCQEAAAANa2V5VXNlckNvdXJzZQAAAAIFAAAADWNhbGxlckFkZHJlc3MFAAAACGNvdXJzZUlkBAAAAAckbWF0Y2gwCQAEIAAAAAEFAAAAC2tVc2VyQ291cnNlAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAdCb29sZWFuBAAAAAF0BQAAAAckbWF0Y2gwBQAAAAF0BwEAAAAWZ2V0VXNlckFscmVhZHlSZXdhcmRlZAAAAAIAAAANY2FsbGVyQWRkcmVzcwAAAAhjb3Vyc2VJZAQAAAANa1VzZXJSZXdhcmRlZAkBAAAAD2tleVVzZXJSZXdhcmRlZAAAAAIFAAAADWNhbGxlckFkZHJlc3MFAAAACGNvdXJzZUlkBAAAAAckbWF0Y2gwCQAEIAAAAAEFAAAADWtVc2VyUmV3YXJkZWQDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAB0Jvb2xlYW4EAAAAAXQFAAAAByRtYXRjaDAFAAAAAXQHAAAAAgAAAAFpAQAAABFwYXlGb3JDZXJ0aWZpY2F0ZQAAAAMAAAAEbmFtZQAAAAhjb3Vyc2VJZAAAAAlzaWduYXR1cmUEAAAADWNhbGxlckFkZHJlc3MJAAQlAAAAAQgFAAAAAWkAAAAMb3JpZ2luQ2FsbGVyBAAAABBrVXNlckNvdXJzZVZhbHVlCQEAAAAWZ2V0VXNlckFscmVhZHlGaW5pc2hlZAAAAAIFAAAADWNhbGxlckFkZHJlc3MFAAAACGNvdXJzZUlkBAAAAApkYXRhVG9TaWduCQABLAAAAAIJAAEsAAAAAgUAAAAEbmFtZQkAAaQAAAABBQAAAAhjb3Vyc2VJZAUAAAANY2FsbGVyQWRkcmVzcwMJAAAAAAAAAgkACcQAAAADCQABmwAAAAEFAAAACmRhdGFUb1NpZ24JAAJZAAAAAQUAAAAJc2lnbmF0dXJlBQAAABBiYWNrZW5kUHVibGljS2V5BwkAAAIAAAABAgAAABxCYWNrZW5kIHByb29mIGlzIG5vdCBjb3JyZWN0AwkBAAAAAiE9AAAAAgkBAAAABXZhbHVlAAAAAQgJAQAAAAV2YWx1ZQAAAAEJAAGRAAAAAggFAAAAAWkAAAAIcGF5bWVudHMAAAAAAAAAAAAAAAAHYXNzZXRJZAUAAAALVXNkbkFzc2V0SWQJAAACAAAAAQIAAAAaMTAgVVNETiBzaG91bGQgYmUgYXR0YWNoZWQDCQEAAAACIT0AAAACCQEAAAAFdmFsdWUAAAABCAkBAAAABXZhbHVlAAAAAQkAAZEAAAACCAUAAAABaQAAAAhwYXltZW50cwAAAAAAAAAAAAAAAAZhbW91bnQFAAAAClVzZG5BbW91bnQJAAACAAAAAQkAASwAAAACCQABLAAAAAICAAAACUF0IGxlYXN0IAkAAaQAAAABBQAAAApVc2RuQW1vdW50AgAAABggVVNETiBzaG91bGQgYmUgYXR0YWNoZWQDBQAAABBrVXNlckNvdXJzZVZhbHVlCQAAAgAAAAECAAAAH1VzZXIgYWxyZWFkeSBnb3QgYSBjZXJ0aWZpY2F0ZSEJAARMAAAAAgkBAAAADEJvb2xlYW5FbnRyeQAAAAIJAQAAAA1rZXlVc2VyQ291cnNlAAAAAgUAAAANY2FsbGVyQWRkcmVzcwUAAAAIY291cnNlSWQGBQAAAANuaWwAAAABaQEAAAAJcGF5VG9Vc2VyAAAAAgAAAAdhZGRyZXNzAAAACGNvdXJzZUlkBAAAABBrVXNlckNvdXJzZVZhbHVlCQEAAAAWZ2V0VXNlckFscmVhZHlGaW5pc2hlZAAAAAIFAAAAB2FkZHJlc3MFAAAACGNvdXJzZUlkBAAAABJrVXNlclJld2FyZGVkVmFsdWUJAQAAABZnZXRVc2VyQWxyZWFkeVJld2FyZGVkAAAAAgUAAAAHYWRkcmVzcwUAAAAIY291cnNlSWQDCQAAAAAAAAIFAAAAEGtVc2VyQ291cnNlVmFsdWUHCQAAAgAAAAECAAAAHVVzZXIgZGlkbid0IGZpbmlzaCB0aGUgY291cnNlAwkAAAAAAAACBQAAABJrVXNlclJld2FyZGVkVmFsdWUGCQAAAgAAAAECAAAAGVVzZXIgd2FzIGFscmVhZHkgcmV3YXJkZWQJAQAAABBjYWxjdWxhdGVSZXdhcmRzAAAAAAAAAABhyAUe", "height": 3321691, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9pbnm4FBiEh6SHREcagzrbJ5CEEeiB88SxQemmqCBwH8 Next: FgvmmPfubPDqAcHqZiS42skP4MWfs5zpvpH5dqqm5tz Diff:
OldNewDifferences
3535 func keyUserRewarded (address,courseId) = (((address + "_course_") + toString(CourseId)) + "_rewarded")
3636
3737
38+func getTokenEquivalent (poolAddress,amount) = {
39+ let assetABalance = getIntegerValue(Address(poolAddress), "A_asset_balance")
40+ let assetBBalance = getIntegerValue(Address(poolAddress), "B_asset_balance")
41+ fraction(assetABalance, amount, assetBBalance)
42+ }
43+
44+
3845 func calculateRewards () = {
3946 let wavesBalanceBefore = wavesBalance(this).regular
4047 if ((wavesBalanceBefore == wavesBalanceBefore))
4148 then {
42- let exchangeWaves = invoke(Address(WavesPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 3000000)])
49+ let exchangeWaves = invoke(Address(WavesPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 4000000)])
4350 if ((exchangeWaves == exchangeWaves))
4451 then {
4552 let wavesBalanceAfter = wavesBalance(this).regular
46-[StringEntry("__debug", ((("Exchange amount: " + toString(wavesBalanceAfter)) + ", before: ") + toString(wavesBalanceBefore)))]
53+ if ((wavesBalanceAfter == wavesBalanceAfter))
54+ then {
55+ let wavesAmount = (wavesBalanceAfter - wavesBalanceBefore)
56+ let eggBalanceBefore = assetBalance(this, EGGAssetId)
57+ if ((eggBalanceBefore == eggBalanceBefore))
58+ then {
59+ let exchangeEgg = invoke(Address(EggPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 4000000)])
60+ if ((exchangeEgg == exchangeEgg))
61+ then {
62+ let eggBalanceAfter = assetBalance(this, EGGAssetId)
63+ if ((eggBalanceAfter == eggBalanceAfter))
64+ then {
65+ let eggAmount = (eggBalanceAfter - eggBalanceBefore)
66+ let swopAmount = getTokenEquivalent(SwopPoolAddress, 4000000)
67+ let wxAmount = getTokenEquivalent(WxPoolAddress, 4000000)
68+ let viresAmount = getTokenEquivalent(ViresPoolAddress, 4000000)
69+[StringEntry("__debug", makeString([toString(wavesAmount), toString(eggAmount), toString(swopAmount), toString(wxAmount), toString(viresAmount)], " || "))]
70+ }
71+ else throw("Strict value is not equal to itself.")
72+ }
73+ else throw("Strict value is not equal to itself.")
74+ }
75+ else throw("Strict value is not equal to itself.")
76+ }
77+ else throw("Strict value is not equal to itself.")
4778 }
4879 else throw("Strict value is not equal to itself.")
4980 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 5 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let CourseId = 0
55
66 let backendPublicKey = base58'74GNYyhC5BPLvUUT8DoisXVQ8AMhcWCGM5D3jJJ2F9cu'
77
88 let UsdnAssetId = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p'
99
1010 let UsdnAmount = 9000000
1111
1212 let WavesAssetId = unit
1313
1414 let WXAssetId = base58'Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on'
1515
1616 let ViresAssetId = base58'DSbbhLsSTeDg5Lsiufk2Aneh3DjVqJuPr2M9uU1gwy5p'
1717
1818 let SwopAssetId = base58'Ehie5xYpeN8op1Cctc6aGUrqx8jq3jtf1DSjXDbfm7aT'
1919
2020 let EGGAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS'
2121
2222 let WavesPoolAddress = base58'3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG'
2323
2424 let WxPoolAddress = base58'3PKi4G3VX2k42ZSmNNrmvgdDH7JzRaUhY7R'
2525
2626 let EggPoolAddress = base58'3PEeJQRJT4v4XvSUBPmxhdWKz439nae7KtQ'
2727
2828 let SwopPoolAddress = base58'3P27S9V36kw2McjWRZ37AxTx8iwkd7HXw6W'
2929
3030 let ViresPoolAddress = base58'3PJ48P3p2wvWUjgQaQiZ2cFbr8qmxMokBGd'
3131
3232 func keyUserCourse (address,courseId) = ((address + "_course_") + toString(CourseId))
3333
3434
3535 func keyUserRewarded (address,courseId) = (((address + "_course_") + toString(CourseId)) + "_rewarded")
3636
3737
38+func getTokenEquivalent (poolAddress,amount) = {
39+ let assetABalance = getIntegerValue(Address(poolAddress), "A_asset_balance")
40+ let assetBBalance = getIntegerValue(Address(poolAddress), "B_asset_balance")
41+ fraction(assetABalance, amount, assetBBalance)
42+ }
43+
44+
3845 func calculateRewards () = {
3946 let wavesBalanceBefore = wavesBalance(this).regular
4047 if ((wavesBalanceBefore == wavesBalanceBefore))
4148 then {
42- let exchangeWaves = invoke(Address(WavesPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 3000000)])
49+ let exchangeWaves = invoke(Address(WavesPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 4000000)])
4350 if ((exchangeWaves == exchangeWaves))
4451 then {
4552 let wavesBalanceAfter = wavesBalance(this).regular
46-[StringEntry("__debug", ((("Exchange amount: " + toString(wavesBalanceAfter)) + ", before: ") + toString(wavesBalanceBefore)))]
53+ if ((wavesBalanceAfter == wavesBalanceAfter))
54+ then {
55+ let wavesAmount = (wavesBalanceAfter - wavesBalanceBefore)
56+ let eggBalanceBefore = assetBalance(this, EGGAssetId)
57+ if ((eggBalanceBefore == eggBalanceBefore))
58+ then {
59+ let exchangeEgg = invoke(Address(EggPoolAddress), "exchange", [1], [AttachedPayment(UsdnAssetId, 4000000)])
60+ if ((exchangeEgg == exchangeEgg))
61+ then {
62+ let eggBalanceAfter = assetBalance(this, EGGAssetId)
63+ if ((eggBalanceAfter == eggBalanceAfter))
64+ then {
65+ let eggAmount = (eggBalanceAfter - eggBalanceBefore)
66+ let swopAmount = getTokenEquivalent(SwopPoolAddress, 4000000)
67+ let wxAmount = getTokenEquivalent(WxPoolAddress, 4000000)
68+ let viresAmount = getTokenEquivalent(ViresPoolAddress, 4000000)
69+[StringEntry("__debug", makeString([toString(wavesAmount), toString(eggAmount), toString(swopAmount), toString(wxAmount), toString(viresAmount)], " || "))]
70+ }
71+ else throw("Strict value is not equal to itself.")
72+ }
73+ else throw("Strict value is not equal to itself.")
74+ }
75+ else throw("Strict value is not equal to itself.")
76+ }
77+ else throw("Strict value is not equal to itself.")
4778 }
4879 else throw("Strict value is not equal to itself.")
4980 }
5081 else throw("Strict value is not equal to itself.")
5182 }
5283
5384
5485 func getUserAlreadyFinished (callerAddress,courseId) = {
5586 let kUserCourse = keyUserCourse(callerAddress, courseId)
5687 match getBoolean(kUserCourse) {
5788 case t: Boolean =>
5889 t
5990 case _ =>
6091 false
6192 }
6293 }
6394
6495
6596 func getUserAlreadyRewarded (callerAddress,courseId) = {
6697 let kUserRewarded = keyUserRewarded(callerAddress, courseId)
6798 match getBoolean(kUserRewarded) {
6899 case t: Boolean =>
69100 t
70101 case _ =>
71102 false
72103 }
73104 }
74105
75106
76107 @Callable(i)
77108 func payForCertificate (name,courseId,signature) = {
78109 let callerAddress = toString(i.originCaller)
79110 let kUserCourseValue = getUserAlreadyFinished(callerAddress, courseId)
80111 let dataToSign = ((name + toString(courseId)) + callerAddress)
81112 if ((sigVerify_8Kb(toBytes(dataToSign), fromBase58String(signature), backendPublicKey) == false))
82113 then throw("Backend proof is not correct")
83114 else if ((value(value(i.payments[0]).assetId) != UsdnAssetId))
84115 then throw("10 USDN should be attached")
85116 else if ((value(value(i.payments[0]).amount) != UsdnAmount))
86117 then throw((("At least " + toString(UsdnAmount)) + " USDN should be attached"))
87118 else if (kUserCourseValue)
88119 then throw("User already got a certificate!")
89120 else [BooleanEntry(keyUserCourse(callerAddress, courseId), true)]
90121 }
91122
92123
93124
94125 @Callable(i)
95126 func payToUser (address,courseId) = {
96127 let kUserCourseValue = getUserAlreadyFinished(address, courseId)
97128 let kUserRewardedValue = getUserAlreadyRewarded(address, courseId)
98129 if ((kUserCourseValue == false))
99130 then throw("User didn't finish the course")
100131 else if ((kUserRewardedValue == true))
101132 then throw("User was already rewarded")
102133 else calculateRewards()
103134 }
104135
105136

github/deemru/w8io/786bc32 
57.37 ms