tx · 3XbnmMeBuBuUCy2ciiVWdKCpovLY4qFi3SgA2tPED8HY 3NA2sejUzEcL7Gg8WfhrcqxP22fHk2SS9pK: -0.00600000 Waves 2022.08.25 08:37 [2199589] smart account 3NA2sejUzEcL7Gg8WfhrcqxP22fHk2SS9pK > SELF 0.00000000 Waves
{ "type": 13, "id": "3XbnmMeBuBuUCy2ciiVWdKCpovLY4qFi3SgA2tPED8HY", "fee": 600000, "feeAssetId": null, "timestamp": 1661405897741, "version": 2, "chainId": 84, "sender": "3NA2sejUzEcL7Gg8WfhrcqxP22fHk2SS9pK", "senderPublicKey": "HMzDczZUThMMhE2Grm1ZmpN3QNZ9N7CUCYnsqh4utSDJ", "proofs": [ "4KnJgaLCsPqd4guj5YuAcBZuoUm9RjVA6bfFq7gLN49D66TUpoR4ExEV6V394CrRZUkE9DP5qXcXaMPhP68AxAuw" ], "script": "base64:BgIYCAISABIAEgMKAQESAwoBARIAEgASABIABgAEdXNkbgEg11KRGPRfT6VehNuJvBkobHB7OMalzc+gLp7N2ofv42AABHVzZGMBIPQcuTcYg4l4Uh6IaJaLWyiuNgmUbeQfgPZEel3eCXgMAAxhZG1pbl93YWxsZXQCIzNOM0RDbmdqaWRpdmtKYlRKd0ZURXZiWVJUZmZDV1ZCTENMAA5hbGZhcmtfdGVzdG5ldAAFAAp2aXJlc19kYXBwARoBVHjn3floRCovnhXY1SHCQGibEg7rsYrFrAENdHJ5R2V0SW50ZWdlcgEDa2V5BAckbWF0Y2gwCQCaCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgNJbnQEAWIFByRtYXRjaDAFAWIAAAgBaQEPYnV5X3VzZG5fdGlja2V0AAMJAQIhPQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUEdXNkbgkAAgECH1BsZWFzZSBkZXBvc2l0IFVTRC1OIHRva2VuIG9ubHkEC3VzZXJfY3JlZGl0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgV1c2RuXwkApQgBCAUBaQxvcmlnaW5DYWxsZXICB19jcmVkaXQEDmRlcG9zaXRfYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQPbmV3X3VzZXJfY3JlZGl0CQBkAgULdXNlcl9jcmVkaXQFDmRlcG9zaXRfYW1vdW50BAphbGxfY3JlZGl0CQENdHJ5R2V0SW50ZWdlcgECD3VzZG5fYWxsX2NyZWRpdAQObmV3X2FsbF9jcmVkaXQJAGQCBQphbGxfY3JlZGl0BQ5kZXBvc2l0X2Ftb3VudAQRdHJhbnNhY3Rpb25fYmxvY2sEByRtYXRjaDAIBQlsYXN0QmxvY2sGaGVpZ2h0AwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQkAAgECHUVycm9yISB3aXRoIGJsb2NoY2hhaW4gaGVpZ2h0BANyZXMJAPwHBAkBB0FkZHJlc3MBBQp2aXJlc19kYXBwAgp1c2ROX3N0YWtlBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHVzZG4FDmRlcG9zaXRfYW1vdW50BQNuaWwDCQAAAgUDcmVzBQNyZXMJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgV1c2RuXwkApQgBCAUBaQxvcmlnaW5DYWxsZXICB19jcmVkaXQFD25ld191c2VyX2NyZWRpdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBXVzZG5fCQClCAEIBQFpDG9yaWdpbkNhbGxlcgIGX2Jsb2NrBRF0cmFuc2FjdGlvbl9ibG9jawkAzAgCCQEMSW50ZWdlckVudHJ5AgIPdXNkbl9hbGxfY3JlZGl0BQ5uZXdfYWxsX2NyZWRpdAkAzAgCCQEMSW50ZWdlckVudHJ5AgIOdXNkbl9hbGxfYmxvY2sFEXRyYW5zYWN0aW9uX2Jsb2NrBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEPYnV5X3VzZGNfdGlja2V0AAMJAQIhPQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUEdXNkYwkAAgECH1BsZWFzZSBkZXBvc2l0IFVTRC1OIHRva2VuIG9ubHkEC3VzZXJfY3JlZGl0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgV1c2RjXwkApQgBCAUBaQxvcmlnaW5DYWxsZXICB19jcmVkaXQEDmRlcG9zaXRfYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQPbmV3X3VzZXJfY3JlZGl0CQBkAgULdXNlcl9jcmVkaXQFDmRlcG9zaXRfYW1vdW50BAphbGxfY3JlZGl0CQENdHJ5R2V0SW50ZWdlcgECD3VzZGNfYWxsX2NyZWRpdAQObmV3X2FsbF9jcmVkaXQJAGQCBQphbGxfY3JlZGl0BQ5kZXBvc2l0X2Ftb3VudAQRdHJhbnNhY3Rpb25fYmxvY2sEByRtYXRjaDAIBQlsYXN0QmxvY2sGaGVpZ2h0AwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQkAAgECEkVycm9yIGJsb2NrIG51bWJlcgQDcmVzCQD8BwQJAQdBZGRyZXNzAQUKdmlyZXNfZGFwcAIKdXNkQ19zdGFrZQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQR1c2RjBQ5kZXBvc2l0X2Ftb3VudAUDbmlsAwkAAAIFA3JlcwUDcmVzCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIFdXNkY18JAKUIAQgFAWkMb3JpZ2luQ2FsbGVyAgdfY3JlZGl0BQ9uZXdfdXNlcl9jcmVkaXQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgV1c2RjXwkApQgBCAUBaQxvcmlnaW5DYWxsZXICBl9ibG9jawURdHJhbnNhY3Rpb25fYmxvY2sJAMwIAgkBDEludGVnZXJFbnRyeQICD3VzZGNfYWxsX2NyZWRpdAUObmV3X2FsbF9jcmVkaXQJAMwIAgkBDEludGVnZXJFbnRyeQICDnVzZGNfYWxsX2Jsb2NrBRF0cmFuc2FjdGlvbl9ibG9jawUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEHNlbGxfdXNkbl90aWNrZXQBBmFtb3VudAQLdXNlcl9jcmVkaXQJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICBXVzZG5fCQClCAEIBQFpDG9yaWdpbkNhbGxlcgIHX2NyZWRpdAMJAGYCBQZhbW91bnQFC3VzZXJfY3JlZGl0CQACAQkArAICAj5zb3JyeSB5b3UgY2FuJ3Qgd2l0aGRyYXcgdGhpcyBhbW91bnQsIGJlY2F1c2UgdT15b3UgaGF2ZSBvbmx5IAkApAMBBQt1c2VyX2NyZWRpdAQPbmV3X3VzZXJfY3JlZGl0CQBlAgULdXNlcl9jcmVkaXQFBmFtb3VudAQKYWxsX2NyZWRpdAkBDXRyeUdldEludGVnZXIBAg91c2RuX2FsbF9jcmVkaXQEDm5ld19hbGxfY3JlZGl0CQBlAgUKYWxsX2NyZWRpdAUGYW1vdW50BBF0cmFuc2FjdGlvbl9ibG9jawQHJG1hdGNoMAgFCWxhc3RCbG9jawZoZWlnaHQDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhCQACAQISRXJyb3IgYmxvY2sgbnVtYmVyBANyZXMJAPwHBAkBB0FkZHJlc3MBBQp2aXJlc19kYXBwAhB1c2ROX2NhbmNlbFN0YWtlCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUDcmVzBQNyZXMJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICAgV1c2RuXwkApQgBCAUBaQxvcmlnaW5DYWxsZXICB19jcmVkaXQFD25ld191c2VyX2NyZWRpdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBXVzZG5fCQClCAEIBQFpDG9yaWdpbkNhbGxlcgIGX2Jsb2NrBRF0cmFuc2FjdGlvbl9ibG9jawkAzAgCCQEMSW50ZWdlckVudHJ5AgIPdXNkbl9hbGxfY3JlZGl0BQ5uZXdfYWxsX2NyZWRpdAkAzAgCCQEMSW50ZWdlckVudHJ5AgIOdXNkbl9hbGxfYmxvY2sFEXRyYW5zYWN0aW9uX2Jsb2NrBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEQc2VsbF91c2RjX3RpY2tldAEGYW1vdW50BAt1c2VyX2NyZWRpdAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIFdXNkY18JAKUIAQgFAWkMb3JpZ2luQ2FsbGVyAgdfY3JlZGl0AwkAZgIFBmFtb3VudAULdXNlcl9jcmVkaXQJAAIBCQCsAgICPnNvcnJ5IHlvdSBjYW4ndCB3aXRoZHJhdyB0aGlzIGFtb3VudCwgYmVjYXVzZSB1PXlvdSBoYXZlIG9ubHkgCQCkAwEFC3VzZXJfY3JlZGl0BA9uZXdfdXNlcl9jcmVkaXQJAGUCBQt1c2VyX2NyZWRpdAUGYW1vdW50BAphbGxfY3JlZGl0CQENdHJ5R2V0SW50ZWdlcgECD3VzZGNfYWxsX2NyZWRpdAQObmV3X2FsbF9jcmVkaXQJAGUCBQphbGxfY3JlZGl0BQZhbW91bnQEEXRyYW5zYWN0aW9uX2Jsb2NrBAckbWF0Y2gwCAUJbGFzdEJsb2NrBmhlaWdodAMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEJAAIBAhJFcnJvciBibG9jayBudW1iZXIEA3JlcwkA/AcECQEHQWRkcmVzcwEFCnZpcmVzX2RhcHACEHVzZENfY2FuY2VsU3Rha2UJAMwIAgUGYW1vdW50BQNuaWwFA25pbAMJAAACBQNyZXMFA3JlcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBXVzZGNfCQClCAEIBQFpDG9yaWdpbkNhbGxlcgIHX2NyZWRpdAUPbmV3X3VzZXJfY3JlZGl0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIFdXNkY18JAKUIAQgFAWkMb3JpZ2luQ2FsbGVyAgZfYmxvY2sFEXRyYW5zYWN0aW9uX2Jsb2NrCQDMCAIJAQxJbnRlZ2VyRW50cnkCAg91c2RjX2FsbF9jcmVkaXQFDm5ld19hbGxfY3JlZGl0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAg51c2RjX2FsbF9ibG9jawURdHJhbnNhY3Rpb25fYmxvY2sFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARd1c2RuX2NhbGNfcHJvZml0X2Ftb3VudAADCQECIT0CCQClCAEIBQFpDG9yaWdpbkNhbGxlcgUMYWRtaW5fd2FsbGV0CQACAQIwU29ycnkhIHlvdSBhcmUgbm90IGFsbG93ZWQgdG8gdXNlIHRoaXMgZnVuYWN0aW9uBBZ1c2RuX3Byb2ZpdF9sYXN0X2Jsb2NrCQENdHJ5R2V0SW50ZWdlcgECFnVzZG5fcHJvZml0X2xhc3RfYmxvY2sEF3VzZG5fcHJvZml0X2xhc3RfYW1vdW50CQENdHJ5R2V0SW50ZWdlcgECF3VzZG5fcHJvZml0X2xhc3RfYW1vdW50BBF0cmFuc2FjdGlvbl9ibG9jawQHJG1hdGNoMAgFCWxhc3RCbG9jawZoZWlnaHQDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhCQACAQISRXJyb3IgYmxvY2sgbnVtYmVyBAZhbGZhcmsJAGUCBRF0cmFuc2FjdGlvbl9ibG9jawUWdXNkbl9wcm9maXRfbGFzdF9ibG9jawMJAGYCBQ5hbGZhcmtfdGVzdG5ldAUGYWxmYXJrCQACAQkArAICCQCsAgICF1BsZWFzZSB0cnkgYWdhaW4gYWZ0ZXIgCQCkAwEJAGUCBQ5hbGZhcmtfdGVzdG5ldAUGYWxmYXJrAgYgYmxvY2sEDHVzZG5fYmFsYW5jZQkA8AcCBQR0aGlzBQR1c2RuCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhZ1c2RuX3Byb2ZpdF9sYXN0X2Jsb2NrBRF0cmFuc2FjdGlvbl9ibG9jawkAzAgCCQEMSW50ZWdlckVudHJ5AgIXdXNkbl9wcm9maXRfbGFzdF9hbW91bnQFDHVzZG5fYmFsYW5jZQUDbmlsAWkBF3VzZG5fc2VuZF9wcm9maXRfYW1vdW50AAQXdXNkbl9wcm9maXRfbGFzdF9hbW91bnQJAQ10cnlHZXRJbnRlZ2VyAQIXdXNkbl9wcm9maXRfbGFzdF9hbW91bnQDCQBnAgAABRd1c2RuX3Byb2ZpdF9sYXN0X2Ftb3VudAkAAgEJAKwCAgIceW91IGRvbnQgaGF2ZSBwcm9maXQgYW1vdW50IAkApAMBBRd1c2RuX3Byb2ZpdF9sYXN0X2Ftb3VudAQIdHJhbnNmZXIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDGFkbWluX3dhbGxldAUXdXNkbl9wcm9maXRfbGFzdF9hbW91bnQFBHVzZG4JAMwIAgUIdHJhbnNmZXIFA25pbAFpARd1c2RjX2NhbGNfcHJvZml0X2Ftb3VudAADCQECIT0CCQClCAEIBQFpDG9yaWdpbkNhbGxlcgUMYWRtaW5fd2FsbGV0CQACAQIwU29ycnkhIHlvdSBhcmUgbm90IGFsbG93ZWQgdG8gdXNlIHRoaXMgZnVuYWN0aW9uBBZ1c2RjX3Byb2ZpdF9sYXN0X2Jsb2NrCQENdHJ5R2V0SW50ZWdlcgECFnVzZGNfcHJvZml0X2xhc3RfYmxvY2sEF3VzZGNfcHJvZml0X2xhc3RfYW1vdW50CQENdHJ5R2V0SW50ZWdlcgECF3VzZGNfcHJvZml0X2xhc3RfYW1vdW50BBF0cmFuc2FjdGlvbl9ibG9jawQHJG1hdGNoMAgFCWxhc3RCbG9jawZoZWlnaHQDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhCQACAQISRXJyb3IgYmxvY2sgbnVtYmVyBAZhbGZhcmsJAGUCBRF0cmFuc2FjdGlvbl9ibG9jawUWdXNkY19wcm9maXRfbGFzdF9ibG9jawMJAGYCBQ5hbGZhcmtfdGVzdG5ldAUGYWxmYXJrCQACAQkArAICCQCsAgICF1BsZWFzZSB0cnkgYWdhaW4gYWZ0ZXIgCQCkAwEJAGUCBQ5hbGZhcmtfdGVzdG5ldAUGYWxmYXJrAgYgYmxvY2sEDHVzZGNfYmFsYW5jZQkA8AcCBQR0aGlzBQR1c2RjCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhZ1c2RjX3Byb2ZpdF9sYXN0X2Jsb2NrBRF0cmFuc2FjdGlvbl9ibG9jawkAzAgCCQEMSW50ZWdlckVudHJ5AgIXdXNkY19wcm9maXRfbGFzdF9hbW91bnQFDHVzZGNfYmFsYW5jZQUDbmlsAWkBF3VzZGNfc2VuZF9wcm9maXRfYW1vdW50AAQXdXNkY19wcm9maXRfbGFzdF9hbW91bnQJAQ10cnlHZXRJbnRlZ2VyAQIXdXNkY19wcm9maXRfbGFzdF9hbW91bnQDCQBnAgAABRd1c2RjX3Byb2ZpdF9sYXN0X2Ftb3VudAkAAgEJAKwCAgIceW91IGRvbnQgaGF2ZSBwcm9maXQgYW1vdW50IAkApAMBBRd1c2RjX3Byb2ZpdF9sYXN0X2Ftb3VudAQIdHJhbnNmZXIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDGFkbWluX3dhbGxldAUXdXNkY19wcm9maXRfbGFzdF9hbW91bnQFBHVzZGMJAMwIAgUIdHJhbnNmZXIFA25pbAECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkc3W8u", "height": 2199589, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GzsGmeLhBaZFsc53yUGCMrTTSHoVjJYByk3e7Uo8THAo Next: FxBJBzLztZC78R4ph8cB9ezFA4Xic3vA5K87HjQLk3YL Diff:
Old | New | Differences | |
---|---|---|---|
28 | 28 | let new_user_credit = (user_credit + deposit_amount) | |
29 | 29 | let all_credit = tryGetInteger("usdn_all_credit") | |
30 | 30 | let new_all_credit = (all_credit + deposit_amount) | |
31 | - | let transaction_block = match | |
31 | + | let transaction_block = match lastBlock.height { | |
32 | 32 | case a: Int => | |
33 | 33 | a | |
34 | 34 | case _ => | |
35 | - | | |
35 | + | throw("Error! with blochchain height") | |
36 | 36 | } | |
37 | 37 | let res = invoke(Address(vires_dapp), "usdN_stake", nil, [AttachedPayment(usdn, deposit_amount)]) | |
38 | 38 | if ((res == res)) | |
51 | 51 | let new_user_credit = (user_credit + deposit_amount) | |
52 | 52 | let all_credit = tryGetInteger("usdc_all_credit") | |
53 | 53 | let new_all_credit = (all_credit + deposit_amount) | |
54 | - | let transaction_block = match | |
54 | + | let transaction_block = match lastBlock.height { | |
55 | 55 | case a: Int => | |
56 | 56 | a | |
57 | 57 | case _ => | |
59 | 59 | } | |
60 | 60 | let res = invoke(Address(vires_dapp), "usdC_stake", nil, [AttachedPayment(usdc, deposit_amount)]) | |
61 | 61 | if ((res == res)) | |
62 | - | then { | |
63 | - | let vires_res = match res { | |
64 | - | case r: List[Any] => | |
65 | - | r | |
66 | - | case _ => | |
67 | - | throw("Incorrect invoke result") | |
68 | - | } | |
69 | - | if ((vires_res == vires_res)) | |
70 | - | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
71 | - | else throw("Strict value is not equal to itself.") | |
72 | - | } | |
62 | + | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
73 | 63 | else throw("Strict value is not equal to itself.") | |
74 | 64 | } | |
75 | 65 | ||
84 | 74 | let new_user_credit = (user_credit - amount) | |
85 | 75 | let all_credit = tryGetInteger("usdn_all_credit") | |
86 | 76 | let new_all_credit = (all_credit - amount) | |
87 | - | let transaction_block = match | |
77 | + | let transaction_block = match lastBlock.height { | |
88 | 78 | case a: Int => | |
89 | 79 | a | |
90 | 80 | case _ => | |
92 | 82 | } | |
93 | 83 | let res = invoke(Address(vires_dapp), "usdN_cancelStake", [amount], nil) | |
94 | 84 | if ((res == res)) | |
95 | - | then { | |
96 | - | let vires_res = match res { | |
97 | - | case r: List[Any] => | |
98 | - | r | |
99 | - | case _ => | |
100 | - | throw("Incorrect invoke result") | |
101 | - | } | |
102 | - | if ((vires_res == vires_res)) | |
103 | - | then [IntegerEntry((("usdn_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdn_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdn_all_credit", new_all_credit), IntegerEntry("usdn_all_block", transaction_block)] | |
104 | - | else throw("Strict value is not equal to itself.") | |
105 | - | } | |
85 | + | then [IntegerEntry((("usdn_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdn_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdn_all_credit", new_all_credit), IntegerEntry("usdn_all_block", transaction_block)] | |
106 | 86 | else throw("Strict value is not equal to itself.") | |
107 | 87 | } | |
108 | 88 | } | |
118 | 98 | let new_user_credit = (user_credit - amount) | |
119 | 99 | let all_credit = tryGetInteger("usdc_all_credit") | |
120 | 100 | let new_all_credit = (all_credit - amount) | |
121 | - | let transaction_block = match | |
101 | + | let transaction_block = match lastBlock.height { | |
122 | 102 | case a: Int => | |
123 | 103 | a | |
124 | 104 | case _ => | |
126 | 106 | } | |
127 | 107 | let res = invoke(Address(vires_dapp), "usdC_cancelStake", [amount], nil) | |
128 | 108 | if ((res == res)) | |
129 | - | then { | |
130 | - | let vires_res = match res { | |
131 | - | case r: List[Any] => | |
132 | - | r | |
133 | - | case _ => | |
134 | - | throw("Incorrect invoke result") | |
135 | - | } | |
136 | - | if ((vires_res == vires_res)) | |
137 | - | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
138 | - | else throw("Strict value is not equal to itself.") | |
139 | - | } | |
109 | + | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
140 | 110 | else throw("Strict value is not equal to itself.") | |
141 | 111 | } | |
142 | 112 | } | |
149 | 119 | else { | |
150 | 120 | let usdn_profit_last_block = tryGetInteger("usdn_profit_last_block") | |
151 | 121 | let usdn_profit_last_amount = tryGetInteger("usdn_profit_last_amount") | |
152 | - | let transaction_block = match | |
122 | + | let transaction_block = match lastBlock.height { | |
153 | 123 | case a: Int => | |
154 | 124 | a | |
155 | 125 | case _ => | |
185 | 155 | else { | |
186 | 156 | let usdc_profit_last_block = tryGetInteger("usdc_profit_last_block") | |
187 | 157 | let usdc_profit_last_amount = tryGetInteger("usdc_profit_last_amount") | |
188 | - | let transaction_block = match | |
158 | + | let transaction_block = match lastBlock.height { | |
189 | 159 | case a: Int => | |
190 | 160 | a | |
191 | 161 | case _ => |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let usdn = base58'FVXgJ86erBw5GAMeAw1CnYXwQn48BFAEAhRyHPUjbMQB' | |
5 | 5 | ||
6 | 6 | let usdc = base58'HRut8ESAGXxwvsKJky1V96qRtqyXQd4Apq4GY7TE5yGP' | |
7 | 7 | ||
8 | 8 | let admin_wallet = "3N3DCngjidivkJbTJwFTEvbYRTffCWVBLCL" | |
9 | 9 | ||
10 | 10 | let alfark_testnet = 5 | |
11 | 11 | ||
12 | 12 | let vires_dapp = base58'3MzwNdM8LQZEPXq3d4uXvxeZGpBwVQXs9RD' | |
13 | 13 | ||
14 | 14 | func tryGetInteger (key) = match getInteger(this, key) { | |
15 | 15 | case b: Int => | |
16 | 16 | b | |
17 | 17 | case _ => | |
18 | 18 | 0 | |
19 | 19 | } | |
20 | 20 | ||
21 | 21 | ||
22 | 22 | @Callable(i) | |
23 | 23 | func buy_usdn_ticket () = if ((i.payments[0].assetId != usdn)) | |
24 | 24 | then throw("Please deposit USD-N token only") | |
25 | 25 | else { | |
26 | 26 | let user_credit = tryGetInteger((("usdn_" + toString(i.originCaller)) + "_credit")) | |
27 | 27 | let deposit_amount = i.payments[0].amount | |
28 | 28 | let new_user_credit = (user_credit + deposit_amount) | |
29 | 29 | let all_credit = tryGetInteger("usdn_all_credit") | |
30 | 30 | let new_all_credit = (all_credit + deposit_amount) | |
31 | - | let transaction_block = match | |
31 | + | let transaction_block = match lastBlock.height { | |
32 | 32 | case a: Int => | |
33 | 33 | a | |
34 | 34 | case _ => | |
35 | - | | |
35 | + | throw("Error! with blochchain height") | |
36 | 36 | } | |
37 | 37 | let res = invoke(Address(vires_dapp), "usdN_stake", nil, [AttachedPayment(usdn, deposit_amount)]) | |
38 | 38 | if ((res == res)) | |
39 | 39 | then [IntegerEntry((("usdn_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdn_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdn_all_credit", new_all_credit), IntegerEntry("usdn_all_block", transaction_block)] | |
40 | 40 | else throw("Strict value is not equal to itself.") | |
41 | 41 | } | |
42 | 42 | ||
43 | 43 | ||
44 | 44 | ||
45 | 45 | @Callable(i) | |
46 | 46 | func buy_usdc_ticket () = if ((i.payments[0].assetId != usdc)) | |
47 | 47 | then throw("Please deposit USD-N token only") | |
48 | 48 | else { | |
49 | 49 | let user_credit = tryGetInteger((("usdc_" + toString(i.originCaller)) + "_credit")) | |
50 | 50 | let deposit_amount = i.payments[0].amount | |
51 | 51 | let new_user_credit = (user_credit + deposit_amount) | |
52 | 52 | let all_credit = tryGetInteger("usdc_all_credit") | |
53 | 53 | let new_all_credit = (all_credit + deposit_amount) | |
54 | - | let transaction_block = match | |
54 | + | let transaction_block = match lastBlock.height { | |
55 | 55 | case a: Int => | |
56 | 56 | a | |
57 | 57 | case _ => | |
58 | 58 | throw("Error block number") | |
59 | 59 | } | |
60 | 60 | let res = invoke(Address(vires_dapp), "usdC_stake", nil, [AttachedPayment(usdc, deposit_amount)]) | |
61 | 61 | if ((res == res)) | |
62 | - | then { | |
63 | - | let vires_res = match res { | |
64 | - | case r: List[Any] => | |
65 | - | r | |
66 | - | case _ => | |
67 | - | throw("Incorrect invoke result") | |
68 | - | } | |
69 | - | if ((vires_res == vires_res)) | |
70 | - | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
71 | - | else throw("Strict value is not equal to itself.") | |
72 | - | } | |
62 | + | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
73 | 63 | else throw("Strict value is not equal to itself.") | |
74 | 64 | } | |
75 | 65 | ||
76 | 66 | ||
77 | 67 | ||
78 | 68 | @Callable(i) | |
79 | 69 | func sell_usdn_ticket (amount) = { | |
80 | 70 | let user_credit = tryGetInteger((("usdn_" + toString(i.originCaller)) + "_credit")) | |
81 | 71 | if ((amount > user_credit)) | |
82 | 72 | then throw(("sorry you can't withdraw this amount, because u=you have only " + toString(user_credit))) | |
83 | 73 | else { | |
84 | 74 | let new_user_credit = (user_credit - amount) | |
85 | 75 | let all_credit = tryGetInteger("usdn_all_credit") | |
86 | 76 | let new_all_credit = (all_credit - amount) | |
87 | - | let transaction_block = match | |
77 | + | let transaction_block = match lastBlock.height { | |
88 | 78 | case a: Int => | |
89 | 79 | a | |
90 | 80 | case _ => | |
91 | 81 | throw("Error block number") | |
92 | 82 | } | |
93 | 83 | let res = invoke(Address(vires_dapp), "usdN_cancelStake", [amount], nil) | |
94 | 84 | if ((res == res)) | |
95 | - | then { | |
96 | - | let vires_res = match res { | |
97 | - | case r: List[Any] => | |
98 | - | r | |
99 | - | case _ => | |
100 | - | throw("Incorrect invoke result") | |
101 | - | } | |
102 | - | if ((vires_res == vires_res)) | |
103 | - | then [IntegerEntry((("usdn_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdn_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdn_all_credit", new_all_credit), IntegerEntry("usdn_all_block", transaction_block)] | |
104 | - | else throw("Strict value is not equal to itself.") | |
105 | - | } | |
85 | + | then [IntegerEntry((("usdn_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdn_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdn_all_credit", new_all_credit), IntegerEntry("usdn_all_block", transaction_block)] | |
106 | 86 | else throw("Strict value is not equal to itself.") | |
107 | 87 | } | |
108 | 88 | } | |
109 | 89 | ||
110 | 90 | ||
111 | 91 | ||
112 | 92 | @Callable(i) | |
113 | 93 | func sell_usdc_ticket (amount) = { | |
114 | 94 | let user_credit = tryGetInteger((("usdc_" + toString(i.originCaller)) + "_credit")) | |
115 | 95 | if ((amount > user_credit)) | |
116 | 96 | then throw(("sorry you can't withdraw this amount, because u=you have only " + toString(user_credit))) | |
117 | 97 | else { | |
118 | 98 | let new_user_credit = (user_credit - amount) | |
119 | 99 | let all_credit = tryGetInteger("usdc_all_credit") | |
120 | 100 | let new_all_credit = (all_credit - amount) | |
121 | - | let transaction_block = match | |
101 | + | let transaction_block = match lastBlock.height { | |
122 | 102 | case a: Int => | |
123 | 103 | a | |
124 | 104 | case _ => | |
125 | 105 | throw("Error block number") | |
126 | 106 | } | |
127 | 107 | let res = invoke(Address(vires_dapp), "usdC_cancelStake", [amount], nil) | |
128 | 108 | if ((res == res)) | |
129 | - | then { | |
130 | - | let vires_res = match res { | |
131 | - | case r: List[Any] => | |
132 | - | r | |
133 | - | case _ => | |
134 | - | throw("Incorrect invoke result") | |
135 | - | } | |
136 | - | if ((vires_res == vires_res)) | |
137 | - | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
138 | - | else throw("Strict value is not equal to itself.") | |
139 | - | } | |
109 | + | then [IntegerEntry((("usdc_" + toString(i.originCaller)) + "_credit"), new_user_credit), IntegerEntry((("usdc_" + toString(i.originCaller)) + "_block"), transaction_block), IntegerEntry("usdc_all_credit", new_all_credit), IntegerEntry("usdc_all_block", transaction_block)] | |
140 | 110 | else throw("Strict value is not equal to itself.") | |
141 | 111 | } | |
142 | 112 | } | |
143 | 113 | ||
144 | 114 | ||
145 | 115 | ||
146 | 116 | @Callable(i) | |
147 | 117 | func usdn_calc_profit_amount () = if ((toString(i.originCaller) != admin_wallet)) | |
148 | 118 | then throw("Sorry! you are not allowed to use this funaction") | |
149 | 119 | else { | |
150 | 120 | let usdn_profit_last_block = tryGetInteger("usdn_profit_last_block") | |
151 | 121 | let usdn_profit_last_amount = tryGetInteger("usdn_profit_last_amount") | |
152 | - | let transaction_block = match | |
122 | + | let transaction_block = match lastBlock.height { | |
153 | 123 | case a: Int => | |
154 | 124 | a | |
155 | 125 | case _ => | |
156 | 126 | throw("Error block number") | |
157 | 127 | } | |
158 | 128 | let alfark = (transaction_block - usdn_profit_last_block) | |
159 | 129 | if ((alfark_testnet > alfark)) | |
160 | 130 | then throw((("Please try again after " + toString((alfark_testnet - alfark))) + " block")) | |
161 | 131 | else { | |
162 | 132 | let usdn_balance = assetBalance(this, usdn) | |
163 | 133 | [IntegerEntry("usdn_profit_last_block", transaction_block), IntegerEntry("usdn_profit_last_amount", usdn_balance)] | |
164 | 134 | } | |
165 | 135 | } | |
166 | 136 | ||
167 | 137 | ||
168 | 138 | ||
169 | 139 | @Callable(i) | |
170 | 140 | func usdn_send_profit_amount () = { | |
171 | 141 | let usdn_profit_last_amount = tryGetInteger("usdn_profit_last_amount") | |
172 | 142 | if ((0 >= usdn_profit_last_amount)) | |
173 | 143 | then throw(("you dont have profit amount " + toString(usdn_profit_last_amount))) | |
174 | 144 | else { | |
175 | 145 | let transfer = ScriptTransfer(addressFromStringValue(admin_wallet), usdn_profit_last_amount, usdn) | |
176 | 146 | [transfer] | |
177 | 147 | } | |
178 | 148 | } | |
179 | 149 | ||
180 | 150 | ||
181 | 151 | ||
182 | 152 | @Callable(i) | |
183 | 153 | func usdc_calc_profit_amount () = if ((toString(i.originCaller) != admin_wallet)) | |
184 | 154 | then throw("Sorry! you are not allowed to use this funaction") | |
185 | 155 | else { | |
186 | 156 | let usdc_profit_last_block = tryGetInteger("usdc_profit_last_block") | |
187 | 157 | let usdc_profit_last_amount = tryGetInteger("usdc_profit_last_amount") | |
188 | - | let transaction_block = match | |
158 | + | let transaction_block = match lastBlock.height { | |
189 | 159 | case a: Int => | |
190 | 160 | a | |
191 | 161 | case _ => | |
192 | 162 | throw("Error block number") | |
193 | 163 | } | |
194 | 164 | let alfark = (transaction_block - usdc_profit_last_block) | |
195 | 165 | if ((alfark_testnet > alfark)) | |
196 | 166 | then throw((("Please try again after " + toString((alfark_testnet - alfark))) + " block")) | |
197 | 167 | else { | |
198 | 168 | let usdc_balance = assetBalance(this, usdc) | |
199 | 169 | [IntegerEntry("usdc_profit_last_block", transaction_block), IntegerEntry("usdc_profit_last_amount", usdc_balance)] | |
200 | 170 | } | |
201 | 171 | } | |
202 | 172 | ||
203 | 173 | ||
204 | 174 | ||
205 | 175 | @Callable(i) | |
206 | 176 | func usdc_send_profit_amount () = { | |
207 | 177 | let usdc_profit_last_amount = tryGetInteger("usdc_profit_last_amount") | |
208 | 178 | if ((0 >= usdc_profit_last_amount)) | |
209 | 179 | then throw(("you dont have profit amount " + toString(usdc_profit_last_amount))) | |
210 | 180 | else { | |
211 | 181 | let transfer = ScriptTransfer(addressFromStringValue(admin_wallet), usdc_profit_last_amount, usdc) | |
212 | 182 | [transfer] | |
213 | 183 | } | |
214 | 184 | } | |
215 | 185 | ||
216 | 186 | ||
217 | 187 | @Verifier(tx) | |
218 | 188 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
219 | 189 |
github/deemru/w8io/026f985 35.95 ms ◑