tx · HPAhB4UqYkF3VhEhQECaCuhmiEjN8k8LhJAfg4RhvPtA

3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx:  -0.01600000 Waves

2024.11.09 18:42 [3364107] smart account 3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx > SELF 0.00000000 Waves

{ "type": 13, "id": "HPAhB4UqYkF3VhEhQECaCuhmiEjN8k8LhJAfg4RhvPtA", "fee": 1600000, "feeAssetId": null, "timestamp": 1731166965368, "version": 2, "chainId": 84, "sender": "3MwFCBSWkWf9JMqmRyN5WEdoF2MCEPUB1Jx", "senderPublicKey": "BVdzAdt4eF9ScXGp5dwKiwoMQXBwMDeVSxLhL4LT1ceu", "proofs": [ "29cQQChUe45dH8jkTHBfrAyiQ4CGB1BzbKCMd37XZ89YzGC2Li5NWGwKVLR6m836Vj4PLj3P8dndNo6SpE16F4Di" ], "script": "base64:BgIyCAISAwoBCBIECgIIARIDCgEIEgQKAggBEgMKAQgSBAoCCAESAwoBARIDCgEIEgMKAQg6AQlpc1Rlc3RFbnYABAd0ZXN0ZW52BAckbWF0Y2gwCQCbCAIFBHRoaXMCB1RFU1RFTlYDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBeAUHJG1hdGNoMAUBeAcFB3Rlc3RlbnYBFHRyeUdldFN0cmluZ0V4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAnQgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABDXRyeUdldEJvb2xlYW4BA2tleQQHJG1hdGNoMAkAoAgBBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBDHRyeUdldFN0cmluZwEDa2V5CQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCBQR0aGlzBQNrZXkBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABCWdldE9yYWNsZQAJAQdBZGRyZXNzAQkA2QQBCQEMdHJ5R2V0U3RyaW5nAQIUc3RhdGljX29yYWNsZUFkZHJlc3MBHnN0YXRpY0tleV90dXJ0bGVTdGFraW5nQWRkcmVzcwACG3N0YXRpY190dXJ0bGVTdGFraW5nQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZVJlYmlydGhBZGRyZXNzAAIbc3RhdGljX3R1cnRsZVJlYmlydGhBZGRyZXNzARVzdGF0aWNLZXlfcm9wZUFkZHJlc3MAAhJzdGF0aWNfcm9wZUFkZHJlc3MBHHN0YXRpY0tleV9sZXZlbFN5c3RlbUFkZHJlc3MAAhlzdGF0aWNfbGV2ZWxTeXN0ZW1BZGRyZXNzARZzdGF0aWNLZXlfc3BpY2VBc3NldElkAAITc3RhdGljX3NwaWNlQXNzZXRJZAEVc3RhdGljS2V5X21hcmtldHBsYWNlAAIZc3RhdGljX21hcmtldHBsYWNlQWRkcmVzcwEZc3RhdGljS2V5X2NhcGFjaXR5QWRkcmVzcwACFnN0YXRpY19jYXBhY2l0eUFkZHJlc3MBHHN0YXRpY0tleV92ZWdnRmFybWluZ0FkZHJlc3MAAhlzdGF0aWNfdmVnZ0Zhcm1pbmdBZGRyZXNzARZzdGF0aWNLZXlfaXRlbXNBZGRyZXNzAAITc3RhdGljX2l0ZW1zQWRkcmVzcwEec3RhdGljS2V5X211dGFudEZhcm1pbmdBZGRyZXNzAAIbc3RhdGljX211dGFudEZhcm1pbmdBZGRyZXNzAR5zdGF0aWNLZXlfY2FuaW5lQnJlZWRlckFkZHJlc3MAAhtzdGF0aWNfY2FuaW5lQnJlZWRlckFkZHJlc3MBHnN0YXRpY0tleV9mZWxpbmVCcmVlZGVyQWRkcmVzcwACG3N0YXRpY19mZWxpbmVCcmVlZGVyQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZUJyZWVkZXJBZGRyZXNzAAIbc3RhdGljX3R1cnRsZUJyZWVkZXJBZGRyZXNzARFnZXRSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIVc3RhdGljX3JlYmlydGhBZGRyZXNzARNnZXRJbmN1YmF0b3JBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhdzdGF0aWNfaW5jdWJhdG9yQWRkcmVzcwERZ2V0RmFybWluZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACGHN0YXRpY19mYXJtaW5nQWRkcmVzc05ldwESZ2V0R2FtZURhcHBBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfZ2FtZURhcHBBZGRyZXNzARJnZXRDYXBhY2l0eUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARlzdGF0aWNLZXlfY2FwYWNpdHlBZGRyZXNzAAEOZ2V0QnVybkFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACEnN0YXRpY19idXJuQWRkcmVzcwESZ2V0QmFieWR1Y2tBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfYmFieUR1Y2tBZGRyZXNzARJnZXRCcmVlZGluZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEQZ2V0TWFzdGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIWc3RhdGljX2NmTWFzdGVyQWRkcmVzcwEXZ2V0VHVydGxlU3Rha2luZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJAR5zdGF0aWNLZXlfdHVydGxlU3Rha2luZ0FkZHJlc3MAARdnZXRUdXJ0bGVSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVSZWJpcnRoQWRkcmVzcwABDmdldFJvcGVBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X3JvcGVBZGRyZXNzAAEPZ2V0U3BpY2VBc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9zcGljZUFzc2V0SWQAARVnZXRMZXZlbFN5c3RlbUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARxzdGF0aWNLZXlfbGV2ZWxTeXN0ZW1BZGRyZXNzAAEVZ2V0TWFya2V0UGxhY2VBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X21hcmtldHBsYWNlAAEVZ2V0VmVnZ0Zhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEcc3RhdGljS2V5X3ZlZ2dGYXJtaW5nQWRkcmVzcwABD2dldEl0ZW1zQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9pdGVtc0FkZHJlc3MAARdnZXRNdXRhbnRGYXJtaW5nQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV9tdXRhbnRGYXJtaW5nQWRkcmVzcwABF2dldENhbmluZUZhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhtzdGF0aWNfY2FuaW5lU3Rha2luZ0FkZHJlc3MBF2dldEZlbGluZUZhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhtzdGF0aWNfZmVsaW5lU3Rha2luZ0FkZHJlc3MBF2dldENhbmluZUJyZWVkZXJBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEec3RhdGljS2V5X2NhbmluZUJyZWVkZXJBZGRyZXNzAAEXZ2V0RmVsaW5lQnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJAR5zdGF0aWNLZXlfZmVsaW5lQnJlZWRlckFkZHJlc3MAARdnZXRUdXJ0bGVCcmVlZGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVCcmVlZGVyQWRkcmVzcwAACHdBY2NQS2V5CQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQEJZ2V0T3JhY2xlAAIPc3RhdGljX3dhcnNQS2V5AhtzdGF0aWNfd2Fyc1BLZXkgbm90IGRlZmluZWQAD3NjQ2FuVXNlQ291cG9ucwkAzAgCCQERZ2V0UmViaXJ0aEFkZHJlc3MACQDMCAIJARNnZXRJbmN1YmF0b3JBZGRyZXNzAAkAzAgCCQERZ2V0RmFybWluZ0FkZHJlc3MACQDMCAIJARJnZXRHYW1lRGFwcEFkZHJlc3MACQDMCAIJARJnZXRCYWJ5ZHVja0FkZHJlc3MACQDMCAIJARJnZXRCcmVlZGluZ0FkZHJlc3MACQDMCAIJARdnZXRUdXJ0bGVTdGFraW5nQWRkcmVzcwAJAMwIAgkBF2dldFR1cnRsZVJlYmlydGhBZGRyZXNzAAkAzAgCCQEOZ2V0Um9wZUFkZHJlc3MACQDMCAIJARVnZXRMZXZlbFN5c3RlbUFkZHJlc3MACQDMCAIJARVnZXRNYXJrZXRQbGFjZUFkZHJlc3MACQDMCAIJARJnZXRDYXBhY2l0eUFkZHJlc3MACQDMCAIJARdnZXRNdXRhbnRGYXJtaW5nQWRkcmVzcwAJAMwIAgkBF2dldENhbmluZUZhcm1pbmdBZGRyZXNzAAkAzAgCCQEXZ2V0RmVsaW5lRmFybWluZ0FkZHJlc3MACQDMCAIJARdnZXRDYW5pbmVCcmVlZGVyQWRkcmVzcwAJAMwIAgkBF2dldEZlbGluZUJyZWVkZXJBZGRyZXNzAAkAzAgCCQEXZ2V0VHVydGxlQnJlZWRlckFkZHJlc3MACQDMCAIFBHRoaXMFA25pbAEQY291cG9uc1VzZXJTcGVuZAEEdXNlcgkArAICBQR1c2VyAgZfc3BlbmQBEWNvdXBvbnNVc2VyQWN0aXZlAQR1c2VyCQCsAgIFBHVzZXICB19hY3RpdmUBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQR1c2VyCQCsAgIJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXICBF9vbGQBEGNvdXBvbnNTcGVuZE9uU2MBAnNjCQCsAgIFAnNjAg9fc3BlbmRfYnlfdXNpbmcBHWFjdGlvblBlckFkZHJlc3NQZXJVc2VyUGVyRGF5BAR1c2VyBmFjdGlvbgtkYXBwQWRkcmVzcwNkYXkJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgULZGFwcEFkZHJlc3MCAV8FBmFjdGlvbgIBXwUEdXNlcgIBXwUDZGF5AghfYWN0aW9ucwEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJMYXN0Q2hlY2tEYXkCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICEl9hY3Rpb25zX2NoZWNrX2RheQEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJBbW91bnRJbkFSb3cCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICFl9hY3Rpb25zX2Ftb3VudF9pbl9yb3cBDnVzZXJFeHBlcmllbmNlAQR1c2VyCQCsAgIFBHVzZXICC19leHBlcmllbmNlARJhZGRDb3Vwb25zSW50ZXJuYWwCBHVzZXIGYW1vdW50BAZrZXlPbGQJARRjb3Vwb25zVXNlckFjdGl2ZU9sZAEFBHVzZXIEA2tleQkBEWNvdXBvbnNVc2VyQWN0aXZlAQUEdXNlcgQKY291cG9uc09sZAkBDXRyeUdldEludGVnZXIBBQNrZXkEB2NvdXBvbnMJAGQCBQpjb3Vwb25zT2xkBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleU9sZAUKY291cG9uc09sZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BQdjb3Vwb25zBQNuaWwACXN0YXJ0VHNNcwCAiNj6qzEBF2NhbGN1bGF0ZURheXNTaW5jZVN0YXJ0AAQEZGlmZgkAZQIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQlzdGFydFRzTXMECmRheXNQYXNzZWQJAGkCBQRkaWZmCQBoAgCAowUA6AcFCmRheXNQYXNzZWQBEGhhc0RvbmVUYXNrN0RheXMFA2RheQdhZGRyZXNzCmFjdGlvbk5hbWUMcmV3YXJkQW1vdW50EnJld2FyZEFtb3VudFdlZWtseQQRdXNlckV4cGVyaWVuY2VLZXkJAQ51c2VyRXhwZXJpZW5jZQEFB2FkZHJlc3MED3VzZXJFeHBUaWxsZGF0ZQkBDXRyeUdldEludGVnZXIBBRF1c2VyRXhwZXJpZW5jZUtleQQLY2hlY2tEYXlLZXkJASNhY3Rpb25QZXJBZGRyZXNzUGVyVXNlckxhc3RDaGVja0RheQIFB2FkZHJlc3MFCmFjdGlvbk5hbWUEDGRheXNJblJvd0tleQkBI2FjdGlvblBlckFkZHJlc3NQZXJVc2VyQW1vdW50SW5BUm93AgUHYWRkcmVzcwUKYWN0aW9uTmFtZQQMbGFzdENoZWNrRGF5CQENdHJ5R2V0SW50ZWdlcgEFC2NoZWNrRGF5S2V5BAlkYXlzSW5Sb3cJAQ10cnlHZXRJbnRlZ2VyAQUMZGF5c0luUm93S2V5BA9kYXlzSW5Sb3dVcGRhdGUDCQAAAgUMbGFzdENoZWNrRGF5CQBlAgUDZGF5AAEJAGQCBQlkYXlzSW5Sb3cAAQMJAGYCCQBlAgUDZGF5AAEFDGxhc3RDaGVja0RheQABAAAEEmxhc3RDaGVja0RheVVwZGF0ZQUDZGF5BAZyZXdhcmQDCQAAAgUPZGF5c0luUm93VXBkYXRlAAcJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUScmV3YXJkQW1vdW50V2Vla2x5CQEPZ2V0U3BpY2VBc3NldElkAAkAzAgCCQEMSW50ZWdlckVudHJ5AgUMZGF5c0luUm93S2V5AAAFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgUMZGF5c0luUm93S2V5BQ9kYXlzSW5Sb3dVcGRhdGUFA25pbAkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQtjaGVja0RheUtleQUSbGFzdENoZWNrRGF5VXBkYXRlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFB2FkZHJlc3MFDHJld2FyZEFtb3VudAkBD2dldFNwaWNlQXNzZXRJZAAJAMwIAgkBDEludGVnZXJFbnRyeQIFEXVzZXJFeHBlcmllbmNlS2V5CQBkAgUPdXNlckV4cFRpbGxkYXRlAAEFA25pbAUGcmV3YXJkAQlwYXlBY3Rpb24ECmFjdGlvbk5hbWULdXNlckFkZHJlc3MGYW1vdW50A2RheQQLY29tcG9zZWRLZXkDCQENdHJ5R2V0Qm9vbGVhbgEJAKwCAgkArAICAgVUQVNLXwUKYWN0aW9uTmFtZQIGX0VWRVJZBQphY3Rpb25OYW1lCQCsAgIJAKwCAgUKYWN0aW9uTmFtZQIBXwkApAMBBQZhbW91bnQDCQENdHJ5R2V0Qm9vbGVhbgEJAKwCAgIFVEFTS18FC2NvbXBvc2VkS2V5CQEQaGFzRG9uZVRhc2s3RGF5cwUFA2RheQkApQgBBQt1c2VyQWRkcmVzcwULY29tcG9zZWRLZXkJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICBVRBU0tfBQtjb21wb3NlZEtleQINX1JFV0FSRF9EQUlMWQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIFVEFTS18FC2NvbXBvc2VkS2V5Ag5fUkVXQVJEX1dFRUtMWQUDbmlsARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMKYWN0aW9uTmFtZQ1hZGRyZXNzQ2FsbGVyB2FkZHJlc3MDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFDWFkZHJlc3NDYWxsZXIJAAIBAj1DUkE6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIHJld2FyZCBtb2R1bGUhBANkYXkJARdjYWxjdWxhdGVEYXlzU2luY2VTdGFydAAECWFjdGlvbktleQkBHWFjdGlvblBlckFkZHJlc3NQZXJVc2VyUGVyRGF5BAkApQgBBQdhZGRyZXNzBQphY3Rpb25OYW1lCQClCAEFDWFkZHJlc3NDYWxsZXIJAKQDAQUDZGF5BAx0b3RhbEFjdGlvbnMJAGQCCQENdHJ5R2V0SW50ZWdlcgEFCWFjdGlvbktleQABCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFCWFjdGlvbktleQUMdG90YWxBY3Rpb25zBQNuaWwJAQlwYXlBY3Rpb24EBQphY3Rpb25OYW1lBQdhZGRyZXNzBQx0b3RhbEFjdGlvbnMFA2RheQkBaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAg9DQ086IGFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgIUc3RhdGljX29yYWNsZUFkZHJlc3MFBm9yYWNsZQUDbmlsAWkBCmFkZENvdXBvbnMCBHVzZXIGYW1vdW50AwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkBAiE9AggFAWkPY2FsbGVyUHVibGljS2V5BQh3QWNjUEtleQcJAAIBAg9DQUM6IGFkbWluIG9ubHkDCQBnAgUGYW1vdW50AICt4gQJAM4IAgkBFHJlY29yZEFjdGlvbkludGVybmFsAwIMVkVHRzEwMDAwMDAwBQR0aGlzCQERQGV4dHJOYXRpdmUoMTA2MikBBQR1c2VyCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50AwkAZwIFBmFtb3VudACgwh4JAM4IAgkBFHJlY29yZEFjdGlvbkludGVybmFsAwIKVkVHRzUwMDAwMAUEdGhpcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUEdXNlcgkBEmFkZENvdXBvbnNJbnRlcm5hbAIFBHVzZXIFBmFtb3VudAkBEmFkZENvdXBvbnNJbnRlcm5hbAIFBHVzZXIFBmFtb3VudAFpAQxyZXNldENoZWF0ZXIBBHVzZXIDAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQECIT0CCAUBaQ9jYWxsZXJQdWJsaWNLZXkFCHdBY2NQS2V5BwkAAgECD0NBQzogYWRtaW4gb25seQQGa2V5T2xkCQEUY291cG9uc1VzZXJBY3RpdmVPbGQBBQR1c2VyBANrZXkJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXIECmNvdXBvbnNPbGQJAQ10cnlHZXRJbnRlZ2VyAQUDa2V5BAdjb3Vwb25zAIC+qND//////wEJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleU9sZAUKY291cG9uc09sZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BQdjb3Vwb25zBQNuaWwBaQERYWRkQ291cG9uc0Zhcm1pbmcCBHVzZXIGYW1vdW50AwMJAQIhPQIIBQFpBmNhbGxlcgkBFWdldFZlZ2dGYXJtaW5nQWRkcmVzcwAJAQIhPQIIBQFpBmNhbGxlcgkBF2dldE11dGFudEZhcm1pbmdBZGRyZXNzAAcJAAIBAhtNZXRob2Qgb25seSBmb3IgZmFybWluZyBzYyEJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQBaQEPYWRkQ291cG9uc0JhdGNoAQViYXRjaAMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpD2NhbGxlclB1YmxpY0tleQUId0FjY1BLZXkHCQACAQIPQ0FDOiBhZG1pbiBvbmx5BAtjb3Vwb25zTGlzdAkAtQkCBQViYXRjaAIBOwoBDGhhbmRsZUNvdXBvbgIDYWNjBmNvdXBvbgQKc3BsaXRBcnJheQkAtQkCBQZjb3Vwb24CAToEBHVzZXIJAJEDAgUKc3BsaXRBcnJheQAABAZhbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpzcGxpdEFycmF5AAEECGJ1cm5DYWxsCQD8BwQJAQ5nZXRCdXJuQWRkcmVzcwACDGJ1cm5CeUludm9rZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFCGJ1cm5DYWxsBQhidXJuQ2FsbAMJAGcCBQZhbW91bnQAgK3iBAkAzggCCQDOCAIFA2FjYwkBFHJlY29yZEFjdGlvbkludGVybmFsAwIMVkVHRzEwMDAwMDAwBQR0aGlzCQERQGV4dHJOYXRpdmUoMTA2MikBBQR1c2VyCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50AwkAZwIFBmFtb3VudACgwh4JAM4IAgkAzggCBQNhY2MJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMCClZFR0c1MDAwMDAFBHRoaXMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHVzZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJAM4IAgUDYWNjCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCgACJGwFC2NvdXBvbnNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQxoYW5kbGVDb3Vwb24CBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAFpAQhDRlJlZnVuZAIJcmVjaXBpZW50BmFtb3VudAQJY2ZBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA1MykCCAUBaQZjYWxsZXICCkNGX0FERFJFU1MEA2tleQkArAICCQCsAgICAmZfBQljZkFkZHJlc3MCDl9zdGFrZV9hZGRyZXNzBAxzdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDUzKQIJARBnZXRNYXN0ZXJBZGRyZXNzAAUDa2V5AwkBAiE9AgUMc3Rha2VBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgkAAgECJkNDUjogVGhpcyBpcyBzb21ldGhpbmcgZmlzaHkgZ29pbmcgb24hCQESYWRkQ291cG9uc0ludGVybmFsAgUJcmVjaXBpZW50BQZhbW91bnQBaQEKdXNlQ291cG9ucwERYW1vdW50VHJ5aW5nVG9QYXkECmludm9raW5nU2MIBQFpBmNhbGxlcgMJAGYCAAAFEWFtb3VudFRyeWluZ1RvUGF5CQACAQIvQ1VDOiBPbmx5IHBvc2l0aXZlIGFtb3VudCBvZiBtb25leSBjYW4gYmUgcGFpZCEDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFCmludm9raW5nU2MJAAIBAj1DVUM6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIGNvdXBvbiBtb2R1bGUhBAR1c2VyCQClCAEIBQFpDG9yaWdpbkNhbGxlcgQJa2V5QWN0aXZlCQERY291cG9uc1VzZXJBY3RpdmUBBQR1c2VyBBBhdmFpbGFibGVDb3Vwb25zCQENdHJ5R2V0SW50ZWdlcgEFCWtleUFjdGl2ZQMJAGYCAAAFEGF2YWlsYWJsZUNvdXBvbnMJAAIBAg5DVUM6IEdldCByZWt0IQQJbGVmdFRvUGF5AwkAZgIFEWFtb3VudFRyeWluZ1RvUGF5BRBhdmFpbGFibGVDb3Vwb25zCQBlAgURYW1vdW50VHJ5aW5nVG9QYXkFEGF2YWlsYWJsZUNvdXBvbnMAAAQKYW1vdW50UGFpZAkAZQIFEWFtb3VudFRyeWluZ1RvUGF5BQlsZWZ0VG9QYXkEFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQBlAgUQYXZhaWxhYmxlQ291cG9ucwUKYW1vdW50UGFpZAMJAGYCAAAFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQACAQIaQ1VDOiBZb3UgdHJ5IHRvIG92ZXJzcGVuZCEECGtleVNwZW5kCQEQY291cG9uc1VzZXJTcGVuZAEFBHVzZXIEBmtleU9sZAkBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQUEdXNlcgQKa2V5U3BlbmRTYwkBEGNvdXBvbnNTcGVuZE9uU2MBCQClCAEIBQFpBmNhbGxlcgQFdG9wVXAJAPwHBAkBFWdldFZlZ2dGYXJtaW5nQWRkcmVzcwACC3RvcFVwUmV3YXJkCQDMCAIJAGgCCQBpAgUKYW1vdW50UGFpZABkABkFA25pbAUDbmlsAwkAAAIFBXRvcFVwBQV0b3BVcAQKdG90YWxTcGVuZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUIa2V5U3BlbmQFCmFtb3VudFBhaWQEDHRvdGFsU3BlbmRTYwkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUKa2V5U3BlbmRTYwUKYW1vdW50UGFpZAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQhrZXlTcGVuZAUKdG90YWxTcGVuZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUGa2V5T2xkBRBhdmFpbGFibGVDb3Vwb25zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrZXlBY3RpdmUFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQprZXlTcGVuZFNjBQx0b3RhbFNwZW5kU2MFA25pbAUKYW1vdW50UGFpZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQxyZWNvcmRBY3Rpb24BCmFjdGlvbk5hbWUJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMFCmFjdGlvbk5hbWUIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyAWkBC2luY3JlYXNlRXhwAQdhZGRyZXNzAwkBAiE9AggFAWkGY2FsbGVyCQEPZ2V0SXRlbXNBZGRyZXNzAAUDbmlsBBF1c2VyRXhwZXJpZW5jZUtleQkBDnVzZXJFeHBlcmllbmNlAQUHYWRkcmVzcwQPdXNlckV4cFRpbGxkYXRlCQENdHJ5R2V0SW50ZWdlcgEFEXVzZXJFeHBlcmllbmNlS2V5CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRF1c2VyRXhwZXJpZW5jZUtleQkAZAIFD3VzZXJFeHBUaWxsZGF0ZQABBQNuaWwBAnR4AQZ2ZXJpZnkAAwkBCWlzVGVzdEVudgAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkECWZpcnN0VXNlcgEgURzk/Wb/EmnS8VoUnzuy4vQ7f8HLaCeiNF5sONdX3W0ECnNlY29uZFVzZXIBIFxyDkuu8SFPZuYZRfpqorHtsTYpWV8ZzMyw4U1BiGp9BAl0aGlyZFVzZXIBIKCvkeUteUNhYTISrY65+hhZUZ0tU0k2w9Cj96hgGTtOBA9maXJzdFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQlmaXJzdFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCWZpcnN0VXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUJZmlyc3RVc2VyAAEAAAQQc2Vjb25kVXNlclNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCnNlY29uZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCnNlY29uZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFCnNlY29uZFVzZXIAAQAABA90aGlyZFVzZXJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQl0aGlyZFVzZXIAAQMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCXRoaXJkVXNlcgABAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUJdGhpcmRVc2VyAAEAAAQPc2lnbmF0dXJlc0NvdW50CQBkAgkAZAIFD2ZpcnN0VXNlclNpZ25lZAUQc2Vjb25kVXNlclNpZ25lZAUPdGhpcmRVc2VyU2lnbmVkBAckbWF0Y2gwBQJ0eAkAZwIFD3NpZ25hdHVyZXNDb3VudAACDfmcpg==", "height": 3364107, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2TSPXaAHWVq8Qor35WL4FtbCcsrQXAJWYjfQLuagGBSn Next: GawZ3g3uLJqCgFPbbjuaS6rfNwHPCk55myHb38Q1cbhb Diff:
OldNewDifferences
284284
285285
286286 @Callable(aP)
287-func addCouponsFarming (aa,an) = if ((aP.caller != P()))
287+func addCouponsFarming (aa,an) = if (if ((aP.caller != P()))
288+ then (aP.caller != R())
289+ else false)
288290 then throw("Method only for farming sc!")
289291 else am(aa, an)
290292
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func a () = {
55 let b = {
66 let c = getBoolean(this, "TESTENV")
77 if ($isInstanceOf(c, "Boolean"))
88 then {
99 let d = c
1010 d
1111 }
1212 else false
1313 }
1414 b
1515 }
1616
1717
1818 func e (f,g) = {
1919 let c = getString(f, g)
2020 if ($isInstanceOf(c, "String"))
2121 then {
2222 let h = c
2323 h
2424 }
2525 else ""
2626 }
2727
2828
2929 func i (g) = {
3030 let c = getBoolean(g)
3131 if ($isInstanceOf(c, "Boolean"))
3232 then {
3333 let j = c
3434 j
3535 }
3636 else false
3737 }
3838
3939
4040 func k (g) = e(this, g)
4141
4242
4343 func l (g) = {
4444 let c = getInteger(this, g)
4545 if ($isInstanceOf(c, "Int"))
4646 then {
4747 let j = c
4848 j
4949 }
5050 else 0
5151 }
5252
5353
5454 func m () = Address(fromBase58String(k("static_oracleAddress")))
5555
5656
5757 func n () = "static_turtleStakingAddress"
5858
5959
6060 func o () = "static_turtleRebirthAddress"
6161
6262
6363 func p () = "static_ropeAddress"
6464
6565
6666 func q () = "static_levelSystemAddress"
6767
6868
6969 func r () = "static_spiceAssetId"
7070
7171
7272 func s () = "static_marketplaceAddress"
7373
7474
7575 func t () = "static_capacityAddress"
7676
7777
7878 func u () = "static_veggFarmingAddress"
7979
8080
8181 func v () = "static_itemsAddress"
8282
8383
8484 func w () = "static_mutantFarmingAddress"
8585
8686
8787 func x () = "static_canineBreederAddress"
8888
8989
9090 func y () = "static_felineBreederAddress"
9191
9292
9393 func z () = "static_turtleBreederAddress"
9494
9595
9696 func A () = Address(fromBase58String(e(m(), "static_rebirthAddress")))
9797
9898
9999 func B () = Address(fromBase58String(e(m(), "static_incubatorAddress")))
100100
101101
102102 func C () = Address(fromBase58String(e(m(), "static_farmingAddressNew")))
103103
104104
105105 func D () = Address(fromBase58String(e(m(), "static_gameDappAddress")))
106106
107107
108108 func E () = Address(fromBase58String(e(m(), t())))
109109
110110
111111 func F () = Address(fromBase58String(e(m(), "static_burnAddress")))
112112
113113
114114 func G () = Address(fromBase58String(e(m(), "static_babyDuckAddress")))
115115
116116
117117 func H () = Address(fromBase58String(e(m(), "static_breederAddress")))
118118
119119
120120 func I () = Address(fromBase58String(e(m(), "static_cfMasterAddress")))
121121
122122
123123 func J () = Address(fromBase58String(e(m(), n())))
124124
125125
126126 func K () = Address(fromBase58String(e(m(), o())))
127127
128128
129129 func L () = Address(fromBase58String(e(m(), p())))
130130
131131
132132 func M () = fromBase58String(e(m(), r()))
133133
134134
135135 func N () = Address(fromBase58String(e(m(), q())))
136136
137137
138138 func O () = Address(fromBase58String(e(m(), s())))
139139
140140
141141 func P () = Address(fromBase58String(e(m(), u())))
142142
143143
144144 func Q () = Address(fromBase58String(e(m(), v())))
145145
146146
147147 func R () = Address(fromBase58String(e(m(), w())))
148148
149149
150150 func S () = Address(fromBase58String(e(m(), "static_canineStakingAddress")))
151151
152152
153153 func T () = Address(fromBase58String(e(m(), "static_felineStakingAddress")))
154154
155155
156156 func U () = Address(fromBase58String(e(m(), x())))
157157
158158
159159 func V () = Address(fromBase58String(e(m(), y())))
160160
161161
162162 func W () = Address(fromBase58String(e(m(), z())))
163163
164164
165165 let X = fromBase58String(valueOrErrorMessage(getString(m(), "static_warsPKey"), "static_warsPKey not defined"))
166166
167167 let Y = [A(), B(), C(), D(), G(), H(), J(), K(), L(), N(), O(), E(), R(), S(), T(), U(), V(), W(), this]
168168
169169 func Z (aa) = (aa + "_spend")
170170
171171
172172 func ab (aa) = (aa + "_active")
173173
174174
175175 func ac (aa) = (ab(aa) + "_old")
176176
177177
178178 func ad (ae) = (ae + "_spend_by_using")
179179
180180
181181 func af (aa,ag,ah,ai) = (((((((ah + "_") + ag) + "_") + aa) + "_") + ai) + "_actions")
182182
183183
184184 func aj (aa,ag) = (((ag + "_") + aa) + "_actions_check_day")
185185
186186
187187 func ak (aa,ag) = (((ag + "_") + aa) + "_actions_amount_in_row")
188188
189189
190190 func al (aa) = (aa + "_experience")
191191
192192
193193 func am (aa,an) = {
194194 let ao = ac(aa)
195195 let g = ab(aa)
196196 let ap = l(g)
197197 let aq = (ap + an)
198198 [IntegerEntry(ao, ap), IntegerEntry(g, aq)]
199199 }
200200
201201
202202 let ar = 1695427200000
203203
204204 func as () = {
205205 let at = (lastBlock.timestamp - ar)
206206 let au = (at / (86400 * 1000))
207207 au
208208 }
209209
210210
211211 func av (ai,f,aw,ax,ay) = {
212212 let az = al(f)
213213 let aA = l(az)
214214 let aB = aj(f, aw)
215215 let aC = ak(f, aw)
216216 let aD = l(aB)
217217 let aE = l(aC)
218218 let aF = if ((aD == (ai - 1)))
219219 then (aE + 1)
220220 else if (((ai - 1) > aD))
221221 then 1
222222 else 0
223223 let aG = ai
224224 let aH = if ((aF == 7))
225225 then [ScriptTransfer(addressFromStringValue(f), ay, M()), IntegerEntry(aC, 0)]
226226 else [IntegerEntry(aC, aF)]
227227 ([IntegerEntry(aB, aG), ScriptTransfer(addressFromStringValue(f), ax, M()), IntegerEntry(az, (aA + 1))] ++ aH)
228228 }
229229
230230
231231 func aI (aw,aJ,an,ai) = {
232232 let aK = if (i((("TASK_" + aw) + "_EVERY")))
233233 then aw
234234 else ((aw + "_") + toString(an))
235235 if (i(("TASK_" + aK)))
236236 then av(ai, toString(aJ), aK, l((("TASK_" + aK) + "_REWARD_DAILY")), l((("TASK_" + aK) + "_REWARD_WEEKLY")))
237237 else nil
238238 }
239239
240240
241241 func aL (aw,aM,f) = if (!(containsElement(Y, aM)))
242242 then throw("CRA: Only certain smart contracts can use this reward module!")
243243 else {
244244 let ai = as()
245245 let aN = af(toString(f), aw, toString(aM), toString(ai))
246246 let aO = (l(aN) + 1)
247247 ([IntegerEntry(aN, aO)] ++ aI(aw, f, aO, ai))
248248 }
249249
250250
251251 @Callable(aP)
252252 func configureOracle (aQ) = if ((aP.caller != this))
253253 then throw("CCO: admin only")
254254 else [StringEntry("static_oracleAddress", aQ)]
255255
256256
257257
258258 @Callable(aP)
259259 func addCoupons (aa,an) = if (if ((aP.caller != this))
260260 then (aP.callerPublicKey != X)
261261 else false)
262262 then throw("CAC: admin only")
263263 else if ((an >= 10000000))
264264 then (aL("VEGG10000000", this, addressFromStringValue(aa)) ++ am(aa, an))
265265 else if ((an >= 500000))
266266 then (aL("VEGG500000", this, addressFromStringValue(aa)) ++ am(aa, an))
267267 else am(aa, an)
268268
269269
270270
271271 @Callable(aP)
272272 func resetCheater (aa) = if (if ((aP.caller != this))
273273 then (aP.callerPublicKey != X)
274274 else false)
275275 then throw("CAC: admin only")
276276 else {
277277 let ao = ac(aa)
278278 let g = ab(aa)
279279 let ap = l(g)
280280 let aq = -100000000
281281 [IntegerEntry(ao, ap), IntegerEntry(g, aq)]
282282 }
283283
284284
285285
286286 @Callable(aP)
287-func addCouponsFarming (aa,an) = if ((aP.caller != P()))
287+func addCouponsFarming (aa,an) = if (if ((aP.caller != P()))
288+ then (aP.caller != R())
289+ else false)
288290 then throw("Method only for farming sc!")
289291 else am(aa, an)
290292
291293
292294
293295 @Callable(aP)
294296 func addCouponsBatch (aR) = if (if ((aP.caller != this))
295297 then (aP.callerPublicKey != X)
296298 else false)
297299 then throw("CAC: admin only")
298300 else {
299301 let aS = split(aR, ";")
300302 func aT (aU,aV) = {
301303 let aW = split(aV, ":")
302304 let aa = aW[0]
303305 let an = parseIntValue(aW[1])
304306 let aX = invoke(F(), "burnByInvoke", [an], nil)
305307 if ((aX == aX))
306308 then if ((an >= 10000000))
307309 then ((aU ++ aL("VEGG10000000", this, addressFromStringValue(aa))) ++ am(aa, an))
308310 else if ((an >= 500000))
309311 then ((aU ++ aL("VEGG500000", this, addressFromStringValue(aa))) ++ am(aa, an))
310312 else (aU ++ am(aa, an))
311313 else throw("Strict value is not equal to itself.")
312314 }
313315
314316 let aY = aS
315317 let aZ = size(aY)
316318 let ba = nil
317319 func bb (bc,bd) = if ((bd >= aZ))
318320 then bc
319321 else aT(bc, aY[bd])
320322
321323 func be (bc,bd) = if ((bd >= aZ))
322324 then bc
323325 else throw("List size exceeds 20")
324326
325327 be(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(bb(ba, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
326328 }
327329
328330
329331
330332 @Callable(aP)
331333 func CFRefund (bf,an) = {
332334 let bg = getStringValue(aP.caller, "CF_ADDRESS")
333335 let g = (("f_" + bg) + "_stake_address")
334336 let bh = getStringValue(I(), g)
335337 if ((bh != toString(aP.caller)))
336338 then throw("CCR: This is something fishy going on!")
337339 else am(bf, an)
338340 }
339341
340342
341343
342344 @Callable(aP)
343345 func useCoupons (bi) = {
344346 let bj = aP.caller
345347 if ((0 > bi))
346348 then throw("CUC: Only positive amount of money can be paid!")
347349 else if (!(containsElement(Y, bj)))
348350 then throw("CUC: Only certain smart contracts can use this coupon module!")
349351 else {
350352 let aa = toString(aP.originCaller)
351353 let bk = ab(aa)
352354 let bl = l(bk)
353355 if ((0 > bl))
354356 then throw("CUC: Get rekt!")
355357 else {
356358 let bm = if ((bi > bl))
357359 then (bi - bl)
358360 else 0
359361 let bn = (bi - bm)
360362 let bo = (bl - bn)
361363 if ((0 > bo))
362364 then throw("CUC: You try to overspend!")
363365 else {
364366 let bp = Z(aa)
365367 let ao = ac(aa)
366368 let bq = ad(toString(aP.caller))
367369 let br = invoke(P(), "topUpReward", [((bn / 100) * 25)], nil)
368370 if ((br == br))
369371 then {
370372 let bs = (l(bp) + bn)
371373 let bt = (l(bq) + bn)
372374 $Tuple2([IntegerEntry(bp, bs), IntegerEntry(ao, bl), IntegerEntry(bk, bo), IntegerEntry(bq, bt)], bn)
373375 }
374376 else throw("Strict value is not equal to itself.")
375377 }
376378 }
377379 }
378380 }
379381
380382
381383
382384 @Callable(aP)
383385 func recordAction (aw) = aL(aw, aP.caller, aP.originCaller)
384386
385387
386388
387389 @Callable(aP)
388390 func increaseExp (f) = if ((aP.caller != Q()))
389391 then nil
390392 else {
391393 let az = al(f)
392394 let aA = l(az)
393395 [IntegerEntry(az, (aA + 1))]
394396 }
395397
396398
397399 @Verifier(bu)
398400 func bv () = if (a())
399401 then sigVerify(bu.bodyBytes, bu.proofs[0], bu.senderPublicKey)
400402 else {
401403 let bw = base58'6TdaXEfhnjYquvPf3yV7MFxt2CbgFmaqsvGwkKfXtKi4'
402404 let bx = base58'7DsP2WaMLocbHuUxux7pbXRjTrrZ1TFQPsi5QumS3gr8'
403405 let by = base58'BpFWP3p3JgYrrP45xfrKzeMcWMEXoinj4FVPPkUiA8D3'
404406 let bz = if (sigVerify(bu.bodyBytes, bu.proofs[0], bw))
405407 then 1
406408 else if (sigVerify(bu.bodyBytes, bu.proofs[1], bw))
407409 then 1
408410 else if (sigVerify(bu.bodyBytes, bu.proofs[2], bw))
409411 then 1
410412 else 0
411413 let bA = if (sigVerify(bu.bodyBytes, bu.proofs[0], bx))
412414 then 1
413415 else if (sigVerify(bu.bodyBytes, bu.proofs[1], bx))
414416 then 1
415417 else if (sigVerify(bu.bodyBytes, bu.proofs[2], bx))
416418 then 1
417419 else 0
418420 let bB = if (sigVerify(bu.bodyBytes, bu.proofs[0], by))
419421 then 1
420422 else if (sigVerify(bu.bodyBytes, bu.proofs[1], by))
421423 then 1
422424 else if (sigVerify(bu.bodyBytes, bu.proofs[2], by))
423425 then 1
424426 else 0
425427 let bC = ((bz + bA) + bB)
426428 let c = bu
427429 (bC >= 2)
428430 }
429431

github/deemru/w8io/169f3d6 
49.51 ms