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