tx · GbwnEtRJYeZa6jmJPJkoEM3pHCJtPLUtjFZawSzfkJ4L

3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ:  -0.01400000 Waves

2022.10.01 13:52 [3318675] smart account 3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ > SELF 0.00000000 Waves

{ "type": 13, "id": "GbwnEtRJYeZa6jmJPJkoEM3pHCJtPLUtjFZawSzfkJ4L", "fee": 1400000, "feeAssetId": null, "timestamp": 1664621625402, "version": 2, "chainId": 87, "sender": "3P2qFiXmUQnGV8iAd9DwC732DdBtQVMigTZ", "senderPublicKey": "Gczkhukah6ZwryrD6feHYGNGJ4yEoXoELZTTmjFGbbDp", "proofs": [ "27gHyvfSkMvN4WGdkXPMmix5qCFuvwkm6QqynBPV4yp9ByKjNiF9sWLqob6Q6n28YidYibTRZDUUwkxUuJ21AjFg" ], "script": "base64:BgJMCAISDgoMCAgICAgBCAgBAQQIEgQKAggIEgQKAggBEgMKAQgSBAoCAQESAwoBBBIECgIICBIFCgMICAgSBAoCCAgSBAoCBAgSAwoBCEAAB3ZlcnNpb24CBTEuMC4xAAtDT05GX0lOSVRfSwILY29uZmlnX2luaXQAC0NPTkZfQU1JTl9LAgxjb25maWdfYWRtaW4ADUNPTkZfT1JBQ0xFX0sCDWNvbmZpZ19vcmFjbGUAE0NPTkZfRkVFX1JFQ0VJVkVSX0sCE2NvbmZpZ19mZWVfcmVjZWl2ZXIAE0NPTkZfQVJUV09SS19EQVBQX0sCE2NvbmZpZ19hcnR3b3JrX2RhcHAAEUNPTkZfVVNFUlNfREFQUF9LAhFjb25maWdfdXNlcnNfZGFwcAAQQ09ORl9GRUVfQVNTRVRfSwIQY29uZmlnX2ZlZV9hc3NldAARQ09ORl9GRUVfQU1PVU5UX0sCEWNvbmZpZ19mZWVfYW1vdW50ABVDT05GX1NXT1BfU0lHTl9EQVBQX0sCFWNvbmZpZ19zd29wX3NpZ25fZGFwcAAUQ09ORl9TV09QX0VUSF9EQVBQX0sCFGNvbmZpZ19zd29wX2V0aF9kYXBwAB9DT05GX0NPTkZJUk1BVElPTlNfRlJPTV9XQVZFU19LAh9jb25maWdfY29uZmlybWF0aW9uc19mcm9tX3dhdmVzAB1DT05GX0NPTkZJUk1BVElPTlNfRlJPTV9FVEhfSwIdY29uZmlnX2NvbmZpcm1hdGlvbnNfZnJvbV9ldGgAD0NPTkZfQVVUT1NXQVBfSwIPY29uZmlnX2F1dG9zd2FwAA1kYXBwUnVubmluZ19LAhRjb25mX2RhcHBfaXNfcnVubmluZwAQbWFpbnRlbmFuY2VNU0dfSwIUY29uZl9tYWludGVuYW5jZV9tc2cAC2RhcHBSdW5uaW5nCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWRhcHBSdW5uaW5nX0sGAA5tYWludGVuYW5jZU1TRwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBRBtYWludGVuYW5jZU1TR19LAgAADXN0YXR1c19MT0NLRUQCBkxPQ0tFRAAPc3RhdHVzX1VOTE9DS0VEAghVTkxPQ0tFRAAOc3RhdHVzX1BFTkRJTkcCB1BFTkRJTkcADXN0YXR1c19DTE9TRUQCBkNMT1NFRAARY3JlYXRvclJlZ2lzdGVyZWQCClJFR0lTVEVSRUQAD2NyZWF0b3JWZXJpZmllZAIIVkVSSUZJRUQACmFydEZsYWdnZWQCB0ZMQUdHRUQACmFydElsbGVnYWwCB0lMTEVHQUwACmFydFBlbmRpbmcCD0NIQU5HRV9SRVFVSVJFRAAITkVUV09SS1MJAMwIAgIDRVRIBQNuaWwBDGtleU5GVHN0YXR1cwEFbmZ0SWQJAKwCAgkArAICAgRuZnRfBQVuZnRJZAIHX3N0YXR1cwEOa2V5VHJhbnNmZXJORlQDBW5mdElkBHR4aWQGY2FsbGVyCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIJdHJhbnNmZXJfBQVuZnRJZAIBXwUEdHhpZAIBXwUGY2FsbGVyAA9rZXlGZWVOb25NaW50ZWQCD2Nvc3Rfbm9uX21pbnRlZAAMa2V5RmVlTWludGVkAgtjb3N0X21pbnRlZAEOZ2V0U3RyaW5nQnlLZXkBA2tleQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQNrZXkCAAEPZ2V0SW50ZWdlckJ5S2V5AQNrZXkJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUDa2V5AAABD2dldEJvb2xlYW5CeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFA2tleQcABWFkbWluCQEFdmFsdWUBCQERQGV4dHJOYXRpdmUoMTA2MikBCQEOZ2V0U3RyaW5nQnlLZXkBBQtDT05GX0FNSU5fSwALZmVlUmVjZWl2ZXIJAQV2YWx1ZQEJAKYIAQkBDmdldFN0cmluZ0J5S2V5AQUTQ09ORl9GRUVfUkVDRUlWRVJfSwAMYXJ0d29ya3NEYXBwCQEFdmFsdWUBCQCmCAEJAQ5nZXRTdHJpbmdCeUtleQEFE0NPTkZfQVJUV09SS19EQVBQX0sACXVzZXJzRGFwcAkBBXZhbHVlAQkApggBCQEOZ2V0U3RyaW5nQnlLZXkBBRFDT05GX1VTRVJTX0RBUFBfSwAKb3JhY2xlQWRkcgkBBXZhbHVlAQkApggBCQEOZ2V0U3RyaW5nQnlLZXkBBQ1DT05GX09SQUNMRV9LAAhhdXRvc3dhcAkBC3ZhbHVlT3JFbHNlAgkBD2dldEJvb2xlYW5CeUtleQEFD0NPTkZfQVVUT1NXQVBfSwcAEGZlZUFjY2VwdGVkQXNzZXQJAQ5nZXRTdHJpbmdCeUtleQEFEENPTkZfRkVFX0FTU0VUX0sAGGZlZUFjY2VwdGVkQW1vdW50Rm9yU2lnbgkBD2dldEludGVnZXJCeUtleQEFEUNPTkZfRkVFX0FNT1VOVF9LARdnZXRTdHJpbmdGcm9tVXNlcnNCeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCdCAIFCXVzZXJzRGFwcAUDa2V5AgABGmdldFN0cmluZ0Zyb21BcnR3b3Jrc0J5S2V5AQNrZXkJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUMYXJ0d29ya3NEYXBwBQNrZXkCAAEZZ2V0SW50ZWdlckJ5S2V5RnJvbU9yYWNsZQEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUKb3JhY2xlQWRkcgUDa2V5AhtJbnRlZ2VyIHVuZGVmaW5lZCBpbiBvcmFjbGUBDGFzc2V0SXNWYWxpZAEMYXNzZXREZXRhaWxzAwMDCQAAAggFDGFzc2V0RGV0YWlscwhxdWFudGl0eQABCQAAAggFDGFzc2V0RGV0YWlscwhkZWNpbWFscwAABwkAAAIIBQxhc3NldERldGFpbHMKcmVpc3N1YWJsZQcHCQAAAggFDGFzc2V0RGV0YWlscwZpc3N1ZXIFDGFydHdvcmtzRGFwcAcBDGlzU2lnbkFydE5GVAECaWQEDGFzc2V0RGV0YWlscwkBBXZhbHVlAQkA7AcBBQJpZAkBDGFzc2V0SXNWYWxpZAEFDGFzc2V0RGV0YWlscwEJaXNQYXltZW50AQFpAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwACCQACAQIZTmVlZCB0byBhdHRhY2ggMiBwYXltZW50cwQLbmZ0X3BheW1lbnQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQKbmZ0X2Ftb3VudAkBBXZhbHVlAQgFC25mdF9wYXltZW50BmFtb3VudAQPZ2F0ZXdheV9wYXltZW50CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAEEDmdhdGV3YXlfYW1vdW50CQEFdmFsdWUBCAUPZ2F0ZXdheV9wYXltZW50BmFtb3VudAkAlgoEBQtuZnRfcGF5bWVudAUKbmZ0X2Ftb3VudAUPZ2F0ZXdheV9wYXltZW50BQ5nYXRld2F5X2Ftb3VudAAGaXNJbml0CQELdmFsdWVPckVsc2UCCQEPZ2V0Qm9vbGVhbkJ5S2V5AQULQ09ORl9JTklUX0sHAQlvd25lck9ubHkBAWkEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIEAmlkCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQECmFsbG93ZWRBcnIDBQZpc0luaXQJAMwIAgkApQgBBQVhZG1pbgkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQClCAEFBHRoaXMFA25pbAkBD2NvbnRhaW5zRWxlbWVudAIFCmFsbG93ZWRBcnIFBmNhbGxlcgEMaWRDYWxsZXJEYXRlAQFpAwkBASEBBQtkYXBwUnVubmluZwkAAgEFDm1haW50ZW5hbmNlTVNHCQCVCgMJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAETZ2V0Q3JlYXRvckZyb21ORlRpZAEFbmZ0aWQEB25mdERhdGEJARpnZXRTdHJpbmdGcm9tQXJ0d29ya3NCeUtleQEJAKwCAgIEbmZ0XwUFbmZ0aWQEB2NyZWF0b3IJAJEDAgkAtQkCBQduZnREYXRhAgFfAAYEBWFydElkCQCRAwIJALUJAgUHbmZ0RGF0YQIBXwAFCQCUCgIFB2NyZWF0b3IFBWFydElkARNnZXRDcmVhdG9yRVJDMjBBZGRyAQRhZGRyCQEXZ2V0U3RyaW5nRnJvbVVzZXJzQnlLZXkBCQCsAgICC3VzZXJfRVJDMjBfBQRhZGRyARBnZXRDcmVhdG9yU3RhdHVzAQRhZGRyCQEXZ2V0U3RyaW5nRnJvbVVzZXJzQnlLZXkBCQCsAgICDHVzZXJfc3RhdHVzXwUEYWRkcgEMZ2V0QXJ0U3RhdHVzAgVhcnRJZARhZGRyCQEaZ2V0U3RyaW5nRnJvbUFydHdvcmtzQnlLZXkBCQCsAgIJAKwCAgkArAICAglhcnRfZmxhZ18FBWFydElkAgFfBQRhZGRyAQ5pc1ZhbGlkQ3JlYXRvcgEGc3RhdHVzAwkAAAIFBnN0YXR1cwURY3JlYXRvclJlZ2lzdGVyZWQGCQAAAgUGc3RhdHVzBQ9jcmVhdG9yVmVyaWZpZWQBCmlzVmFsaWRBcnQBBnN0YXR1cwMDCQECIT0CBQZzdGF0dXMFCmFydEZsYWdnZWQJAQIhPQIFBnN0YXR1cwUKYXJ0SWxsZWdhbAcJAQIhPQIFBnN0YXR1cwUKYXJ0UGVuZGluZwcBDGlzRXZtQWRkcmVzcwEEYWRkcgMJAAACCQCxAgEFBGFkZHIAKgkAAAIJAK8CAgUEYWRkcgACAgIweAcBEHNldFN3b3BEYXBwc0Z1bmMCCHNpZ25EYXBwB2V0aERhcHAJAMwIAgkBC1N0cmluZ0VudHJ5AgUVQ09ORl9TV09QX1NJR05fREFQUF9LBQhzaWduRGFwcAkAzAgCCQELU3RyaW5nRW50cnkCBRRDT05GX1NXT1BfRVRIX0RBUFBfSwUHZXRoRGFwcAUDbmlsARJzZXRGZWVSZWNlaXZlckZ1bmMBBGFkZHIJAMwIAgkBC1N0cmluZ0VudHJ5AgUTQ09ORl9GRUVfUkVDRUlWRVJfSwUEYWRkcgUDbmlsAQpzZXRGZWVGdW5jAghmZWVBc3NldAlmZWVBbW91bnQEDGFzc2V0RGV0YWlscwkA7AcBCQDZBAEFCGZlZUFzc2V0BAdkZWNpbWFsCAkBBXZhbHVlAQUMYXNzZXREZXRhaWxzCGRlY2ltYWxzBA9iYXNlMTBGZWVBbW91bnQJAGwGBQlmZWVBbW91bnQAAAAKAAEFB2RlY2ltYWwFBkhBTEZVUAkAzAgCCQELU3RyaW5nRW50cnkCBRBDT05GX0ZFRV9BU1NFVF9LBQhmZWVBc3NldAkAzAgCCQEMSW50ZWdlckVudHJ5AgURQ09ORl9GRUVfQU1PVU5UX0sFD2Jhc2UxMEZlZUFtb3VudAUDbmlsARRzZXRDb25maXJtYXRpb25zRnVuYwIQY29uZmlybWZyb21XYXZlcw5jb25maXJtZnJvbUV0aAkAzAgCCQEMSW50ZWdlckVudHJ5AgUfQ09ORl9DT05GSVJNQVRJT05TX0ZST01fV0FWRVNfSwUQY29uZmlybWZyb21XYXZlcwkAzAgCCQEMSW50ZWdlckVudHJ5AgUdQ09ORl9DT05GSVJNQVRJT05TX0ZST01fRVRIX0sFDmNvbmZpcm1mcm9tRXRoBQNuaWwBEnNldEF1dG9zd2FwRmVlRnVuYwELYXV0b3N3YXBGZWUJAMwIAgkBDEJvb2xlYW5FbnRyeQIFD0NPTkZfQVVUT1NXQVBfSwULYXV0b3N3YXBGZWUFA25pbAsBaQEEaW5pdAwJYWRtaW5BZGRyCm9yYWNsZUFkZHIMYXJ0d29ya3NEYXBwCXVzZXJzRGFwcAhmZWVBc3NldAlmZWVBbW91bnQMc2lnblN3b3BEYXBwC2V0aFN3b3BEYXBwEGNvbmZpcm1mcm9tV2F2ZXMOY29uZmlybWZyb21FdGgLYXV0b3N3YXBGZWUPZmVlUmVjZWl2ZXJBZGRyAwkBCW93bmVyT25seQEFAWkEDHNldFN3b3BEYXBwcwkBEHNldFN3b3BEYXBwc0Z1bmMCBQxzaWduU3dvcERhcHAFC2V0aFN3b3BEYXBwBAZzZXRGZWUJAQpzZXRGZWVGdW5jAgUIZmVlQXNzZXQFCWZlZUFtb3VudAQOc2V0RmVlUmVjZWl2ZXIJARJzZXRGZWVSZWNlaXZlckZ1bmMBBQ9mZWVSZWNlaXZlckFkZHIEEHNldENvbmZpcm1hdGlvbnMJARRzZXRDb25maXJtYXRpb25zRnVuYwIFEGNvbmZpcm1mcm9tV2F2ZXMFDmNvbmZpcm1mcm9tRXRoBA5zZXRBdXRvc3dhcEZlZQkBEnNldEF1dG9zd2FwRmVlRnVuYwEFC2F1dG9zd2FwRmVlCQDOCAIJAM4IAgkAzggCCQDOCAIJAM4IAgkAzAgCCQELU3RyaW5nRW50cnkCBQtDT05GX0FNSU5fSwUJYWRtaW5BZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFDUNPTkZfT1JBQ0xFX0sFCm9yYWNsZUFkZHIJAMwIAgkBC1N0cmluZ0VudHJ5AgUTQ09ORl9BUlRXT1JLX0RBUFBfSwUMYXJ0d29ya3NEYXBwCQDMCAIJAQtTdHJpbmdFbnRyeQIFEUNPTkZfVVNFUlNfREFQUF9LBQl1c2Vyc0RhcHAJAMwIAgkBDEJvb2xlYW5FbnRyeQIFC0NPTkZfSU5JVF9LBgUDbmlsBQxzZXRTd29wRGFwcHMFDnNldEZlZVJlY2VpdmVyBQZzZXRGZWUFEHNldENvbmZpcm1hdGlvbnMFDnNldEF1dG9zd2FwRmVlCQACAQILTm90IGFsbG93ZWQBaQEMc2V0U3dvcERhcHBzAghzaWduRGFwcAdldGhEYXBwAwkBCW93bmVyT25seQEFAWkJARBzZXRTd29wRGFwcHNGdW5jAgUIc2lnbkRhcHAFB2V0aERhcHAJAAIBAgtOb3QgYWxsb3dlZAFpAQZzZXRGZWUCCGZlZUFzc2V0CWZlZUFtb3VudAMJAQlvd25lck9ubHkBBQFpCQEKc2V0RmVlRnVuYwIFCGZlZUFzc2V0BQlmZWVBbW91bnQJAAIBAgtOb3QgYWxsb3dlZAFpAQ5zZXRGZWVSZWNlaXZlcgEEYWRkcgMJAQlvd25lck9ubHkBBQFpCQESc2V0RmVlUmVjZWl2ZXJGdW5jAQUEYWRkcgkAAgECC05vdCBhbGxvd2VkAWkBEHNldENvbmZpcm1hdGlvbnMCEGNvbmZpcm1mcm9tV2F2ZXMOY29uZmlybWZyb21FdGgDCQEJb3duZXJPbmx5AQUBaQkBFHNldENvbmZpcm1hdGlvbnNGdW5jAgUQY29uZmlybWZyb21XYXZlcwUOY29uZmlybWZyb21FdGgJAAIBAgtOb3QgYWxsb3dlZAFpAQ5zZXRBdXRvc3dhcEZlZQELYXV0b3N3YXBGZWUDCQEJb3duZXJPbmx5AQUBaQkBEnNldEF1dG9zd2FwRmVlRnVuYwEFC2F1dG9zd2FwRmVlCQACAQILTm90IGFsbG93ZWQBaQEEbG9jawIJcmVjaXBpZW50B25ldHdvcmsDCQEBIQEFBmlzSW5pdAkAAgECDmRBcHAgbm90IHJlYWR5AwkBASEBCQEPY29udGFpbnNFbGVtZW50AgUITkVUV09SS1MFB25ldHdvcmsJAAIBAhVOZXR3b3JrIG5vdCBzdXBwb3J0ZWQDCQEBIQEJAQxpc0V2bUFkZHJlc3MBBQlyZWNpcGllbnQJAAIBAhdXcm9uZyByZWNpcGllbnQgYWRkcmVzcwQLJHQwNzczMjc3NzEJAQxpZENhbGxlckRhdGUBBQFpBAJpZAgFCyR0MDc3MzI3NzcxAl8xBAZjYWxsZXIIBQskdDA3NzMyNzc3MQJfMgQEZGF0ZQgFCyR0MDc3MzI3NzcxAl8zBAskdDA3Nzc0Nzg1MQkBCWlzUGF5bWVudAEFAWkEC25mdF9wYXltZW50CAULJHQwNzc3NDc4NTECXzEECm5mdF9hbW91bnQIBQskdDA3Nzc0Nzg1MQJfMgQPZ2F0ZXdheV9wYXltZW50CAULJHQwNzc3NDc4NTECXzMEDmdhdGV3YXlfYW1vdW50CAULJHQwNzc3NDc4NTECXzQDCQECIT0CBQpuZnRfYW1vdW50AAEJAAIBAg9ObyBORlQgYXR0YWNoZWQEBW5mdElkAwMJAQlpc0RlZmluZWQBCAULbmZ0X3BheW1lbnQHYXNzZXRJZAkBDGlzU2lnbkFydE5GVAEJAQV2YWx1ZQEIBQtuZnRfcGF5bWVudAdhc3NldElkBwkA2AQBCQEFdmFsdWUBCAULbmZ0X3BheW1lbnQHYXNzZXRJZAkAAgECG09ubHkgU0lHTiBBcnQgTkZUIGFjY2VwdGVkLgQLJHQwODEzODgyMjAJARNnZXRDcmVhdG9yRnJvbU5GVGlkAQUFbmZ0SWQEB2NyZWF0b3IIBQskdDA4MTM4ODIyMAJfMQQFYXJ0SWQIBQskdDA4MTM4ODIyMAJfMgMJAQEhAQkBDmlzVmFsaWRDcmVhdG9yAQkBEGdldENyZWF0b3JTdGF0dXMBBQdjcmVhdG9yCQACAQkArAICAhNDcmVhdG9yIHN0YXR1cyBpcyA6CQEQZ2V0Q3JlYXRvclN0YXR1cwEFB2NyZWF0b3IDCQEBIQEJAQppc1ZhbGlkQXJ0AQkBDGdldEFydFN0YXR1cwIFBWFydElkBQdjcmVhdG9yCQACAQkArAICAhNBcnR3b3JrIHN0YXR1cyBpcyA6CQEMZ2V0QXJ0U3RhdHVzAgUFYXJ0SWQFB2NyZWF0b3IECWVyYzIwQWRkcgkBE2dldENyZWF0b3JFUkMyMEFkZHIBBQdjcmVhdG9yAwkAAAIJALECAQUJZXJjMjBBZGRyAAAJAAIBAixUaGlzIGFydGlzdCBkaWRuJ3QgYWxsb3cgY3Jvc3NjaGFpbiB0cmFuc2ZlcgQJbmZ0U3RhdHVzCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQDAwkAAAIFCW5mdFN0YXR1cwUNc3RhdHVzX0xPQ0tFRAYJAAACBQluZnRTdGF0dXMFDnN0YXR1c19QRU5ESU5HCQACAQISTkZUIGFscmVhZHkgbG9ja2VkBA9nYXNGZWVOb25NaW50ZWQJARlnZXRJbnRlZ2VyQnlLZXlGcm9tT3JhY2xlAQUPa2V5RmVlTm9uTWludGVkBAxnYXNGZWVNaW50ZWQJARlnZXRJbnRlZ2VyQnlLZXlGcm9tT3JhY2xlAQUMa2V5RmVlTWludGVkBAhpc01pbnRlZAMJAAACBQluZnRTdGF0dXMFD3N0YXR1c19VTkxPQ0tFRAYHAwMJAQEhAQkBCWlzRGVmaW5lZAEIBQ9nYXRld2F5X3BheW1lbnQHYXNzZXRJZAYJAQIhPQIJANgEAQkBBXZhbHVlAQgFD2dhdGV3YXlfcGF5bWVudAdhc3NldElkBRBmZWVBY2NlcHRlZEFzc2V0CQACAQITV3JvbmcgcGF5bWVudCBhc3NldAMDBQhpc01pbnRlZAkAZgIFDmdhdGV3YXlfYW1vdW50CQBkAgUMZ2FzRmVlTWludGVkBRhmZWVBY2NlcHRlZEFtb3VudEZvclNpZ24HCQACAQIeV3JvbmcgcGF5bWVudCBhbW91bnQgdG8gdW5sb2NrAwMJAQEhAQUIaXNNaW50ZWQJAGYCBQ5nYXRld2F5X2Ftb3VudAkAZAIFD2dhc0ZlZU5vbk1pbnRlZAUYZmVlQWNjZXB0ZWRBbW91bnRGb3JTaWduBwkAAgECJ1dyb25nIHBheW1lbnQgYW1vdW50IHRvIG1pbnQgYW5kIHVubG9jawQQdXNkblRvU3dhcEZvckV0aAMFCGlzTWludGVkBQxnYXNGZWVNaW50ZWQFD2dhc0ZlZU5vbk1pbnRlZAMFCGF1dG9zd2FwBBFzd2FwX3VzZG5fdG9fc2lnbgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBCQEOZ2V0U3RyaW5nQnlLZXkBBRVDT05GX1NXT1BfU0lHTl9EQVBQX0sCCGV4Y2hhbmdlCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFEGZlZUFjY2VwdGVkQXNzZXQFGGZlZUFjY2VwdGVkQW1vdW50Rm9yU2lnbgUDbmlsAwkAAAIFEXN3YXBfdXNkbl90b19zaWduBRFzd2FwX3VzZG5fdG9fc2lnbgQQc3dhcF91c2RuX3RvX2V0aAkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBCQEOZ2V0U3RyaW5nQnlLZXkBBRRDT05GX1NXT1BfRVRIX0RBUFBfSwIIZXhjaGFuZ2UJAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUQZmVlQWNjZXB0ZWRBc3NldAUQdXNkblRvU3dhcEZvckV0aAUDbmlsAwkAAAIFEHN3YXBfdXNkbl90b19ldGgFEHN3YXBfdXNkbl90b19ldGgEByRtYXRjaDAFEXN3YXBfdXNkbl90b19zaWduAwkAAQIFByRtYXRjaDACEShJbnQsIEJ5dGVWZWN0b3IpBBFzd2FwX3VzZG5fdG9fc2lnbgUHJG1hdGNoMAQNJHQwMTAxMTgxMDE3MAURc3dhcF91c2RuX3RvX3NpZ24EDWFtb3VudFdpdGhGZWUIBQ0kdDAxMDExODEwMTcwAl8xBAthc3NldElkU2VuZAgFDSR0MDEwMTE4MTAxNzACXzIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGtleU5GVHN0YXR1cwEFBW5mdElkBQ5zdGF0dXNfUEVORElORwkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgkBDmtleVRyYW5zZmVyTkZUAwUFbmZ0SWQFAmlkBQZjYWxsZXICAV8FDnN0YXR1c19QRU5ESU5HCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQlyZWNpcGllbnQCAV8FB25ldHdvcmsCAV8FBmNhbGxlcgIBXwUCaWQCAV8ICQEFdmFsdWUBCQDsBwEJAQV2YWx1ZQEIBQtuZnRfcGF5bWVudAdhc3NldElkBG5hbWUCAV8JAKQDAQUEZGF0ZQIBXwkApAMBBQZoZWlnaHQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwULZmVlUmVjZWl2ZXIFDWFtb3VudFdpdGhGZWUFC2Fzc2V0SWRTZW5kBQNuaWwJAAIBAkBJbmNvcnJlY3QgaW52b2tlIHJlc3VsdDogZXhwZWN0ZWQgYW1vdW50V2l0aEZlZSBhbmQgYXNzZXRzSWRTZW5kCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQxrZXlORlRzdGF0dXMBBQVuZnRJZAUOc3RhdHVzX1BFTkRJTkcJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAQ5rZXlUcmFuc2Zlck5GVAMFBW5mdElkBQJpZAUGY2FsbGVyAgFfBQ5zdGF0dXNfUEVORElORwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUJcmVjaXBpZW50AgFfBQduZXR3b3JrAgFfBQZjYWxsZXICAV8FAmlkAgFfCAkBBXZhbHVlAQkA7AcBCQEFdmFsdWUBCAULbmZ0X3BheW1lbnQHYXNzZXRJZARuYW1lAgFfCQCkAwEFBGRhdGUCAV8JAKQDAQUGaGVpZ2h0BQNuaWwBaQELY29uZmlybUxvY2sDBW5mdElkCnRyYW5zZmVySWQGY2FsbGVyAwkBASEBBQZpc0luaXQJAAIBAg5kQXBwIG5vdCByZWFkeQMJAQlvd25lck9ubHkBBQFpBAluZnRTdGF0dXMJAQ5nZXRTdHJpbmdCeUtleQEJAQxrZXlORlRzdGF0dXMBBQVuZnRJZAMJAQIhPQIFCW5mdFN0YXR1cwUOc3RhdHVzX1BFTkRJTkcJAAIBAg9ORlQgbm90IHBlbmRpbmcEA3ZhbAkBDmdldFN0cmluZ0J5S2V5AQkArAICCQCsAgIJAQ5rZXlUcmFuc2Zlck5GVAMFBW5mdElkBQp0cmFuc2ZlcklkBQZjYWxsZXICAV8FDnN0YXR1c19QRU5ESU5HBAZuZXdLZXkJAKwCAgkArAICCQEOa2V5VHJhbnNmZXJORlQDBQVuZnRJZAUKdHJhbnNmZXJJZAUGY2FsbGVyAgFfBQ1zdGF0dXNfQ0xPU0VECQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQEOa2V5VHJhbnNmZXJORlQDBQVuZnRJZAUKdHJhbnNmZXJJZAUGY2FsbGVyAgFfBQ5zdGF0dXNfUEVORElORwkAzAgCCQELU3RyaW5nRW50cnkCBQZuZXdLZXkFA3ZhbAkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5TkZUc3RhdHVzAQUFbmZ0SWQFDXN0YXR1c19MT0NLRUQFA25pbAkAAgECC05vdCBhbGxvd2VkAWkBBnVubG9jawIJcmVjaXBpZW50BW5mdElkAwkBASEBBQZpc0luaXQJAAIBAg5kQXBwIG5vdCByZWFkeQMJAQlvd25lck9ubHkBBQFpBAluZnRTdGF0dXMJAQ5nZXRTdHJpbmdCeUtleQEJAQxrZXlORlRzdGF0dXMBBQVuZnRJZAMJAQIhPQIFCW5mdFN0YXR1cwUNc3RhdHVzX0xPQ0tFRAkAAgECKU5GVCBub3QgbG9ja2VkLCBmaW5hbGl6ZSBmaXJzdCBpZiBwZW5kaW5nCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQxrZXlORlRzdGF0dXMBBQVuZnRJZAUPc3RhdHVzX1VOTE9DS0VECQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQdBZGRyZXNzAQkA2QQBBQlyZWNpcGllbnQAAQkA2QQBBQVuZnRJZAUDbmlsCQACAQILTm90IGFsbG93ZWQBaQEKYXBwUnVubmluZwIGaXNMaXZlB21lc3NhZ2UDCQEBIQEFBmlzSW5pdAkAAgECDmRBcHAgbm90IHJlYWR5AwkBCW93bmVyT25seQEFAWkJAMwIAgkBDEJvb2xlYW5FbnRyeQIFDWRhcHBSdW5uaW5nX0sFBmlzTGl2ZQkAzAgCCQELU3RyaW5nRW50cnkCBRBtYWludGVuYW5jZU1TR19LBQdtZXNzYWdlBQNuaWwJAAIBAiJZb3UgYXJlIG5vdCBhbGxvd2VkIHRvIGNoYW5nZSB0aGlzAWkBC2RlbGV0ZUVudHJ5AQVlbnRyeQMJAQlvd25lck9ubHkBBQFpCQDMCAIJAQtEZWxldGVFbnRyeQEFBWVudHJ5BQNuaWwJAAIBAgJubwBrrhWW", "height": 3318675, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 458jviEZEe8fGshyEmAd82jm9RvZRja18x8Sahdd3JHi Next: none Diff:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
4-let version = "1.0"
4+let version = "1.0.1"
55
66 let CONF_INIT_K = "config_init"
77
255255 else if (!(isEvmAddress(recipient)))
256256 then throw("Wrong recipient address")
257257 else {
258- let $t077307769 = idCallerDate(i)
259- let id = $t077307769._1
260- let caller = $t077307769._2
261- let date = $t077307769._3
262- let $t077727849 = isPayment(i)
263- let nft_payment = $t077727849._1
264- let nft_amount = $t077727849._2
265- let gateway_payment = $t077727849._3
266- let gateway_amount = $t077727849._4
258+ let $t077327771 = idCallerDate(i)
259+ let id = $t077327771._1
260+ let caller = $t077327771._2
261+ let date = $t077327771._3
262+ let $t077747851 = isPayment(i)
263+ let nft_payment = $t077747851._1
264+ let nft_amount = $t077747851._2
265+ let gateway_payment = $t077747851._3
266+ let gateway_amount = $t077747851._4
267267 if ((nft_amount != 1))
268268 then throw("No NFT attached")
269269 else {
272272 else false)
273273 then toBase58String(value(nft_payment.assetId))
274274 else throw("Only SIGN Art NFT accepted.")
275- let $t081368218 = getCreatorFromNFTid(nftId)
276- let creator = $t081368218._1
277- let artId = $t081368218._2
275+ let $t081388220 = getCreatorFromNFTid(nftId)
276+ let creator = $t081388220._1
277+ let artId = $t081388220._2
278278 if (!(isValidCreator(getCreatorStatus(creator))))
279279 then throw(("Creator status is :" + getCreatorStatus(creator)))
280280 else if (!(isValidArt(getArtStatus(artId, creator))))
320320 if ((swap_usdn_to_eth == swap_usdn_to_eth))
321321 then match swap_usdn_to_sign {
322322 case swap_usdn_to_sign: (Int, ByteVector) =>
323- let $t01011610168 = swap_usdn_to_sign
324- let amountWithFee = $t01011610168._1
325- let assetIdSend = $t01011610168._2
323+ let $t01011810170 = swap_usdn_to_sign
324+ let amountWithFee = $t01011810170._1
325+ let assetIdSend = $t01011810170._2
326326 [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))), ScriptTransfer(feeReceiver, amountWithFee, assetIdSend)]
327327 case _ =>
328328 throw("Incorrect invoke result: expected amountWithFee and assetsIdSend")
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
4-let version = "1.0"
4+let version = "1.0.1"
55
66 let CONF_INIT_K = "config_init"
77
88 let CONF_AMIN_K = "config_admin"
99
1010 let CONF_ORACLE_K = "config_oracle"
1111
1212 let CONF_FEE_RECEIVER_K = "config_fee_receiver"
1313
1414 let CONF_ARTWORK_DAPP_K = "config_artwork_dapp"
1515
1616 let CONF_USERS_DAPP_K = "config_users_dapp"
1717
1818 let CONF_FEE_ASSET_K = "config_fee_asset"
1919
2020 let CONF_FEE_AMOUNT_K = "config_fee_amount"
2121
2222 let CONF_SWOP_SIGN_DAPP_K = "config_swop_sign_dapp"
2323
2424 let CONF_SWOP_ETH_DAPP_K = "config_swop_eth_dapp"
2525
2626 let CONF_CONFIRMATIONS_FROM_WAVES_K = "config_confirmations_from_waves"
2727
2828 let CONF_CONFIRMATIONS_FROM_ETH_K = "config_confirmations_from_eth"
2929
3030 let CONF_AUTOSWAP_K = "config_autoswap"
3131
3232 let dappRunning_K = "conf_dapp_is_running"
3333
3434 let maintenanceMSG_K = "conf_maintenance_msg"
3535
3636 let dappRunning = valueOrElse(getBoolean(this, dappRunning_K), true)
3737
3838 let maintenanceMSG = valueOrElse(getString(this, maintenanceMSG_K), "")
3939
4040 let status_LOCKED = "LOCKED"
4141
4242 let status_UNLOCKED = "UNLOCKED"
4343
4444 let status_PENDING = "PENDING"
4545
4646 let status_CLOSED = "CLOSED"
4747
4848 let creatorRegistered = "REGISTERED"
4949
5050 let creatorVerified = "VERIFIED"
5151
5252 let artFlagged = "FLAGGED"
5353
5454 let artIllegal = "ILLEGAL"
5555
5656 let artPending = "CHANGE_REQUIRED"
5757
5858 let NETWORKS = ["ETH"]
5959
6060 func keyNFTstatus (nftId) = (("nft_" + nftId) + "_status")
6161
6262
6363 func keyTransferNFT (nftId,txid,caller) = ((((("transfer_" + nftId) + "_") + txid) + "_") + caller)
6464
6565
6666 let keyFeeNonMinted = "cost_non_minted"
6767
6868 let keyFeeMinted = "cost_minted"
6969
7070 func getStringByKey (key) = valueOrElse(getString(this, key), "")
7171
7272
7373 func getIntegerByKey (key) = valueOrElse(getInteger(this, key), 0)
7474
7575
7676 func getBooleanByKey (key) = valueOrElse(getBoolean(this, key), false)
7777
7878
7979 let admin = value(addressFromStringValue(getStringByKey(CONF_AMIN_K)))
8080
8181 let feeReceiver = value(addressFromString(getStringByKey(CONF_FEE_RECEIVER_K)))
8282
8383 let artworksDapp = value(addressFromString(getStringByKey(CONF_ARTWORK_DAPP_K)))
8484
8585 let usersDapp = value(addressFromString(getStringByKey(CONF_USERS_DAPP_K)))
8686
8787 let oracleAddr = value(addressFromString(getStringByKey(CONF_ORACLE_K)))
8888
8989 let autoswap = valueOrElse(getBooleanByKey(CONF_AUTOSWAP_K), false)
9090
9191 let feeAcceptedAsset = getStringByKey(CONF_FEE_ASSET_K)
9292
9393 let feeAcceptedAmountForSign = getIntegerByKey(CONF_FEE_AMOUNT_K)
9494
9595 func getStringFromUsersByKey (key) = valueOrElse(getString(usersDapp, key), "")
9696
9797
9898 func getStringFromArtworksByKey (key) = valueOrElse(getString(artworksDapp, key), "")
9999
100100
101101 func getIntegerByKeyFromOracle (key) = valueOrErrorMessage(getInteger(oracleAddr, key), "Integer undefined in oracle")
102102
103103
104104 func assetIsValid (assetDetails) = if (if (if ((assetDetails.quantity == 1))
105105 then (assetDetails.decimals == 0)
106106 else false)
107107 then (assetDetails.reissuable == false)
108108 else false)
109109 then (assetDetails.issuer == artworksDapp)
110110 else false
111111
112112
113113 func isSignArtNFT (id) = {
114114 let assetDetails = value(assetInfo(id))
115115 assetIsValid(assetDetails)
116116 }
117117
118118
119119 func isPayment (i) = if ((size(i.payments) != 2))
120120 then throw("Need to attach 2 payments")
121121 else {
122122 let nft_payment = value(i.payments[0])
123123 let nft_amount = value(nft_payment.amount)
124124 let gateway_payment = value(i.payments[1])
125125 let gateway_amount = value(gateway_payment.amount)
126126 $Tuple4(nft_payment, nft_amount, gateway_payment, gateway_amount)
127127 }
128128
129129
130130 let isInit = valueOrElse(getBooleanByKey(CONF_INIT_K), false)
131131
132132 func ownerOnly (i) = {
133133 let caller = toString(i.caller)
134134 let id = toBase58String(i.transactionId)
135135 let allowedArr = if (isInit)
136136 then [toString(admin), toString(this)]
137137 else [toString(this)]
138138 containsElement(allowedArr, caller)
139139 }
140140
141141
142142 func idCallerDate (i) = if (!(dappRunning))
143143 then throw(maintenanceMSG)
144144 else $Tuple3(toBase58String(i.transactionId), toBase58String(i.caller.bytes), lastBlock.timestamp)
145145
146146
147147 func getCreatorFromNFTid (nftid) = {
148148 let nftData = getStringFromArtworksByKey(("nft_" + nftid))
149149 let creator = split(nftData, "_")[6]
150150 let artId = split(nftData, "_")[5]
151151 $Tuple2(creator, artId)
152152 }
153153
154154
155155 func getCreatorERC20Addr (addr) = getStringFromUsersByKey(("user_ERC20_" + addr))
156156
157157
158158 func getCreatorStatus (addr) = getStringFromUsersByKey(("user_status_" + addr))
159159
160160
161161 func getArtStatus (artId,addr) = getStringFromArtworksByKey(((("art_flag_" + artId) + "_") + addr))
162162
163163
164164 func isValidCreator (status) = if ((status == creatorRegistered))
165165 then true
166166 else (status == creatorVerified)
167167
168168
169169 func isValidArt (status) = if (if ((status != artFlagged))
170170 then (status != artIllegal)
171171 else false)
172172 then (status != artPending)
173173 else false
174174
175175
176176 func isEvmAddress (addr) = if ((size(addr) == 42))
177177 then (take(addr, 2) == "0x")
178178 else false
179179
180180
181181 func setSwopDappsFunc (signDapp,ethDapp) = [StringEntry(CONF_SWOP_SIGN_DAPP_K, signDapp), StringEntry(CONF_SWOP_ETH_DAPP_K, ethDapp)]
182182
183183
184184 func setFeeReceiverFunc (addr) = [StringEntry(CONF_FEE_RECEIVER_K, addr)]
185185
186186
187187 func setFeeFunc (feeAsset,feeAmount) = {
188188 let assetDetails = assetInfo(fromBase58String(feeAsset))
189189 let decimal = value(assetDetails).decimals
190190 let base10FeeAmount = pow(feeAmount, 0, 10, 1, decimal, HALFUP)
191191 [StringEntry(CONF_FEE_ASSET_K, feeAsset), IntegerEntry(CONF_FEE_AMOUNT_K, base10FeeAmount)]
192192 }
193193
194194
195195 func setConfirmationsFunc (confirmfromWaves,confirmfromEth) = [IntegerEntry(CONF_CONFIRMATIONS_FROM_WAVES_K, confirmfromWaves), IntegerEntry(CONF_CONFIRMATIONS_FROM_ETH_K, confirmfromEth)]
196196
197197
198198 func setAutoswapFeeFunc (autoswapFee) = [BooleanEntry(CONF_AUTOSWAP_K, autoswapFee)]
199199
200200
201201 @Callable(i)
202202 func init (adminAddr,oracleAddr,artworksDapp,usersDapp,feeAsset,feeAmount,signSwopDapp,ethSwopDapp,confirmfromWaves,confirmfromEth,autoswapFee,feeReceiverAddr) = if (ownerOnly(i))
203203 then {
204204 let setSwopDapps = setSwopDappsFunc(signSwopDapp, ethSwopDapp)
205205 let setFee = setFeeFunc(feeAsset, feeAmount)
206206 let setFeeReceiver = setFeeReceiverFunc(feeReceiverAddr)
207207 let setConfirmations = setConfirmationsFunc(confirmfromWaves, confirmfromEth)
208208 let setAutoswapFee = setAutoswapFeeFunc(autoswapFee)
209209 ((((([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) ++ setFeeReceiver) ++ setFee) ++ setConfirmations) ++ setAutoswapFee)
210210 }
211211 else throw("Not allowed")
212212
213213
214214
215215 @Callable(i)
216216 func setSwopDapps (signDapp,ethDapp) = if (ownerOnly(i))
217217 then setSwopDappsFunc(signDapp, ethDapp)
218218 else throw("Not allowed")
219219
220220
221221
222222 @Callable(i)
223223 func setFee (feeAsset,feeAmount) = if (ownerOnly(i))
224224 then setFeeFunc(feeAsset, feeAmount)
225225 else throw("Not allowed")
226226
227227
228228
229229 @Callable(i)
230230 func setFeeReceiver (addr) = if (ownerOnly(i))
231231 then setFeeReceiverFunc(addr)
232232 else throw("Not allowed")
233233
234234
235235
236236 @Callable(i)
237237 func setConfirmations (confirmfromWaves,confirmfromEth) = if (ownerOnly(i))
238238 then setConfirmationsFunc(confirmfromWaves, confirmfromEth)
239239 else throw("Not allowed")
240240
241241
242242
243243 @Callable(i)
244244 func setAutoswapFee (autoswapFee) = if (ownerOnly(i))
245245 then setAutoswapFeeFunc(autoswapFee)
246246 else throw("Not allowed")
247247
248248
249249
250250 @Callable(i)
251251 func lock (recipient,network) = if (!(isInit))
252252 then throw("dApp not ready")
253253 else if (!(containsElement(NETWORKS, network)))
254254 then throw("Network not supported")
255255 else if (!(isEvmAddress(recipient)))
256256 then throw("Wrong recipient address")
257257 else {
258- let $t077307769 = idCallerDate(i)
259- let id = $t077307769._1
260- let caller = $t077307769._2
261- let date = $t077307769._3
262- let $t077727849 = isPayment(i)
263- let nft_payment = $t077727849._1
264- let nft_amount = $t077727849._2
265- let gateway_payment = $t077727849._3
266- let gateway_amount = $t077727849._4
258+ let $t077327771 = idCallerDate(i)
259+ let id = $t077327771._1
260+ let caller = $t077327771._2
261+ let date = $t077327771._3
262+ let $t077747851 = isPayment(i)
263+ let nft_payment = $t077747851._1
264+ let nft_amount = $t077747851._2
265+ let gateway_payment = $t077747851._3
266+ let gateway_amount = $t077747851._4
267267 if ((nft_amount != 1))
268268 then throw("No NFT attached")
269269 else {
270270 let nftId = if (if (isDefined(nft_payment.assetId))
271271 then isSignArtNFT(value(nft_payment.assetId))
272272 else false)
273273 then toBase58String(value(nft_payment.assetId))
274274 else throw("Only SIGN Art NFT accepted.")
275- let $t081368218 = getCreatorFromNFTid(nftId)
276- let creator = $t081368218._1
277- let artId = $t081368218._2
275+ let $t081388220 = getCreatorFromNFTid(nftId)
276+ let creator = $t081388220._1
277+ let artId = $t081388220._2
278278 if (!(isValidCreator(getCreatorStatus(creator))))
279279 then throw(("Creator status is :" + getCreatorStatus(creator)))
280280 else if (!(isValidArt(getArtStatus(artId, creator))))
281281 then throw(("Artwork status is :" + getArtStatus(artId, creator)))
282282 else {
283283 let erc20Addr = getCreatorERC20Addr(creator)
284284 if ((size(erc20Addr) == 0))
285285 then throw("This artist didn't allow crosschain transfer")
286286 else {
287287 let nftStatus = getStringByKey(keyNFTstatus(nftId))
288288 if (if ((nftStatus == status_LOCKED))
289289 then true
290290 else (nftStatus == status_PENDING))
291291 then throw("NFT already locked")
292292 else {
293293 let gasFeeNonMinted = getIntegerByKeyFromOracle(keyFeeNonMinted)
294294 let gasFeeMinted = getIntegerByKeyFromOracle(keyFeeMinted)
295295 let isMinted = if ((nftStatus == status_UNLOCKED))
296296 then true
297297 else false
298298 if (if (!(isDefined(gateway_payment.assetId)))
299299 then true
300300 else (toBase58String(value(gateway_payment.assetId)) != feeAcceptedAsset))
301301 then throw("Wrong payment asset")
302302 else if (if (isMinted)
303303 then (gateway_amount > (gasFeeMinted + feeAcceptedAmountForSign))
304304 else false)
305305 then throw("Wrong payment amount to unlock")
306306 else if (if (!(isMinted))
307307 then (gateway_amount > (gasFeeNonMinted + feeAcceptedAmountForSign))
308308 else false)
309309 then throw("Wrong payment amount to mint and unlock")
310310 else {
311311 let usdnToSwapForEth = if (isMinted)
312312 then gasFeeMinted
313313 else gasFeeNonMinted
314314 if (autoswap)
315315 then {
316316 let swap_usdn_to_sign = invoke(addressFromStringValue(getStringByKey(CONF_SWOP_SIGN_DAPP_K)), "exchange", [1], [AttachedPayment(fromBase58String(feeAcceptedAsset), feeAcceptedAmountForSign)])
317317 if ((swap_usdn_to_sign == swap_usdn_to_sign))
318318 then {
319319 let swap_usdn_to_eth = invoke(addressFromStringValue(getStringByKey(CONF_SWOP_ETH_DAPP_K)), "exchange", [1], [AttachedPayment(fromBase58String(feeAcceptedAsset), usdnToSwapForEth)])
320320 if ((swap_usdn_to_eth == swap_usdn_to_eth))
321321 then match swap_usdn_to_sign {
322322 case swap_usdn_to_sign: (Int, ByteVector) =>
323- let $t01011610168 = swap_usdn_to_sign
324- let amountWithFee = $t01011610168._1
325- let assetIdSend = $t01011610168._2
323+ let $t01011810170 = swap_usdn_to_sign
324+ let amountWithFee = $t01011810170._1
325+ let assetIdSend = $t01011810170._2
326326 [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))), ScriptTransfer(feeReceiver, amountWithFee, assetIdSend)]
327327 case _ =>
328328 throw("Incorrect invoke result: expected amountWithFee and assetsIdSend")
329329 }
330330 else throw("Strict value is not equal to itself.")
331331 }
332332 else throw("Strict value is not equal to itself.")
333333 }
334334 else [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)))]
335335 }
336336 }
337337 }
338338 }
339339 }
340340 }
341341
342342
343343
344344 @Callable(i)
345345 func confirmLock (nftId,transferId,caller) = if (!(isInit))
346346 then throw("dApp not ready")
347347 else if (ownerOnly(i))
348348 then {
349349 let nftStatus = getStringByKey(keyNFTstatus(nftId))
350350 if ((nftStatus != status_PENDING))
351351 then throw("NFT not pending")
352352 else {
353353 let val = getStringByKey(((keyTransferNFT(nftId, transferId, caller) + "_") + status_PENDING))
354354 let newKey = ((keyTransferNFT(nftId, transferId, caller) + "_") + status_CLOSED)
355355 [DeleteEntry(((keyTransferNFT(nftId, transferId, caller) + "_") + status_PENDING)), StringEntry(newKey, val), StringEntry(keyNFTstatus(nftId), status_LOCKED)]
356356 }
357357 }
358358 else throw("Not allowed")
359359
360360
361361
362362 @Callable(i)
363363 func unlock (recipient,nftId) = if (!(isInit))
364364 then throw("dApp not ready")
365365 else if (ownerOnly(i))
366366 then {
367367 let nftStatus = getStringByKey(keyNFTstatus(nftId))
368368 if ((nftStatus != status_LOCKED))
369369 then throw("NFT not locked, finalize first if pending")
370370 else [StringEntry(keyNFTstatus(nftId), status_UNLOCKED), ScriptTransfer(Address(fromBase58String(recipient)), 1, fromBase58String(nftId))]
371371 }
372372 else throw("Not allowed")
373373
374374
375375
376376 @Callable(i)
377377 func appRunning (isLive,message) = if (!(isInit))
378378 then throw("dApp not ready")
379379 else if (ownerOnly(i))
380380 then [BooleanEntry(dappRunning_K, isLive), StringEntry(maintenanceMSG_K, message)]
381381 else throw("You are not allowed to change this")
382382
383383
384384
385385 @Callable(i)
386386 func deleteEntry (entry) = if (ownerOnly(i))
387387 then [DeleteEntry(entry)]
388388 else throw("no")
389389
390390

github/deemru/w8io/6500d08 
62.16 ms