tx · 1Mz7mwzezs2d338Rz2xSKHzeTQouTYDtwBNRdU2jdgP

3Mr1kq2Xf6MTBbXFoxF2giBr5DWjc1RZm9S:  -0.01600000 Waves

2024.10.03 14:08 [3310593] smart account 3Mr1kq2Xf6MTBbXFoxF2giBr5DWjc1RZm9S > SELF 0.00000000 Waves

{ "type": 13, "id": "1Mz7mwzezs2d338Rz2xSKHzeTQouTYDtwBNRdU2jdgP", "fee": 1600000, "feeAssetId": null, "timestamp": 1727953766652, "version": 2, "chainId": 84, "sender": "3Mr1kq2Xf6MTBbXFoxF2giBr5DWjc1RZm9S", "senderPublicKey": "6VfcgiUzfgdxbMEsGa5ZZ1vN8wDQxPGb4kUz8Kron4Pt", "proofs": [ "4ME9hekL2qBjzmMv8rtLQrbSAJunnuAoExhgDGcEfSvMWEJaCEZ1bPU7EkvywaqfiEdLTTRaik9ca6vDNMfjDH9r" ], "script": "base64:BgIuCAISBAoCAQESBAoCAQESBAoCCAgSBAoCGAgSAwoBCBIDCgEIEgMKAQgSAwoBCCUBF3N0YXRpY0tleV9vcmFjbGVBZGRyZXNzAAIUc3RhdGljX29yYWNsZUFkZHJlc3MBFXN0YXRpY0tleV9odW50QWRkcmVzcwACEnN0YXRpY19odW50QWRkcmVzcwEYc3RhdGljS2V5X2JyZWVkZXJBZGRyZXNzAAIVc3RhdGljX2JyZWVkZXJBZGRyZXNzARRzdGF0aWNLZXlfZWdnQXNzZXRJZAACEXN0YXRpY19lZ2dBc3NldElkARdzdGF0aWNLZXlfbWluUGVyY2VudGFnZQACFHN0YXRpY19taW5QZXJjZW50YWdlARdzdGF0aWNLZXlfbWF4UGVyY2VudGFnZQACFHN0YXRpY19tYXhQZXJjZW50YWdlARtzdGF0aWNLZXlfYWNjZXNzSXRlbUFzc2V0SWQAAhhzdGF0aWNfYWNjZXNzSXRlbUFzc2V0SWQBGXN0YXRpY0tleV9hY2Nlc3NJdGVtUHJpY2UAAhZzdGF0aWNfYWNjZXNzSXRlbVByaWNlARZzdGF0aWNLZXlfZGVwb3NpdFN0ZXBzAAITc3RhdGljX2RlcG9zaXRTdGVwcwEac3RhdGljS2V5X3JlbnRTbG90c0dlbmVyYWwAAhBzdGF0aWNfcmVudFNsb3RzARBrZXlfZ2V0RHVja093bmVyAQRkdWNrCQCsAgIJAKwCAgIFZHVja18FBGR1Y2sCBl9vd25lcgERa2V5X2dldER1Y2tTdGF0dXMBBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawIHX3N0YXR1cwETa2V5X2dldER1Y2tSZW50ZWRCeQEEZHVjawkArAICCQCsAgICBWR1Y2tfBQRkdWNrAglfcmVudGVkQnkBE2tleV9nZXREdWNrRHVyYXRpb24BBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawIJX2R1cmF0aW9uARRrZXlfZ2V0RHVja1JlbnRzdGFydAEEZHVjawkArAICCQCsAgICBWR1Y2tfBQRkdWNrAglfc3RhcnRfdHMBFWtleV9nZXREdWNrUGVyY2VudGFnZQEEZHVjawkArAICCQCsAgICBWR1Y2tfBQRkdWNrAgtfcGVyY2VudGFnZQETa2V5X2dldER1Y2tMYXN0UGFpZAEEZHVjawkArAICCQCsAgICBWR1Y2tfBQRkdWNrAglfbGFzdFBhaWQBEmtleV9nZXRUb3RhbFJlbnRlZAEEdXNlcgkArAICCQCsAgICB3JlbnRlZF8FBHVzZXICB19hbW91bnQBHGtleV9nZXRUb3RhbEJvdWdodEV4dHJhU3BvdHMBBHVzZXIJAKwCAgkArAICAgZzcG90c18FBHVzZXICB19hbW91bnQBFGtleV9nZXRSZWZ1bmRhYmxlRmVlAgR1c2VyBGR1Y2sJAKwCAgkArAICCQCsAgIJAKwCAgIHcmVmdW5kXwUEdXNlcgIBXwUEZHVjawIHX2Ftb3VudAEca2V5X2dhbWVQcmVGdW5kZWRJdGVtRm9yRHVjawEEZHVjawkArAICAg5hY2Nlc3NfZnVuZGVkXwUEZHVjawEPa2V5X3Nwb3RzQm91Z2h0AQphZGRyZXNzU3RyCQCsAgIJAKwCAgIIYWRkcmVzc18FCmFkZHJlc3NTdHICDF9zcG90c0JvdWdodAENa2V5X3Nwb3RzQnVzeQEKYWRkcmVzc1N0cgkArAICCQCsAgICCGFkZHJlc3NfBQphZGRyZXNzU3RyAgpfc3BvdHNCdXN5ARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIHYWRkcmVzcwNrZXkEByRtYXRjaDAJAJ0IAgUHYWRkcmVzcwUDa2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAUBYQIAAQx0cnlHZXRTdHJpbmcBA2tleQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgUEdGhpcwUDa2V5ARV0cnlHZXRJbnRlZ2VyRXh0ZXJuYWwCB2FkZHJlc3MDa2V5BAckbWF0Y2gwCQCaCAIFB2FkZHJlc3MFA2tleQMJAAECBQckbWF0Y2gwAgNJbnQEAWIFByRtYXRjaDAFAWIAAAENdHJ5R2V0SW50ZWdlcgEDa2V5CQEVdHJ5R2V0SW50ZWdlckV4dGVybmFsAgUEdGhpcwUDa2V5AQVhc0ludAEFdmFsdWUEByRtYXRjaDAFBXZhbHVlAwkAAQIFByRtYXRjaDACA0ludAQDaW50BQckbWF0Y2gwBQNpbnQJAAIBAh5SQUk6IHdyb25nIHR5cGUsIGV4cGVjdGVkOiBJbnQAC0dlbmVyYXRpb25zCQDMCAICAUcJAMwIAgIBSAkAzAgCAgFJCQDMCAICAUsJAMwIAgIBTAkAzAgCAgFNCQDMCAICAU4JAMwIAgIBTwUDbmlsAQlnZXRPcmFjbGUACQEHQWRkcmVzcwEJANkEAQkBDHRyeUdldFN0cmluZwEJARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwABDmdldEh1bnRBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X2h1bnRBZGRyZXNzAAERZ2V0QnJlZWRlckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARhzdGF0aWNLZXlfYnJlZWRlckFkZHJlc3MAAQ1nZXRFZ2dBc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFHN0YXRpY0tleV9lZ2dBc3NldElkAAEUZ2V0QWNjZXNzSXRlbUFzc2V0SWQACQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJARtzdGF0aWNLZXlfYWNjZXNzSXRlbUFzc2V0SWQAARJnZXRBY2Nlc3NJdGVtUHJpY2UACQEVdHJ5R2V0SW50ZWdlckV4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBGXN0YXRpY0tleV9hY2Nlc3NJdGVtUHJpY2UAARJwdXRGb3JSZW50SW50ZXJuYWwDAWkMZHVyYXRpb25Jbk1zCnBlcmNlbnRhZ2UEDGZpcnN0UGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAZkdWNrSWQJANgEAQkBBXZhbHVlAQgFDGZpcnN0UGF5bWVudAdhc3NldElkAwkBAiE9AggFDGZpcnN0UGF5bWVudAZhbW91bnQAAQkAAgECGVJQRlI6IE5GVCBpcyBub3QgYXR0YWNoZWQECGNoaWxkcmVuCQEFYXNJbnQBCQD8BwQJARFnZXRCcmVlZGVyQWRkcmVzcwACFnZhbGlkYXRlQW5kR2V0Q2hpbGRyZW4JAMwIAgUGZHVja0lkBQNuaWwFA25pbAMJAAACBQhjaGlsZHJlbgUIY2hpbGRyZW4EC2JvdWdodFNwb3RzCQEVdHJ5R2V0SW50ZWdlckV4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBD2tleV9zcG90c0JvdWdodAEJAKUIAQgFAWkGY2FsbGVyBAlidXN5U3BvdHMJARV0cnlHZXRJbnRlZ2VyRXh0ZXJuYWwCCQEOZ2V0SHVudEFkZHJlc3MACQENa2V5X3Nwb3RzQnVzeQEJAKUIAQgFAWkGY2FsbGVyAwkAZwIFCWJ1c3lTcG90cwULYm91Z2h0U3BvdHMJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICFVJQRlI6IE5vIGZyZWUgc3BvdHMhIAkApAMBBQlidXN5U3BvdHMCASAJAKQDAQULYm91Z2h0U3BvdHMCASAJAKUIAQgFAWkGY2FsbGVyAgEgCQClCAEJAQ5nZXRIdW50QWRkcmVzcwADAwkAZgIFCnBlcmNlbnRhZ2UJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARdzdGF0aWNLZXlfbWF4UGVyY2VudGFnZQAGCQBmAgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBF3N0YXRpY0tleV9taW5QZXJjZW50YWdlAAUKcGVyY2VudGFnZQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgInUlBGUjogcGxlYXNlIHBpY2sgYSBwZXJjZW50YWdlIGJldHdlZW4gCQEXc3RhdGljS2V5X21pblBlcmNlbnRhZ2UAAgUgYW5kIAkBF3N0YXRpY0tleV9tYXhQZXJjZW50YWdlAAIBJQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFWtleV9nZXREdWNrUGVyY2VudGFnZQEFBmR1Y2tJZAUKcGVyY2VudGFnZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBE2tleV9nZXREdWNrRHVyYXRpb24BBQZkdWNrSWQFDGR1cmF0aW9uSW5NcwkAzAgCCQELU3RyaW5nRW50cnkCCQEQa2V5X2dldER1Y2tPd25lcgEFBmR1Y2tJZAkApQgBCAUBaQZjYWxsZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAgRJRExFBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDXRyeUdldEJvb2xlYW4BA2tleQQHJG1hdGNoMAkAoAgBBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcIAWkBCnB1dEZvclJlbnQCDGR1cmF0aW9uSW5NcwpwZXJjZW50YWdlCQEScHV0Rm9yUmVudEludGVybmFsAwUBaQUMZHVyYXRpb25Jbk1zBQpwZXJjZW50YWdlAWkBF2J1eUdsYXNzZXNBbmRQdXRGb3JSZW50AgxkdXJhdGlvbkluTXMKcGVyY2VudGFnZQQKYnV5R2xhc3NlcwkA/AcECQEOZ2V0SHVudEFkZHJlc3MAAg1idXlBY2Nlc3NJdGVtBQNuaWwJAMwIAgkAkQMCCAUBaQhwYXltZW50cwABBQNuaWwDCQAAAgUKYnV5R2xhc3NlcwUKYnV5R2xhc3NlcwkBEnB1dEZvclJlbnRJbnRlcm5hbAMFAWkFDGR1cmF0aW9uSW5NcwUKcGVyY2VudGFnZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARByZW50RHVja0Zyb21Vc2VyAgZkdWNrSWQEZ2FtZQQFZ2VuZXMJALUJAggJAQV2YWx1ZQEJAOwHAQkA2QQBBQZkdWNrSWQEbmFtZQIABApnZW5lcmF0aW9uCQCRAwIFBWdlbmVzAA4ECm11bHRpcGxpZXIDCQAAAgUKZ2VuZXJhdGlvbgIBSgAICQBkAgkBBXZhbHVlAQkAzwgCBQtHZW5lcmF0aW9ucwUKZ2VuZXJhdGlvbgABBANmZWUJAGgCBQptdWx0aXBsaWVyCQERQGV4dHJOYXRpdmUoMTA1NSkBCQEWc3RhdGljS2V5X2RlcG9zaXRTdGVwcwAEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AgkBBXZhbHVlAQgFA3BtdAdhc3NldElkCQENZ2V0RWdnQXNzZXRJZAAJAAIBAidUQlQ6IFBsZWFzZSBhdHRhY2ggdGhlIGNvcnJlY3QgcGF5bWVudCEDCQECIT0CCAUDcG10BmFtb3VudAUDZmVlCQACAQIwUlJERlU6IFBsZWFzZSBhdHRhY2ggZW5vdWdoIHJlZnVuZGFibGUgZGVwb3NpdHMhBApkdWNrU3RhdHVzCQEMdHJ5R2V0U3RyaW5nAQkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAwkBAiE9AgUKZHVja1N0YXR1cwIESURMRQkAAgEJAKwCAgJBUlJERlU6IFlvdSBjYW4gb25seSByZW50IGR1Y2tzIHdpdGggSURMRSBzdGF0dXMuIEN1cnJlbnQgc3RhdHVzOiAFCmR1Y2tTdGF0dXMECWR1Y2tPd25lcgkBDHRyeUdldFN0cmluZwEJARBrZXlfZ2V0RHVja093bmVyAQUGZHVja0lkBAtib3VnaHRTcG90cwkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJAQ9rZXlfc3BvdHNCb3VnaHQBBQlkdWNrT3duZXIECWJ1c3lTcG90cwkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJAQ1rZXlfc3BvdHNCdXN5AQUJZHVja093bmVyBA9idXlTcG90SWZOZWVkZWQDCQAAAgULYm91Z2h0U3BvdHMFCWJ1c3lTcG90cwQEY2FsbAkA/AcECQEOZ2V0SHVudEFkZHJlc3MAAhJidXlBY2Nlc3NJdGVtT3RoZXIJAMwIAgUJZHVja093bmVyBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBG3N0YXRpY0tleV9hY2Nlc3NJdGVtQXNzZXRJZAAJARFAZXh0ck5hdGl2ZSgxMDUwKQIJAQ5nZXRIdW50QWRkcmVzcwAJARlzdGF0aWNLZXlfYWNjZXNzSXRlbVByaWNlAAUDbmlsAwkAAAIFBGNhbGwFBGNhbGwJAMwIAgkBDEJvb2xlYW5FbnRyeQIJARxrZXlfZ2FtZVByZUZ1bmRlZEl0ZW1Gb3JEdWNrAQUGZHVja0lkBgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwDCQAAAgUPYnV5U3BvdElmTmVlZGVkBQ9idXlTcG90SWZOZWVkZWQDCQECIT0CBQRnYW1lAgRIVU5UCQACAQIYUlJERlU6IFVuc3VwcG9ydGVkIGdhbWUhBAdzdGFydFRzCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQOc2VuZFRvSHVudERhdGEJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAIPbG9ja0R1Y2tSZW50aW5nCQDMCAIFCWR1Y2tPd25lcgUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFBmR1Y2tJZAABBQNuaWwDCQAAAgUOc2VuZFRvSHVudERhdGEFDnNlbmRUb0h1bnREYXRhBA9hbW91bnRSZW50ZWRLZXkJARJrZXlfZ2V0VG90YWxSZW50ZWQBCQClCAEIBQFpBmNhbGxlcgQJYm91Z2h0S2V5CQEca2V5X2dldFRvdGFsQm91Z2h0RXh0cmFTcG90cwEJAKUIAQgFAWkGY2FsbGVyBA9uZXdBbW91bnRSZW50ZWQJAGQCCQENdHJ5R2V0SW50ZWdlcgEFD2Ftb3VudFJlbnRlZEtleQABBAp0b3RhbFNwb3RzCQBkAgkBDXRyeUdldEludGVnZXIBBQlib3VnaHRLZXkJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARpzdGF0aWNLZXlfcmVudFNsb3RzR2VuZXJhbAADCQBmAgUPbmV3QW1vdW50UmVudGVkBQp0b3RhbFNwb3RzCQACAQkArAICAi9SUkRGVTogWW91IGFscmVhZHkgcmVudGVkIG1heCBhbW91bnQgb2YgZHVja3MhIAkApAMBBQp0b3RhbFNwb3RzCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJARRrZXlfZ2V0RHVja1JlbnRzdGFydAEFBmR1Y2tJZAUHc3RhcnRUcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFGtleV9nZXRSZWZ1bmRhYmxlRmVlAgkApQgBCAUBaQZjYWxsZXIFBmR1Y2tJZAUDZmVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9hbW91bnRSZW50ZWRLZXkFD25ld0Ftb3VudFJlbnRlZAkAzAgCCQELU3RyaW5nRW50cnkCCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQCBlJFTlRFRAkAzAgCCQELU3RyaW5nRW50cnkCCQETa2V5X2dldER1Y2tSZW50ZWRCeQEFBmR1Y2tJZAkApQgBCAUBaQZjYWxsZXIFA25pbAUPYnV5U3BvdElmTmVlZGVkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBDHRvcFVwUmV3YXJkcwIUZHVja0lkQW5kQW1vdW50c0xpc3QHYXNzZXRJZAoBC2hhbmRsZVRvcFVwAgNhY2MNdXNlckFuZEFtb3VudAQKc3BsaXRBcnJheQkAtQkCBQ11c2VyQW5kQW1vdW50AgE6BAR1c2VyCQCRAwIFCnNwbGl0QXJyYXkAAAQGYW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKc3BsaXRBcnJheQABBAZkdWNrSWQJAJEDAgUKc3BsaXRBcnJheQACCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHVzZXIJAGgCBQZhbW91bnQAoI0GCQDZBAEFB2Fzc2V0SWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARNrZXlfZ2V0RHVja0xhc3RQYWlkAQUGZHVja0lkCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUDbmlsCgACJGwFFGR1Y2tJZEFuZEFtb3VudHNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQtoYW5kbGVUb3BVcAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTUJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8BaQENY2xhaW1EdWNrQmFjawEGZHVja0lkBAlkdWNrT3duZXIJAQx0cnlHZXRTdHJpbmcBCQEQa2V5X2dldER1Y2tPd25lcgEFBmR1Y2tJZAMJAQIhPQIFCWR1Y2tPd25lcgkApQgBCAUBaQZjYWxsZXIJAAIBAjJSQ0RCOiBQbGVhc2UgZG9uJ3QgdHJ5IHRvIHN0ZWFsIHNvbWVvbmUgZWxzZSBkdWNrIQMDCQENdHJ5R2V0Qm9vbGVhbgEJARxrZXlfZ2FtZVByZUZ1bmRlZEl0ZW1Gb3JEdWNrAQUGZHVja0lkAwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAQIhPQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEOZ2V0SHVudEFkZHJlc3MACQEbc3RhdGljS2V5X2FjY2Vzc0l0ZW1Bc3NldElkAAYJAQIhPQIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CQERQGV4dHJOYXRpdmUoMTA1MCkCCQEOZ2V0SHVudEFkZHJlc3MACQEZc3RhdGljS2V5X2FjY2Vzc0l0ZW1QcmljZQAHCQACAQkArAICAkdQbGVhc2UgbWFrZSBzdXJlIHRvIGF0dGFjaCBlbm91Z2ggZnVuZHMgdG8gcGF5IGZvciB5b3VyIHByZXZpb3VzIHNwb3QhIAkApAMBCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQKZHVja1N0YXR1cwkBDHRyeUdldFN0cmluZwEJARFrZXlfZ2V0RHVja1N0YXR1cwEFBmR1Y2tJZAMJAAACBQpkdWNrU3RhdHVzAgRJRExFCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgABCQDZBAEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBHGtleV9nYW1lUHJlRnVuZGVkSXRlbUZvckR1Y2sBBQZkdWNrSWQFA25pbAQHc3RhcnRUcwkBDXRyeUdldEludGVnZXIBCQEUa2V5X2dldER1Y2tSZW50c3RhcnQBBQZkdWNrSWQDCQBmAggFCWxhc3RCbG9jawl0aW1lc3RhbXAJAGQCBQdzdGFydFRzCQENdHJ5R2V0SW50ZWdlcgEJARNrZXlfZ2V0RHVja0R1cmF0aW9uAQUGZHVja0lkBAZwbGF5ZXIJAQx0cnlHZXRTdHJpbmcBCQETa2V5X2dldER1Y2tSZW50ZWRCeQEFBmR1Y2tJZAQOcmVtb3ZlRnJvbUh1bnQJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAIRdW5sb2NrRHVja1JlbnRpbmcJAMwIAgUGZHVja0lkCQDMCAIFCWR1Y2tPd25lcgUDbmlsBQNuaWwDCQAAAgUOcmVtb3ZlRnJvbUh1bnQFDnJlbW92ZUZyb21IdW50BA9hbW91bnRSZW50ZWRLZXkJARJrZXlfZ2V0VG90YWxSZW50ZWQBBQZwbGF5ZXIED25ld0Ftb3VudFJlbnRlZAkAZQIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFD2Ftb3VudFJlbnRlZEtleQABBAxyZWZ1bmRGZWVLZXkJARRrZXlfZ2V0UmVmdW5kYWJsZUZlZQIFBnBsYXllcgUGZHVja0lkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9hbW91bnRSZW50ZWRLZXkFD25ld0Ftb3VudFJlbnRlZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQZwbGF5ZXIJAQ10cnlHZXRJbnRlZ2VyAQUMcmVmdW5kRmVlS2V5CQENZ2V0RWdnQXNzZXRJZAAJAMwIAgkBC0RlbGV0ZUVudHJ5AQUMcmVmdW5kRmVlS2V5CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCWR1Y2tPd25lcgABCQDZBAEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBHGtleV9nYW1lUHJlRnVuZGVkSXRlbUZvckR1Y2sBBQZkdWNrSWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQLbGFzdFBheW1lbnQJAQ10cnlHZXRJbnRlZ2VyAQkBE2tleV9nZXREdWNrTGFzdFBhaWQBBQZkdWNrSWQEDXRocmVlRGF5c0luTXMJAGgCCQBoAgkAaAIAAwAYADwA6AcDCQBmAggFCWxhc3RCbG9jawZoZWlnaHQJAGQCBQtsYXN0UGF5bWVudAUNdGhyZWVEYXlzSW5NcwQGcGxheWVyCQEMdHJ5R2V0U3RyaW5nAQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQEB3Vuc3Rha2UJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAIRdW5sb2NrRHVja1JlbnRpbmcJAMwIAgUGZHVja0lkCQDMCAIFCWR1Y2tPd25lcgUDbmlsBQNuaWwDCQAAAgUHdW5zdGFrZQUHdW5zdGFrZQQPYW1vdW50UmVudGVkS2V5CQESa2V5X2dldFRvdGFsUmVudGVkAQUGcGxheWVyBA9uZXdBbW91bnRSZW50ZWQJAGUCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ9hbW91bnRSZW50ZWRLZXkAAQkAzAgCCQEMSW50ZWdlckVudHJ5AgUPYW1vdW50UmVudGVkS2V5BQ9uZXdBbW91bnRSZW50ZWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUJZHVja093bmVyAAEJANkEAQUGZHVja0lkCQDMCAIJAQtEZWxldGVFbnRyeQEJARFrZXlfZ2V0RHVja1N0YXR1cwEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQETa2V5X2dldER1Y2tSZW50ZWRCeQEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQEca2V5X2dhbWVQcmVGdW5kZWRJdGVtRm9yRHVjawEFBmR1Y2tJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQI2UkNEQjogUmVudGluZyBwZXJpb2QgaXMgbm90IG92ZXIgYW5kIHBsYXllciBpcyBhY3RpdmUhAWkBDHNlbmREdWNrQmFjawEGZHVja0lkBAhyZW50ZWRCeQkBDHRyeUdldFN0cmluZwEJARNrZXlfZ2V0RHVja1JlbnRlZEJ5AQUGZHVja0lkAwkBAiE9AgUIcmVudGVkQnkJAKUIAQgFAWkGY2FsbGVyCQACAQIgUlNEQjogWW91IGRpZG4ndCByZW50IHRoaXMgZHVjayEECWR1Y2tPd25lcgkBDHRyeUdldFN0cmluZwEJARBrZXlfZ2V0RHVja093bmVyAQUGZHVja0lkBAxyZWZ1bmRGZWVLZXkJARRrZXlfZ2V0UmVmdW5kYWJsZUZlZQIJAKUIAQgFAWkGY2FsbGVyBQZkdWNrSWQED2Ftb3VudFJlbnRlZEtleQkBEmtleV9nZXRUb3RhbFJlbnRlZAEJAKUIAQgFAWkGY2FsbGVyBA9uZXdBbW91bnRSZW50ZWQJAGUCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ9hbW91bnRSZW50ZWRLZXkAAQQOcmVtb3ZlRnJvbUh1bnQJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAIRdW5sb2NrRHVja1JlbnRpbmcJAMwIAgUGZHVja0lkCQDMCAIFCWR1Y2tPd25lcgUDbmlsBQNuaWwDCQAAAgUOcmVtb3ZlRnJvbUh1bnQFDnJlbW92ZUZyb21IdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgkBDXRyeUdldEludGVnZXIBBQxyZWZ1bmRGZWVLZXkJAQ1nZXRFZ2dBc3NldElkAAkAzAgCCQELRGVsZXRlRW50cnkBBQxyZWZ1bmRGZWVLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAgRJRExFCQDMCAIJAQtEZWxldGVFbnRyeQEJARNrZXlfZ2V0RHVja1JlbnRlZEJ5AQUGZHVja0lkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9hbW91bnRSZW50ZWRLZXkFD25ld0Ftb3VudFJlbnRlZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEXNlbmREdWNrQmFja090aGVyAQZkdWNrSWQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAg9SVU86IGFkbWluIG9ubHkECHJlbnRlZEJ5CQEMdHJ5R2V0U3RyaW5nAQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQECWR1Y2tPd25lcgkBDHRyeUdldFN0cmluZwEJARBrZXlfZ2V0RHVja093bmVyAQUGZHVja0lkBAxyZWZ1bmRGZWVLZXkJARRrZXlfZ2V0UmVmdW5kYWJsZUZlZQIFCHJlbnRlZEJ5BQZkdWNrSWQED2Ftb3VudFJlbnRlZEtleQkBEmtleV9nZXRUb3RhbFJlbnRlZAEFCHJlbnRlZEJ5BA9uZXdBbW91bnRSZW50ZWQJAGUCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ9hbW91bnRSZW50ZWRLZXkAAQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQhyZW50ZWRCeQkBDXRyeUdldEludGVnZXIBBQxyZWZ1bmRGZWVLZXkJAQ1nZXRFZ2dBc3NldElkAAkAzAgCCQELRGVsZXRlRW50cnkBBQxyZWZ1bmRGZWVLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAgRJRExFCQDMCAIJAQtEZWxldGVFbnRyeQEJARNrZXlfZ2V0RHVja1JlbnRlZEJ5AQUGZHVja0lkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9hbW91bnRSZW50ZWRLZXkFD25ld0Ftb3VudFJlbnRlZAUDbmlsAWkBD2NvbmZpZ3VyZU9yYWNsZQEGb3JhY2xlAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIPUkNPOiBhZG1pbiBvbmx5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwAFBm9yYWNsZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBF3N0YXRpY0tleV9taW5QZXJjZW50YWdlAAAFCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEXc3RhdGljS2V5X21heFBlcmNlbnRhZ2UAAFAJAMwIAgkBDEludGVnZXJFbnRyeQIJARZzdGF0aWNLZXlfZGVwb3NpdFN0ZXBzAACA4esXCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEac3RhdGljS2V5X3JlbnRTbG90c0dlbmVyYWwAAAUFA25pbABZ998O", "height": 3310593, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: A8cJVJWaQKwAxd4vujfAewoobad9cUH9QD22x2YBGzyV Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 6 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+func staticKey_oracleAddress () = "static_oracleAddress"
5+
6+
7+func staticKey_huntAddress () = "static_huntAddress"
8+
9+
10+func staticKey_breederAddress () = "static_breederAddress"
11+
12+
13+func staticKey_eggAssetId () = "static_eggAssetId"
14+
15+
16+func staticKey_minPercentage () = "static_minPercentage"
17+
18+
19+func staticKey_maxPercentage () = "static_maxPercentage"
20+
21+
22+func staticKey_accessItemAssetId () = "static_accessItemAssetId"
23+
24+
25+func staticKey_accessItemPrice () = "static_accessItemPrice"
26+
27+
28+func staticKey_depositSteps () = "static_depositSteps"
29+
30+
31+func staticKey_rentSlotsGeneral () = "static_rentSlots"
32+
33+
34+func key_getDuckOwner (duck) = (("duck_" + duck) + "_owner")
35+
36+
37+func key_getDuckStatus (duck) = (("duck_" + duck) + "_status")
38+
39+
40+func key_getDuckRentedBy (duck) = (("duck_" + duck) + "_rentedBy")
41+
42+
43+func key_getDuckDuration (duck) = (("duck_" + duck) + "_duration")
44+
45+
46+func key_getDuckRentstart (duck) = (("duck_" + duck) + "_start_ts")
47+
48+
49+func key_getDuckPercentage (duck) = (("duck_" + duck) + "_percentage")
50+
51+
52+func key_getDuckLastPaid (duck) = (("duck_" + duck) + "_lastPaid")
53+
54+
55+func key_getTotalRented (user) = (("rented_" + user) + "_amount")
56+
57+
58+func key_getTotalBoughtExtraSpots (user) = (("spots_" + user) + "_amount")
59+
60+
61+func key_getRefundableFee (user,duck) = (((("refund_" + user) + "_") + duck) + "_amount")
62+
63+
64+func key_gamePreFundedItemForDuck (duck) = ("access_funded_" + duck)
65+
66+
67+func key_spotsBought (addressStr) = (("address_" + addressStr) + "_spotsBought")
68+
69+
70+func key_spotsBusy (addressStr) = (("address_" + addressStr) + "_spotsBusy")
71+
72+
73+func tryGetStringExternal (address,key) = match getString(address, key) {
74+ case a: String =>
75+ a
76+ case _ =>
77+ ""
78+}
79+
80+
81+func tryGetString (key) = tryGetStringExternal(this, key)
82+
83+
84+func tryGetIntegerExternal (address,key) = match getInteger(address, key) {
85+ case b: Int =>
86+ b
87+ case _ =>
88+ 0
89+}
90+
91+
92+func tryGetInteger (key) = tryGetIntegerExternal(this, key)
93+
94+
95+func asInt (value) = match value {
96+ case int: Int =>
97+ int
98+ case _ =>
99+ throw("RAI: wrong type, expected: Int")
100+}
101+
102+
103+let Generations = ["G", "H", "I", "K", "L", "M", "N", "O"]
104+
105+func getOracle () = Address(fromBase58String(tryGetString(staticKey_oracleAddress())))
106+
107+
108+func getHuntAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_huntAddress())))
109+
110+
111+func getBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_breederAddress())))
112+
113+
114+func getEggAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_eggAssetId()))
115+
116+
117+func getAccessItemAssetId () = fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId()))
118+
119+
120+func getAccessItemPrice () = tryGetIntegerExternal(getHuntAddress(), staticKey_accessItemPrice())
121+
122+
123+func putForRentInternal (i,durationInMs,percentage) = {
124+ let firstPayment = value(i.payments[0])
125+ let duckId = toBase58String(value(firstPayment.assetId))
126+ if ((firstPayment.amount != 1))
127+ then throw("RPFR: NFT is not attached")
128+ else {
129+ let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [duckId], nil))
130+ if ((children == children))
131+ then {
132+ let boughtSpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBought(toString(i.caller)))
133+ let busySpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBusy(toString(i.caller)))
134+ if ((busySpots >= boughtSpots))
135+ then throw(((((((("RPFR: No free spots! " + toString(busySpots)) + " ") + toString(boughtSpots)) + " ") + toString(i.caller)) + " ") + toString(getHuntAddress())))
136+ else if (if ((percentage > getIntegerValue(this, staticKey_maxPercentage())))
137+ then true
138+ else (getIntegerValue(this, staticKey_minPercentage()) > percentage))
139+ then throw((((("RPFR: please pick a percentage between " + staticKey_minPercentage()) + " and ") + staticKey_maxPercentage()) + "%"))
140+ else [IntegerEntry(key_getDuckPercentage(duckId), percentage), IntegerEntry(key_getDuckDuration(duckId), durationInMs), StringEntry(key_getDuckOwner(duckId), toString(i.caller)), StringEntry(key_getDuckStatus(duckId), "IDLE")]
141+ }
142+ else throw("Strict value is not equal to itself.")
143+ }
144+ }
145+
146+
147+func tryGetBoolean (key) = match getBoolean(key) {
148+ case b: Boolean =>
149+ b
150+ case _ =>
151+ false
152+}
153+
154+
155+@Callable(i)
156+func putForRent (durationInMs,percentage) = putForRentInternal(i, durationInMs, percentage)
157+
158+
159+
160+@Callable(i)
161+func buyGlassesAndPutForRent (durationInMs,percentage) = {
162+ let buyGlasses = invoke(getHuntAddress(), "buyAccessItem", nil, [i.payments[1]])
163+ if ((buyGlasses == buyGlasses))
164+ then putForRentInternal(i, durationInMs, percentage)
165+ else throw("Strict value is not equal to itself.")
166+ }
167+
168+
169+
170+@Callable(i)
171+func rentDuckFromUser (duckId,game) = {
172+ let genes = split(value(assetInfo(fromBase58String(duckId))).name, "")
173+ let generation = genes[14]
174+ let multiplier = if ((generation == "J"))
175+ then 8
176+ else (value(indexOf(Generations, generation)) + 1)
177+ let fee = (multiplier * getIntegerValue(staticKey_depositSteps()))
178+ let pmt = value(i.payments[0])
179+ if ((value(pmt.assetId) != getEggAssetId()))
180+ then throw("TBT: Please attach the correct payment!")
181+ else if ((pmt.amount != fee))
182+ then throw("RRDFU: Please attach enough refundable deposits!")
183+ else {
184+ let duckStatus = tryGetString(key_getDuckStatus(duckId))
185+ if ((duckStatus != "IDLE"))
186+ then throw(("RRDFU: You can only rent ducks with IDLE status. Current status: " + duckStatus))
187+ else {
188+ let duckOwner = tryGetString(key_getDuckOwner(duckId))
189+ let boughtSpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBought(duckOwner))
190+ let busySpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBusy(duckOwner))
191+ let buySpotIfNeeded = if ((boughtSpots == busySpots))
192+ then {
193+ let call = invoke(getHuntAddress(), "buyAccessItemOther", [duckOwner], [AttachedPayment(fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId())), getIntegerValue(getHuntAddress(), staticKey_accessItemPrice()))])
194+ if ((call == call))
195+ then [BooleanEntry(key_gamePreFundedItemForDuck(duckId), true)]
196+ else throw("Strict value is not equal to itself.")
197+ }
198+ else nil
199+ if ((buySpotIfNeeded == buySpotIfNeeded))
200+ then if ((game != "HUNT"))
201+ then throw("RRDFU: Unsupported game!")
202+ else {
203+ let startTs = lastBlock.timestamp
204+ let sendToHuntData = invoke(getHuntAddress(), "lockDuckRenting", [duckOwner], [AttachedPayment(fromBase58String(duckId), 1)])
205+ if ((sendToHuntData == sendToHuntData))
206+ then {
207+ let amountRentedKey = key_getTotalRented(toString(i.caller))
208+ let boughtKey = key_getTotalBoughtExtraSpots(toString(i.caller))
209+ let newAmountRented = (tryGetInteger(amountRentedKey) + 1)
210+ let totalSpots = (tryGetInteger(boughtKey) + getIntegerValue(this, staticKey_rentSlotsGeneral()))
211+ if ((newAmountRented > totalSpots))
212+ then throw(("RRDFU: You already rented max amount of ducks! " + toString(totalSpots)))
213+ else ([IntegerEntry(key_getDuckRentstart(duckId), startTs), IntegerEntry(key_getRefundableFee(toString(i.caller), duckId), fee), IntegerEntry(amountRentedKey, newAmountRented), StringEntry(key_getDuckStatus(duckId), "RENTED"), StringEntry(key_getDuckRentedBy(duckId), toString(i.caller))] ++ buySpotIfNeeded)
214+ }
215+ else throw("Strict value is not equal to itself.")
216+ }
217+ else throw("Strict value is not equal to itself.")
218+ }
219+ }
220+ }
221+
222+
223+
224+@Callable(i)
225+func topUpRewards (duckIdAndAmountsList,assetId) = {
226+ func handleTopUp (acc,userAndAmount) = {
227+ let splitArray = split(userAndAmount, ":")
228+ let user = splitArray[0]
229+ let amount = parseIntValue(splitArray[1])
230+ let duckId = splitArray[2]
231+[ScriptTransfer(addressFromStringValue(user), (amount * 100000), fromBase58String(assetId)), IntegerEntry(key_getDuckLastPaid(duckId), lastBlock.timestamp)]
232+ }
233+
234+ let $l = duckIdAndAmountsList
235+ let $s = size($l)
236+ let $acc0 = nil
237+ func $f0_1 ($a,$i) = if (($i >= $s))
238+ then $a
239+ else handleTopUp($a, $l[$i])
240+
241+ func $f0_2 ($a,$i) = if (($i >= $s))
242+ then $a
243+ else throw("List size exceeds 15")
244+
245+ $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
246+ }
247+
248+
249+
250+@Callable(i)
251+func claimDuckBack (duckId) = {
252+ let duckOwner = tryGetString(key_getDuckOwner(duckId))
253+ if ((duckOwner != toString(i.caller)))
254+ then throw("RCDB: Please don't try to steal someone else duck!")
255+ else if (if (tryGetBoolean(key_gamePreFundedItemForDuck(duckId)))
256+ then if (if ((size(i.payments) != 1))
257+ then true
258+ else (i.payments[0].assetId != fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId()))))
259+ then true
260+ else (i.payments[0].amount != getIntegerValue(getHuntAddress(), staticKey_accessItemPrice()))
261+ else false)
262+ then throw(("Please make sure to attach enough funds to pay for your previous spot! " + toString(i.payments[0].amount)))
263+ else {
264+ let duckStatus = tryGetString(key_getDuckStatus(duckId))
265+ if ((duckStatus == "IDLE"))
266+ then [ScriptTransfer(i.caller, 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_gamePreFundedItemForDuck(duckId))]
267+ else {
268+ let startTs = tryGetInteger(key_getDuckRentstart(duckId))
269+ if ((lastBlock.timestamp > (startTs + tryGetInteger(key_getDuckDuration(duckId)))))
270+ then {
271+ let player = tryGetString(key_getDuckRentedBy(duckId))
272+ let removeFromHunt = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
273+ if ((removeFromHunt == removeFromHunt))
274+ then {
275+ let amountRentedKey = key_getTotalRented(player)
276+ let newAmountRented = (getIntegerValue(this, amountRentedKey) - 1)
277+ let refundFeeKey = key_getRefundableFee(player, duckId)
278+[IntegerEntry(amountRentedKey, newAmountRented), ScriptTransfer(addressFromStringValue(player), tryGetInteger(refundFeeKey), getEggAssetId()), DeleteEntry(refundFeeKey), ScriptTransfer(addressFromStringValue(duckOwner), 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_getDuckRentedBy(duckId)), DeleteEntry(key_gamePreFundedItemForDuck(duckId))]
279+ }
280+ else throw("Strict value is not equal to itself.")
281+ }
282+ else {
283+ let lastPayment = tryGetInteger(key_getDuckLastPaid(duckId))
284+ let threeDaysInMs = (((3 * 24) * 60) * 1000)
285+ if ((lastBlock.height > (lastPayment + threeDaysInMs)))
286+ then {
287+ let player = tryGetString(key_getDuckRentedBy(duckId))
288+ let unstake = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
289+ if ((unstake == unstake))
290+ then {
291+ let amountRentedKey = key_getTotalRented(player)
292+ let newAmountRented = (getIntegerValue(this, amountRentedKey) - 1)
293+[IntegerEntry(amountRentedKey, newAmountRented), ScriptTransfer(addressFromStringValue(duckOwner), 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_getDuckRentedBy(duckId)), DeleteEntry(key_gamePreFundedItemForDuck(duckId))]
294+ }
295+ else throw("Strict value is not equal to itself.")
296+ }
297+ else throw("RCDB: Renting period is not over and player is active!")
298+ }
299+ }
300+ }
301+ }
302+
303+
304+
305+@Callable(i)
306+func sendDuckBack (duckId) = {
307+ let rentedBy = tryGetString(key_getDuckRentedBy(duckId))
308+ if ((rentedBy != toString(i.caller)))
309+ then throw("RSDB: You didn't rent this duck!")
310+ else {
311+ let duckOwner = tryGetString(key_getDuckOwner(duckId))
312+ let refundFeeKey = key_getRefundableFee(toString(i.caller), duckId)
313+ let amountRentedKey = key_getTotalRented(toString(i.caller))
314+ let newAmountRented = (getIntegerValue(this, amountRentedKey) - 1)
315+ let removeFromHunt = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
316+ if ((removeFromHunt == removeFromHunt))
317+ then [ScriptTransfer(i.caller, tryGetInteger(refundFeeKey), getEggAssetId()), DeleteEntry(refundFeeKey), StringEntry(key_getDuckStatus(duckId), "IDLE"), DeleteEntry(key_getDuckRentedBy(duckId)), IntegerEntry(amountRentedKey, newAmountRented)]
318+ else throw("Strict value is not equal to itself.")
319+ }
320+ }
321+
322+
323+
324+@Callable(i)
325+func sendDuckBackOther (duckId) = if ((i.caller != this))
326+ then throw("RUO: admin only")
327+ else {
328+ let rentedBy = tryGetString(key_getDuckRentedBy(duckId))
329+ let duckOwner = tryGetString(key_getDuckOwner(duckId))
330+ let refundFeeKey = key_getRefundableFee(rentedBy, duckId)
331+ let amountRentedKey = key_getTotalRented(rentedBy)
332+ let newAmountRented = (getIntegerValue(this, amountRentedKey) - 1)
333+[ScriptTransfer(addressFromStringValue(rentedBy), tryGetInteger(refundFeeKey), getEggAssetId()), DeleteEntry(refundFeeKey), StringEntry(key_getDuckStatus(duckId), "IDLE"), DeleteEntry(key_getDuckRentedBy(duckId)), IntegerEntry(amountRentedKey, newAmountRented)]
334+ }
335+
336+
337+
338+@Callable(i)
339+func configureOracle (oracle) = if ((i.caller != this))
340+ then throw("RCO: admin only")
341+ else [StringEntry(staticKey_oracleAddress(), oracle), IntegerEntry(staticKey_minPercentage(), 5), IntegerEntry(staticKey_maxPercentage(), 80), IntegerEntry(staticKey_depositSteps(), 50000000), IntegerEntry(staticKey_rentSlotsGeneral(), 5)]
342+
343+

github/deemru/w8io/c3f4982 
20.13 ms