tx · HqYJXCvBaSc1T3fALEAVcVGydd5Lwm9gaLGyRHj7iZNo 3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ: -0.01400000 Waves 2022.09.21 07:41 [3303874] smart account 3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ > SELF 0.00000000 Waves
{ "type": 13, "id": "HqYJXCvBaSc1T3fALEAVcVGydd5Lwm9gaLGyRHj7iZNo", "fee": 1400000, "feeAssetId": null, "timestamp": 1663735332178, "version": 2, "chainId": 87, "sender": "3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ", "senderPublicKey": "Gczkhukah6ZwryrD6feHYGNGJ4yEoXoELZTTmjFGbbDp", "proofs": [ "2jduTJrF3EbSdCAKcPFvWXnXCtcH3Ay2aBcB68vuMd713GWnWCLJDrNbyULxCPDMv8eHcC1xZCKFQy9v1aXo7SKa" ], "script": "base64:BgJGCAISDQoLCAgICAgBCAgBAQQSBAoCCAgSBAoCCAESBAoCAQESAwoBBBIECgIICBIFCgMICAgSBAoCCAgSBAoCBAgSAwoBCD0AB3ZlcnNpb24CAzEuMAALQ09ORl9JTklUX0sCC2NvbmZpZ19pbml0AAtDT05GX0FNSU5fSwIMY29uZmlnX2FkbWluAA1DT05GX09SQUNMRV9LAg1jb25maWdfb3JhY2xlABNDT05GX0FSVFdPUktfREFQUF9LAhNjb25maWdfYXJ0d29ya19kYXBwABFDT05GX1VTRVJTX0RBUFBfSwIRY29uZmlnX3VzZXJzX2RhcHAAEENPTkZfRkVFX0FTU0VUX0sCEGNvbmZpZ19mZWVfYXNzZXQAEUNPTkZfRkVFX0FNT1VOVF9LAhFjb25maWdfZmVlX2Ftb3VudAAVQ09ORl9TV09QX1NJR05fREFQUF9LAhVjb25maWdfc3dvcF9zaWduX2RhcHAAFENPTkZfU1dPUF9FVEhfREFQUF9LAhRjb25maWdfc3dvcF9ldGhfZGFwcAAfQ09ORl9DT05GSVJNQVRJT05TX0ZST01fV0FWRVNfSwIfY29uZmlnX2NvbmZpcm1hdGlvbnNfZnJvbV93YXZlcwAdQ09ORl9DT05GSVJNQVRJT05TX0ZST01fRVRIX0sCHWNvbmZpZ19jb25maXJtYXRpb25zX2Zyb21fZXRoAA9DT05GX0FVVE9TV0FQX0sCD2NvbmZpZ19hdXRvc3dhcAANZGFwcFJ1bm5pbmdfSwIUY29uZl9kYXBwX2lzX3J1bm5pbmcAEG1haW50ZW5hbmNlTVNHX0sCFGNvbmZfbWFpbnRlbmFuY2VfbXNnAAtkYXBwUnVubmluZwkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQ1kYXBwUnVubmluZ19LBgAObWFpbnRlbmFuY2VNU0cJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUQbWFpbnRlbmFuY2VNU0dfSwIAAA1zdGF0dXNfTE9DS0VEAgZMT0NLRUQAD3N0YXR1c19VTkxPQ0tFRAIIVU5MT0NLRUQADnN0YXR1c19QRU5ESU5HAgdQRU5ESU5HAA1zdGF0dXNfQ0xPU0VEAgZDTE9TRUQAEWNyZWF0b3JSZWdpc3RlcmVkAgpSRUdJU1RFUkVEAA9jcmVhdG9yVmVyaWZpZWQCCFZFUklGSUVEAAphcnRGbGFnZ2VkAgdGTEFHR0VEAAphcnRJbGxlZ2FsAgdJTExFR0FMAAphcnRQZW5kaW5nAg9DSEFOR0VfUkVRVUlSRUQACE5FVFdPUktTCQDMCAICA0VUSAUDbmlsAQxrZXlORlRzdGF0dXMBBW5mdElkCQCsAgIJAKwCAgIEbmZ0XwUFbmZ0SWQCB19zdGF0dXMBDmtleVRyYW5zZmVyTkZUAwVuZnRJZAR0eGlkBmNhbGxlcgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICCXRyYW5zZmVyXwUFbmZ0SWQCAV8FBHR4aWQCAV8FBmNhbGxlcgAPa2V5RmVlTm9uTWludGVkAg9jb3N0X25vbl9taW50ZWQADGtleUZlZU1pbnRlZAILY29zdF9taW50ZWQBDmdldFN0cmluZ0J5S2V5AQNrZXkJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUDa2V5AgABD2dldEludGVnZXJCeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFA2tleQAAAQ9nZXRCb29sZWFuQnlLZXkBA2tleQkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQNrZXkHAAVhZG1pbgkBBXZhbHVlAQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDmdldFN0cmluZ0J5S2V5AQULQ09ORl9BTUlOX0sADGFydHdvcmtzRGFwcAkBBXZhbHVlAQkApggBCQEOZ2V0U3RyaW5nQnlLZXkBBRNDT05GX0FSVFdPUktfREFQUF9LAAl1c2Vyc0RhcHAJAQV2YWx1ZQEJAKYIAQkBDmdldFN0cmluZ0J5S2V5AQURQ09ORl9VU0VSU19EQVBQX0sACm9yYWNsZUFkZHIJAQV2YWx1ZQEJAKYIAQkBDmdldFN0cmluZ0J5S2V5AQUNQ09ORl9PUkFDTEVfSwAIYXV0b3N3YXAJAQt2YWx1ZU9yRWxzZQIJAQ9nZXRCb29sZWFuQnlLZXkBBQ9DT05GX0FVVE9TV0FQX0sHABBmZWVBY2NlcHRlZEFzc2V0CQEOZ2V0U3RyaW5nQnlLZXkBBRBDT05GX0ZFRV9BU1NFVF9LABhmZWVBY2NlcHRlZEFtb3VudEZvclNpZ24JAQ9nZXRJbnRlZ2VyQnlLZXkBBRFDT05GX0ZFRV9BTU9VTlRfSwEXZ2V0U3RyaW5nRnJvbVVzZXJzQnlLZXkBA2tleQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQl1c2Vyc0RhcHAFA2tleQIAARpnZXRTdHJpbmdGcm9tQXJ0d29ya3NCeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCdCAIFDGFydHdvcmtzRGFwcAUDa2V5AgABGWdldEludGVnZXJCeUtleUZyb21PcmFjbGUBA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFCm9yYWNsZUFkZHIFA2tleQIbSW50ZWdlciB1bmRlZmluZWQgaW4gb3JhY2xlAQxhc3NldElzVmFsaWQBDGFzc2V0RGV0YWlscwMDAwkAAAIIBQxhc3NldERldGFpbHMIcXVhbnRpdHkAAQkAAAIIBQxhc3NldERldGFpbHMIZGVjaW1hbHMAAAcJAAACCAUMYXNzZXREZXRhaWxzCnJlaXNzdWFibGUHBwkAAAIIBQxhc3NldERldGFpbHMGaXNzdWVyBQxhcnR3b3Jrc0RhcHAHAQxpc1NpZ25BcnRORlQBAmlkBAxhc3NldERldGFpbHMJAQV2YWx1ZQEJAOwHAQUCaWQJAQxhc3NldElzVmFsaWQBBQxhc3NldERldGFpbHMBCWlzUGF5bWVudAEBaQMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAgkAAgECGU5lZWQgdG8gYXR0YWNoIDIgcGF5bWVudHMEC25mdF9wYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAECm5mdF9hbW91bnQJAQV2YWx1ZQEIBQtuZnRfcGF5bWVudAZhbW91bnQED2dhdGV3YXlfcGF5bWVudAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwABBA5nYXRld2F5X2Ftb3VudAkBBXZhbHVlAQgFD2dhdGV3YXlfcGF5bWVudAZhbW91bnQJAJYKBAULbmZ0X3BheW1lbnQFCm5mdF9hbW91bnQFD2dhdGV3YXlfcGF5bWVudAUOZ2F0ZXdheV9hbW91bnQABmlzSW5pdAkBC3ZhbHVlT3JFbHNlAgkBD2dldEJvb2xlYW5CeUtleQEFC0NPTkZfSU5JVF9LBwEJb3duZXJPbmx5AQFpBAZjYWxsZXIJAKUIAQgFAWkGY2FsbGVyBAJpZAkA2AQBCAUBaQ10cmFuc2FjdGlvbklkBAphbGxvd2VkQXJyAwUGaXNJbml0CQDMCAIJAKUIAQUFYWRtaW4JAMwIAgkApQgBBQR0aGlzBQNuaWwJAMwIAgkApQgBBQR0aGlzBQNuaWwJAQ9jb250YWluc0VsZW1lbnQCBQphbGxvd2VkQXJyBQZjYWxsZXIBDGlkQ2FsbGVyRGF0ZQEBaQMJAQEhAQULZGFwcFJ1bm5pbmcJAAIBBQ5tYWludGVuYW5jZU1TRwkAlQoDCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQJANgEAQgIBQFpBmNhbGxlcgVieXRlcwgFCWxhc3RCbG9jawl0aW1lc3RhbXABE2dldENyZWF0b3JGcm9tTkZUaWQBBW5mdGlkBAduZnREYXRhCQEaZ2V0U3RyaW5nRnJvbUFydHdvcmtzQnlLZXkBCQCsAgICBG5mdF8FBW5mdGlkBAdjcmVhdG9yCQCRAwIJALUJAgUHbmZ0RGF0YQIBXwAGBAVhcnRJZAkAkQMCCQC1CQIFB25mdERhdGECAV8ABQkAlAoCBQdjcmVhdG9yBQVhcnRJZAETZ2V0Q3JlYXRvckVSQzIwQWRkcgEEYWRkcgkBF2dldFN0cmluZ0Zyb21Vc2Vyc0J5S2V5AQkArAICAgt1c2VyX0VSQzIwXwUEYWRkcgEQZ2V0Q3JlYXRvclN0YXR1cwEEYWRkcgkBF2dldFN0cmluZ0Zyb21Vc2Vyc0J5S2V5AQkArAICAgx1c2VyX3N0YXR1c18FBGFkZHIBDGdldEFydFN0YXR1cwIFYXJ0SWQEYWRkcgkBGmdldFN0cmluZ0Zyb21BcnR3b3Jrc0J5S2V5AQkArAICCQCsAgIJAKwCAgIJYXJ0X2ZsYWdfBQVhcnRJZAIBXwUEYWRkcgEOaXNWYWxpZENyZWF0b3IBBnN0YXR1cwMJAAACBQZzdGF0dXMFEWNyZWF0b3JSZWdpc3RlcmVkBgkAAAIFBnN0YXR1cwUPY3JlYXRvclZlcmlmaWVkAQppc1ZhbGlkQXJ0AQZzdGF0dXMDAwkBAiE9AgUGc3RhdHVzBQphcnRGbGFnZ2VkCQECIT0CBQZzdGF0dXMFCmFydElsbGVnYWwHCQECIT0CBQZzdGF0dXMFCmFydFBlbmRpbmcHAQxpc0V2bUFkZHJlc3MBBGFkZHIDCQAAAgkAsQIBBQRhZGRyACoJAAACCQCvAgIFBGFkZHIAAgICMHgHARBzZXRTd29wRGFwcHNGdW5jAghzaWduRGFwcAdldGhEYXBwCQDMCAIJAQtTdHJpbmdFbnRyeQIFFUNPTkZfU1dPUF9TSUdOX0RBUFBfSwUIc2lnbkRhcHAJAMwIAgkBC1N0cmluZ0VudHJ5AgUUQ09ORl9TV09QX0VUSF9EQVBQX0sFB2V0aERhcHAFA25pbAEKc2V0RmVlRnVuYwIIZmVlQXNzZXQJZmVlQW1vdW50BAxhc3NldERldGFpbHMJAOwHAQkA2QQBBQhmZWVBc3NldAQHZGVjaW1hbAgJAQV2YWx1ZQEFDGFzc2V0RGV0YWlscwhkZWNpbWFscwQPYmFzZTEwRmVlQW1vdW50CQBsBgUJZmVlQW1vdW50AAAACgABBQdkZWNpbWFsBQZIQUxGVVAJAMwIAgkBC1N0cmluZ0VudHJ5AgUQQ09ORl9GRUVfQVNTRVRfSwUIZmVlQXNzZXQJAMwIAgkBDEludGVnZXJFbnRyeQIFEUNPTkZfRkVFX0FNT1VOVF9LBQ9iYXNlMTBGZWVBbW91bnQFA25pbAEUc2V0Q29uZmlybWF0aW9uc0Z1bmMCEGNvbmZpcm1mcm9tV2F2ZXMOY29uZmlybWZyb21FdGgJAMwIAgkBDEludGVnZXJFbnRyeQIFH0NPTkZfQ09ORklSTUFUSU9OU19GUk9NX1dBVkVTX0sFEGNvbmZpcm1mcm9tV2F2ZXMJAMwIAgkBDEludGVnZXJFbnRyeQIFHUNPTkZfQ09ORklSTUFUSU9OU19GUk9NX0VUSF9LBQ5jb25maXJtZnJvbUV0aAUDbmlsARJzZXRBdXRvc3dhcEZlZUZ1bmMBC2F1dG9zd2FwRmVlCQDMCAIJAQxCb29sZWFuRW50cnkCBQ9DT05GX0FVVE9TV0FQX0sFC2F1dG9zd2FwRmVlBQNuaWwKAWkBBGluaXQLCWFkbWluQWRkcgpvcmFjbGVBZGRyDGFydHdvcmtzRGFwcAl1c2Vyc0RhcHAIZmVlQXNzZXQJZmVlQW1vdW50DHNpZ25Td29wRGFwcAtldGhTd29wRGFwcBBjb25maXJtZnJvbVdhdmVzDmNvbmZpcm1mcm9tRXRoC2F1dG9zd2FwRmVlAwkBCW93bmVyT25seQEFAWkEDHNldFN3b3BEYXBwcwkBEHNldFN3b3BEYXBwc0Z1bmMCBQxzaWduU3dvcERhcHAFC2V0aFN3b3BEYXBwBAZzZXRGZWUJAQpzZXRGZWVGdW5jAgUIZmVlQXNzZXQFCWZlZUFtb3VudAQQc2V0Q29uZmlybWF0aW9ucwkBFHNldENvbmZpcm1hdGlvbnNGdW5jAgUQY29uZmlybWZyb21XYXZlcwUOY29uZmlybWZyb21FdGgEDnNldEF1dG9zd2FwRmVlCQESc2V0QXV0b3N3YXBGZWVGdW5jAQULYXV0b3N3YXBGZWUJAM4IAgkAzggCCQDOCAIJAM4IAgkAzAgCCQELU3RyaW5nRW50cnkCBQtDT05GX0FNSU5fSwUJYWRtaW5BZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFDUNPTkZfT1JBQ0xFX0sFCm9yYWNsZUFkZHIJAMwIAgkBC1N0cmluZ0VudHJ5AgUTQ09ORl9BUlRXT1JLX0RBUFBfSwUMYXJ0d29ya3NEYXBwCQDMCAIJAQtTdHJpbmdFbnRyeQIFEUNPTkZfVVNFUlNfREFQUF9LBQl1c2Vyc0RhcHAJAMwIAgkBDEJvb2xlYW5FbnRyeQIFC0NPTkZfSU5JVF9LBgUDbmlsBQxzZXRTd29wRGFwcHMFBnNldEZlZQUQc2V0Q29uZmlybWF0aW9ucwUOc2V0QXV0b3N3YXBGZWUJAAIBAgtOb3QgYWxsb3dlZAFpAQxzZXRTd29wRGFwcHMCCHNpZ25EYXBwB2V0aERhcHADCQEJb3duZXJPbmx5AQUBaQkBEHNldFN3b3BEYXBwc0Z1bmMCBQhzaWduRGFwcAUHZXRoRGFwcAkAAgECC05vdCBhbGxvd2VkAWkBBnNldEZlZQIIZmVlQXNzZXQJZmVlQW1vdW50AwkBCW93bmVyT25seQEFAWkJAQpzZXRGZWVGdW5jAgUIZmVlQXNzZXQFCWZlZUFtb3VudAkAAgECC05vdCBhbGxvd2VkAWkBEHNldENvbmZpcm1hdGlvbnMCEGNvbmZpcm1mcm9tV2F2ZXMOY29uZmlybWZyb21FdGgDCQEJb3duZXJPbmx5AQUBaQkBFHNldENvbmZpcm1hdGlvbnNGdW5jAgUQY29uZmlybWZyb21XYXZlcwUOY29uZmlybWZyb21FdGgJAAIBAgtOb3QgYWxsb3dlZAFpAQ5zZXRBdXRvc3dhcEZlZQELYXV0b3N3YXBGZWUDCQEJb3duZXJPbmx5AQUBaQkBEnNldEF1dG9zd2FwRmVlRnVuYwEFC2F1dG9zd2FwRmVlCQACAQILTm90IGFsbG93ZWQBaQEEbG9jawIJcmVjaXBpZW50B25ldHdvcmsDCQEBIQEFBmlzSW5pdAkAAgECDmRBcHAgbm90IHJlYWR5AwkBASEBCQEPY29udGFpbnNFbGVtZW50AgUITkVUV09SS1MFB25ldHdvcmsJAAIBAhVOZXR3b3JrIG5vdCBzdXBwb3J0ZWQDCQEBIQEJAQxpc0V2bUFkZHJlc3MBBQlyZWNpcGllbnQJAAIBAhdXcm9uZyByZWNpcGllbnQgYWRkcmVzcwQLJHQwNzI2NDczMDMJAQxpZENhbGxlckRhdGUBBQFpBAJpZAgFCyR0MDcyNjQ3MzAzAl8xBAZjYWxsZXIIBQskdDA3MjY0NzMwMwJfMgQEZGF0ZQgFCyR0MDcyNjQ3MzAzAl8zBAskdDA3MzA2NzM4MwkBCWlzUGF5bWVudAEFAWkEC25mdF9wYXltZW50CAULJHQwNzMwNjczODMCXzEECm5mdF9hbW91bnQIBQskdDA3MzA2NzM4MwJfMgQPZ2F0ZXdheV9wYXltZW50CAULJHQwNzMwNjczODMCXzMEDmdhdGV3YXlfYW1vdW50CAULJHQwNzMwNjczODMCXzQDCQECIT0CBQpuZnRfYW1vdW50AAEJAAIBAg9ObyBORlQgYXR0YWNoZWQEBW5mdElkAwMJAQlpc0RlZmluZWQBCAULbmZ0X3BheW1lbnQHYXNzZXRJZAkBDGlzU2lnbkFydE5GVAEJAQV2YWx1ZQEIBQtuZnRfcGF5bWVudAdhc3NldElkBwkA2AQBCQEFdmFsdWUBCAULbmZ0X3BheW1lbnQHYXNzZXRJZAkAAgECG09ubHkgU0lHTiBBcnQgTkZUIGFjY2VwdGVkLgQLJHQwNzY3MDc3NTIJARNnZXRDcmVhdG9yRnJvbU5GVGlkAQUFbmZ0SWQEB2NyZWF0b3IIBQskdDA3NjcwNzc1MgJfMQQFYXJ0SWQIBQskdDA3NjcwNzc1MgJfMgMJAQEhAQkBDmlzVmFsaWRDcmVhdG9yAQkBEGdldENyZWF0b3JTdGF0dXMBBQdjcmVhdG9yCQACAQkArAICAhNDcmVhdG9yIHN0YXR1cyBpcyA6CQEQZ2V0Q3JlYXRvclN0YXR1cwEFB2NyZWF0b3IDCQEBIQEJAQppc1ZhbGlkQXJ0AQkBDGdldEFydFN0YXR1cwIFBWFydElkBQdjcmVhdG9yCQACAQkArAICAhNBcnR3b3JrIHN0YXR1cyBpcyA6CQEMZ2V0QXJ0U3RhdHVzAgUFYXJ0SWQFB2NyZWF0b3IECWVyYzIwQWRkcgkBE2dldENyZWF0b3JFUkMyMEFkZHIBBQdjcmVhdG9yAwkAAAIJALECAQUJZXJjMjBBZGRyAAAJAAIBAixUaGlzIGFydGlzdCBkaWRuJ3QgYWxsb3cgY3Jvc3NjaGFpbiB0cmFuc2ZlcgQJbmZ0U3RhdHVzCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQDAwkAAAIFCW5mdFN0YXR1cwUNc3RhdHVzX0xPQ0tFRAYJAAACBQluZnRTdGF0dXMFDnN0YXR1c19QRU5ESU5HCQACAQISTkZUIGFscmVhZHkgbG9ja2VkBA9nYXNGZWVOb25NaW50ZWQJARlnZXRJbnRlZ2VyQnlLZXlGcm9tT3JhY2xlAQUPa2V5RmVlTm9uTWludGVkBAxnYXNGZWVNaW50ZWQJARlnZXRJbnRlZ2VyQnlLZXlGcm9tT3JhY2xlAQUMa2V5RmVlTWludGVkBAhpc01pbnRlZAMJAAACBQluZnRTdGF0dXMFD3N0YXR1c19VTkxPQ0tFRAYHAwMJAQEhAQkBCWlzRGVmaW5lZAEIBQ9nYXRld2F5X3BheW1lbnQHYXNzZXRJZAYJAQIhPQIJANgEAQkBBXZhbHVlAQgFD2dhdGV3YXlfcGF5bWVudAdhc3NldElkBRBmZWVBY2NlcHRlZEFzc2V0CQACAQITV3JvbmcgcGF5bWVudCBhc3NldAMDBQhpc01pbnRlZAkAZgIFDmdhdGV3YXlfYW1vdW50CQBkAgUMZ2FzRmVlTWludGVkBRhmZWVBY2NlcHRlZEFtb3VudEZvclNpZ24HCQACAQIeV3JvbmcgcGF5bWVudCBhbW91bnQgdG8gdW5sb2NrAwMJAQEhAQUIaXNNaW50ZWQJAGYCBQ5nYXRld2F5X2Ftb3VudAkAZAIFD2dhc0ZlZU5vbk1pbnRlZAUYZmVlQWNjZXB0ZWRBbW91bnRGb3JTaWduBwkAAgECJ1dyb25nIHBheW1lbnQgYW1vdW50IHRvIG1pbnQgYW5kIHVubG9jawQQdXNkblRvU3dhcEZvckV0aAMFCGlzTWludGVkBQxnYXNGZWVNaW50ZWQFD2dhc0ZlZU5vbk1pbnRlZAQRc3dhcF91c2RuX3RvX3NpZ24DBQhhdXRvc3dhcAkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBCQEOZ2V0U3RyaW5nQnlLZXkBBRVDT05GX1NXT1BfU0lHTl9EQVBQX0sCCGV4Y2hhbmdlCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFEGZlZUFjY2VwdGVkQXNzZXQFGGZlZUFjY2VwdGVkQW1vdW50Rm9yU2lnbgUDbmlsBQR1bml0AwkAAAIFEXN3YXBfdXNkbl90b19zaWduBRFzd2FwX3VzZG5fdG9fc2lnbgQQc3dhcF91c2RuX3RvX2V0aAMFCGF1dG9zd2FwCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ5nZXRTdHJpbmdCeUtleQEFFENPTkZfU1dPUF9FVEhfREFQUF9LAghleGNoYW5nZQkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBRBmZWVBY2NlcHRlZEFzc2V0BRB1c2RuVG9Td2FwRm9yRXRoBQNuaWwFBHVuaXQDCQAAAgUQc3dhcF91c2RuX3RvX2V0aAUQc3dhcF91c2RuX3RvX2V0aAkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQFDnN0YXR1c19QRU5ESU5HCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQEOa2V5VHJhbnNmZXJORlQDBQVuZnRJZAUCaWQFBmNhbGxlcgIBXwUOc3RhdHVzX1BFTkRJTkcJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFCXJlY2lwaWVudAIBXwUHbmV0d29yawIBXwUGY2FsbGVyAgFfBQJpZAIBXwgJAQV2YWx1ZQEJAOwHAQkBBXZhbHVlAQgFC25mdF9wYXltZW50B2Fzc2V0SWQEbmFtZQIBXwkApAMBBQRkYXRlAgFfCQCkAwEFBmhlaWdodAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBC2NvbmZpcm1Mb2NrAwVuZnRJZAp0cmFuc2ZlcklkBmNhbGxlcgMJAQEhAQUGaXNJbml0CQACAQIOZEFwcCBub3QgcmVhZHkDCQEJb3duZXJPbmx5AQUBaQQJbmZ0U3RhdHVzCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQDCQECIT0CBQluZnRTdGF0dXMFDnN0YXR1c19QRU5ESU5HCQACAQIPTkZUIG5vdCBwZW5kaW5nBAN2YWwJAQ5nZXRTdHJpbmdCeUtleQEJAKwCAgkArAICCQEOa2V5VHJhbnNmZXJORlQDBQVuZnRJZAUKdHJhbnNmZXJJZAUGY2FsbGVyAgFfBQ5zdGF0dXNfUEVORElORwQGbmV3S2V5CQCsAgIJAKwCAgkBDmtleVRyYW5zZmVyTkZUAwUFbmZ0SWQFCnRyYW5zZmVySWQFBmNhbGxlcgIBXwUNc3RhdHVzX0NMT1NFRAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkBDmtleVRyYW5zZmVyTkZUAwUFbmZ0SWQFCnRyYW5zZmVySWQFBmNhbGxlcgIBXwUOc3RhdHVzX1BFTkRJTkcJAMwIAgkBC1N0cmluZ0VudHJ5AgUGbmV3S2V5BQN2YWwJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGtleU5GVHN0YXR1cwEFBW5mdElkBQ1zdGF0dXNfTE9DS0VEBQNuaWwJAAIBAgtOb3QgYWxsb3dlZAFpAQZ1bmxvY2sCCXJlY2lwaWVudAVuZnRJZAMJAQEhAQUGaXNJbml0CQACAQIOZEFwcCBub3QgcmVhZHkDCQEJb3duZXJPbmx5AQUBaQQJbmZ0U3RhdHVzCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQDCQECIT0CBQluZnRTdGF0dXMFDXN0YXR1c19MT0NLRUQJAAIBAilORlQgbm90IGxvY2tlZCwgZmluYWxpemUgZmlyc3QgaWYgcGVuZGluZwkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQFD3N0YXR1c19VTkxPQ0tFRAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQEHQWRkcmVzcwEJANkEAQUJcmVjaXBpZW50AAEJANkEAQUFbmZ0SWQFA25pbAkAAgECC05vdCBhbGxvd2VkAWkBCmFwcFJ1bm5pbmcCBmlzTGl2ZQdtZXNzYWdlAwkBASEBBQZpc0luaXQJAAIBAg5kQXBwIG5vdCByZWFkeQMJAQlvd25lck9ubHkBBQFpCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1kYXBwUnVubmluZ19LBQZpc0xpdmUJAMwIAgkBC1N0cmluZ0VudHJ5AgUQbWFpbnRlbmFuY2VNU0dfSwUHbWVzc2FnZQUDbmlsCQACAQIiWW91IGFyZSBub3QgYWxsb3dlZCB0byBjaGFuZ2UgdGhpcwFpAQtkZWxldGVFbnRyeQEFZW50cnkDCQEJb3duZXJPbmx5AQUBaQkAzAgCCQELRGVsZXRlRW50cnkBBQVlbnRyeQUDbmlsCQACAQICbm8Aat4MTQ==", "height": 3303874, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: 458jviEZEe8fGshyEmAd82jm9RvZRja18x8Sahdd3JHi Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let version = "1.0" | |
5 | + | ||
6 | + | let CONF_INIT_K = "config_init" | |
7 | + | ||
8 | + | let CONF_AMIN_K = "config_admin" | |
9 | + | ||
10 | + | let CONF_ORACLE_K = "config_oracle" | |
11 | + | ||
12 | + | let CONF_ARTWORK_DAPP_K = "config_artwork_dapp" | |
13 | + | ||
14 | + | let CONF_USERS_DAPP_K = "config_users_dapp" | |
15 | + | ||
16 | + | let CONF_FEE_ASSET_K = "config_fee_asset" | |
17 | + | ||
18 | + | let CONF_FEE_AMOUNT_K = "config_fee_amount" | |
19 | + | ||
20 | + | let CONF_SWOP_SIGN_DAPP_K = "config_swop_sign_dapp" | |
21 | + | ||
22 | + | let CONF_SWOP_ETH_DAPP_K = "config_swop_eth_dapp" | |
23 | + | ||
24 | + | let CONF_CONFIRMATIONS_FROM_WAVES_K = "config_confirmations_from_waves" | |
25 | + | ||
26 | + | let CONF_CONFIRMATIONS_FROM_ETH_K = "config_confirmations_from_eth" | |
27 | + | ||
28 | + | let CONF_AUTOSWAP_K = "config_autoswap" | |
29 | + | ||
30 | + | let dappRunning_K = "conf_dapp_is_running" | |
31 | + | ||
32 | + | let maintenanceMSG_K = "conf_maintenance_msg" | |
33 | + | ||
34 | + | let dappRunning = valueOrElse(getBoolean(this, dappRunning_K), true) | |
35 | + | ||
36 | + | let maintenanceMSG = valueOrElse(getString(this, maintenanceMSG_K), "") | |
37 | + | ||
38 | + | let status_LOCKED = "LOCKED" | |
39 | + | ||
40 | + | let status_UNLOCKED = "UNLOCKED" | |
41 | + | ||
42 | + | let status_PENDING = "PENDING" | |
43 | + | ||
44 | + | let status_CLOSED = "CLOSED" | |
45 | + | ||
46 | + | let creatorRegistered = "REGISTERED" | |
47 | + | ||
48 | + | let creatorVerified = "VERIFIED" | |
49 | + | ||
50 | + | let artFlagged = "FLAGGED" | |
51 | + | ||
52 | + | let artIllegal = "ILLEGAL" | |
53 | + | ||
54 | + | let artPending = "CHANGE_REQUIRED" | |
55 | + | ||
56 | + | let NETWORKS = ["ETH"] | |
57 | + | ||
58 | + | func keyNFTstatus (nftId) = (("nft_" + nftId) + "_status") | |
59 | + | ||
60 | + | ||
61 | + | func keyTransferNFT (nftId,txid,caller) = ((((("transfer_" + nftId) + "_") + txid) + "_") + caller) | |
62 | + | ||
63 | + | ||
64 | + | let keyFeeNonMinted = "cost_non_minted" | |
65 | + | ||
66 | + | let keyFeeMinted = "cost_minted" | |
67 | + | ||
68 | + | func getStringByKey (key) = valueOrElse(getString(this, key), "") | |
69 | + | ||
70 | + | ||
71 | + | func getIntegerByKey (key) = valueOrElse(getInteger(this, key), 0) | |
72 | + | ||
73 | + | ||
74 | + | func getBooleanByKey (key) = valueOrElse(getBoolean(this, key), false) | |
75 | + | ||
76 | + | ||
77 | + | let admin = value(addressFromStringValue(getStringByKey(CONF_AMIN_K))) | |
78 | + | ||
79 | + | let artworksDapp = value(addressFromString(getStringByKey(CONF_ARTWORK_DAPP_K))) | |
80 | + | ||
81 | + | let usersDapp = value(addressFromString(getStringByKey(CONF_USERS_DAPP_K))) | |
82 | + | ||
83 | + | let oracleAddr = value(addressFromString(getStringByKey(CONF_ORACLE_K))) | |
84 | + | ||
85 | + | let autoswap = valueOrElse(getBooleanByKey(CONF_AUTOSWAP_K), false) | |
86 | + | ||
87 | + | let feeAcceptedAsset = getStringByKey(CONF_FEE_ASSET_K) | |
88 | + | ||
89 | + | let feeAcceptedAmountForSign = getIntegerByKey(CONF_FEE_AMOUNT_K) | |
90 | + | ||
91 | + | func getStringFromUsersByKey (key) = valueOrElse(getString(usersDapp, key), "") | |
92 | + | ||
93 | + | ||
94 | + | func getStringFromArtworksByKey (key) = valueOrElse(getString(artworksDapp, key), "") | |
95 | + | ||
96 | + | ||
97 | + | func getIntegerByKeyFromOracle (key) = valueOrErrorMessage(getInteger(oracleAddr, key), "Integer undefined in oracle") | |
98 | + | ||
99 | + | ||
100 | + | func assetIsValid (assetDetails) = if (if (if ((assetDetails.quantity == 1)) | |
101 | + | then (assetDetails.decimals == 0) | |
102 | + | else false) | |
103 | + | then (assetDetails.reissuable == false) | |
104 | + | else false) | |
105 | + | then (assetDetails.issuer == artworksDapp) | |
106 | + | else false | |
107 | + | ||
108 | + | ||
109 | + | func isSignArtNFT (id) = { | |
110 | + | let assetDetails = value(assetInfo(id)) | |
111 | + | assetIsValid(assetDetails) | |
112 | + | } | |
113 | + | ||
114 | + | ||
115 | + | func isPayment (i) = if ((size(i.payments) != 2)) | |
116 | + | then throw("Need to attach 2 payments") | |
117 | + | else { | |
118 | + | let nft_payment = value(i.payments[0]) | |
119 | + | let nft_amount = value(nft_payment.amount) | |
120 | + | let gateway_payment = value(i.payments[1]) | |
121 | + | let gateway_amount = value(gateway_payment.amount) | |
122 | + | $Tuple4(nft_payment, nft_amount, gateway_payment, gateway_amount) | |
123 | + | } | |
124 | + | ||
125 | + | ||
126 | + | let isInit = valueOrElse(getBooleanByKey(CONF_INIT_K), false) | |
127 | + | ||
128 | + | func ownerOnly (i) = { | |
129 | + | let caller = toString(i.caller) | |
130 | + | let id = toBase58String(i.transactionId) | |
131 | + | let allowedArr = if (isInit) | |
132 | + | then [toString(admin), toString(this)] | |
133 | + | else [toString(this)] | |
134 | + | containsElement(allowedArr, caller) | |
135 | + | } | |
136 | + | ||
137 | + | ||
138 | + | func idCallerDate (i) = if (!(dappRunning)) | |
139 | + | then throw(maintenanceMSG) | |
140 | + | else $Tuple3(toBase58String(i.transactionId), toBase58String(i.caller.bytes), lastBlock.timestamp) | |
141 | + | ||
142 | + | ||
143 | + | func getCreatorFromNFTid (nftid) = { | |
144 | + | let nftData = getStringFromArtworksByKey(("nft_" + nftid)) | |
145 | + | let creator = split(nftData, "_")[6] | |
146 | + | let artId = split(nftData, "_")[5] | |
147 | + | $Tuple2(creator, artId) | |
148 | + | } | |
149 | + | ||
150 | + | ||
151 | + | func getCreatorERC20Addr (addr) = getStringFromUsersByKey(("user_ERC20_" + addr)) | |
152 | + | ||
153 | + | ||
154 | + | func getCreatorStatus (addr) = getStringFromUsersByKey(("user_status_" + addr)) | |
155 | + | ||
156 | + | ||
157 | + | func getArtStatus (artId,addr) = getStringFromArtworksByKey(((("art_flag_" + artId) + "_") + addr)) | |
158 | + | ||
159 | + | ||
160 | + | func isValidCreator (status) = if ((status == creatorRegistered)) | |
161 | + | then true | |
162 | + | else (status == creatorVerified) | |
163 | + | ||
164 | + | ||
165 | + | func isValidArt (status) = if (if ((status != artFlagged)) | |
166 | + | then (status != artIllegal) | |
167 | + | else false) | |
168 | + | then (status != artPending) | |
169 | + | else false | |
170 | + | ||
171 | + | ||
172 | + | func isEvmAddress (addr) = if ((size(addr) == 42)) | |
173 | + | then (take(addr, 2) == "0x") | |
174 | + | else false | |
175 | + | ||
176 | + | ||
177 | + | func setSwopDappsFunc (signDapp,ethDapp) = [StringEntry(CONF_SWOP_SIGN_DAPP_K, signDapp), StringEntry(CONF_SWOP_ETH_DAPP_K, ethDapp)] | |
178 | + | ||
179 | + | ||
180 | + | func setFeeFunc (feeAsset,feeAmount) = { | |
181 | + | let assetDetails = assetInfo(fromBase58String(feeAsset)) | |
182 | + | let decimal = value(assetDetails).decimals | |
183 | + | let base10FeeAmount = pow(feeAmount, 0, 10, 1, decimal, HALFUP) | |
184 | + | [StringEntry(CONF_FEE_ASSET_K, feeAsset), IntegerEntry(CONF_FEE_AMOUNT_K, base10FeeAmount)] | |
185 | + | } | |
186 | + | ||
187 | + | ||
188 | + | func setConfirmationsFunc (confirmfromWaves,confirmfromEth) = [IntegerEntry(CONF_CONFIRMATIONS_FROM_WAVES_K, confirmfromWaves), IntegerEntry(CONF_CONFIRMATIONS_FROM_ETH_K, confirmfromEth)] | |
189 | + | ||
190 | + | ||
191 | + | func setAutoswapFeeFunc (autoswapFee) = [BooleanEntry(CONF_AUTOSWAP_K, autoswapFee)] | |
192 | + | ||
193 | + | ||
194 | + | @Callable(i) | |
195 | + | func init (adminAddr,oracleAddr,artworksDapp,usersDapp,feeAsset,feeAmount,signSwopDapp,ethSwopDapp,confirmfromWaves,confirmfromEth,autoswapFee) = if (ownerOnly(i)) | |
196 | + | then { | |
197 | + | let setSwopDapps = setSwopDappsFunc(signSwopDapp, ethSwopDapp) | |
198 | + | let setFee = setFeeFunc(feeAsset, feeAmount) | |
199 | + | let setConfirmations = setConfirmationsFunc(confirmfromWaves, confirmfromEth) | |
200 | + | let setAutoswapFee = setAutoswapFeeFunc(autoswapFee) | |
201 | + | (((([StringEntry(CONF_AMIN_K, adminAddr), StringEntry(CONF_ORACLE_K, oracleAddr), StringEntry(CONF_ARTWORK_DAPP_K, artworksDapp), StringEntry(CONF_USERS_DAPP_K, usersDapp), BooleanEntry(CONF_INIT_K, true)] ++ setSwopDapps) ++ setFee) ++ setConfirmations) ++ setAutoswapFee) | |
202 | + | } | |
203 | + | else throw("Not allowed") | |
204 | + | ||
205 | + | ||
206 | + | ||
207 | + | @Callable(i) | |
208 | + | func setSwopDapps (signDapp,ethDapp) = if (ownerOnly(i)) | |
209 | + | then setSwopDappsFunc(signDapp, ethDapp) | |
210 | + | else throw("Not allowed") | |
211 | + | ||
212 | + | ||
213 | + | ||
214 | + | @Callable(i) | |
215 | + | func setFee (feeAsset,feeAmount) = if (ownerOnly(i)) | |
216 | + | then setFeeFunc(feeAsset, feeAmount) | |
217 | + | else throw("Not allowed") | |
218 | + | ||
219 | + | ||
220 | + | ||
221 | + | @Callable(i) | |
222 | + | func setConfirmations (confirmfromWaves,confirmfromEth) = if (ownerOnly(i)) | |
223 | + | then setConfirmationsFunc(confirmfromWaves, confirmfromEth) | |
224 | + | else throw("Not allowed") | |
225 | + | ||
226 | + | ||
227 | + | ||
228 | + | @Callable(i) | |
229 | + | func setAutoswapFee (autoswapFee) = if (ownerOnly(i)) | |
230 | + | then setAutoswapFeeFunc(autoswapFee) | |
231 | + | else throw("Not allowed") | |
232 | + | ||
233 | + | ||
234 | + | ||
235 | + | @Callable(i) | |
236 | + | func lock (recipient,network) = if (!(isInit)) | |
237 | + | then throw("dApp not ready") | |
238 | + | else if (!(containsElement(NETWORKS, network))) | |
239 | + | then throw("Network not supported") | |
240 | + | else if (!(isEvmAddress(recipient))) | |
241 | + | then throw("Wrong recipient address") | |
242 | + | else { | |
243 | + | let $t072647303 = idCallerDate(i) | |
244 | + | let id = $t072647303._1 | |
245 | + | let caller = $t072647303._2 | |
246 | + | let date = $t072647303._3 | |
247 | + | let $t073067383 = isPayment(i) | |
248 | + | let nft_payment = $t073067383._1 | |
249 | + | let nft_amount = $t073067383._2 | |
250 | + | let gateway_payment = $t073067383._3 | |
251 | + | let gateway_amount = $t073067383._4 | |
252 | + | if ((nft_amount != 1)) | |
253 | + | then throw("No NFT attached") | |
254 | + | else { | |
255 | + | let nftId = if (if (isDefined(nft_payment.assetId)) | |
256 | + | then isSignArtNFT(value(nft_payment.assetId)) | |
257 | + | else false) | |
258 | + | then toBase58String(value(nft_payment.assetId)) | |
259 | + | else throw("Only SIGN Art NFT accepted.") | |
260 | + | let $t076707752 = getCreatorFromNFTid(nftId) | |
261 | + | let creator = $t076707752._1 | |
262 | + | let artId = $t076707752._2 | |
263 | + | if (!(isValidCreator(getCreatorStatus(creator)))) | |
264 | + | then throw(("Creator status is :" + getCreatorStatus(creator))) | |
265 | + | else if (!(isValidArt(getArtStatus(artId, creator)))) | |
266 | + | then throw(("Artwork status is :" + getArtStatus(artId, creator))) | |
267 | + | else { | |
268 | + | let erc20Addr = getCreatorERC20Addr(creator) | |
269 | + | if ((size(erc20Addr) == 0)) | |
270 | + | then throw("This artist didn't allow crosschain transfer") | |
271 | + | else { | |
272 | + | let nftStatus = getStringByKey(keyNFTstatus(nftId)) | |
273 | + | if (if ((nftStatus == status_LOCKED)) | |
274 | + | then true | |
275 | + | else (nftStatus == status_PENDING)) | |
276 | + | then throw("NFT already locked") | |
277 | + | else { | |
278 | + | let gasFeeNonMinted = getIntegerByKeyFromOracle(keyFeeNonMinted) | |
279 | + | let gasFeeMinted = getIntegerByKeyFromOracle(keyFeeMinted) | |
280 | + | let isMinted = if ((nftStatus == status_UNLOCKED)) | |
281 | + | then true | |
282 | + | else false | |
283 | + | if (if (!(isDefined(gateway_payment.assetId))) | |
284 | + | then true | |
285 | + | else (toBase58String(value(gateway_payment.assetId)) != feeAcceptedAsset)) | |
286 | + | then throw("Wrong payment asset") | |
287 | + | else if (if (isMinted) | |
288 | + | then (gateway_amount > (gasFeeMinted + feeAcceptedAmountForSign)) | |
289 | + | else false) | |
290 | + | then throw("Wrong payment amount to unlock") | |
291 | + | else if (if (!(isMinted)) | |
292 | + | then (gateway_amount > (gasFeeNonMinted + feeAcceptedAmountForSign)) | |
293 | + | else false) | |
294 | + | then throw("Wrong payment amount to mint and unlock") | |
295 | + | else { | |
296 | + | let usdnToSwapForEth = if (isMinted) | |
297 | + | then gasFeeMinted | |
298 | + | else gasFeeNonMinted | |
299 | + | let swap_usdn_to_sign = if (autoswap) | |
300 | + | then invoke(addressFromStringValue(getStringByKey(CONF_SWOP_SIGN_DAPP_K)), "exchange", [1], [AttachedPayment(fromBase58String(feeAcceptedAsset), feeAcceptedAmountForSign)]) | |
301 | + | else unit | |
302 | + | if ((swap_usdn_to_sign == swap_usdn_to_sign)) | |
303 | + | then { | |
304 | + | let swap_usdn_to_eth = if (autoswap) | |
305 | + | then invoke(addressFromStringValue(getStringByKey(CONF_SWOP_ETH_DAPP_K)), "exchange", [1], [AttachedPayment(fromBase58String(feeAcceptedAsset), usdnToSwapForEth)]) | |
306 | + | else unit | |
307 | + | if ((swap_usdn_to_eth == swap_usdn_to_eth)) | |
308 | + | then [StringEntry(keyNFTstatus(nftId), status_PENDING), StringEntry(((keyTransferNFT(nftId, id, caller) + "_") + status_PENDING), ((((((((((((recipient + "_") + network) + "_") + caller) + "_") + id) + "_") + value(assetInfo(value(nft_payment.assetId))).name) + "_") + toString(date)) + "_") + toString(height)))] | |
309 | + | else throw("Strict value is not equal to itself.") | |
310 | + | } | |
311 | + | else throw("Strict value is not equal to itself.") | |
312 | + | } | |
313 | + | } | |
314 | + | } | |
315 | + | } | |
316 | + | } | |
317 | + | } | |
318 | + | ||
319 | + | ||
320 | + | ||
321 | + | @Callable(i) | |
322 | + | func confirmLock (nftId,transferId,caller) = if (!(isInit)) | |
323 | + | then throw("dApp not ready") | |
324 | + | else if (ownerOnly(i)) | |
325 | + | then { | |
326 | + | let nftStatus = getStringByKey(keyNFTstatus(nftId)) | |
327 | + | if ((nftStatus != status_PENDING)) | |
328 | + | then throw("NFT not pending") | |
329 | + | else { | |
330 | + | let val = getStringByKey(((keyTransferNFT(nftId, transferId, caller) + "_") + status_PENDING)) | |
331 | + | let newKey = ((keyTransferNFT(nftId, transferId, caller) + "_") + status_CLOSED) | |
332 | + | [DeleteEntry(((keyTransferNFT(nftId, transferId, caller) + "_") + status_PENDING)), StringEntry(newKey, val), StringEntry(keyNFTstatus(nftId), status_LOCKED)] | |
333 | + | } | |
334 | + | } | |
335 | + | else throw("Not allowed") | |
336 | + | ||
337 | + | ||
338 | + | ||
339 | + | @Callable(i) | |
340 | + | func unlock (recipient,nftId) = if (!(isInit)) | |
341 | + | then throw("dApp not ready") | |
342 | + | else if (ownerOnly(i)) | |
343 | + | then { | |
344 | + | let nftStatus = getStringByKey(keyNFTstatus(nftId)) | |
345 | + | if ((nftStatus != status_LOCKED)) | |
346 | + | then throw("NFT not locked, finalize first if pending") | |
347 | + | else [StringEntry(keyNFTstatus(nftId), status_UNLOCKED), ScriptTransfer(Address(fromBase58String(recipient)), 1, fromBase58String(nftId))] | |
348 | + | } | |
349 | + | else throw("Not allowed") | |
350 | + | ||
351 | + | ||
352 | + | ||
353 | + | @Callable(i) | |
354 | + | func appRunning (isLive,message) = if (!(isInit)) | |
355 | + | then throw("dApp not ready") | |
356 | + | else if (ownerOnly(i)) | |
357 | + | then [BooleanEntry(dappRunning_K, isLive), StringEntry(maintenanceMSG_K, message)] | |
358 | + | else throw("You are not allowed to change this") | |
359 | + | ||
360 | + | ||
361 | + | ||
362 | + | @Callable(i) | |
363 | + | func deleteEntry (entry) = if (ownerOnly(i)) | |
364 | + | then [DeleteEntry(entry)] | |
365 | + | else throw("no") | |
366 | + | ||
367 | + |
github/deemru/w8io/6500d08 41.15 ms ◑