tx · GawZ3g3uLJqCgFPbbjuaS6rfNwHPCk55myHb38Q1cbhb

3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx:  -0.01600000 Waves

2024.12.09 20:53 [3407396] smart account 3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx > SELF 0.00000000 Waves

{ "type": 13, "id": "GawZ3g3uLJqCgFPbbjuaS6rfNwHPCk55myHb38Q1cbhb", "fee": 1600000, "feeAssetId": null, "timestamp": 1733766817370, "version": 2, "chainId": 84, "sender": "3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx", "senderPublicKey": "BVdzAdt4eF9ScXGp5dwKiwoMQXBwMDeVSxLhL4LT1ceu", "proofs": [ "3Cj2dYJD4PdgeE2UUvgveaSVp4vmCcAHu7ieEAn3zRwneu5mu9cNBUEnQshKu8SeS3j3YyGReJjTf9LiVV175JPp" ], "script": "base64:BgIyCAISAwoBCBIECgIIARIDCgEIEgQKAggBEgMKAQgSBAoCCAESAwoBARIDCgEIEgMKAQg6AQlpc1Rlc3RFbnYABAd0ZXN0ZW52BAckbWF0Y2gwCQCbCAIFBHRoaXMCB1RFU1RFTlYDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcFB3Rlc3RlbnYBFHRyeUdldFN0cmluZ0V4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAnQgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABDXRyeUdldEJvb2xlYW4BA2tleQQHJG1hdGNoMAkAoAgBBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBDHRyeUdldFN0cmluZwEDa2V5CQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCBQR0aGlzBQNrZXkBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABCWdldE9yYWNsZQAJAQdBZGRyZXNzAQkA2QQBCQEMdHJ5R2V0U3RyaW5nAQIUc3RhdGljX29yYWNsZUFkZHJlc3MBHnN0YXRpY0tleV90dXJ0bGVTdGFraW5nQWRkcmVzcwACG3N0YXRpY190dXJ0bGVTdGFraW5nQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZVJlYmlydGhBZGRyZXNzAAIbc3RhdGljX3R1cnRsZVJlYmlydGhBZGRyZXNzARVzdGF0aWNLZXlfcm9wZUFkZHJlc3MAAhJzdGF0aWNfcm9wZUFkZHJlc3MBHHN0YXRpY0tleV9sZXZlbFN5c3RlbUFkZHJlc3MAAhlzdGF0aWNfbGV2ZWxTeXN0ZW1BZGRyZXNzARZzdGF0aWNLZXlfc3BpY2VBc3NldElkAAITc3RhdGljX3NwaWNlQXNzZXRJZAEVc3RhdGljS2V5X21hcmtldHBsYWNlAAIZc3RhdGljX21hcmtldHBsYWNlQWRkcmVzcwEZc3RhdGljS2V5X2NhcGFjaXR5QWRkcmVzcwACFnN0YXRpY19jYXBhY2l0eUFkZHJlc3MBHHN0YXRpY0tleV92ZWdnRmFybWluZ0FkZHJlc3MAAhlzdGF0aWNfdmVnZ0Zhcm1pbmdBZGRyZXNzARZzdGF0aWNLZXlfaXRlbXNBZGRyZXNzAAITc3RhdGljX2l0ZW1zQWRkcmVzcwEec3RhdGljS2V5X211dGFudEZhcm1pbmdBZGRyZXNzAAIbc3RhdGljX211dGFudEZhcm1pbmdBZGRyZXNzAR5zdGF0aWNLZXlfY2FuaW5lQnJlZWRlckFkZHJlc3MAAhtzdGF0aWNfY2FuaW5lQnJlZWRlckFkZHJlc3MBHnN0YXRpY0tleV9mZWxpbmVCcmVlZGVyQWRkcmVzcwACG3N0YXRpY19mZWxpbmVCcmVlZGVyQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZUJyZWVkZXJBZGRyZXNzAAIbc3RhdGljX3R1cnRsZUJyZWVkZXJBZGRyZXNzARFnZXRSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIVc3RhdGljX3JlYmlydGhBZGRyZXNzARNnZXRJbmN1YmF0b3JBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhdzdGF0aWNfaW5jdWJhdG9yQWRkcmVzcwERZ2V0RmFybWluZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACGHN0YXRpY19mYXJtaW5nQWRkcmVzc05ldwESZ2V0R2FtZURhcHBBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfZ2FtZURhcHBBZGRyZXNzARJnZXRDYXBhY2l0eUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARlzdGF0aWNLZXlfY2FwYWNpdHlBZGRyZXNzAAEOZ2V0QnVybkFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACEnN0YXRpY19idXJuQWRkcmVzcwESZ2V0QmFieWR1Y2tBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfYmFieUR1Y2tBZGRyZXNzARJnZXRCcmVlZGluZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEQZ2V0TWFzdGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIWc3RhdGljX2NmTWFzdGVyQWRkcmVzcwEXZ2V0VHVydGxlU3Rha2luZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJAR5zdGF0aWNLZXlfdHVydGxlU3Rha2luZ0FkZHJlc3MAARdnZXRUdXJ0bGVSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVSZWJpcnRoQWRkcmVzcwABDmdldFJvcGVBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X3JvcGVBZGRyZXNzAAEPZ2V0U3BpY2VBc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9zcGljZUFzc2V0SWQAARVnZXRMZXZlbFN5c3RlbUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARxzdGF0aWNLZXlfbGV2ZWxTeXN0ZW1BZGRyZXNzAAEVZ2V0TWFya2V0UGxhY2VBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X21hcmtldHBsYWNlAAEVZ2V0VmVnZ0Zhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEcc3RhdGljS2V5X3ZlZ2dGYXJtaW5nQWRkcmVzcwABD2dldEl0ZW1zQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9pdGVtc0FkZHJlc3MAARdnZXRNdXRhbnRGYXJtaW5nQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV9tdXRhbnRGYXJtaW5nQWRkcmVzcwABF2dldENhbmluZUZhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhtzdGF0aWNfY2FuaW5lU3Rha2luZ0FkZHJlc3MBF2dldEZlbGluZUZhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhtzdGF0aWNfZmVsaW5lU3Rha2luZ0FkZHJlc3MBF2dldENhbmluZUJyZWVkZXJBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEec3RhdGljS2V5X2NhbmluZUJyZWVkZXJBZGRyZXNzAAEXZ2V0RmVsaW5lQnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJAR5zdGF0aWNLZXlfZmVsaW5lQnJlZWRlckFkZHJlc3MAARdnZXRUdXJ0bGVCcmVlZGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVCcmVlZGVyQWRkcmVzcwAACHdBY2NQS2V5CQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQEJZ2V0T3JhY2xlAAIPc3RhdGljX3dhcnNQS2V5AhtzdGF0aWNfd2Fyc1BLZXkgbm90IGRlZmluZWQAD3NjQ2FuVXNlQ291cG9ucwkAzAgCCQERZ2V0UmViaXJ0aEFkZHJlc3MACQDMCAIJARNnZXRJbmN1YmF0b3JBZGRyZXNzAAkAzAgCCQERZ2V0RmFybWluZ0FkZHJlc3MACQDMCAIJARJnZXRHYW1lRGFwcEFkZHJlc3MACQDMCAIJARJnZXRCYWJ5ZHVja0FkZHJlc3MACQDMCAIJARJnZXRCcmVlZGluZ0FkZHJlc3MACQDMCAIJARdnZXRUdXJ0bGVTdGFraW5nQWRkcmVzcwAJAMwIAgkBF2dldFR1cnRsZVJlYmlydGhBZGRyZXNzAAkAzAgCCQEOZ2V0Um9wZUFkZHJlc3MACQDMCAIJARVnZXRMZXZlbFN5c3RlbUFkZHJlc3MACQDMCAIJARVnZXRNYXJrZXRQbGFjZUFkZHJlc3MACQDMCAIJARJnZXRDYXBhY2l0eUFkZHJlc3MACQDMCAIJARdnZXRNdXRhbnRGYXJtaW5nQWRkcmVzcwAJAMwIAgkBF2dldENhbmluZUZhcm1pbmdBZGRyZXNzAAkAzAgCCQEXZ2V0RmVsaW5lRmFybWluZ0FkZHJlc3MACQDMCAIJARdnZXRDYW5pbmVCcmVlZGVyQWRkcmVzcwAJAMwIAgkBF2dldEZlbGluZUJyZWVkZXJBZGRyZXNzAAkAzAgCCQEXZ2V0VHVydGxlQnJlZWRlckFkZHJlc3MACQDMCAIFBHRoaXMFA25pbAEQY291cG9uc1VzZXJTcGVuZAEEdXNlcgkArAICBQR1c2VyAgZfc3BlbmQBEWNvdXBvbnNVc2VyQWN0aXZlAQR1c2VyCQCsAgIFBHVzZXICB19hY3RpdmUBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQR1c2VyCQCsAgIJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXICBF9vbGQBEGNvdXBvbnNTcGVuZE9uU2MBAnNjCQCsAgIFAnNjAg9fc3BlbmRfYnlfdXNpbmcBHWFjdGlvblBlckFkZHJlc3NQZXJVc2VyUGVyRGF5BAR1c2VyBmFjdGlvbgtkYXBwQWRkcmVzcwNkYXkJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgULZGFwcEFkZHJlc3MCAV8FBmFjdGlvbgIBXwUEdXNlcgIBXwUDZGF5AghfYWN0aW9ucwEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJMYXN0Q2hlY2tEYXkCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICEl9hY3Rpb25zX2NoZWNrX2RheQEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJBbW91bnRJbkFSb3cCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICFl9hY3Rpb25zX2Ftb3VudF9pbl9yb3cBDnVzZXJFeHBlcmllbmNlAQR1c2VyCQCsAgIFBHVzZXICC19leHBlcmllbmNlARJhZGRDb3Vwb25zSW50ZXJuYWwCBHVzZXIGYW1vdW50BAZrZXlPbGQJARRjb3Vwb25zVXNlckFjdGl2ZU9sZAEFBHVzZXIEA2tleQkBEWNvdXBvbnNVc2VyQWN0aXZlAQUEdXNlcgQKY291cG9uc09sZAkBDXRyeUdldEludGVnZXIBBQNrZXkEB2NvdXBvbnMJAGQCBQpjb3Vwb25zT2xkBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleU9sZAUKY291cG9uc09sZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BQdjb3Vwb25zBQNuaWwACXN0YXJ0VHNNcwCAiNj6qzEBF2NhbGN1bGF0ZURheXNTaW5jZVN0YXJ0AAQEZGlmZgkAZQIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQlzdGFydFRzTXMECmRheXNQYXNzZWQJAGkCBQRkaWZmCQBoAgCAowUA6AcFCmRheXNQYXNzZWQBEGhhc0RvbmVUYXNrN0RheXMFA2RheQdhZGRyZXNzCmFjdGlvbk5hbWUMcmV3YXJkQW1vdW50EnJld2FyZEFtb3VudFdlZWtseQQRdXNlckV4cGVyaWVuY2VLZXkJAQ51c2VyRXhwZXJpZW5jZQEFB2FkZHJlc3MED3VzZXJFeHBUaWxsZGF0ZQkBDXRyeUdldEludGVnZXIBBRF1c2VyRXhwZXJpZW5jZUtleQQLY2hlY2tEYXlLZXkJASNhY3Rpb25QZXJBZGRyZXNzUGVyVXNlckxhc3RDaGVja0RheQIFB2FkZHJlc3MFCmFjdGlvbk5hbWUEDGRheXNJblJvd0tleQkBI2FjdGlvblBlckFkZHJlc3NQZXJVc2VyQW1vdW50SW5BUm93AgUHYWRkcmVzcwUKYWN0aW9uTmFtZQQMbGFzdENoZWNrRGF5CQENdHJ5R2V0SW50ZWdlcgEFC2NoZWNrRGF5S2V5BAlkYXlzSW5Sb3cJAQ10cnlHZXRJbnRlZ2VyAQUMZGF5c0luUm93S2V5BA9kYXlzSW5Sb3dVcGRhdGUDCQAAAgUMbGFzdENoZWNrRGF5CQBlAgUDZGF5AAEJAGQCBQlkYXlzSW5Sb3cAAQMJAGYCCQBlAgUDZGF5AAEFDGxhc3RDaGVja0RheQABAAAEEmxhc3RDaGVja0RheVVwZGF0ZQUDZGF5BAZyZXdhcmQDCQAAAgUPZGF5c0luUm93VXBkYXRlAAcJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUScmV3YXJkQW1vdW50V2Vla2x5CQEPZ2V0U3BpY2VBc3NldElkAAkAzAgCCQEMSW50ZWdlckVudHJ5AgUMZGF5c0luUm93S2V5AAAFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgUMZGF5c0luUm93S2V5BQ9kYXlzSW5Sb3dVcGRhdGUFA25pbAkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQtjaGVja0RheUtleQUSbGFzdENoZWNrRGF5VXBkYXRlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFB2FkZHJlc3MFDHJld2FyZEFtb3VudAkBD2dldFNwaWNlQXNzZXRJZAAJAMwIAgkBDEludGVnZXJFbnRyeQIFEXVzZXJFeHBlcmllbmNlS2V5CQBkAgUPdXNlckV4cFRpbGxkYXRlAAEFA25pbAUGcmV3YXJkAQlwYXlBY3Rpb24ECmFjdGlvbk5hbWULdXNlckFkZHJlc3MGYW1vdW50A2RheQQLY29tcG9zZWRLZXkDCQENdHJ5R2V0Qm9vbGVhbgEJAKwCAgkArAICAgVUQVNLXwUKYWN0aW9uTmFtZQIGX0VWRVJZBQphY3Rpb25OYW1lCQCsAgIJAKwCAgUKYWN0aW9uTmFtZQIBXwkApAMBBQZhbW91bnQDCQENdHJ5R2V0Qm9vbGVhbgEJAKwCAgIFVEFTS18FC2NvbXBvc2VkS2V5CQEQaGFzRG9uZVRhc2s3RGF5cwUFA2RheQkApQgBBQt1c2VyQWRkcmVzcwULY29tcG9zZWRLZXkJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICBVRBU0tfBQtjb21wb3NlZEtleQINX1JFV0FSRF9EQUlMWQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIFVEFTS18FC2NvbXBvc2VkS2V5Ag5fUkVXQVJEX1dFRUtMWQUDbmlsARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMKYWN0aW9uTmFtZQ1hZGRyZXNzQ2FsbGVyB2FkZHJlc3MDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFDWFkZHJlc3NDYWxsZXIJAAIBAj1DUkE6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIHJld2FyZCBtb2R1bGUhBANkYXkJARdjYWxjdWxhdGVEYXlzU2luY2VTdGFydAAECWFjdGlvbktleQkBHWFjdGlvblBlckFkZHJlc3NQZXJVc2VyUGVyRGF5BAkApQgBBQdhZGRyZXNzBQphY3Rpb25OYW1lCQClCAEFDWFkZHJlc3NDYWxsZXIJAKQDAQUDZGF5BAx0b3RhbEFjdGlvbnMJAGQCCQENdHJ5R2V0SW50ZWdlcgEFCWFjdGlvbktleQABCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFCWFjdGlvbktleQUMdG90YWxBY3Rpb25zBQNuaWwJAQlwYXlBY3Rpb24EBQphY3Rpb25OYW1lBQdhZGRyZXNzBQx0b3RhbEFjdGlvbnMFA2RheQkBaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAg9DQ086IGFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgIUc3RhdGljX29yYWNsZUFkZHJlc3MFBm9yYWNsZQUDbmlsAWkBCmFkZENvdXBvbnMCBHVzZXIGYW1vdW50AwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkBAiE9AggFAWkPY2FsbGVyUHVibGljS2V5BQh3QWNjUEtleQcJAAIBAg9DQUM6IGFkbWluIG9ubHkDCQBnAgUGYW1vdW50AICt4gQJAM4IAgkBFHJlY29yZEFjdGlvbkludGVybmFsAwIMVkVHRzEwMDAwMDAwBQR0aGlzCQERQGV4dHJOYXRpdmUoMTA2MikBBQR1c2VyCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50AwkAZwIFBmFtb3VudACgwh4JAM4IAgkBFHJlY29yZEFjdGlvbkludGVybmFsAwIKVkVHRzUwMDAwMAUEdGhpcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUEdXNlcgkBEmFkZENvdXBvbnNJbnRlcm5hbAIFBHVzZXIFBmFtb3VudAkBEmFkZENvdXBvbnNJbnRlcm5hbAIFBHVzZXIFBmFtb3VudAFpAQxyZXNldENoZWF0ZXIBBHVzZXIDAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQECIT0CCAUBaQ9jYWxsZXJQdWJsaWNLZXkFCHdBY2NQS2V5BwkAAgECD0NBQzogYWRtaW4gb25seQQGa2V5T2xkCQEUY291cG9uc1VzZXJBY3RpdmVPbGQBBQR1c2VyBANrZXkJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXIECmNvdXBvbnNPbGQJAQ10cnlHZXRJbnRlZ2VyAQUDa2V5BAdjb3Vwb25zAIC+qND//////wEJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleU9sZAUKY291cG9uc09sZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BQdjb3Vwb25zBQNuaWwBaQERYWRkQ291cG9uc0Zhcm1pbmcCBHVzZXIGYW1vdW50AwMJAQIhPQIIBQFpBmNhbGxlcgkBFWdldFZlZ2dGYXJtaW5nQWRkcmVzcwAJAQIhPQIIBQFpBmNhbGxlcgkBF2dldE11dGFudEZhcm1pbmdBZGRyZXNzAAcJAAIBAhtNZXRob2Qgb25seSBmb3IgZmFybWluZyBzYyEJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQBaQEPYWRkQ291cG9uc0JhdGNoAQViYXRjaAMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpD2NhbGxlclB1YmxpY0tleQUId0FjY1BLZXkHCQACAQIPQ0FDOiBhZG1pbiBvbmx5BAtjb3Vwb25zTGlzdAkAtQkCBQViYXRjaAIBOwoBDGhhbmRsZUNvdXBvbgIDYWNjBmNvdXBvbgQKc3BsaXRBcnJheQkAtQkCBQZjb3Vwb24CAToEBHVzZXIJAJEDAgUKc3BsaXRBcnJheQAABAZhbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpzcGxpdEFycmF5AAEECGJ1cm5DYWxsCQD8BwQJAQ5nZXRCdXJuQWRkcmVzcwACDGJ1cm5CeUludm9rZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFCGJ1cm5DYWxsBQhidXJuQ2FsbAMJAGcCBQZhbW91bnQAgK3iBAkAzggCCQDOCAIFA2FjYwkBFHJlY29yZEFjdGlvbkludGVybmFsAwIMVkVHRzEwMDAwMDAwBQR0aGlzCQERQGV4dHJOYXRpdmUoMTA2MikBBQR1c2VyCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50AwkAZwIFBmFtb3VudACgwh4JAM4IAgkAzggCBQNhY2MJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMCClZFR0c1MDAwMDAFBHRoaXMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHVzZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJAM4IAgUDYWNjCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCgACJGwFC2NvdXBvbnNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQxoYW5kbGVDb3Vwb24CBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAFpAQhDRlJlZnVuZAIJcmVjaXBpZW50BmFtb3VudAQJY2ZBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA1MykCCAUBaQZjYWxsZXICCkNGX0FERFJFU1MEA2tleQkArAICCQCsAgICAmZfBQljZkFkZHJlc3MCDl9zdGFrZV9hZGRyZXNzBAxzdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDUzKQIJARBnZXRNYXN0ZXJBZGRyZXNzAAUDa2V5AwkBAiE9AgUMc3Rha2VBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgkAAgECJkNDUjogVGhpcyBpcyBzb21ldGhpbmcgZmlzaHkgZ29pbmcgb24hCQESYWRkQ291cG9uc0ludGVybmFsAgUJcmVjaXBpZW50BQZhbW91bnQBaQEKdXNlQ291cG9ucwERYW1vdW50VHJ5aW5nVG9QYXkECmludm9raW5nU2MIBQFpBmNhbGxlcgMJAGYCAAAFEWFtb3VudFRyeWluZ1RvUGF5CQACAQIvQ1VDOiBPbmx5IHBvc2l0aXZlIGFtb3VudCBvZiBtb25leSBjYW4gYmUgcGFpZCEDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFCmludm9raW5nU2MJAAIBAj1DVUM6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIGNvdXBvbiBtb2R1bGUhBAR1c2VyCQClCAEIBQFpDG9yaWdpbkNhbGxlcgQJa2V5QWN0aXZlCQERY291cG9uc1VzZXJBY3RpdmUBBQR1c2VyBBBhdmFpbGFibGVDb3Vwb25zCQENdHJ5R2V0SW50ZWdlcgEFCWtleUFjdGl2ZQMJAGYCAAAFEGF2YWlsYWJsZUNvdXBvbnMJAAIBAg5DVUM6IEdldCByZWt0IQQJbGVmdFRvUGF5AwkAZgIFEWFtb3VudFRyeWluZ1RvUGF5BRBhdmFpbGFibGVDb3Vwb25zCQBlAgURYW1vdW50VHJ5aW5nVG9QYXkFEGF2YWlsYWJsZUNvdXBvbnMAAAQKYW1vdW50UGFpZAkAZQIFEWFtb3VudFRyeWluZ1RvUGF5BQlsZWZ0VG9QYXkEFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQBlAgUQYXZhaWxhYmxlQ291cG9ucwUKYW1vdW50UGFpZAMJAGYCAAAFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQACAQIaQ1VDOiBZb3UgdHJ5IHRvIG92ZXJzcGVuZCEECGtleVNwZW5kCQEQY291cG9uc1VzZXJTcGVuZAEFBHVzZXIEBmtleU9sZAkBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQUEdXNlcgQKa2V5U3BlbmRTYwkBEGNvdXBvbnNTcGVuZE9uU2MBCQClCAEIBQFpBmNhbGxlcgQFdG9wVXAJAPwHBAkBFWdldFZlZ2dGYXJtaW5nQWRkcmVzcwACC3RvcFVwUmV3YXJkCQDMCAIJAGgCCQBpAgUKYW1vdW50UGFpZABkABkFA25pbAUDbmlsAwkAAAIFBXRvcFVwBQV0b3BVcAQGdG9wVXAyAwkAAAIFCmludm9raW5nU2MJARdnZXRNdXRhbnRGYXJtaW5nQWRkcmVzcwAFBHVuaXQJAPwHBAkBF2dldE11dGFudEZhcm1pbmdBZGRyZXNzAAILdG9wVXBSZXdhcmQJAMwIAgIEVkVHRwkAzAgCCQBoAgkAaQIFCmFtb3VudFBhaWQAZAAPBQNuaWwFA25pbAMJAAACBQZ0b3BVcDIFBnRvcFVwMgQKdG90YWxTcGVuZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUIa2V5U3BlbmQFCmFtb3VudFBhaWQEDHRvdGFsU3BlbmRTYwkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUKa2V5U3BlbmRTYwUKYW1vdW50UGFpZAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQhrZXlTcGVuZAUKdG90YWxTcGVuZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUGa2V5T2xkBRBhdmFpbGFibGVDb3Vwb25zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrZXlBY3RpdmUFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQprZXlTcGVuZFNjBQx0b3RhbFNwZW5kU2MFA25pbAUKYW1vdW50UGFpZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQxyZWNvcmRBY3Rpb24BCmFjdGlvbk5hbWUJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMFCmFjdGlvbk5hbWUIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyAWkBC2luY3JlYXNlRXhwAQdhZGRyZXNzAwkBAiE9AggFAWkGY2FsbGVyCQEPZ2V0SXRlbXNBZGRyZXNzAAUDbmlsBBF1c2VyRXhwZXJpZW5jZUtleQkBDnVzZXJFeHBlcmllbmNlAQUHYWRkcmVzcwQPdXNlckV4cFRpbGxkYXRlCQENdHJ5R2V0SW50ZWdlcgEFEXVzZXJFeHBlcmllbmNlS2V5CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRF1c2VyRXhwZXJpZW5jZUtleQkAZAIFD3VzZXJFeHBUaWxsZGF0ZQABBQNuaWwBAnR4AQZ2ZXJpZnkAAwkBCWlzVGVzdEVudgAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkECWZpcnN0VXNlcgEgURzk/Wb/EmnS8VoUnzuy4vQ7f8HLaCeiNF5sONdX3W0ECnNlY29uZFVzZXIBIFxyDkuu8SFPZuYZRfpqorHtsTYpWV8ZzMyw4U1BiGp9BAl0aGlyZFVzZXIBIKCvkeUteUNhYTISrY65+hhZUZ0tU0k2w9Cj96hgGTtOBA9maXJzdFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQlmaXJzdFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCWZpcnN0VXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUJZmlyc3RVc2VyAAEAAAQQc2Vjb25kVXNlclNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCnNlY29uZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCnNlY29uZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCnNlY29uZFVzZXIAAQAABA90aGlyZFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQl0aGlyZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCXRoaXJkVXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUJdGhpcmRVc2VyAAEAAAQPc2lnbmF0dXJlc0NvdW50CQBkAgkAZAIFD2ZpcnN0VXNlclNpZ25lZAUQc2Vjb25kVXNlclNpZ25lZAUPdGhpcmRVc2VyU2lnbmVkBAckbWF0Y2gwBQJ0eAkAZwIFD3NpZ25hdHVyZXNDb3VudAABH6f5dw==", "height": 3407396, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HPAhB4UqYkF3VhEhQECaCuhmiEjN8k8LhJAfg4RhvPtA Next: 9jacSvFrYPxq4Uw785yMCqwxzAJP6NRCbUzpShJa2amf Diff:
OldNewDifferences
357357 let topUp = invoke(getVeggFarmingAddress(), "topUpReward", [((amountPaid / 100) * 25)], nil)
358358 if ((topUp == topUp))
359359 then {
360- let totalSpend = (tryGetInteger(keySpend) + amountPaid)
361- let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
362- $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
360+ let topUp2 = if ((invokingSc == getMutantFarmingAddress()))
361+ then unit
362+ else invoke(getMutantFarmingAddress(), "topUpReward", ["VEGG", ((amountPaid / 100) * 15)], nil)
363+ if ((topUp2 == topUp2))
364+ then {
365+ let totalSpend = (tryGetInteger(keySpend) + amountPaid)
366+ let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
367+ $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
368+ }
369+ else throw("Strict value is not equal to itself.")
363370 }
364371 else throw("Strict value is not equal to itself.")
365372 }
415422 let signaturesCount = ((firstUserSigned + secondUserSigned) + thirdUserSigned)
416423 match tx {
417424 case _ =>
418- (signaturesCount >= 2)
425+ (signaturesCount >= 1)
419426 }
420427 }
421428
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func isTestEnv () = {
55 let testenv = match getBoolean(this, "TESTENV") {
66 case x: Boolean =>
77 x
88 case _ =>
99 false
1010 }
1111 testenv
1212 }
1313
1414
1515 func tryGetStringExternal (address,key) = match getString(address, key) {
1616 case a: String =>
1717 a
1818 case _ =>
1919 ""
2020 }
2121
2222
2323 func tryGetBoolean (key) = match getBoolean(key) {
2424 case b: Boolean =>
2525 b
2626 case _ =>
2727 false
2828 }
2929
3030
3131 func tryGetString (key) = tryGetStringExternal(this, key)
3232
3333
3434 func tryGetInteger (key) = match getInteger(this, key) {
3535 case b: Int =>
3636 b
3737 case _ =>
3838 0
3939 }
4040
4141
4242 func getOracle () = Address(fromBase58String(tryGetString("static_oracleAddress")))
4343
4444
4545 func staticKey_turtleStakingAddress () = "static_turtleStakingAddress"
4646
4747
4848 func staticKey_turtleRebirthAddress () = "static_turtleRebirthAddress"
4949
5050
5151 func staticKey_ropeAddress () = "static_ropeAddress"
5252
5353
5454 func staticKey_levelSystemAddress () = "static_levelSystemAddress"
5555
5656
5757 func staticKey_spiceAssetId () = "static_spiceAssetId"
5858
5959
6060 func staticKey_marketplace () = "static_marketplaceAddress"
6161
6262
6363 func staticKey_capacityAddress () = "static_capacityAddress"
6464
6565
6666 func staticKey_veggFarmingAddress () = "static_veggFarmingAddress"
6767
6868
6969 func staticKey_itemsAddress () = "static_itemsAddress"
7070
7171
7272 func staticKey_mutantFarmingAddress () = "static_mutantFarmingAddress"
7373
7474
7575 func staticKey_canineBreederAddress () = "static_canineBreederAddress"
7676
7777
7878 func staticKey_felineBreederAddress () = "static_felineBreederAddress"
7979
8080
8181 func staticKey_turtleBreederAddress () = "static_turtleBreederAddress"
8282
8383
8484 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_rebirthAddress")))
8585
8686
8787 func getIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_incubatorAddress")))
8888
8989
9090 func getFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_farmingAddressNew")))
9191
9292
9393 func getGameDappAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_gameDappAddress")))
9494
9595
9696 func getCapacityAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_capacityAddress())))
9797
9898
9999 func getBurnAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_burnAddress")))
100100
101101
102102 func getBabyduckAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_babyDuckAddress")))
103103
104104
105105 func getBreedingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_breederAddress")))
106106
107107
108108 func getMasterAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_cfMasterAddress")))
109109
110110
111111 func getTurtleStakingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleStakingAddress())))
112112
113113
114114 func getTurtleRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleRebirthAddress())))
115115
116116
117117 func getRopeAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_ropeAddress())))
118118
119119
120120 func getSpiceAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_spiceAssetId()))
121121
122122
123123 func getLevelSystemAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_levelSystemAddress())))
124124
125125
126126 func getMarketPlaceAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_marketplace())))
127127
128128
129129 func getVeggFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_veggFarmingAddress())))
130130
131131
132132 func getItemsAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_itemsAddress())))
133133
134134
135135 func getMutantFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_mutantFarmingAddress())))
136136
137137
138138 func getCanineFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_canineStakingAddress")))
139139
140140
141141 func getFelineFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_felineStakingAddress")))
142142
143143
144144 func getCanineBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_canineBreederAddress())))
145145
146146
147147 func getFelineBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_felineBreederAddress())))
148148
149149
150150 func getTurtleBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleBreederAddress())))
151151
152152
153153 let wAccPKey = fromBase58String(valueOrErrorMessage(getString(getOracle(), "static_warsPKey"), "static_warsPKey not defined"))
154154
155155 let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress(), getMarketPlaceAddress(), getCapacityAddress(), getMutantFarmingAddress(), getCanineFarmingAddress(), getFelineFarmingAddress(), getCanineBreederAddress(), getFelineBreederAddress(), getTurtleBreederAddress(), this]
156156
157157 func couponsUserSpend (user) = (user + "_spend")
158158
159159
160160 func couponsUserActive (user) = (user + "_active")
161161
162162
163163 func couponsUserActiveOld (user) = (couponsUserActive(user) + "_old")
164164
165165
166166 func couponsSpendOnSc (sc) = (sc + "_spend_by_using")
167167
168168
169169 func actionPerAddressPerUserPerDay (user,action,dappAddress,day) = (((((((dappAddress + "_") + action) + "_") + user) + "_") + day) + "_actions")
170170
171171
172172 func actionPerAddressPerUserLastCheckDay (user,action) = (((action + "_") + user) + "_actions_check_day")
173173
174174
175175 func actionPerAddressPerUserAmountInARow (user,action) = (((action + "_") + user) + "_actions_amount_in_row")
176176
177177
178178 func userExperience (user) = (user + "_experience")
179179
180180
181181 func addCouponsInternal (user,amount) = {
182182 let keyOld = couponsUserActiveOld(user)
183183 let key = couponsUserActive(user)
184184 let couponsOld = tryGetInteger(key)
185185 let coupons = (couponsOld + amount)
186186 [IntegerEntry(keyOld, couponsOld), IntegerEntry(key, coupons)]
187187 }
188188
189189
190190 let startTsMs = 1695427200000
191191
192192 func calculateDaysSinceStart () = {
193193 let diff = (lastBlock.timestamp - startTsMs)
194194 let daysPassed = (diff / (86400 * 1000))
195195 daysPassed
196196 }
197197
198198
199199 func hasDoneTask7Days (day,address,actionName,rewardAmount,rewardAmountWeekly) = {
200200 let userExperienceKey = userExperience(address)
201201 let userExpTilldate = tryGetInteger(userExperienceKey)
202202 let checkDayKey = actionPerAddressPerUserLastCheckDay(address, actionName)
203203 let daysInRowKey = actionPerAddressPerUserAmountInARow(address, actionName)
204204 let lastCheckDay = tryGetInteger(checkDayKey)
205205 let daysInRow = tryGetInteger(daysInRowKey)
206206 let daysInRowUpdate = if ((lastCheckDay == (day - 1)))
207207 then (daysInRow + 1)
208208 else if (((day - 1) > lastCheckDay))
209209 then 1
210210 else 0
211211 let lastCheckDayUpdate = day
212212 let reward = if ((daysInRowUpdate == 7))
213213 then [ScriptTransfer(addressFromStringValue(address), rewardAmountWeekly, getSpiceAssetId()), IntegerEntry(daysInRowKey, 0)]
214214 else [IntegerEntry(daysInRowKey, daysInRowUpdate)]
215215 ([IntegerEntry(checkDayKey, lastCheckDayUpdate), ScriptTransfer(addressFromStringValue(address), rewardAmount, getSpiceAssetId()), IntegerEntry(userExperienceKey, (userExpTilldate + 1))] ++ reward)
216216 }
217217
218218
219219 func payAction (actionName,userAddress,amount,day) = {
220220 let composedKey = if (tryGetBoolean((("TASK_" + actionName) + "_EVERY")))
221221 then actionName
222222 else ((actionName + "_") + toString(amount))
223223 if (tryGetBoolean(("TASK_" + composedKey)))
224224 then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY")), tryGetInteger((("TASK_" + composedKey) + "_REWARD_WEEKLY")))
225225 else nil
226226 }
227227
228228
229229 func recordActionInternal (actionName,addressCaller,address) = if (!(containsElement(scCanUseCoupons, addressCaller)))
230230 then throw("CRA: Only certain smart contracts can use this reward module!")
231231 else {
232232 let day = calculateDaysSinceStart()
233233 let actionKey = actionPerAddressPerUserPerDay(toString(address), actionName, toString(addressCaller), toString(day))
234234 let totalActions = (tryGetInteger(actionKey) + 1)
235235 ([IntegerEntry(actionKey, totalActions)] ++ payAction(actionName, address, totalActions, day))
236236 }
237237
238238
239239 @Callable(i)
240240 func configureOracle (oracle) = if ((i.caller != this))
241241 then throw("CCO: admin only")
242242 else [StringEntry("static_oracleAddress", oracle)]
243243
244244
245245
246246 @Callable(i)
247247 func addCoupons (user,amount) = if (if ((i.caller != this))
248248 then (i.callerPublicKey != wAccPKey)
249249 else false)
250250 then throw("CAC: admin only")
251251 else if ((amount >= 10000000))
252252 then (recordActionInternal("VEGG10000000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
253253 else if ((amount >= 500000))
254254 then (recordActionInternal("VEGG500000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
255255 else addCouponsInternal(user, amount)
256256
257257
258258
259259 @Callable(i)
260260 func resetCheater (user) = if (if ((i.caller != this))
261261 then (i.callerPublicKey != wAccPKey)
262262 else false)
263263 then throw("CAC: admin only")
264264 else {
265265 let keyOld = couponsUserActiveOld(user)
266266 let key = couponsUserActive(user)
267267 let couponsOld = tryGetInteger(key)
268268 let coupons = -100000000
269269 [IntegerEntry(keyOld, couponsOld), IntegerEntry(key, coupons)]
270270 }
271271
272272
273273
274274 @Callable(i)
275275 func addCouponsFarming (user,amount) = if (if ((i.caller != getVeggFarmingAddress()))
276276 then (i.caller != getMutantFarmingAddress())
277277 else false)
278278 then throw("Method only for farming sc!")
279279 else addCouponsInternal(user, amount)
280280
281281
282282
283283 @Callable(i)
284284 func addCouponsBatch (batch) = if (if ((i.caller != this))
285285 then (i.callerPublicKey != wAccPKey)
286286 else false)
287287 then throw("CAC: admin only")
288288 else {
289289 let couponsList = split(batch, ";")
290290 func handleCoupon (acc,coupon) = {
291291 let splitArray = split(coupon, ":")
292292 let user = splitArray[0]
293293 let amount = parseIntValue(splitArray[1])
294294 let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil)
295295 if ((burnCall == burnCall))
296296 then if ((amount >= 10000000))
297297 then ((acc ++ recordActionInternal("VEGG10000000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
298298 else if ((amount >= 500000))
299299 then ((acc ++ recordActionInternal("VEGG500000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
300300 else (acc ++ addCouponsInternal(user, amount))
301301 else throw("Strict value is not equal to itself.")
302302 }
303303
304304 let $l = couponsList
305305 let $s = size($l)
306306 let $acc0 = nil
307307 func $f0_1 ($a,$i) = if (($i >= $s))
308308 then $a
309309 else handleCoupon($a, $l[$i])
310310
311311 func $f0_2 ($a,$i) = if (($i >= $s))
312312 then $a
313313 else throw("List size exceeds 20")
314314
315315 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
316316 }
317317
318318
319319
320320 @Callable(i)
321321 func CFRefund (recipient,amount) = {
322322 let cfAddress = getStringValue(i.caller, "CF_ADDRESS")
323323 let key = (("f_" + cfAddress) + "_stake_address")
324324 let stakeAddress = getStringValue(getMasterAddress(), key)
325325 if ((stakeAddress != toString(i.caller)))
326326 then throw("CCR: This is something fishy going on!")
327327 else addCouponsInternal(recipient, amount)
328328 }
329329
330330
331331
332332 @Callable(i)
333333 func useCoupons (amountTryingToPay) = {
334334 let invokingSc = i.caller
335335 if ((0 > amountTryingToPay))
336336 then throw("CUC: Only positive amount of money can be paid!")
337337 else if (!(containsElement(scCanUseCoupons, invokingSc)))
338338 then throw("CUC: Only certain smart contracts can use this coupon module!")
339339 else {
340340 let user = toString(i.originCaller)
341341 let keyActive = couponsUserActive(user)
342342 let availableCoupons = tryGetInteger(keyActive)
343343 if ((0 > availableCoupons))
344344 then throw("CUC: Get rekt!")
345345 else {
346346 let leftToPay = if ((amountTryingToPay > availableCoupons))
347347 then (amountTryingToPay - availableCoupons)
348348 else 0
349349 let amountPaid = (amountTryingToPay - leftToPay)
350350 let availableCouponsLeft = (availableCoupons - amountPaid)
351351 if ((0 > availableCouponsLeft))
352352 then throw("CUC: You try to overspend!")
353353 else {
354354 let keySpend = couponsUserSpend(user)
355355 let keyOld = couponsUserActiveOld(user)
356356 let keySpendSc = couponsSpendOnSc(toString(i.caller))
357357 let topUp = invoke(getVeggFarmingAddress(), "topUpReward", [((amountPaid / 100) * 25)], nil)
358358 if ((topUp == topUp))
359359 then {
360- let totalSpend = (tryGetInteger(keySpend) + amountPaid)
361- let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
362- $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
360+ let topUp2 = if ((invokingSc == getMutantFarmingAddress()))
361+ then unit
362+ else invoke(getMutantFarmingAddress(), "topUpReward", ["VEGG", ((amountPaid / 100) * 15)], nil)
363+ if ((topUp2 == topUp2))
364+ then {
365+ let totalSpend = (tryGetInteger(keySpend) + amountPaid)
366+ let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
367+ $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
368+ }
369+ else throw("Strict value is not equal to itself.")
363370 }
364371 else throw("Strict value is not equal to itself.")
365372 }
366373 }
367374 }
368375 }
369376
370377
371378
372379 @Callable(i)
373380 func recordAction (actionName) = recordActionInternal(actionName, i.caller, i.originCaller)
374381
375382
376383
377384 @Callable(i)
378385 func increaseExp (address) = if ((i.caller != getItemsAddress()))
379386 then nil
380387 else {
381388 let userExperienceKey = userExperience(address)
382389 let userExpTilldate = tryGetInteger(userExperienceKey)
383390 [IntegerEntry(userExperienceKey, (userExpTilldate + 1))]
384391 }
385392
386393
387394 @Verifier(tx)
388395 func verify () = if (isTestEnv())
389396 then sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
390397 else {
391398 let firstUser = base58'6TdaXEfhnjYquvPf3yV7MFxt2CbgFmaqsvGwkKfXtKi4'
392399 let secondUser = base58'7DsP2WaMLocbHuUxux7pbXRjTrrZ1TFQPsi5QumS3gr8'
393400 let thirdUser = base58'BpFWP3p3JgYrrP45xfrKzeMcWMEXoinj4FVPPkUiA8D3'
394401 let firstUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], firstUser))
395402 then 1
396403 else if (sigVerify(tx.bodyBytes, tx.proofs[1], firstUser))
397404 then 1
398405 else if (sigVerify(tx.bodyBytes, tx.proofs[2], firstUser))
399406 then 1
400407 else 0
401408 let secondUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], secondUser))
402409 then 1
403410 else if (sigVerify(tx.bodyBytes, tx.proofs[1], secondUser))
404411 then 1
405412 else if (sigVerify(tx.bodyBytes, tx.proofs[2], secondUser))
406413 then 1
407414 else 0
408415 let thirdUserSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], thirdUser))
409416 then 1
410417 else if (sigVerify(tx.bodyBytes, tx.proofs[1], thirdUser))
411418 then 1
412419 else if (sigVerify(tx.bodyBytes, tx.proofs[2], thirdUser))
413420 then 1
414421 else 0
415422 let signaturesCount = ((firstUserSigned + secondUserSigned) + thirdUserSigned)
416423 match tx {
417424 case _ =>
418- (signaturesCount >= 2)
425+ (signaturesCount >= 1)
419426 }
420427 }
421428

github/deemru/w8io/026f985 
39.62 ms