tx · 9k4EuFxvBSvXY4PAitq9h8L8TQAv67BRyCqttdd2SL4R

3N8xXaYjE27Aa79d5hHrhHu9HaFoTBmhDEj:  -0.01200000 Waves

2023.01.28 07:15 [2424324] smart account 3N8xXaYjE27Aa79d5hHrhHu9HaFoTBmhDEj > SELF 0.00000000 Waves

{ "type": 13, "id": "9k4EuFxvBSvXY4PAitq9h8L8TQAv67BRyCqttdd2SL4R", "fee": 1200000, "feeAssetId": null, "timestamp": 1674879318879, "version": 2, "chainId": 84, "sender": "3N8xXaYjE27Aa79d5hHrhHu9HaFoTBmhDEj", "senderPublicKey": "A2m227AHcq7gWfSU59Q3UJaqkEa7SccFYmJuWHbFrrKE", "proofs": [ "5HaSviWXmFVunqYo4vXhQEQ6PJtV7Wz2tgScbTGhWz4sdUxcNARkBVX7vULVnCByG8jVge5Ah3WmMqhb9J4jwnj7" ], "script": "base64:BgJNCAISBAoCCAgSBAoCBAgSAwoBBBIICgYICAgIAQgSCAoGCAgICAEIEgQKAggIEgYKBAgICAgSAwoBCBIGCgQICAEBEgQKAggIEgMKAQgqAAdWRVJTSU9OAgMxLjUBDmdldFN0cmluZ0J5S2V5AQNrZXkJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUDa2V5AgABD2dldEJvb2xlYW5CeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFA2tleQcBD2dldEludGVnZXJCeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFA2tleQAAAAVjaHJpcwkBDmdldFN0cmluZ0J5S2V5AQIMY29uZl9hZG1pbl8xAA5kYXBwUnVubmluZ0tleQIUY29uZl9kYXBwX2lzX3J1bm5pbmcAEW1haW50ZW5hbmNlTVNHS2V5AhRjb25mX21haW50ZW5hbmNlX21zZwASd2hpdGVsaXN0ZWRvbmx5S2V5AhVjb25mX3doaXRlbGlzdGVkX29ubHkAC2RhcHBSdW5uaW5nCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDmRhcHBSdW5uaW5nS2V5BgAObWFpbnRlbmFuY2VNU0cJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwURbWFpbnRlbmFuY2VNU0dLZXkCAAAPd2hpdGVsaXN0ZWRvbmx5CQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFEndoaXRlbGlzdGVkb25seUtleQYADXdoaXRlbGlzdERhcHAJAQV2YWx1ZQEJAKYIAQkBDmdldFN0cmluZ0J5S2V5AQITY29uZl93aGl0ZWxpc3RfZGFwcAALdXNlckFsbG93ZWQCB0FMTE9XRUQADnVzZXJSZWdpc3RlcmVkAgpSRUdJU1RFUkVEAAx1c2VyVmVyaWZpZWQCCFZFUklGSUVEAA11c2VyU3VzcGVuZGVkAglTVVNQRU5ERUQAC3VzZXJSZW1vdmVkAgdSRU1PVkVEABJ1c2VyQ2hhbmdlUmVxdWlyZWQCD0NIQU5HRV9SRVFVSVJFRAAQdXNlclVucmVnaXN0ZXJlZAIMVU5SRUdJU1RFUkVEAAl1c2VyUmVzZXQCBVJFU0VUAQtrZXlVc2VyQWRkcgEGY2FsbGVyCQCsAgICBXVzZXJfBQZjYWxsZXIBC2tleVVzZXJOYW1lAQZjYWxsZXIJAKwCAgIKdXNlcl9uYW1lXwUGY2FsbGVyAQtrZXlVc2VyRGVzYwEGY2FsbGVyCQCsAgICCnVzZXJfZGVzY18FBmNhbGxlcgENa2V5VXNlclNvY2lhbAEGY2FsbGVyCQCsAgICDHVzZXJfc29jaWFsXwUGY2FsbGVyAQxrZXlVc2VyVGh1bWIBBmNhbGxlcgkArAICAgt1c2VyX3RodW1iXwUGY2FsbGVyAQ1rZXlVc2VyU3RhdHVzAQZjYWxsZXIJAKwCAgIMdXNlcl9zdGF0dXNfBQZjYWxsZXIBEGtleVVzZXJSb3lhbHRpZXMBBmNhbGxlcgkArAICAg91c2VyX3JveWFsdGllc18FBmNhbGxlcgELa2V5VXNlckRhdGUBBmNhbGxlcgkArAICAgp1c2VyX2RhdGVfBQZjYWxsZXIBDGtleVVzZXJFUkMyMAEGY2FsbGVyCQCsAgICC3VzZXJfRVJDMjBfBQZjYWxsZXIBC2tleVVzZXJOb3RlAQZjYWxsZXIJAKwCAgIKdXNlcl9ub3RlXwUGY2FsbGVyAQxrZXlVc2VyTGFiZWwBBmNhbGxlcgkArAICAgt1c2VyX2xhYmVsXwUGY2FsbGVyARJrZXlBcnRpc3RBZ2VudEFkZHIBCmFydGlzdEFkZHIJAKwCAgINYXJ0aXN0X2FnZW50XwUKYXJ0aXN0QWRkcgESa2V5QWdlbnRBcnRpc3RBZGRyAglhZ2VudEFkZHIKYXJ0aXN0QWRkcgkArAICCQCsAgIJAKwCAgIGYWdlbnRfBQlhZ2VudEFkZHICAV8FCmFydGlzdEFkZHIBD2tleVByaW1hcnlTaGFyZQEKYXJ0aXN0QWRkcgkArAICAhVhcnRpc3RfYWdlbnRfcHJpbWFyeV8FCmFydGlzdEFkZHIBEWtleVNlY29uZGFyeVNoYXJlAQphcnRpc3RBZGRyCQCsAgICF2FydGlzdF9hZ2VudF9zZWNvbmRhcnlfBQphcnRpc3RBZGRyAQ5jaGVja1doaXRlbGlzdAEDa2V5CQELdmFsdWVPckVsc2UCCQCaCAIFDXdoaXRlbGlzdERhcHAFA2tleQAAAQt2YWxpZGF0ZUNJRAEDY2lkAwkBCGNvbnRhaW5zAgUDY2lkAgEvAwMJAGYCAEwJALECAQUDY2lkCQAAAgkAsQIBCQCRAwIJALUJAgUDY2lkAgEvAAAAOwcJAGYCABAJALECAQkAkQMCCQC1CQIFA2NpZAIBLwABBwcBDXZhbGlkVXNlckRhdGEFBmNhbGxlcgRuYW1lC2Rlc2NyaXB0aW9uBXRodW1iCmlzQW5VcGRhdGUECHZhbGlkQ0lEAwkBAiE9AgkAsQIBBQV0aHVtYgAACQELdmFsaWRhdGVDSUQBBQV0aHVtYgYDCQEBIQEFCHZhbGlkQ0lECQACAQIcQ0lEIGRvbid0IG1hdGNoIHJlcXVpcmVtZW50IQMDCQAAAgUEbmFtZQIABgkAAAIFC2Rlc2NyaXB0aW9uAgAJAAIBAiROYW1lIGFuZCBkZXNjcmlwdGlvbiBjYW5ub3QgYmUgZW1wdHkDCQBmAgkAsQIBBQtkZXNjcmlwdGlvbgDYBAkAAgECGTYwMCBDaGFyLiBtYXggZGVzY3JpcHRpb24DCQBmAgkAsQIBBQRuYW1lAC0JAAIBAhE0NSBDaGFyLiBtYXggbmFtZQQGc3RhdHVzCQEOZ2V0U3RyaW5nQnlLZXkBCQENa2V5VXNlclN0YXR1cwEFBmNhbGxlcgMDCQAAAgUGc3RhdHVzBQ11c2VyU3VzcGVuZGVkBgkAAAIFBnN0YXR1cwULdXNlclJlbW92ZWQJAAIBAhtBY2NvdW50IHN1c3BlbmRlZC8gcmVtb3ZlZC4DAwkBASEBBQppc0FuVXBkYXRlCQAAAgUGc3RhdHVzBQ51c2VyUmVnaXN0ZXJlZAcJAAIBAhJBbHJlYWR5IHJlZ2lzdGVyZWQDAwMJAQEhAQUKaXNBblVwZGF0ZQkAAAIFBnN0YXR1cwIABwUPd2hpdGVsaXN0ZWRvbmx5BwkAAgECI0Nhbid0IHJlZ2lzdGVyLCBnZXQgYXBwcm92ZWQgZmlyc3QuAwMDBQppc0FuVXBkYXRlCQAAAgUGc3RhdHVzAgAHBgMFCmlzQW5VcGRhdGUJAAACBQZzdGF0dXMFC3VzZXJBbGxvd2VkBwkAAgECDlJlZ2lzdGVyIGZpcnN0BgERdmFsaWRhdGVOZXdTdGF0dXMDBnN0YXR1cwdhZGRyZXNzDWN1cnJlbnRTdGF0dXMECWFsbFN0YXR1cwkAzAgCBQx1c2VyVmVyaWZpZWQJAMwIAgUOdXNlclJlZ2lzdGVyZWQJAMwIAgUNdXNlclN1c3BlbmRlZAkAzAgCBQt1c2VyUmVtb3ZlZAkAzAgCBQt1c2VyQWxsb3dlZAkAzAgCBRJ1c2VyQ2hhbmdlUmVxdWlyZWQFA25pbAQLc3RhdHVzVG9TZXQDCQEPY29udGFpbnNFbGVtZW50AgUJYWxsU3RhdHVzBQZzdGF0dXMFBnN0YXR1cwMDCQAAAgUGc3RhdHVzBQl1c2VyUmVzZXQJAAACBQ1jdXJyZW50U3RhdHVzBQt1c2VyQWxsb3dlZAcCAAkAAgECDlVua25vd24gc3RhdHVzBBB1c2VySXNSZWdpc3RlcmVkCQEPZ2V0SW50ZWdlckJ5S2V5AQkBC2tleVVzZXJEYXRlAQUHYWRkcmVzcwMDCQAAAgUQdXNlcklzUmVnaXN0ZXJlZAAACQECIT0CBQtzdGF0dXNUb1NldAULdXNlckFsbG93ZWQHCQACAQIxWW91IGNhbnQgc2V0IHRoaXMgc3RhdHVzLCB1c2VyIGlzIG5vdCByZWdpc3RlcmVkLgMDCQAAAgUNY3VycmVudFN0YXR1cwULdXNlckFsbG93ZWQJAAACBQtzdGF0dXNUb1NldAULdXNlckFsbG93ZWQHCQACAQIUVXNlciBhbHJlYWR5IGFsbG93ZWQDAwkAAAIFDWN1cnJlbnRTdGF0dXMFDnVzZXJSZWdpc3RlcmVkCQAAAgULc3RhdHVzVG9TZXQFC3VzZXJBbGxvd2VkBwkAAgECIVVzZXIgYWxyZWFkeSBhbGxvd2VkICYgcmVnaXN0ZXJlZAMDCQAAAgUNY3VycmVudFN0YXR1cwUMdXNlclZlcmlmaWVkCQAAAgULc3RhdHVzVG9TZXQFC3VzZXJBbGxvd2VkBwkAAgECH1VzZXIgYWxyZWFkeSBhbGxvd2VkICYgdmVyaWZpZWQFC3N0YXR1c1RvU2V0AQhtYWtlSlNPTgMEbmFtZQV0aHVtYgRkYXRlCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAg97InVzZXJfbmFtZSI6ICIFBG5hbWUCESIsICJ1c2VyX3RodW1iIjoiBQV0aHVtYgIPIiwidXNlcl9kYXRlIjoiBQRkYXRlAgIifQEIYXNTdHJpbmcBAmJ2BAckbWF0Y2gwBQJidgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEA2J2MAUHJG1hdGNoMAUDYnYwCQACAQIkU3BvbnNvcmVkIFB1YmxpYyBLZXkgU3RyaW5nIGV4cGVjdGVkAQlnZXRDYWxsZXICAWkGcHViS2V5BAtpc1Nwb25zb3JlZAMJAQIhPQIFBnB1YktleQIACQELdmFsdWVPckVsc2UCCQEOY2hlY2tXaGl0ZWxpc3QBCQCsAgIJAKUIAQkApwgBCQDZBAEFBnB1YktleQIJX2ZyZWVfdHhzAAAAAAQGY2FsbGVyAwMJAAACCQDYBAEICAUBaQZjYWxsZXIFYnl0ZXMJAKUIAQUEdGhpcwkAZgIFC2lzU3BvbnNvcmVkAAAHCQClCAEJAKcIAQkA2QQBBQZwdWJLZXkJANgEAQgIBQFpBmNhbGxlcgVieXRlcwQTZ2V0X3Nwb25zb3JlZF93YXZlcwMJAQIhPQIFBnB1YktleQIACQD8BwQFDXdoaXRlbGlzdERhcHACCXVzZUZyZWVUeAkAzAgCCQClCAEJAKcIAQkA2QQBBQZwdWJLZXkFA25pbAUDbmlsBQR1bml0AwkAAAIFE2dldF9zcG9uc29yZWRfd2F2ZXMFE2dldF9zcG9uc29yZWRfd2F2ZXMJAJQKAgUGY2FsbGVyCQBmAgULaXNTcG9uc29yZWQAAAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgsGaW52b2tlAQdzZXRDb25mAgNrZXkDdmFsBAZjYWxsZXIJAKUIAQgFBmludm9rZQZjYWxsZXIDCQEPY29udGFpbnNFbGVtZW50AgkAzAgCBQVjaHJpcwkAzAgCCQClCAEFBHRoaXMFA25pbAUGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIFA2tleQUDdmFsBQNuaWwJAAIBAiJZb3UgYXJlIG5vdCBhbGxvd2VkIHRvIGNoYW5nZSB0aGlzBmludm9rZQEKYXBwUnVubmluZwIGaXNMaXZlB21lc3NhZ2UEBmNhbGxlcgkApQgBCAUGaW52b2tlBmNhbGxlcgMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFBWNocmlzCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQZjYWxsZXIJAMwIAgkBDEJvb2xlYW5FbnRyeQIFDmRhcHBSdW5uaW5nS2V5BQZpc0xpdmUJAMwIAgkBC1N0cmluZ0VudHJ5AgURbWFpbnRlbmFuY2VNU0dLZXkFB21lc3NhZ2UFA25pbAkAAgECIllvdSBhcmUgbm90IGFsbG93ZWQgdG8gY2hhbmdlIHRoaXMGaW52b2tlARByZWdpc3RyYXRpb25Nb2RlAQZXTG9ubHkEBmNhbGxlcgkApQgBCAUGaW52b2tlBmNhbGxlcgMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFBWNocmlzCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQZjYWxsZXIJAMwIAgkBDEJvb2xlYW5FbnRyeQIFEndoaXRlbGlzdGVkb25seUtleQUGV0xvbmx5BQNuaWwJAAIBAiJZb3UgYXJlIG5vdCBhbGxvd2VkIHRvIGNoYW5nZSB0aGlzBmludm9rZQEMcmVnaXN0ZXJVc2VyBgRuYW1lC2Rlc2NyaXB0aW9uBXRodW1iBnNvY2lhbAlyb3lhbHRpZXMGcHViS2V5AwkBASEBBQtkYXBwUnVubmluZwkAAgEFDm1haW50ZW5hbmNlTVNHBAskdDA3MzE5NzM3MQkBCWdldENhbGxlcgIFBmludm9rZQUGcHViS2V5BAZjYWxsZXIIBQskdDA3MzE5NzM3MQJfMQQLaXNTcG9uc29yZWQIBQskdDA3MzE5NzM3MQJfMgQCaWQJANgEAQgFBmludm9rZQ10cmFuc2FjdGlvbklkBAl0aW1lc3RhbXAIBQlsYXN0QmxvY2sJdGltZXN0YW1wBARub3RlCQEOZ2V0U3RyaW5nQnlLZXkBCQELa2V5VXNlck5vdGUBBQZjYWxsZXIEBWxhYmVsCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5VXNlckxhYmVsAQUGY2FsbGVyAwkBASEBCQENdmFsaWRVc2VyRGF0YQUFBmNhbGxlcgUEbmFtZQULZGVzY3JpcHRpb24FBXRodW1iBwkAAgECFFNvbWV0aGluZyB3ZW50IHdyb25nBARqc29uCQEIbWFrZUpTT04DCQDaBAEJAJsDAQUEbmFtZQkA2gQBCQCbAwEFBXRodW1iCQCkAwEFCXRpbWVzdGFtcAMDCQBmAgAABQlyb3lhbHRpZXMGCQBmAgUJcm95YWx0aWVzAOgHCQACAQIzUm95YWx0aWVzIGNhbm5vdCBiZSBsZXNzIHRoYW4gMCUgb3IgaGlnaGVyIHRoYW4gMTAlBAp0eFRvQ2FsbGVyAwULaXNTcG9uc29yZWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBCQDZBAEFBmNhbGxlcgAABQR1bml0BQNuaWwFA25pbAkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQELa2V5VXNlckRhdGUBBQZjYWxsZXIFCXRpbWVzdGFtcAkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5VXNlckFkZHIBBQZjYWxsZXIJAKwCAgkArAICBQJpZAIBXwkApAMBBQl0aW1lc3RhbXAJAMwIAgkBC1N0cmluZ0VudHJ5AgkBC2tleVVzZXJOYW1lAQUGY2FsbGVyBQRuYW1lCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlVc2VyRGVzYwEFBmNhbGxlcgULZGVzY3JpcHRpb24JAMwIAgkBC1N0cmluZ0VudHJ5AgkBDWtleVVzZXJTb2NpYWwBBQZjYWxsZXIFBnNvY2lhbAkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5VXNlclRodW1iAQUGY2FsbGVyBQV0aHVtYgkAzAgCCQELU3RyaW5nRW50cnkCCQENa2V5VXNlclN0YXR1cwEFBmNhbGxlcgUOdXNlclJlZ2lzdGVyZWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARBrZXlVc2VyUm95YWx0aWVzAQUGY2FsbGVyBQlyb3lhbHRpZXMJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICAghBTExPV0VEXwUGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICBQ51c2VyUmVnaXN0ZXJlZAIBXwUGY2FsbGVyBQRqc29uCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlVc2VyTm90ZQEFBmNhbGxlcgUEbm90ZQkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5VXNlckxhYmVsAQUGY2FsbGVyBQVsYWJlbAUDbmlsBQp0eFRvQ2FsbGVyBmludm9rZQEKdXBkYXRlVXNlcgYEbmFtZQtkZXNjcmlwdGlvbgV0aHVtYgZzb2NpYWwJcm95YWx0aWVzBnB1YktleQMJAQEhAQULZGFwcFJ1bm5pbmcJAAIBBQ5tYWludGVuYW5jZU1TRwQLJHQwOTAxNzkxMjEJAQlnZXRDYWxsZXICBQZpbnZva2UFBnB1YktleQQGY2FsbGVyCAULJHQwOTAxNzkxMjECXzEEC2lzU3BvbnNvcmVkCAULJHQwOTAxNzkxMjECXzIEBnN0YXR1cwkBDmdldFN0cmluZ0J5S2V5AQkBDWtleVVzZXJTdGF0dXMBBQZjYWxsZXIDCQEBIQEJAQ12YWxpZFVzZXJEYXRhBQUGY2FsbGVyBQRuYW1lBQtkZXNjcmlwdGlvbgUFdGh1bWIGCQACAQIUU29tZXRoaW5nIHdlbnQgd3JvbmcEBGRhdGUJAQ9nZXRJbnRlZ2VyQnlLZXkBCQELa2V5VXNlckRhdGUBBQZjYWxsZXIEBGpzb24JAQhtYWtlSlNPTgMJANoEAQkAmwMBBQRuYW1lCQDaBAEJAJsDAQUFdGh1bWIJAKQDAQUEZGF0ZQMDCQBmAgAABQlyb3lhbHRpZXMGCQBmAgUJcm95YWx0aWVzAOgHCQACAQIzUm95YWx0aWVzIGNhbm5vdCBiZSBsZXNzIHRoYW4gMCUgb3IgaGlnaGVyIHRoYW4gMTAlBAp0eFRvQ2FsbGVyAwULaXNTcG9uc29yZWQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBCQDZBAEFBmNhbGxlcgAABQR1bml0BQNuaWwFA25pbAkAzggCCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlVc2VyTmFtZQEFBmNhbGxlcgUEbmFtZQkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5VXNlckRlc2MBBQZjYWxsZXIFC2Rlc2NyaXB0aW9uCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ1rZXlVc2VyU29jaWFsAQUGY2FsbGVyBQZzb2NpYWwJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGtleVVzZXJUaHVtYgEFBmNhbGxlcgUFdGh1bWIJAMwIAgkBDEludGVnZXJFbnRyeQIJARBrZXlVc2VyUm95YWx0aWVzAQUGY2FsbGVyBQlyb3lhbHRpZXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIFBnN0YXR1cwIBXwUGY2FsbGVyBQRqc29uBQNuaWwFCnR4VG9DYWxsZXIGaW52b2tlAQxzZXRFUkMyMFVzZXICBWVyYzIwBnB1YktleQMJAQEhAQULZGFwcFJ1bm5pbmcJAAIBBQ5tYWludGVuYW5jZU1TRwQNJHQwMTAzMDgxMDQxMQkBCWdldENhbGxlcgIFBmludm9rZQUGcHViS2V5BAZjYWxsZXIIBQ0kdDAxMDMwODEwNDExAl8xBAtpc1Nwb25zb3JlZAgFDSR0MDEwMzA4MTA0MTECXzIEBnN0YXR1cwkBDmdldFN0cmluZ0J5S2V5AQkBDWtleVVzZXJTdGF0dXMBBQZjYWxsZXIDAwkBAiE9AgUGc3RhdHVzBQ51c2VyUmVnaXN0ZXJlZAkBAiE9AgUGc3RhdHVzBQx1c2VyVmVyaWZpZWQHCQACAQIgTm90IGFsbG93ZWQgdG8gc2V0IEVSQzIwIGFkZHJlc3MECGZpcnN0VHdvCQCvAgIFBWVyYzIwAAIDAwkBAiE9AgUIZmlyc3RUd28CAjB4BgkBAiE9AgkAsQIBBQVlcmMyMAAqCQACAQIcVGhpcyBpcyBub3QgYW4gZXJjMjAgYWRkcmVzcwQKdHhUb0NhbGxlcgMFC2lzU3BvbnNvcmVkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQdBZGRyZXNzAQkA2QQBBQZjYWxsZXIAAAUEdW5pdAUDbmlsBQNuaWwJAM4IAgkAzAgCCQELU3RyaW5nRW50cnkCCQEMa2V5VXNlckVSQzIwAQUGY2FsbGVyBQVlcmMyMAUDbmlsBQp0eFRvQ2FsbGVyBmludm9rZQEQY2hhbmdlVXNlclN0YXR1cwQHYWRkcmVzcwZzdGF0dXMEbm90ZQVsYWJlbAQGY2FsbGVyCQClCAEIBQZpbnZva2UGY2FsbGVyAwkAAAIJALECAQUHYWRkcmVzcwAACQACAQIXQWRkcmVzcyBjYW5ub3QgYmUgZW1wdHkEC2N1cnJlbnROb3RlCQEOZ2V0U3RyaW5nQnlLZXkBCQELa2V5VXNlck5vdGUBBQdhZGRyZXNzBAxjdXJyZW50TGFiZWwJAQ5nZXRTdHJpbmdCeUtleQEJAQxrZXlVc2VyTGFiZWwBBQdhZGRyZXNzBAlub3RlVG9Vc2UDCQECIT0CCQCxAgEFBG5vdGUAAAUEbm90ZQULY3VycmVudE5vdGUECmxhYmVsVG9Vc2UDCQECIT0CCQCxAgEFBWxhYmVsAAAFBWxhYmVsBQxjdXJyZW50TGFiZWwDCQEPY29udGFpbnNFbGVtZW50AgkAzAgCBQVjaHJpcwkAzAgCCQClCAEFBHRoaXMFA25pbAUGY2FsbGVyAwkAAAIJALECAQUGc3RhdHVzAAAEDWN1cnJlbnRTdGF0dXMJAQ5nZXRTdHJpbmdCeUtleQEJAQ1rZXlVc2VyU3RhdHVzAQUHYWRkcmVzcwMJAAACBQ1jdXJyZW50U3RhdHVzAgAJAAIBAhdVc2VyIGhhdmUgbm8gc3RhdHVzIHlldAkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5VXNlck5vdGUBBQdhZGRyZXNzBQlub3RlVG9Vc2UJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGtleVVzZXJMYWJlbAEFB2FkZHJlc3MFCmxhYmVsVG9Vc2UFA25pbAQNY3VycmVudFN0YXR1cwkBDmdldFN0cmluZ0J5S2V5AQkBDWtleVVzZXJTdGF0dXMBBQdhZGRyZXNzBAtzdGF0dXNUb1NldAkBEXZhbGlkYXRlTmV3U3RhdHVzAwUGc3RhdHVzBQdhZGRyZXNzBQ1jdXJyZW50U3RhdHVzBARuYW1lCQDaBAEJAJsDAQkBDmdldFN0cmluZ0J5S2V5AQkBC2tleVVzZXJOYW1lAQUHYWRkcmVzcwQFdGh1bWIJANoEAQkAmwMBCQEOZ2V0U3RyaW5nQnlLZXkBCQEMa2V5VXNlclRodW1iAQUHYWRkcmVzcwQEZGF0ZQkBD2dldEludGVnZXJCeUtleQEJAQtrZXlVc2VyRGF0ZQEFB2FkZHJlc3MEBGpzb24JAQhtYWtlSlNPTgMFBG5hbWUFBXRodW1iCQCkAwEFBGRhdGUJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDWtleVVzZXJTdGF0dXMBBQdhZGRyZXNzBQtzdGF0dXNUb1NldAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgUNY3VycmVudFN0YXR1cwIBXwUHYWRkcmVzcwkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgULc3RhdHVzVG9TZXQCAV8FB2FkZHJlc3MFBGpzb24JAMwIAgkBC1N0cmluZ0VudHJ5AgkBC2tleVVzZXJOb3RlAQUHYWRkcmVzcwUJbm90ZVRvVXNlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQxrZXlVc2VyTGFiZWwBBQdhZGRyZXNzBQpsYWJlbFRvVXNlBQNuaWwJAAIBAiFOb3QgYWxsb3dlZCB0byBjaGFuZ2UgdXNlciBzdGF0dXMGaW52b2tlAQpkZWxldGVVc2VyAQdhZGRyZXNzBAZjYWxsZXIJAKUIAQgFBmludm9rZQZjYWxsZXIEDWN1cnJlbnRTdGF0dXMJAQ5nZXRTdHJpbmdCeUtleQEJAQ1rZXlVc2VyU3RhdHVzAQUHYWRkcmVzcwMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFBWNocmlzCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQZjYWxsZXIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBC2tleVVzZXJEYXRlAQUHYWRkcmVzcwkAzAgCCQELRGVsZXRlRW50cnkBCQELa2V5VXNlckFkZHIBBQdhZGRyZXNzCQDMCAIJAQtEZWxldGVFbnRyeQEJAQtrZXlVc2VyTmFtZQEFB2FkZHJlc3MJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBC2tleVVzZXJEZXNjAQUHYWRkcmVzcwkAzAgCCQELRGVsZXRlRW50cnkBCQENa2V5VXNlclNvY2lhbAEFB2FkZHJlc3MJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDGtleVVzZXJUaHVtYgEFB2FkZHJlc3MJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICAgp1c2VyX25vdGVfBQdhZGRyZXNzCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICBQ1jdXJyZW50U3RhdHVzAgFfBQdhZGRyZXNzCQDMCAIJAQtEZWxldGVFbnRyeQEJARBrZXlVc2VyUm95YWx0aWVzAQUHYWRkcmVzcwkAzAgCCQELU3RyaW5nRW50cnkCCQENa2V5VXNlclN0YXR1cwEFB2FkZHJlc3MFC3VzZXJSZW1vdmVkBQNuaWwJAAIBAgtOb3QgYWxsb3dlZAFpAQhzZXRBZ2VudAQKYXJ0aXN0QWRkcglhZ2VudEFkZHIMcHJpbWFyeVNoYXJlDnNlY29uZGFyeVNoYXJlAwkBASEBBQtkYXBwUnVubmluZwkAAgEFDm1haW50ZW5hbmNlTVNHBAZjYWxsZXIJAKUIAQgFAWkGY2FsbGVyAwkBD2NvbnRhaW5zRWxlbWVudAIJAMwIAgUFY2hyaXMJAMwIAgkApQgBBQR0aGlzBQNuaWwFBmNhbGxlcgMDCQECIT0CCQCxAgEFCmFydGlzdEFkZHIAIwYJAQIhPQIJALECAQUJYWdlbnRBZGRyACMJAAIBAg1Xcm9uZyBhZGRyZXNzCQDMCAIJAQtTdHJpbmdFbnRyeQIJARJrZXlBcnRpc3RBZ2VudEFkZHIBBQphcnRpc3RBZGRyBQlhZ2VudEFkZHIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBEmtleUFnZW50QXJ0aXN0QWRkcgIFCWFnZW50QWRkcgUKYXJ0aXN0QWRkcgUKYXJ0aXN0QWRkcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBD2tleVByaW1hcnlTaGFyZQEFCmFydGlzdEFkZHIFDHByaW1hcnlTaGFyZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEWtleVNlY29uZGFyeVNoYXJlAQUKYXJ0aXN0QWRkcgUOc2Vjb25kYXJ5U2hhcmUFA25pbAkAAgECE1lvdSBhcmUgbm90IGFsbG93ZWQBaQEKdW5zZXRBZ2VudAIKYXJ0aXN0QWRkcglhZ2VudEFkZHIDCQEBIQEFC2RhcHBSdW5uaW5nCQACAQUObWFpbnRlbmFuY2VNU0cEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIDCQEPY29udGFpbnNFbGVtZW50AgkAzAgCBQVjaHJpcwkAzAgCCQClCAEFBHRoaXMFA25pbAUGY2FsbGVyAwMJAQIhPQIJALECAQUKYXJ0aXN0QWRkcgAjBgkBAiE9AgkAsQIBBQlhZ2VudEFkZHIAIwkAAgECDVdyb25nIGFkZHJlc3MJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBEmtleUFydGlzdEFnZW50QWRkcgEFCmFydGlzdEFkZHIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBEmtleUFnZW50QXJ0aXN0QWRkcgIFCWFnZW50QWRkcgUKYXJ0aXN0QWRkcgkAzAgCCQELRGVsZXRlRW50cnkBCQEPa2V5UHJpbWFyeVNoYXJlAQUKYXJ0aXN0QWRkcgkAzAgCCQELRGVsZXRlRW50cnkBCQERa2V5U2Vjb25kYXJ5U2hhcmUBBQphcnRpc3RBZGRyBQNuaWwJAAIBAhNZb3UgYXJlIG5vdCBhbGxvd2VkAWkBC2RlbGV0ZUVudHJ5AQVlbnRyeQQGY2FsbGVyCQClCAEIBQFpBmNhbGxlcgMJAAACBQZjYWxsZXIFBWNocmlzCQDMCAIJAQtEZWxldGVFbnRyeQEFBWVudHJ5BQNuaWwJAAIBAgJubwECdHgBCHZlcmlmaWVyAAQHJG1hdGNoMAUCdHgDCQABAgUHJG1hdGNoMAIXSW52b2tlU2NyaXB0VHJhbnNhY3Rpb24EA2ludgUHJG1hdGNoMAMDAwMJAAACCAUDaW52CGZ1bmN0aW9uAgxyZWdpc3RlclVzZXIJAAACCAUDaW52BGRBcHAFBHRoaXMHCQAAAggFA2ludgNmZWUAoMIeBwkAAAIIBQNpbnYKZmVlQXNzZXRJZAUEdW5pdAcJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAJANkEAQkBCGFzU3RyaW5nAQkAkQMCCAUDaW52BGFyZ3MABQMDAwMJAAACCAUDaW52CGZ1bmN0aW9uAgp1cGRhdGVVc2VyCQAAAggFA2ludgRkQXBwBQR0aGlzBwkAAAIIBQNpbnYDZmVlAKDCHgcJAAACCAUDaW52CmZlZUFzc2V0SWQFBHVuaXQHCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACQDZBAEJAQhhc1N0cmluZwEJAJEDAggFA2ludgRhcmdzAAUDAwMDCQAAAggFA2ludghmdW5jdGlvbgIMc2V0RVJDMjBVc2VyCQAAAggFA2ludgRkQXBwBQR0aGlzBwkAAAIIBQNpbnYDZmVlAKDCHgcJAAACCAUDaW52CmZlZUFzc2V0SWQFBHVuaXQHCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACQDZBAEJAQhhc1N0cmluZwEJAJEDAggFA2ludgRhcmdzAAIJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXmrQVVe", "height": 2424324, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 7MNNQHXVM5mXEWKoFQTJGZ2egQFhsWnE2yYTqUaFECxq Next: HUBnemqiBAEuFsRwe4GNxdgjSSXdW3LnFEjb1up741yK Diff:
OldNewDifferences
323323 @Callable(invoke)
324324 func changeUserStatus (address,status,note,label) = {
325325 let caller = toString(invoke.caller)
326- if (containsElement([chris, toString(this)], caller))
327- then if ((size(status) == 0))
328- then {
329- let currentStatus = getStringByKey(keyUserStatus(address))
330- if ((currentStatus == ""))
331- then throw("User have no status yet")
332- else [StringEntry(keyUserNote(address), note), StringEntry(keyUserLabel(address), label)]
333- }
334- else {
335- let currentStatus = getStringByKey(keyUserStatus(address))
336- let statusToSet = validateNewStatus(status, address, currentStatus)
337- let name = toBase64String(toBytes(getStringByKey(keyUserName(address))))
338- let thumb = toBase64String(toBytes(getStringByKey(keyUserThumb(address))))
339- let date = getIntegerByKey(keyUserDate(address))
340- let json = makeJSON(name, thumb, toString(date))
341-[StringEntry(keyUserStatus(address), statusToSet), DeleteEntry(((currentStatus + "_") + address)), StringEntry(((statusToSet + "_") + address), json), StringEntry(keyUserNote(address), note), StringEntry(keyUserLabel(address), label)]
342- }
343- else throw("Not allowed to change user status")
326+ if ((size(address) == 0))
327+ then throw("Address cannot be empty")
328+ else {
329+ let currentNote = getStringByKey(keyUserNote(address))
330+ let currentLabel = getStringByKey(keyUserLabel(address))
331+ let noteToUse = if ((size(note) != 0))
332+ then note
333+ else currentNote
334+ let labelToUse = if ((size(label) != 0))
335+ then label
336+ else currentLabel
337+ if (containsElement([chris, toString(this)], caller))
338+ then if ((size(status) == 0))
339+ then {
340+ let currentStatus = getStringByKey(keyUserStatus(address))
341+ if ((currentStatus == ""))
342+ then throw("User have no status yet")
343+ else [StringEntry(keyUserNote(address), noteToUse), StringEntry(keyUserLabel(address), labelToUse)]
344+ }
345+ else {
346+ let currentStatus = getStringByKey(keyUserStatus(address))
347+ let statusToSet = validateNewStatus(status, address, currentStatus)
348+ let name = toBase64String(toBytes(getStringByKey(keyUserName(address))))
349+ let thumb = toBase64String(toBytes(getStringByKey(keyUserThumb(address))))
350+ let date = getIntegerByKey(keyUserDate(address))
351+ let json = makeJSON(name, thumb, toString(date))
352+[StringEntry(keyUserStatus(address), statusToSet), DeleteEntry(((currentStatus + "_") + address)), StringEntry(((statusToSet + "_") + address), json), StringEntry(keyUserNote(address), noteToUse), StringEntry(keyUserLabel(address), labelToUse)]
353+ }
354+ else throw("Not allowed to change user status")
355+ }
344356 }
345357
346358
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let VERSION = "1.5"
55
66 func getStringByKey (key) = valueOrElse(getString(this, key), "")
77
88
99 func getBooleanByKey (key) = valueOrElse(getBoolean(this, key), false)
1010
1111
1212 func getIntegerByKey (key) = valueOrElse(getInteger(this, key), 0)
1313
1414
1515 let chris = getStringByKey("conf_admin_1")
1616
1717 let dappRunningKey = "conf_dapp_is_running"
1818
1919 let maintenanceMSGKey = "conf_maintenance_msg"
2020
2121 let whitelistedonlyKey = "conf_whitelisted_only"
2222
2323 let dappRunning = valueOrElse(getBoolean(this, dappRunningKey), true)
2424
2525 let maintenanceMSG = valueOrElse(getString(this, maintenanceMSGKey), "")
2626
2727 let whitelistedonly = valueOrElse(getBoolean(this, whitelistedonlyKey), true)
2828
2929 let whitelistDapp = value(addressFromString(getStringByKey("conf_whitelist_dapp")))
3030
3131 let userAllowed = "ALLOWED"
3232
3333 let userRegistered = "REGISTERED"
3434
3535 let userVerified = "VERIFIED"
3636
3737 let userSuspended = "SUSPENDED"
3838
3939 let userRemoved = "REMOVED"
4040
4141 let userChangeRequired = "CHANGE_REQUIRED"
4242
4343 let userUnregistered = "UNREGISTERED"
4444
4545 let userReset = "RESET"
4646
4747 func keyUserAddr (caller) = ("user_" + caller)
4848
4949
5050 func keyUserName (caller) = ("user_name_" + caller)
5151
5252
5353 func keyUserDesc (caller) = ("user_desc_" + caller)
5454
5555
5656 func keyUserSocial (caller) = ("user_social_" + caller)
5757
5858
5959 func keyUserThumb (caller) = ("user_thumb_" + caller)
6060
6161
6262 func keyUserStatus (caller) = ("user_status_" + caller)
6363
6464
6565 func keyUserRoyalties (caller) = ("user_royalties_" + caller)
6666
6767
6868 func keyUserDate (caller) = ("user_date_" + caller)
6969
7070
7171 func keyUserERC20 (caller) = ("user_ERC20_" + caller)
7272
7373
7474 func keyUserNote (caller) = ("user_note_" + caller)
7575
7676
7777 func keyUserLabel (caller) = ("user_label_" + caller)
7878
7979
8080 func keyArtistAgentAddr (artistAddr) = ("artist_agent_" + artistAddr)
8181
8282
8383 func keyAgentArtistAddr (agentAddr,artistAddr) = ((("agent_" + agentAddr) + "_") + artistAddr)
8484
8585
8686 func keyPrimaryShare (artistAddr) = ("artist_agent_primary_" + artistAddr)
8787
8888
8989 func keySecondaryShare (artistAddr) = ("artist_agent_secondary_" + artistAddr)
9090
9191
9292 func checkWhitelist (key) = valueOrElse(getInteger(whitelistDapp, key), 0)
9393
9494
9595 func validateCID (cid) = if (contains(cid, "/"))
9696 then if (if ((76 > size(cid)))
9797 then (size(split(cid, "/")[0]) == 59)
9898 else false)
9999 then (16 > size(split(cid, "/")[1]))
100100 else false
101101 else false
102102
103103
104104 func validUserData (caller,name,description,thumb,isAnUpdate) = {
105105 let validCID = if ((size(thumb) != 0))
106106 then validateCID(thumb)
107107 else true
108108 if (!(validCID))
109109 then throw("CID don't match requirement!")
110110 else if (if ((name == ""))
111111 then true
112112 else (description == ""))
113113 then throw("Name and description cannot be empty")
114114 else if ((size(description) > 600))
115115 then throw("600 Char. max description")
116116 else if ((size(name) > 45))
117117 then throw("45 Char. max name")
118118 else {
119119 let status = getStringByKey(keyUserStatus(caller))
120120 if (if ((status == userSuspended))
121121 then true
122122 else (status == userRemoved))
123123 then throw("Account suspended/ removed.")
124124 else if (if (!(isAnUpdate))
125125 then (status == userRegistered)
126126 else false)
127127 then throw("Already registered")
128128 else if (if (if (!(isAnUpdate))
129129 then (status == "")
130130 else false)
131131 then whitelistedonly
132132 else false)
133133 then throw("Can't register, get approved first.")
134134 else if (if (if (isAnUpdate)
135135 then (status == "")
136136 else false)
137137 then true
138138 else if (isAnUpdate)
139139 then (status == userAllowed)
140140 else false)
141141 then throw("Register first")
142142 else true
143143 }
144144 }
145145
146146
147147 func validateNewStatus (status,address,currentStatus) = {
148148 let allStatus = [userVerified, userRegistered, userSuspended, userRemoved, userAllowed, userChangeRequired]
149149 let statusToSet = if (containsElement(allStatus, status))
150150 then status
151151 else if (if ((status == userReset))
152152 then (currentStatus == userAllowed)
153153 else false)
154154 then ""
155155 else throw("Unknown status")
156156 let userIsRegistered = getIntegerByKey(keyUserDate(address))
157157 if (if ((userIsRegistered == 0))
158158 then (statusToSet != userAllowed)
159159 else false)
160160 then throw("You cant set this status, user is not registered.")
161161 else if (if ((currentStatus == userAllowed))
162162 then (statusToSet == userAllowed)
163163 else false)
164164 then throw("User already allowed")
165165 else if (if ((currentStatus == userRegistered))
166166 then (statusToSet == userAllowed)
167167 else false)
168168 then throw("User already allowed & registered")
169169 else if (if ((currentStatus == userVerified))
170170 then (statusToSet == userAllowed)
171171 else false)
172172 then throw("User already allowed & verified")
173173 else statusToSet
174174 }
175175
176176
177177 func makeJSON (name,thumb,date) = (((((("{\"user_name\": \"" + name) + "\", \"user_thumb\":\"") + thumb) + "\",\"user_date\":\"") + date) + "\"}")
178178
179179
180180 func asString (bv) = match bv {
181181 case bv0: String =>
182182 bv0
183183 case _ =>
184184 throw("Sponsored Public Key String expected")
185185 }
186186
187187
188188 func getCaller (i,pubKey) = {
189189 let isSponsored = if ((pubKey != ""))
190190 then valueOrElse(checkWhitelist((toString(addressFromPublicKey(fromBase58String(pubKey))) + "_free_txs")), 0)
191191 else 0
192192 let caller = if (if ((toBase58String(i.caller.bytes) == toString(this)))
193193 then (isSponsored > 0)
194194 else false)
195195 then toString(addressFromPublicKey(fromBase58String(pubKey)))
196196 else toBase58String(i.caller.bytes)
197197 let get_sponsored_waves = if ((pubKey != ""))
198198 then invoke(whitelistDapp, "useFreeTx", [toString(addressFromPublicKey(fromBase58String(pubKey)))], nil)
199199 else unit
200200 if ((get_sponsored_waves == get_sponsored_waves))
201201 then $Tuple2(caller, (isSponsored > 0))
202202 else throw("Strict value is not equal to itself.")
203203 }
204204
205205
206206 @Callable(invoke)
207207 func setConf (key,val) = {
208208 let caller = toString(invoke.caller)
209209 if (containsElement([chris, toString(this)], caller))
210210 then [StringEntry(key, val)]
211211 else throw("You are not allowed to change this")
212212 }
213213
214214
215215
216216 @Callable(invoke)
217217 func appRunning (isLive,message) = {
218218 let caller = toString(invoke.caller)
219219 if (containsElement([chris, toString(this)], caller))
220220 then [BooleanEntry(dappRunningKey, isLive), StringEntry(maintenanceMSGKey, message)]
221221 else throw("You are not allowed to change this")
222222 }
223223
224224
225225
226226 @Callable(invoke)
227227 func registrationMode (WLonly) = {
228228 let caller = toString(invoke.caller)
229229 if (containsElement([chris, toString(this)], caller))
230230 then [BooleanEntry(whitelistedonlyKey, WLonly)]
231231 else throw("You are not allowed to change this")
232232 }
233233
234234
235235
236236 @Callable(invoke)
237237 func registerUser (name,description,thumb,social,royalties,pubKey) = if (!(dappRunning))
238238 then throw(maintenanceMSG)
239239 else {
240240 let $t073197371 = getCaller(invoke, pubKey)
241241 let caller = $t073197371._1
242242 let isSponsored = $t073197371._2
243243 let id = toBase58String(invoke.transactionId)
244244 let timestamp = lastBlock.timestamp
245245 let note = getStringByKey(keyUserNote(caller))
246246 let label = getStringByKey(keyUserLabel(caller))
247247 if (!(validUserData(caller, name, description, thumb, false)))
248248 then throw("Something went wrong")
249249 else {
250250 let json = makeJSON(toBase64String(toBytes(name)), toBase64String(toBytes(thumb)), toString(timestamp))
251251 if (if ((0 > royalties))
252252 then true
253253 else (royalties > 1000))
254254 then throw("Royalties cannot be less than 0% or higher than 10%")
255255 else {
256256 let txToCaller = if (isSponsored)
257257 then [ScriptTransfer(Address(fromBase58String(caller)), 0, unit)]
258258 else nil
259259 ([IntegerEntry(keyUserDate(caller), timestamp), StringEntry(keyUserAddr(caller), ((id + "_") + toString(timestamp))), StringEntry(keyUserName(caller), name), StringEntry(keyUserDesc(caller), description), StringEntry(keyUserSocial(caller), social), StringEntry(keyUserThumb(caller), thumb), StringEntry(keyUserStatus(caller), userRegistered), IntegerEntry(keyUserRoyalties(caller), royalties), DeleteEntry(("ALLOWED_" + caller)), StringEntry(((userRegistered + "_") + caller), json), StringEntry(keyUserNote(caller), note), StringEntry(keyUserLabel(caller), label)] ++ txToCaller)
260260 }
261261 }
262262 }
263263
264264
265265
266266 @Callable(invoke)
267267 func updateUser (name,description,thumb,social,royalties,pubKey) = if (!(dappRunning))
268268 then throw(maintenanceMSG)
269269 else {
270270 let $t090179121 = getCaller(invoke, pubKey)
271271 let caller = $t090179121._1
272272 let isSponsored = $t090179121._2
273273 let status = getStringByKey(keyUserStatus(caller))
274274 if (!(validUserData(caller, name, description, thumb, true)))
275275 then throw("Something went wrong")
276276 else {
277277 let date = getIntegerByKey(keyUserDate(caller))
278278 let json = makeJSON(toBase64String(toBytes(name)), toBase64String(toBytes(thumb)), toString(date))
279279 if (if ((0 > royalties))
280280 then true
281281 else (royalties > 1000))
282282 then throw("Royalties cannot be less than 0% or higher than 10%")
283283 else {
284284 let txToCaller = if (isSponsored)
285285 then [ScriptTransfer(Address(fromBase58String(caller)), 0, unit)]
286286 else nil
287287 ([StringEntry(keyUserName(caller), name), StringEntry(keyUserDesc(caller), description), StringEntry(keyUserSocial(caller), social), StringEntry(keyUserThumb(caller), thumb), IntegerEntry(keyUserRoyalties(caller), royalties), StringEntry(((status + "_") + caller), json)] ++ txToCaller)
288288 }
289289 }
290290 }
291291
292292
293293
294294 @Callable(invoke)
295295 func setERC20User (erc20,pubKey) = if (!(dappRunning))
296296 then throw(maintenanceMSG)
297297 else {
298298 let $t01030810411 = getCaller(invoke, pubKey)
299299 let caller = $t01030810411._1
300300 let isSponsored = $t01030810411._2
301301 let status = getStringByKey(keyUserStatus(caller))
302302 if (if ((status != userRegistered))
303303 then (status != userVerified)
304304 else false)
305305 then throw("Not allowed to set ERC20 address")
306306 else {
307307 let firstTwo = take(erc20, 2)
308308 if (if ((firstTwo != "0x"))
309309 then true
310310 else (size(erc20) != 42))
311311 then throw("This is not an erc20 address")
312312 else {
313313 let txToCaller = if (isSponsored)
314314 then [ScriptTransfer(Address(fromBase58String(caller)), 0, unit)]
315315 else nil
316316 ([StringEntry(keyUserERC20(caller), erc20)] ++ txToCaller)
317317 }
318318 }
319319 }
320320
321321
322322
323323 @Callable(invoke)
324324 func changeUserStatus (address,status,note,label) = {
325325 let caller = toString(invoke.caller)
326- if (containsElement([chris, toString(this)], caller))
327- then if ((size(status) == 0))
328- then {
329- let currentStatus = getStringByKey(keyUserStatus(address))
330- if ((currentStatus == ""))
331- then throw("User have no status yet")
332- else [StringEntry(keyUserNote(address), note), StringEntry(keyUserLabel(address), label)]
333- }
334- else {
335- let currentStatus = getStringByKey(keyUserStatus(address))
336- let statusToSet = validateNewStatus(status, address, currentStatus)
337- let name = toBase64String(toBytes(getStringByKey(keyUserName(address))))
338- let thumb = toBase64String(toBytes(getStringByKey(keyUserThumb(address))))
339- let date = getIntegerByKey(keyUserDate(address))
340- let json = makeJSON(name, thumb, toString(date))
341-[StringEntry(keyUserStatus(address), statusToSet), DeleteEntry(((currentStatus + "_") + address)), StringEntry(((statusToSet + "_") + address), json), StringEntry(keyUserNote(address), note), StringEntry(keyUserLabel(address), label)]
342- }
343- else throw("Not allowed to change user status")
326+ if ((size(address) == 0))
327+ then throw("Address cannot be empty")
328+ else {
329+ let currentNote = getStringByKey(keyUserNote(address))
330+ let currentLabel = getStringByKey(keyUserLabel(address))
331+ let noteToUse = if ((size(note) != 0))
332+ then note
333+ else currentNote
334+ let labelToUse = if ((size(label) != 0))
335+ then label
336+ else currentLabel
337+ if (containsElement([chris, toString(this)], caller))
338+ then if ((size(status) == 0))
339+ then {
340+ let currentStatus = getStringByKey(keyUserStatus(address))
341+ if ((currentStatus == ""))
342+ then throw("User have no status yet")
343+ else [StringEntry(keyUserNote(address), noteToUse), StringEntry(keyUserLabel(address), labelToUse)]
344+ }
345+ else {
346+ let currentStatus = getStringByKey(keyUserStatus(address))
347+ let statusToSet = validateNewStatus(status, address, currentStatus)
348+ let name = toBase64String(toBytes(getStringByKey(keyUserName(address))))
349+ let thumb = toBase64String(toBytes(getStringByKey(keyUserThumb(address))))
350+ let date = getIntegerByKey(keyUserDate(address))
351+ let json = makeJSON(name, thumb, toString(date))
352+[StringEntry(keyUserStatus(address), statusToSet), DeleteEntry(((currentStatus + "_") + address)), StringEntry(((statusToSet + "_") + address), json), StringEntry(keyUserNote(address), noteToUse), StringEntry(keyUserLabel(address), labelToUse)]
353+ }
354+ else throw("Not allowed to change user status")
355+ }
344356 }
345357
346358
347359
348360 @Callable(invoke)
349361 func deleteUser (address) = {
350362 let caller = toString(invoke.caller)
351363 let currentStatus = getStringByKey(keyUserStatus(address))
352364 if (containsElement([chris, toString(this)], caller))
353365 then [DeleteEntry(keyUserDate(address)), DeleteEntry(keyUserAddr(address)), DeleteEntry(keyUserName(address)), DeleteEntry(keyUserDesc(address)), DeleteEntry(keyUserSocial(address)), DeleteEntry(keyUserThumb(address)), DeleteEntry(("user_note_" + address)), DeleteEntry(((currentStatus + "_") + address)), DeleteEntry(keyUserRoyalties(address)), StringEntry(keyUserStatus(address), userRemoved)]
354366 else throw("Not allowed")
355367 }
356368
357369
358370
359371 @Callable(i)
360372 func setAgent (artistAddr,agentAddr,primaryShare,secondaryShare) = if (!(dappRunning))
361373 then throw(maintenanceMSG)
362374 else {
363375 let caller = toString(i.caller)
364376 if (containsElement([chris, toString(this)], caller))
365377 then if (if ((size(artistAddr) != 35))
366378 then true
367379 else (size(agentAddr) != 35))
368380 then throw("Wrong address")
369381 else [StringEntry(keyArtistAgentAddr(artistAddr), agentAddr), StringEntry(keyAgentArtistAddr(agentAddr, artistAddr), artistAddr), IntegerEntry(keyPrimaryShare(artistAddr), primaryShare), IntegerEntry(keySecondaryShare(artistAddr), secondaryShare)]
370382 else throw("You are not allowed")
371383 }
372384
373385
374386
375387 @Callable(i)
376388 func unsetAgent (artistAddr,agentAddr) = if (!(dappRunning))
377389 then throw(maintenanceMSG)
378390 else {
379391 let caller = toString(i.caller)
380392 if (containsElement([chris, toString(this)], caller))
381393 then if (if ((size(artistAddr) != 35))
382394 then true
383395 else (size(agentAddr) != 35))
384396 then throw("Wrong address")
385397 else [DeleteEntry(keyArtistAgentAddr(artistAddr)), DeleteEntry(keyAgentArtistAddr(agentAddr, artistAddr)), DeleteEntry(keyPrimaryShare(artistAddr)), DeleteEntry(keySecondaryShare(artistAddr))]
386398 else throw("You are not allowed")
387399 }
388400
389401
390402
391403 @Callable(i)
392404 func deleteEntry (entry) = {
393405 let caller = toString(i.caller)
394406 if ((caller == chris))
395407 then [DeleteEntry(entry)]
396408 else throw("no")
397409 }
398410
399411
400412 @Verifier(tx)
401413 func verifier () = match tx {
402414 case inv: InvokeScriptTransaction =>
403415 if (if (if (if ((inv.function == "registerUser"))
404416 then (inv.dApp == this)
405417 else false)
406418 then (inv.fee == 500000)
407419 else false)
408420 then (inv.feeAssetId == unit)
409421 else false)
410422 then sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(asString(inv.args[5])))
411423 else if (if (if (if ((inv.function == "updateUser"))
412424 then (inv.dApp == this)
413425 else false)
414426 then (inv.fee == 500000)
415427 else false)
416428 then (inv.feeAssetId == unit)
417429 else false)
418430 then sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(asString(inv.args[5])))
419431 else if (if (if (if ((inv.function == "setERC20User"))
420432 then (inv.dApp == this)
421433 else false)
422434 then (inv.fee == 500000)
423435 else false)
424436 then (inv.feeAssetId == unit)
425437 else false)
426438 then sigVerify(tx.bodyBytes, tx.proofs[0], fromBase58String(asString(inv.args[2])))
427439 else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
428440 case _ =>
429441 sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
430442 }
431443

github/deemru/w8io/3ef1775 
60.34 ms