tx · 8bqM4e6gyf92q4cZtTwp1jYPheQQkp9KDk2EYX4zKEnU

3P8FgFUEvZCD1c6FkZM3zT5eYezocydyxDD:  -0.01400000 Waves

2023.03.29 15:50 [3576871] smart account 3P8FgFUEvZCD1c6FkZM3zT5eYezocydyxDD > SELF 0.00000000 Waves

{ "type": 13, "id": "8bqM4e6gyf92q4cZtTwp1jYPheQQkp9KDk2EYX4zKEnU", "fee": 1400000, "feeAssetId": null, "timestamp": 1680094307004, "version": 2, "chainId": 87, "sender": "3P8FgFUEvZCD1c6FkZM3zT5eYezocydyxDD", "senderPublicKey": "DkxqS5tLpEQJtue73P7Cwt117bTL6nZjvnLiSnkEd1QQ", "proofs": [ "2PN3DqYSqVCVvEApsLHpHDdW6Zs72vwbDfeJLUQTny4tJnN7Uj6cGJZ3tQnsenC4hHa8cTejFeBEejTh9yKVoZg9" ], "script": "base64:BgIpCAISBAoCAQESBAoCAQESBAoCCAgSBAoCGAgSAwoBCBIDCgEIEgMKAQglARdzdGF0aWNLZXlfb3JhY2xlQWRkcmVzcwACFHN0YXRpY19vcmFjbGVBZGRyZXNzARVzdGF0aWNLZXlfaHVudEFkZHJlc3MAAhJzdGF0aWNfaHVudEFkZHJlc3MBGHN0YXRpY0tleV9icmVlZGVyQWRkcmVzcwACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEUc3RhdGljS2V5X2VnZ0Fzc2V0SWQAAhFzdGF0aWNfZWdnQXNzZXRJZAEXc3RhdGljS2V5X21pblBlcmNlbnRhZ2UAAhRzdGF0aWNfbWluUGVyY2VudGFnZQEXc3RhdGljS2V5X21heFBlcmNlbnRhZ2UAAhRzdGF0aWNfbWF4UGVyY2VudGFnZQEbc3RhdGljS2V5X2FjY2Vzc0l0ZW1Bc3NldElkAAIYc3RhdGljX2FjY2Vzc0l0ZW1Bc3NldElkARlzdGF0aWNLZXlfYWNjZXNzSXRlbVByaWNlAAIWc3RhdGljX2FjY2Vzc0l0ZW1QcmljZQEWc3RhdGljS2V5X2RlcG9zaXRTdGVwcwACE3N0YXRpY19kZXBvc2l0U3RlcHMBGnN0YXRpY0tleV9yZW50U2xvdHNHZW5lcmFsAAIQc3RhdGljX3JlbnRTbG90cwEQa2V5X2dldER1Y2tPd25lcgEEZHVjawkArAICCQCsAgICBWR1Y2tfBQRkdWNrAgZfb3duZXIBEWtleV9nZXREdWNrU3RhdHVzAQRkdWNrCQCsAgIJAKwCAgIFZHVja18FBGR1Y2sCB19zdGF0dXMBE2tleV9nZXREdWNrUmVudGVkQnkBBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawIJX3JlbnRlZEJ5ARNrZXlfZ2V0RHVja0R1cmF0aW9uAQRkdWNrCQCsAgIJAKwCAgIFZHVja18FBGR1Y2sCCV9kdXJhdGlvbgEUa2V5X2dldER1Y2tSZW50c3RhcnQBBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawIJX3N0YXJ0X3RzARVrZXlfZ2V0RHVja1BlcmNlbnRhZ2UBBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawILX3BlcmNlbnRhZ2UBE2tleV9nZXREdWNrTGFzdFBhaWQBBGR1Y2sJAKwCAgkArAICAgVkdWNrXwUEZHVjawIJX2xhc3RQYWlkARJrZXlfZ2V0VG90YWxSZW50ZWQBBHVzZXIJAKwCAgkArAICAgdyZW50ZWRfBQR1c2VyAgdfYW1vdW50ARxrZXlfZ2V0VG90YWxCb3VnaHRFeHRyYVNwb3RzAQR1c2VyCQCsAgIJAKwCAgIGc3BvdHNfBQR1c2VyAgdfYW1vdW50ARRrZXlfZ2V0UmVmdW5kYWJsZUZlZQIEdXNlcgRkdWNrCQCsAgIJAKwCAgkArAICCQCsAgICB3JlZnVuZF8FBHVzZXICAV8FBGR1Y2sCB19hbW91bnQBHGtleV9nYW1lUHJlRnVuZGVkSXRlbUZvckR1Y2sBBGR1Y2sJAKwCAgIOYWNjZXNzX2Z1bmRlZF8FBGR1Y2sBD2tleV9zcG90c0JvdWdodAEKYWRkcmVzc1N0cgkArAICCQCsAgICCGFkZHJlc3NfBQphZGRyZXNzU3RyAgxfc3BvdHNCb3VnaHQBDWtleV9zcG90c0J1c3kBCmFkZHJlc3NTdHIJAKwCAgkArAICAghhZGRyZXNzXwUKYWRkcmVzc1N0cgIKX3Nwb3RzQnVzeQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCB2FkZHJlc3MDa2V5BAckbWF0Y2gwCQCdCAIFB2FkZHJlc3MFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAFAWECAAEMdHJ5R2V0U3RyaW5nAQNrZXkJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIFBHRoaXMFA2tleQEVdHJ5R2V0SW50ZWdlckV4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAmggCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABDXRyeUdldEludGVnZXIBA2tleQkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIFBHRoaXMFA2tleQEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIeUkFJOiB3cm9uZyB0eXBlLCBleHBlY3RlZDogSW50AAtHZW5lcmF0aW9ucwkAzAgCAgFHCQDMCAICAUgJAMwIAgIBSQkAzAgCAgFLCQDMCAICAUwJAMwIAgIBTQkAzAgCAgFOCQDMCAICAU8FA25pbAEJZ2V0T3JhY2xlAAkBB0FkZHJlc3MBCQDZBAEJAQx0cnlHZXRTdHJpbmcBCQEXc3RhdGljS2V5X29yYWNsZUFkZHJlc3MAAQ5nZXRIdW50QWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFXN0YXRpY0tleV9odW50QWRkcmVzcwABEWdldEJyZWVkZXJBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEYc3RhdGljS2V5X2JyZWVkZXJBZGRyZXNzAAENZ2V0RWdnQXNzZXRJZAAJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARRzdGF0aWNLZXlfZWdnQXNzZXRJZAABFGdldEFjY2Vzc0l0ZW1Bc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEOZ2V0SHVudEFkZHJlc3MACQEbc3RhdGljS2V5X2FjY2Vzc0l0ZW1Bc3NldElkAAESZ2V0QWNjZXNzSXRlbVByaWNlAAkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJARlzdGF0aWNLZXlfYWNjZXNzSXRlbVByaWNlAAEScHV0Rm9yUmVudEludGVybmFsAwFpDGR1cmF0aW9uSW5NcwpwZXJjZW50YWdlBAxmaXJzdFBheW1lbnQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQGZHVja0lkCQDYBAEJAQV2YWx1ZQEIBQxmaXJzdFBheW1lbnQHYXNzZXRJZAMJAQIhPQIIBQxmaXJzdFBheW1lbnQGYW1vdW50AAEJAAIBAhlSUEZSOiBORlQgaXMgbm90IGF0dGFjaGVkBAhjaGlsZHJlbgkBBWFzSW50AQkA/AcECQERZ2V0QnJlZWRlckFkZHJlc3MAAhZ2YWxpZGF0ZUFuZEdldENoaWxkcmVuCQDMCAIFBmR1Y2tJZAUDbmlsBQNuaWwDCQAAAgUIY2hpbGRyZW4FCGNoaWxkcmVuBAtib3VnaHRTcG90cwkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJAQ9rZXlfc3BvdHNCb3VnaHQBCQClCAEIBQFpBmNhbGxlcgQJYnVzeVNwb3RzCQEVdHJ5R2V0SW50ZWdlckV4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBDWtleV9zcG90c0J1c3kBCQClCAEIBQFpBmNhbGxlcgMJAGcCBQlidXN5U3BvdHMFC2JvdWdodFNwb3RzCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhVSUEZSOiBObyBmcmVlIHNwb3RzISAJAKQDAQUJYnVzeVNwb3RzAgEgCQCkAwEFC2JvdWdodFNwb3RzAgEgCQClCAEIBQFpBmNhbGxlcgIBIAkApQgBCQEOZ2V0SHVudEFkZHJlc3MAAwMJAGYCBQpwZXJjZW50YWdlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQEXc3RhdGljS2V5X21heFBlcmNlbnRhZ2UABgkAZgIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARdzdGF0aWNLZXlfbWluUGVyY2VudGFnZQAFCnBlcmNlbnRhZ2UJAAIBCQCsAgIJAKwCAgkArAICCQCsAgICJ1JQRlI6IHBsZWFzZSBwaWNrIGEgcGVyY2VudGFnZSBiZXR3ZWVuIAkBF3N0YXRpY0tleV9taW5QZXJjZW50YWdlAAIFIGFuZCAJARdzdGF0aWNLZXlfbWF4UGVyY2VudGFnZQACASUJAMwIAgkBDEludGVnZXJFbnRyeQIJARVrZXlfZ2V0RHVja1BlcmNlbnRhZ2UBBQZkdWNrSWQFCnBlcmNlbnRhZ2UJAMwIAgkBDEludGVnZXJFbnRyeQIJARNrZXlfZ2V0RHVja0R1cmF0aW9uAQUGZHVja0lkBQxkdXJhdGlvbkluTXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEGtleV9nZXREdWNrT3duZXIBBQZkdWNrSWQJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARFrZXlfZ2V0RHVja1N0YXR1cwEFBmR1Y2tJZAIESURMRQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ10cnlHZXRCb29sZWFuAQNrZXkEByRtYXRjaDAJAKAIAQUDa2V5AwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EAWIFByRtYXRjaDAFAWIHBwFpAQpwdXRGb3JSZW50AgxkdXJhdGlvbkluTXMKcGVyY2VudGFnZQkBEnB1dEZvclJlbnRJbnRlcm5hbAMFAWkFDGR1cmF0aW9uSW5NcwUKcGVyY2VudGFnZQFpARdidXlHbGFzc2VzQW5kUHV0Rm9yUmVudAIMZHVyYXRpb25Jbk1zCnBlcmNlbnRhZ2UECmJ1eUdsYXNzZXMJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAINYnV5QWNjZXNzSXRlbQUDbmlsCQDMCAIJAJEDAggFAWkIcGF5bWVudHMAAQUDbmlsAwkAAAIFCmJ1eUdsYXNzZXMFCmJ1eUdsYXNzZXMJARJwdXRGb3JSZW50SW50ZXJuYWwDBQFpBQxkdXJhdGlvbkluTXMFCnBlcmNlbnRhZ2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEQcmVudER1Y2tGcm9tVXNlcgIGZHVja0lkBGdhbWUEBWdlbmVzCQC1CQIICQEFdmFsdWUBCQDsBwEJANkEAQUGZHVja0lkBG5hbWUCAAQKZ2VuZXJhdGlvbgkAkQMCBQVnZW5lcwAOBANmZWUJAGgCCQBkAgkBBXZhbHVlAQkAzwgCBQtHZW5lcmF0aW9ucwUKZ2VuZXJhdGlvbgABCQERQGV4dHJOYXRpdmUoMTA1NSkBCQEWc3RhdGljS2V5X2RlcG9zaXRTdGVwcwAEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AgkBBXZhbHVlAQgFA3BtdAdhc3NldElkCQENZ2V0RWdnQXNzZXRJZAAJAAIBAidUQlQ6IFBsZWFzZSBhdHRhY2ggdGhlIGNvcnJlY3QgcGF5bWVudCEDCQECIT0CCAUDcG10BmFtb3VudAUDZmVlCQACAQIwUlJERlU6IFBsZWFzZSBhdHRhY2ggZW5vdWdoIHJlZnVuZGFibGUgZGVwb3NpdHMhBApkdWNrU3RhdHVzCQEMdHJ5R2V0U3RyaW5nAQkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAwkBAiE9AgUKZHVja1N0YXR1cwIESURMRQkAAgEJAKwCAgJBUlJERlU6IFlvdSBjYW4gb25seSByZW50IGR1Y2tzIHdpdGggSURMRSBzdGF0dXMuIEN1cnJlbnQgc3RhdHVzOiAFCmR1Y2tTdGF0dXMECWR1Y2tPd25lcgkBDHRyeUdldFN0cmluZwEJARBrZXlfZ2V0RHVja093bmVyAQUGZHVja0lkBAtib3VnaHRTcG90cwkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJAQ9rZXlfc3BvdHNCb3VnaHQBBQlkdWNrT3duZXIECWJ1c3lTcG90cwkBFXRyeUdldEludGVnZXJFeHRlcm5hbAIJAQ5nZXRIdW50QWRkcmVzcwAJAQ1rZXlfc3BvdHNCdXN5AQUJZHVja093bmVyBA9idXlTcG90SWZOZWVkZWQDCQBnAgUJYnVzeVNwb3RzBQtib3VnaHRTcG90cwQEY2FsbAkA/AcECQEOZ2V0SHVudEFkZHJlc3MAAhJidXlBY2Nlc3NJdGVtT3RoZXIJAMwIAgUJZHVja093bmVyBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBG3N0YXRpY0tleV9hY2Nlc3NJdGVtQXNzZXRJZAAJARFAZXh0ck5hdGl2ZSgxMDUwKQIJAQ5nZXRIdW50QWRkcmVzcwAJARlzdGF0aWNLZXlfYWNjZXNzSXRlbVByaWNlAAUDbmlsAwkAAAIFBGNhbGwFBGNhbGwJAMwIAgkBDEJvb2xlYW5FbnRyeQIJARxrZXlfZ2FtZVByZUZ1bmRlZEl0ZW1Gb3JEdWNrAQUGZHVja0lkBgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwDCQECIT0CBQRnYW1lAgRIVU5UCQACAQIYUlJERlU6IFVuc3VwcG9ydGVkIGdhbWUhBAdzdGFydFRzCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQOc2VuZFRvSHVudERhdGEJAPwHBAkBDmdldEh1bnRBZGRyZXNzAAIPbG9ja0R1Y2tSZW50aW5nCQDMCAIFCWR1Y2tPd25lcgUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFBmR1Y2tJZAABBQNuaWwDCQAAAgUOc2VuZFRvSHVudERhdGEFDnNlbmRUb0h1bnREYXRhBA9hbW91bnRSZW50ZWRLZXkJARJrZXlfZ2V0VG90YWxSZW50ZWQBCQClCAEIBQFpBmNhbGxlcgQJYm91Z2h0S2V5CQEca2V5X2dldFRvdGFsQm91Z2h0RXh0cmFTcG90cwEJAKUIAQgFAWkGY2FsbGVyBA9uZXdBbW91bnRSZW50ZWQJAGQCCQENdHJ5R2V0SW50ZWdlcgEFD2Ftb3VudFJlbnRlZEtleQABBAp0b3RhbFNwb3RzCQBkAgkBDXRyeUdldEludGVnZXIBBQlib3VnaHRLZXkJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARpzdGF0aWNLZXlfcmVudFNsb3RzR2VuZXJhbAADCQBmAgUPbmV3QW1vdW50UmVudGVkBQp0b3RhbFNwb3RzCQACAQkArAICAi9SUkRGVTogWW91IGFscmVhZHkgcmVudGVkIG1heCBhbW91bnQgb2YgZHVja3MhIAkApAMBBQp0b3RhbFNwb3RzCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEUa2V5X2dldER1Y2tSZW50c3RhcnQBBQZkdWNrSWQFB3N0YXJ0VHMJAMwIAgkBDEludGVnZXJFbnRyeQIJARRrZXlfZ2V0UmVmdW5kYWJsZUZlZQIJAKUIAQgFAWkGY2FsbGVyBQZkdWNrSWQFA2ZlZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUPYW1vdW50UmVudGVkS2V5BQ9uZXdBbW91bnRSZW50ZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkAgZSRU5URUQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQJAKUIAQgFAWkGY2FsbGVyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEMdG9wVXBSZXdhcmRzAhRkdWNrSWRBbmRBbW91bnRzTGlzdAdhc3NldElkCgELaGFuZGxlVG9wVXACA2FjYw11c2VyQW5kQW1vdW50BApzcGxpdEFycmF5CQC1CQIFDXVzZXJBbmRBbW91bnQCAToEBHVzZXIJAJEDAgUKc3BsaXRBcnJheQAABAZhbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpzcGxpdEFycmF5AAEEBmR1Y2tJZAkAkQMCBQpzcGxpdEFycmF5AAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUEdXNlcgkAaAIFBmFtb3VudACgjQYJANkEAQUHYXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBE2tleV9nZXREdWNrTGFzdFBhaWQBBQZkdWNrSWQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQNuaWwKAAIkbAUUZHVja0lkQW5kQW1vdW50c0xpc3QKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBC2hhbmRsZVRvcFVwAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxNQkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwFpAQ1jbGFpbUR1Y2tCYWNrAQZkdWNrSWQECWR1Y2tPd25lcgkBDHRyeUdldFN0cmluZwEJARBrZXlfZ2V0RHVja093bmVyAQUGZHVja0lkAwkBAiE9AgUJZHVja093bmVyCQClCAEIBQFpBmNhbGxlcgkAAgECMlJDREI6IFBsZWFzZSBkb24ndCB0cnkgdG8gc3RlYWwgc29tZW9uZSBlbHNlIGR1Y2shAwMJAQ10cnlHZXRCb29sZWFuAQkBHGtleV9nYW1lUHJlRnVuZGVkSXRlbUZvckR1Y2sBBQZkdWNrSWQDCQECIT0CCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBDmdldEh1bnRBZGRyZXNzAAkBG3N0YXRpY0tleV9hY2Nlc3NJdGVtQXNzZXRJZAAGCQECIT0CCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAkBEUBleHRyTmF0aXZlKDEwNTApAgkBDmdldEh1bnRBZGRyZXNzAAkBGXN0YXRpY0tleV9hY2Nlc3NJdGVtUHJpY2UABwkAAgECRlBsZWFzZSBtYWtlIHN1cmUgdG8gYXR0YWNoIGVub3VnaCBmdW5kcyB0byBwYXkgZm9yIHlvdXIgcHJldmlvdXMgc3BvdCEECmR1Y2tTdGF0dXMJAQx0cnlHZXRTdHJpbmcBCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQDCQAAAgUKZHVja1N0YXR1cwIESURMRQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIAAQkA2QQBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkBQNuaWwEB3N0YXJ0VHMJAQ10cnlHZXRJbnRlZ2VyAQkBFGtleV9nZXREdWNrUmVudHN0YXJ0AQUGZHVja0lkAwkAZgIIBQlsYXN0QmxvY2sJdGltZXN0YW1wCQBkAgUHc3RhcnRUcwkBDXRyeUdldEludGVnZXIBCQETa2V5X2dldER1Y2tEdXJhdGlvbgEFBmR1Y2tJZAQGcGxheWVyCQEMdHJ5R2V0U3RyaW5nAQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQEDnJlbW92ZUZyb21IdW50CQD8BwQJAQ5nZXRIdW50QWRkcmVzcwACEXVubG9ja0R1Y2tSZW50aW5nCQDMCAIFBmR1Y2tJZAkAzAgCBQlkdWNrT3duZXIFA25pbAUDbmlsAwkAAAIFDnJlbW92ZUZyb21IdW50BQ5yZW1vdmVGcm9tSHVudAQMcmVmdW5kRmVlS2V5CQEUa2V5X2dldFJlZnVuZGFibGVGZWUCBQZwbGF5ZXIFBmR1Y2tJZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQZwbGF5ZXIJAQ10cnlHZXRJbnRlZ2VyAQUMcmVmdW5kRmVlS2V5CQENZ2V0RWdnQXNzZXRJZAAJAMwIAgkBC0RlbGV0ZUVudHJ5AQUMcmVmdW5kRmVlS2V5CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCWR1Y2tPd25lcgABCQDZBAEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQLbGFzdFBheW1lbnQJAQ10cnlHZXRJbnRlZ2VyAQkBE2tleV9nZXREdWNrTGFzdFBhaWQBBQZkdWNrSWQEDXRocmVlRGF5c0luTXMJAGgCCQBoAgkAaAIAAwAYADwA6AcDCQBmAggFCWxhc3RCbG9jawZoZWlnaHQJAGQCBQtsYXN0UGF5bWVudAUNdGhyZWVEYXlzSW5NcwQHdW5zdGFrZQkA/AcECQEOZ2V0SHVudEFkZHJlc3MAAhF1bmxvY2tEdWNrUmVudGluZwkAzAgCBQZkdWNrSWQJAMwIAgUJZHVja093bmVyBQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCWR1Y2tPd25lcgABCQDZBAEFBmR1Y2tJZAkAzAgCCQELRGVsZXRlRW50cnkBCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBE2tleV9nZXREdWNrUmVudGVkQnkBBQZkdWNrSWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECNlJDREI6IFJlbnRpbmcgcGVyaW9kIGlzIG5vdCBvdmVyIGFuZCBwbGF5ZXIgaXMgYWN0aXZlIQFpAQxzZW5kRHVja0JhY2sBBmR1Y2tJZAQIcmVudGVkQnkJAQx0cnlHZXRTdHJpbmcBCQETa2V5X2dldER1Y2tSZW50ZWRCeQEFBmR1Y2tJZAMJAQIhPQIFCHJlbnRlZEJ5CQClCAEIBQFpBmNhbGxlcgkAAgECIFJTREI6IFlvdSBkaWRuJ3QgcmVudCB0aGlzIGR1Y2shBAlkdWNrT3duZXIJAQx0cnlHZXRTdHJpbmcBCQEQa2V5X2dldER1Y2tPd25lcgEFBmR1Y2tJZAQMcmVmdW5kRmVlS2V5CQEUa2V5X2dldFJlZnVuZGFibGVGZWUCCQClCAEIBQFpBmNhbGxlcgUGZHVja0lkBA5yZW1vdmVGcm9tSHVudAkA/AcECQEOZ2V0SHVudEFkZHJlc3MAAhF1bmxvY2tEdWNrUmVudGluZwkAzAgCBQZkdWNrSWQJAMwIAgUJZHVja093bmVyBQNuaWwFA25pbAMJAAACBQ5yZW1vdmVGcm9tSHVudAUOcmVtb3ZlRnJvbUh1bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyCQENdHJ5R2V0SW50ZWdlcgEFDHJlZnVuZEZlZUtleQkBDWdldEVnZ0Fzc2V0SWQACQDMCAIJAQtEZWxldGVFbnRyeQEFDHJlZnVuZEZlZUtleQkAzAgCCQELU3RyaW5nRW50cnkCCQERa2V5X2dldER1Y2tTdGF0dXMBBQZkdWNrSWQCBElETEUJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBEWtleV9nZXREdWNrU3RhdHVzAQUGZHVja0lkCQDMCAIJAQtEZWxldGVFbnRyeQEJARNrZXlfZ2V0RHVja1JlbnRlZEJ5AQUGZHVja0lkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAg9SQ086IGFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBF3N0YXRpY0tleV9vcmFjbGVBZGRyZXNzAAUGb3JhY2xlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEXc3RhdGljS2V5X21pblBlcmNlbnRhZ2UAAAUJAMwIAgkBDEludGVnZXJFbnRyeQIJARdzdGF0aWNLZXlfbWF4UGVyY2VudGFnZQAAUAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFnN0YXRpY0tleV9kZXBvc2l0U3RlcHMAAIDh6xcJAMwIAgkBDEludGVnZXJFbnRyeQIJARpzdGF0aWNLZXlfcmVudFNsb3RzR2VuZXJhbAAABQUDbmlsAC8DkcA=", "height": 3576871, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6XMcy9JCqwcGV3HdeZUg6kcbuqqdwZPzrnVURWqpTP51 Next: 3K3BE1ZimM5nDzQoboSm7rUeMwNKwirCSdPqr1AK7KaA Diff:
OldNewDifferences
2626
2727
2828 func staticKey_depositSteps () = "static_depositSteps"
29+
30+
31+func staticKey_rentSlotsGeneral () = "static_rentSlots"
2932
3033
3134 func key_getDuckOwner (duck) = (("duck_" + duck) + "_owner")
200203 let amountRentedKey = key_getTotalRented(toString(i.caller))
201204 let boughtKey = key_getTotalBoughtExtraSpots(toString(i.caller))
202205 let newAmountRented = (tryGetInteger(amountRentedKey) + 1)
203- let totalSpots = (tryGetInteger(boughtKey) + 5)
206+ let totalSpots = (tryGetInteger(boughtKey) + getIntegerValue(this, staticKey_rentSlotsGeneral()))
204207 if ((newAmountRented > totalSpots))
205208 then throw(("RRDFU: You already rented max amount of ducks! " + toString(totalSpots)))
206209 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))]
214217
215218
216219 @Callable(i)
217-func topUpRewards (duckIdAndAmountsList,amounts,assetId) = {
218- func handleTopUp (acc,duckIdAndAmount) = {
219- let splitArray = split(duckIdAndAmount, ":")
220- let duckId = splitArray[0]
220+func topUpRewards (duckIdAndAmountsList,assetId) = {
221+ func handleTopUp (acc,userAndAmount) = {
222+ let splitArray = split(userAndAmount, ":")
223+ let user = splitArray[0]
221224 let amount = parseIntValue(splitArray[1])
222- let duckOwner = tryGetString(key_getDuckOwner(duckId))
223- let renter = tryGetString(key_getDuckRentedBy(duckId))
224- let feePercentage = tryGetInteger(key_getDuckPercentage(duckId))
225- let forOwnerAmount = fraction(amount, feePercentage, 100)
226- let forPlayerAmount = (amount - forOwnerAmount)
227-[ScriptTransfer(addressFromStringValue(duckOwner), (forOwnerAmount * 100000), fromBase58String(assetId)), ScriptTransfer(addressFromStringValue(renter), (forPlayerAmount * 100000), fromBase58String(assetId)), IntegerEntry(key_getDuckLastPaid(duckId), lastBlock.timestamp)]
225+ let duckId = splitArray[2]
226+[ScriptTransfer(addressFromStringValue(user), (amount * 100000), fromBase58String(assetId)), IntegerEntry(key_getDuckLastPaid(duckId), lastBlock.timestamp)]
228227 }
229228
230229 let $l = duckIdAndAmountsList
309308 @Callable(i)
310309 func configureOracle (oracle) = if ((i.caller != this))
311310 then throw("RCO: admin only")
312- else [StringEntry(staticKey_oracleAddress(), oracle), IntegerEntry(staticKey_minPercentage(), 5), IntegerEntry(staticKey_maxPercentage(), 80), IntegerEntry(staticKey_depositSteps(), 50000000)]
311+ else [StringEntry(staticKey_oracleAddress(), oracle), IntegerEntry(staticKey_minPercentage(), 5), IntegerEntry(staticKey_maxPercentage(), 80), IntegerEntry(staticKey_depositSteps(), 50000000), IntegerEntry(staticKey_rentSlotsGeneral(), 5)]
313312
314313
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func staticKey_oracleAddress () = "static_oracleAddress"
55
66
77 func staticKey_huntAddress () = "static_huntAddress"
88
99
1010 func staticKey_breederAddress () = "static_breederAddress"
1111
1212
1313 func staticKey_eggAssetId () = "static_eggAssetId"
1414
1515
1616 func staticKey_minPercentage () = "static_minPercentage"
1717
1818
1919 func staticKey_maxPercentage () = "static_maxPercentage"
2020
2121
2222 func staticKey_accessItemAssetId () = "static_accessItemAssetId"
2323
2424
2525 func staticKey_accessItemPrice () = "static_accessItemPrice"
2626
2727
2828 func staticKey_depositSteps () = "static_depositSteps"
29+
30+
31+func staticKey_rentSlotsGeneral () = "static_rentSlots"
2932
3033
3134 func key_getDuckOwner (duck) = (("duck_" + duck) + "_owner")
3235
3336
3437 func key_getDuckStatus (duck) = (("duck_" + duck) + "_status")
3538
3639
3740 func key_getDuckRentedBy (duck) = (("duck_" + duck) + "_rentedBy")
3841
3942
4043 func key_getDuckDuration (duck) = (("duck_" + duck) + "_duration")
4144
4245
4346 func key_getDuckRentstart (duck) = (("duck_" + duck) + "_start_ts")
4447
4548
4649 func key_getDuckPercentage (duck) = (("duck_" + duck) + "_percentage")
4750
4851
4952 func key_getDuckLastPaid (duck) = (("duck_" + duck) + "_lastPaid")
5053
5154
5255 func key_getTotalRented (user) = (("rented_" + user) + "_amount")
5356
5457
5558 func key_getTotalBoughtExtraSpots (user) = (("spots_" + user) + "_amount")
5659
5760
5861 func key_getRefundableFee (user,duck) = (((("refund_" + user) + "_") + duck) + "_amount")
5962
6063
6164 func key_gamePreFundedItemForDuck (duck) = ("access_funded_" + duck)
6265
6366
6467 func key_spotsBought (addressStr) = (("address_" + addressStr) + "_spotsBought")
6568
6669
6770 func key_spotsBusy (addressStr) = (("address_" + addressStr) + "_spotsBusy")
6871
6972
7073 func tryGetStringExternal (address,key) = match getString(address, key) {
7174 case a: String =>
7275 a
7376 case _ =>
7477 ""
7578 }
7679
7780
7881 func tryGetString (key) = tryGetStringExternal(this, key)
7982
8083
8184 func tryGetIntegerExternal (address,key) = match getInteger(address, key) {
8285 case b: Int =>
8386 b
8487 case _ =>
8588 0
8689 }
8790
8891
8992 func tryGetInteger (key) = tryGetIntegerExternal(this, key)
9093
9194
9295 func asInt (value) = match value {
9396 case int: Int =>
9497 int
9598 case _ =>
9699 throw("RAI: wrong type, expected: Int")
97100 }
98101
99102
100103 let Generations = ["G", "H", "I", "K", "L", "M", "N", "O"]
101104
102105 func getOracle () = Address(fromBase58String(tryGetString(staticKey_oracleAddress())))
103106
104107
105108 func getHuntAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_huntAddress())))
106109
107110
108111 func getBreederAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_breederAddress())))
109112
110113
111114 func getEggAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_eggAssetId()))
112115
113116
114117 func getAccessItemAssetId () = fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId()))
115118
116119
117120 func getAccessItemPrice () = tryGetIntegerExternal(getHuntAddress(), staticKey_accessItemPrice())
118121
119122
120123 func putForRentInternal (i,durationInMs,percentage) = {
121124 let firstPayment = value(i.payments[0])
122125 let duckId = toBase58String(value(firstPayment.assetId))
123126 if ((firstPayment.amount != 1))
124127 then throw("RPFR: NFT is not attached")
125128 else {
126129 let children = asInt(invoke(getBreederAddress(), "validateAndGetChildren", [duckId], nil))
127130 if ((children == children))
128131 then {
129132 let boughtSpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBought(toString(i.caller)))
130133 let busySpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBusy(toString(i.caller)))
131134 if ((busySpots >= boughtSpots))
132135 then throw(((((((("RPFR: No free spots! " + toString(busySpots)) + " ") + toString(boughtSpots)) + " ") + toString(i.caller)) + " ") + toString(getHuntAddress())))
133136 else if (if ((percentage > getIntegerValue(this, staticKey_maxPercentage())))
134137 then true
135138 else (getIntegerValue(this, staticKey_minPercentage()) > percentage))
136139 then throw((((("RPFR: please pick a percentage between " + staticKey_minPercentage()) + " and ") + staticKey_maxPercentage()) + "%"))
137140 else [IntegerEntry(key_getDuckPercentage(duckId), percentage), IntegerEntry(key_getDuckDuration(duckId), durationInMs), StringEntry(key_getDuckOwner(duckId), toString(i.caller)), StringEntry(key_getDuckStatus(duckId), "IDLE")]
138141 }
139142 else throw("Strict value is not equal to itself.")
140143 }
141144 }
142145
143146
144147 func tryGetBoolean (key) = match getBoolean(key) {
145148 case b: Boolean =>
146149 b
147150 case _ =>
148151 false
149152 }
150153
151154
152155 @Callable(i)
153156 func putForRent (durationInMs,percentage) = putForRentInternal(i, durationInMs, percentage)
154157
155158
156159
157160 @Callable(i)
158161 func buyGlassesAndPutForRent (durationInMs,percentage) = {
159162 let buyGlasses = invoke(getHuntAddress(), "buyAccessItem", nil, [i.payments[1]])
160163 if ((buyGlasses == buyGlasses))
161164 then putForRentInternal(i, durationInMs, percentage)
162165 else throw("Strict value is not equal to itself.")
163166 }
164167
165168
166169
167170 @Callable(i)
168171 func rentDuckFromUser (duckId,game) = {
169172 let genes = split(value(assetInfo(fromBase58String(duckId))).name, "")
170173 let generation = genes[14]
171174 let fee = ((value(indexOf(Generations, generation)) + 1) * getIntegerValue(staticKey_depositSteps()))
172175 let pmt = value(i.payments[0])
173176 if ((value(pmt.assetId) != getEggAssetId()))
174177 then throw("TBT: Please attach the correct payment!")
175178 else if ((pmt.amount != fee))
176179 then throw("RRDFU: Please attach enough refundable deposits!")
177180 else {
178181 let duckStatus = tryGetString(key_getDuckStatus(duckId))
179182 if ((duckStatus != "IDLE"))
180183 then throw(("RRDFU: You can only rent ducks with IDLE status. Current status: " + duckStatus))
181184 else {
182185 let duckOwner = tryGetString(key_getDuckOwner(duckId))
183186 let boughtSpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBought(duckOwner))
184187 let busySpots = tryGetIntegerExternal(getHuntAddress(), key_spotsBusy(duckOwner))
185188 let buySpotIfNeeded = if ((busySpots >= boughtSpots))
186189 then {
187190 let call = invoke(getHuntAddress(), "buyAccessItemOther", [duckOwner], [AttachedPayment(fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId())), getIntegerValue(getHuntAddress(), staticKey_accessItemPrice()))])
188191 if ((call == call))
189192 then [BooleanEntry(key_gamePreFundedItemForDuck(duckId), true)]
190193 else throw("Strict value is not equal to itself.")
191194 }
192195 else nil
193196 if ((game != "HUNT"))
194197 then throw("RRDFU: Unsupported game!")
195198 else {
196199 let startTs = lastBlock.timestamp
197200 let sendToHuntData = invoke(getHuntAddress(), "lockDuckRenting", [duckOwner], [AttachedPayment(fromBase58String(duckId), 1)])
198201 if ((sendToHuntData == sendToHuntData))
199202 then {
200203 let amountRentedKey = key_getTotalRented(toString(i.caller))
201204 let boughtKey = key_getTotalBoughtExtraSpots(toString(i.caller))
202205 let newAmountRented = (tryGetInteger(amountRentedKey) + 1)
203- let totalSpots = (tryGetInteger(boughtKey) + 5)
206+ let totalSpots = (tryGetInteger(boughtKey) + getIntegerValue(this, staticKey_rentSlotsGeneral()))
204207 if ((newAmountRented > totalSpots))
205208 then throw(("RRDFU: You already rented max amount of ducks! " + toString(totalSpots)))
206209 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))]
207210 }
208211 else throw("Strict value is not equal to itself.")
209212 }
210213 }
211214 }
212215 }
213216
214217
215218
216219 @Callable(i)
217-func topUpRewards (duckIdAndAmountsList,amounts,assetId) = {
218- func handleTopUp (acc,duckIdAndAmount) = {
219- let splitArray = split(duckIdAndAmount, ":")
220- let duckId = splitArray[0]
220+func topUpRewards (duckIdAndAmountsList,assetId) = {
221+ func handleTopUp (acc,userAndAmount) = {
222+ let splitArray = split(userAndAmount, ":")
223+ let user = splitArray[0]
221224 let amount = parseIntValue(splitArray[1])
222- let duckOwner = tryGetString(key_getDuckOwner(duckId))
223- let renter = tryGetString(key_getDuckRentedBy(duckId))
224- let feePercentage = tryGetInteger(key_getDuckPercentage(duckId))
225- let forOwnerAmount = fraction(amount, feePercentage, 100)
226- let forPlayerAmount = (amount - forOwnerAmount)
227-[ScriptTransfer(addressFromStringValue(duckOwner), (forOwnerAmount * 100000), fromBase58String(assetId)), ScriptTransfer(addressFromStringValue(renter), (forPlayerAmount * 100000), fromBase58String(assetId)), IntegerEntry(key_getDuckLastPaid(duckId), lastBlock.timestamp)]
225+ let duckId = splitArray[2]
226+[ScriptTransfer(addressFromStringValue(user), (amount * 100000), fromBase58String(assetId)), IntegerEntry(key_getDuckLastPaid(duckId), lastBlock.timestamp)]
228227 }
229228
230229 let $l = duckIdAndAmountsList
231230 let $s = size($l)
232231 let $acc0 = nil
233232 func $f0_1 ($a,$i) = if (($i >= $s))
234233 then $a
235234 else handleTopUp($a, $l[$i])
236235
237236 func $f0_2 ($a,$i) = if (($i >= $s))
238237 then $a
239238 else throw("List size exceeds 15")
240239
241240 $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)
242241 }
243242
244243
245244
246245 @Callable(i)
247246 func claimDuckBack (duckId) = {
248247 let duckOwner = tryGetString(key_getDuckOwner(duckId))
249248 if ((duckOwner != toString(i.caller)))
250249 then throw("RCDB: Please don't try to steal someone else duck!")
251250 else if (if (tryGetBoolean(key_gamePreFundedItemForDuck(duckId)))
252251 then if ((i.payments[0].assetId != fromBase58String(tryGetStringExternal(getHuntAddress(), staticKey_accessItemAssetId()))))
253252 then true
254253 else (i.payments[0].amount != getIntegerValue(getHuntAddress(), staticKey_accessItemPrice()))
255254 else false)
256255 then throw("Please make sure to attach enough funds to pay for your previous spot!")
257256 else {
258257 let duckStatus = tryGetString(key_getDuckStatus(duckId))
259258 if ((duckStatus == "IDLE"))
260259 then [ScriptTransfer(i.caller, 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId))]
261260 else {
262261 let startTs = tryGetInteger(key_getDuckRentstart(duckId))
263262 if ((lastBlock.timestamp > (startTs + tryGetInteger(key_getDuckDuration(duckId)))))
264263 then {
265264 let player = tryGetString(key_getDuckRentedBy(duckId))
266265 let removeFromHunt = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
267266 if ((removeFromHunt == removeFromHunt))
268267 then {
269268 let refundFeeKey = key_getRefundableFee(player, duckId)
270269 [ScriptTransfer(addressFromStringValue(player), tryGetInteger(refundFeeKey), getEggAssetId()), DeleteEntry(refundFeeKey), ScriptTransfer(addressFromStringValue(duckOwner), 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_getDuckRentedBy(duckId))]
271270 }
272271 else throw("Strict value is not equal to itself.")
273272 }
274273 else {
275274 let lastPayment = tryGetInteger(key_getDuckLastPaid(duckId))
276275 let threeDaysInMs = (((3 * 24) * 60) * 1000)
277276 if ((lastBlock.height > (lastPayment + threeDaysInMs)))
278277 then {
279278 let unstake = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
280279 if ((unstake == unstake))
281280 then [ScriptTransfer(addressFromStringValue(duckOwner), 1, fromBase58String(duckId)), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_getDuckRentedBy(duckId))]
282281 else throw("Strict value is not equal to itself.")
283282 }
284283 else throw("RCDB: Renting period is not over and player is active!")
285284 }
286285 }
287286 }
288287 }
289288
290289
291290
292291 @Callable(i)
293292 func sendDuckBack (duckId) = {
294293 let rentedBy = tryGetString(key_getDuckRentedBy(duckId))
295294 if ((rentedBy != toString(i.caller)))
296295 then throw("RSDB: You didn't rent this duck!")
297296 else {
298297 let duckOwner = tryGetString(key_getDuckOwner(duckId))
299298 let refundFeeKey = key_getRefundableFee(toString(i.caller), duckId)
300299 let removeFromHunt = invoke(getHuntAddress(), "unlockDuckRenting", [duckId, duckOwner], nil)
301300 if ((removeFromHunt == removeFromHunt))
302301 then [ScriptTransfer(i.caller, tryGetInteger(refundFeeKey), getEggAssetId()), DeleteEntry(refundFeeKey), StringEntry(key_getDuckStatus(duckId), "IDLE"), DeleteEntry(key_getDuckStatus(duckId)), DeleteEntry(key_getDuckRentedBy(duckId))]
303302 else throw("Strict value is not equal to itself.")
304303 }
305304 }
306305
307306
308307
309308 @Callable(i)
310309 func configureOracle (oracle) = if ((i.caller != this))
311310 then throw("RCO: admin only")
312- else [StringEntry(staticKey_oracleAddress(), oracle), IntegerEntry(staticKey_minPercentage(), 5), IntegerEntry(staticKey_maxPercentage(), 80), IntegerEntry(staticKey_depositSteps(), 50000000)]
311+ else [StringEntry(staticKey_oracleAddress(), oracle), IntegerEntry(staticKey_minPercentage(), 5), IntegerEntry(staticKey_maxPercentage(), 80), IntegerEntry(staticKey_depositSteps(), 50000000), IntegerEntry(staticKey_rentSlotsGeneral(), 5)]
313312
314313

github/deemru/w8io/6500d08 
65.86 ms