tx · 5mtLk5yDbhh7ZsS8NNH5W3B1B2vrjSL5KmL1rqxpEwh4

3MrQ4g9YCsAN2Wr4QUXiWAPhNPv7DGdQNWb:  -0.00800000 Waves

2023.03.17 20:13 [2494289] smart account 3MrQ4g9YCsAN2Wr4QUXiWAPhNPv7DGdQNWb > SELF 0.00000000 Waves

{ "type": 13, "id": "5mtLk5yDbhh7ZsS8NNH5W3B1B2vrjSL5KmL1rqxpEwh4", "fee": 800000, "feeAssetId": null, "timestamp": 1679073204910, "version": 2, "chainId": 84, "sender": "3MrQ4g9YCsAN2Wr4QUXiWAPhNPv7DGdQNWb", "senderPublicKey": "2VQGRNRWyFAZvjDtkgZwdZcTwZvBJJ61n8zJfYYxm5eK", "proofs": [ "2G8K369Ykhh2yNF7ZWH4cqwaruxBmqS4RjUDbgg6HxebN4yR379KuT3f4QKRpUKDABEXPg57YWgRBkydBNJT5ygt" ], "script": "base64:BgJTCAISBAoCGBgSBQoDCBgYEgQKAggIEgQKAggIEgQKAggIEgUKAwgICBIDCgECEgMKAQgSBAoCCAgSBQoDCAgIEgQKAggIEgYKBAgBAQESBAoCAQEKAA5jb2xsZWN0aW9uTmFtZQkBEUBleHRyTmF0aXZlKDEwNTgpAQIOY29sbGVjdGlvbk5hbWUABnN5bWJvbAkBEUBleHRyTmF0aXZlKDEwNTgpAQIGc3ltYm9sAAtkZXNjcmlwdGlvbgkBEUBleHRyTmF0aXZlKDEwNTgpAQILZGVzY3JpcHRpb24AC3RvdGFsQW1vdW50CQERQGV4dHJOYXRpdmUoMTA1NSkBAgt0b3RhbEFtb3VudAAIZEFwcEpzb24JAQdBZGRyZXNzAQkA2QQBAiMzTXJHYVpWUmhrbkVHZkhKMTl0dFVQTm5EUm9GcWNIaFZONwAMdG9rZW5QYXltZW50CQEHQWRkcmVzcwEJARFAZXh0ck5hdGl2ZSgxMDU3KQECDHRva2VuUGF5bWVudAEMb25seUludGVybmFsAQZjYWxsZXIDCQAAAgUGY2FsbGVyBQR0aGlzBQR1bml0CQACAQIST25seSBpbnRlcm5hbCBjYWxsAQ10cmFuc2Zlck9yTm90AgJ0bwdhc3NldElkAwkAAAIFAnRvBQR0aGlzCQELU3RyaW5nRW50cnkCAg7QutC+0YHRgtGL0LvRjAIO0LrQvtGB0YLRi9C70YwJAQ5TY3JpcHRUcmFuc2ZlcgMFAnRvAAEFB2Fzc2V0SWQBDnBhcnNlSWR0b0Fzc2V0AQdhc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQkA2QQBBQdhc3NldElkAhxDYW4ndCBmaW5kIGFzc2V0IGJ5IGFzc2V0IGlkAQ9jaGVja0Fzc2V0T3duZXICBmNhbGxlcgdhc3NldElkAwkAAAIJAPAHAgUGY2FsbGVyCQDZBAEFB2Fzc2V0SWQAAQUEdW5pdAkAAgECEE9ubHkgYXNzZXQgb3duZXINAWkBEG1ha2VKU09OSW50ZXJuYWwCB2FycktleXMJYXJyVmFsdWVzCQELdmFsdWVPckVsc2UCCQEMb25seUludGVybmFsAQgFAWkGY2FsbGVyBANyZXMJAPwHBAUIZEFwcEpzb24CCG1ha2VKU09OCQDMCAIFB2FycktleXMJAMwIAgUJYXJyVmFsdWVzBQNuaWwFA25pbAMJAAACBQNyZXMFA3JlcwkAlAoCBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARFhZGRUb0pTT05JbnRlcm5hbAMEanNvbgdhcnJLZXlzCWFyclZhbHVlcwkBC3ZhbHVlT3JFbHNlAgkBDG9ubHlJbnRlcm5hbAEIBQFpBmNhbGxlcgQDcmVzCQD8BwQFCGRBcHBKc29uAglhZGRUb0pTT04JAMwIAgUEanNvbgkAzAgCBQdhcnJLZXlzCQDMCAIFCWFyclZhbHVlcwUDbmlsBQNuaWwDCQAAAgUDcmVzBQNyZXMJAJQKAgUDbmlsBQNyZXMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEVcmVhZEJ5SlNPTktleUludGVybmFsAgRqc29uA2tleQkBC3ZhbHVlT3JFbHNlAgkBDG9ubHlJbnRlcm5hbAEIBQFpBmNhbGxlcgQDcmVzCQD8BwQFCGRBcHBKc29uAg1yZWFkQnlKU09OS2V5CQDMCAIFBGpzb24JAMwIAgUDa2V5BQNuaWwFA25pbAMJAAACBQNyZXMFA3JlcwkAlAoCBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARdkZWxldGVCeUpTT05LZXlJbnRlcm5hbAIEanNvbgNrZXkJAQt2YWx1ZU9yRWxzZQIJAQxvbmx5SW50ZXJuYWwBCAUBaQZjYWxsZXIEA3JlcwkA/AcEBQhkQXBwSnNvbgIPZGVsZXRlQnlKU09OS2V5CQDMCAIFBGpzb24JAMwIAgUDa2V5BQNuaWwFA25pbAMJAAACBQNyZXMFA3JlcwkAlAoCBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARNzdG9yYWdlSnNvbkludGVybmFsAgdqc29uS2V5Cmpzb25TdHJpbmcJAQt2YWx1ZU9yRWxzZQIJAQxvbmx5SW50ZXJuYWwBCAUBaQZjYWxsZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgUHanNvbktleQUKanNvblN0cmluZwUDbmlsAWkBB3NldFVzZXIDB2Fzc2V0SWQEdXNlcgdleHBpcmVzBANyZXMJAPwHBAUIZEFwcEpzb24CCG1ha2VKU09OCQDMCAIJAMwIAgIEdXNlcgkAzAgCAgdleHBpcmVzBQNuaWwJAMwIAgkAzAgCBQR1c2VyCQDMCAIFB2V4cGlyZXMFA25pbAUDbmlsBQNuaWwDCQAAAgUDcmVzBQNyZXMJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgICB3VzZXJPZi0FB2Fzc2V0SWQKAAFABQNyZXMDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ9zZXRUb2tlblBheW1lbnQBB2Fzc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAQxvbmx5SW50ZXJuYWwBCAUBaQZjYWxsZXIJAMwIAgkBC0JpbmFyeUVudHJ5AgIMdG9rZW5QYXltZW50BQdhc3NldElkBQNuaWwBaQEQZGVsZXRlVmFsdWVCeUtleQEDa2V5CQELdmFsdWVPckVsc2UCCQEMb25seUludGVybmFsAQgFAWkGY2FsbGVyCQDMCAIJAQtEZWxldGVFbnRyeQEFA2tleQUDbmlsAWkBCXNldFN0cmluZwIDa2V5BXZhbHVlCQELdmFsdWVPckVsc2UCCQEMb25seUludGVybmFsAQgFAWkGY2FsbGVyCQDMCAIJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUFA25pbAFpAQRpbml0Aw5jb2xsZWN0aW9uTmFtZQZzeW1ib2wLZGVzY3JpcHRpb24JAQt2YWx1ZU9yRWxzZQIJAQxvbmx5SW50ZXJuYWwBCAUBaQZjYWxsZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgIOY29sbGVjdGlvbk5hbWUFDmNvbGxlY3Rpb25OYW1lCQDMCAIJAQtTdHJpbmdFbnRyeQICBnN5bWJvbAUGc3ltYm9sCQDMCAIJAQtTdHJpbmdFbnRyeQICC2Rlc2NyaXB0aW9uBQtkZXNjcmlwdGlvbgkAzAgCCQEMSW50ZWdlckVudHJ5AgILdG90YWxBbW91bnQAAAUDbmlsAWkBBG1pbnQCAnRvCHRva2VuVVJJBAd0b2tlbklkCQBkAgULdG90YWxBbW91bnQAAQQHcHJlTmFtZQkArAICCQCsAgIFBnN5bWJvbAIBIwkApAMBBQd0b2tlbklkBARuYW1lAwkAZwIAEAkAsQIBBQdwcmVOYW1lBQdwcmVOYW1lCQCkAwEFB3Rva2VuSWQEBGpzb24KAAFACQD8BwQFCGRBcHBKc29uAghtYWtlSlNPTgkAzAgCCQDMCAICCHRva2VuVVJJBQNuaWwJAMwIAgkAzAgCBQh0b2tlblVSSQUDbmlsBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcEBWFzc2V0CQDDCAcFBG5hbWUFBGpzb24AAQAABwUEdW5pdAUGaGVpZ2h0BAdhc3NldElkCQC4CAEFBWFzc2V0BAl0b0FkZHJlc3MJAQdBZGRyZXNzAQkA2QQBBQJ0bwQIdHJhbnNmZXIJAQ10cmFuc2Zlck9yTm90AgUJdG9BZGRyZXNzBQdhc3NldElkAwkAAAIFCHRyYW5zZmVyBQh0cmFuc2ZlcgkAzAgCBQVhc3NldAkAzAgCBQh0cmFuc2ZlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgILdG90YWxBbW91bnQFB3Rva2VuSWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUEbmFtZQUIdG9rZW5VUkkFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhpbml0TGVuZAQHYXNzZXRJZA90aW1lVW5pdFNlY29uZHMNdGltZVVuaXRQcmljZQ10aW1lVW5pdENvdW50CQELdmFsdWVPckVsc2UCCQEPY2hlY2tBc3NldE93bmVyAggFAWkGY2FsbGVyBQdhc3NldElkBAVhc3NldAkBDnBhcnNlSWR0b0Fzc2V0AQUHYXNzZXRJZAQIdG9rZW5VUkkKAAFACQD8BwQFCGRBcHBKc29uAg1yZWFkQnlKU09OS2V5CQDMCAIIBQVhc3NldAtkZXNjcmlwdGlvbgkAzAgCAgh0b2tlblVSSQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nAwkAAAIFCHRva2VuVVJJBQh0b2tlblVSSQQFbGVuZHMJARFAZXh0ck5hdGl2ZSgxMDU4KQECBUxlbmRzBAZkZWxldGUKAAFACQD8BwQFCGRBcHBKc29uAg9kZWxldGVCeUpTT05LZXkJAMwIAgUFbGVuZHMJAMwIAgIJbGVuZENvdW50BQNuaWwFA25pbAMJAAECBQFAAhAoU3RyaW5nLCBTdHJpbmcpBQFACQACAQkArAICCQADAQUBQAIlIGNvdWxkbid0IGJlIGNhc3QgdG8gKFN0cmluZywgU3RyaW5nKQMJAAACBQZkZWxldGUFBmRlbGV0ZQQGbGVuZElkCAUGZGVsZXRlAl8xBAhuZXdDb3VudAkApAMBCQBkAgkBDXBhcnNlSW50VmFsdWUBBQZsZW5kSWQAAQQEbWFrZQoAAUAJAPwHBAUIZEFwcEpzb24CCG1ha2VKU09OCQDMCAIJAMwIAgISc3VwcG9ydGVkSW50ZXJmYWNlCQDMCAICCGFzc2V0ZElkCQDMCAICCHRva2VuVVJJCQDMCAICBW93bmVyCQDMCAICD3RpbWVVbml0U2Vjb25kcwkAzAgCAg10aW1lVW5pdFByaWNlCQDMCAICDXRpbWVVbml0Q291bnQJAMwIAgIOc3RhcnRUaW1lc3RhbXAJAMwIAgIMZW5kVGltZXN0YW1wCQDMCAICB2RlcG9zaXQJAMwIAgIHY2xhaW1lZAkAzAgCAgVyZW50cwUDbmlsCQDMCAIJAMwIAgIBMAkAzAgCBQdhc3NldElkCQDMCAIFCHRva2VuVVJJCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAKQDAQUPdGltZVVuaXRTZWNvbmRzCQDMCAIJAKQDAQUNdGltZVVuaXRQcmljZQkAzAgCCQCkAwEFDXRpbWVVbml0Q291bnQJAMwIAgkApAMBCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQCkAwEJAGQCCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAaAIFD3RpbWVVbml0U2Vjb25kcwUNdGltZVVuaXRDb3VudAkAzAgCAgEwCQDMCAICATAJAMwIAgIReyJyZW50Q291bnQiOiIwIn0FA25pbAUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nAwkAAAIFBG1ha2UFBG1ha2UEBmluc2VydAoAAUAJAPwHBAUIZEFwcEpzb24CCWFkZFRvSlNPTgkAzAgCCAUGZGVsZXRlAl8yCQDMCAIJAMwIAgUGbGVuZElkCQDMCAICCWxlbmRDb3VudAUDbmlsCQDMCAIJAMwIAgUEbWFrZQkAzAgCBQhuZXdDb3VudAUDbmlsBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcDCQAAAgUGaW5zZXJ0BQZpbnNlcnQJAMwIAgkBC1N0cmluZ0VudHJ5AgIFTGVuZHMFBmluc2VydAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCGluaXRSZW50AgZsZW5kSWQNdGltZVVuaXRDb3VudAQMbGVuZElkU3RyaW5nCQCkAwEFBmxlbmRJZAQFbGVuZHMJARFAZXh0ck5hdGl2ZSgxMDU4KQECBUxlbmRzBA9kZWxldGVMZW5kQ291bnQKAAFACQD8BwQFCGRBcHBKc29uAg9kZWxldGVCeUpTT05LZXkJAMwIAgUFbGVuZHMJAMwIAgIJbGVuZENvdW50BQNuaWwFA25pbAMJAAECBQFAAhAoU3RyaW5nLCBTdHJpbmcpBQFACQACAQkArAICCQADAQUBQAIlIGNvdWxkbid0IGJlIGNhc3QgdG8gKFN0cmluZywgU3RyaW5nKQMJAAACBQ9kZWxldGVMZW5kQ291bnQFD2RlbGV0ZUxlbmRDb3VudAQKZGVsZXRlTGVuZAoAAUAJAPwHBAUIZEFwcEpzb24CD2RlbGV0ZUJ5SlNPTktleQkAzAgCCAUPZGVsZXRlTGVuZENvdW50Al8yCQDMCAIFDGxlbmRJZFN0cmluZwUDbmlsBQNuaWwDCQABAgUBQAIQKFN0cmluZywgU3RyaW5nKQUBQAkAAgEJAKwCAgkAAwEFAUACJSBjb3VsZG4ndCBiZSBjYXN0IHRvIChTdHJpbmcsIFN0cmluZykDCQAAAgUKZGVsZXRlTGVuZAUKZGVsZXRlTGVuZAQLZGVsZXRlUmVudHMKAAFACQD8BwQFCGRBcHBKc29uAg9kZWxldGVCeUpTT05LZXkJAMwIAggFCmRlbGV0ZUxlbmQCXzEJAMwIAgIFcmVudHMFA25pbAUDbmlsAwkAAQIFAUACEChTdHJpbmcsIFN0cmluZykFAUAJAAIBCQCsAgIJAAMBBQFAAiUgY291bGRuJ3QgYmUgY2FzdCB0byAoU3RyaW5nLCBTdHJpbmcpAwkAAAIFC2RlbGV0ZVJlbnRzBQtkZWxldGVSZW50cwQPZGVsZXRlUmVudENvdW50CgABQAkA/AcEBQhkQXBwSnNvbgIPZGVsZXRlQnlKU09OS2V5CQDMCAIIBQtkZWxldGVSZW50cwJfMQkAzAgCAglyZW50Q291bnQFA25pbAUDbmlsAwkAAQIFAUACEChTdHJpbmcsIFN0cmluZykFAUAJAAIBCQCsAgIJAAMBBQFAAiUgY291bGRuJ3QgYmUgY2FzdCB0byAoU3RyaW5nLCBTdHJpbmcpAwkAAAIFD2RlbGV0ZVJlbnRDb3VudAUPZGVsZXRlUmVudENvdW50BAZyZW50SWQIBQ9kZWxldGVSZW50Q291bnQCXzEEDG5ld0xlbmRDb3VudAkApAMBCQBkAgkBDXBhcnNlSW50VmFsdWUBCAUPZGVsZXRlTGVuZENvdW50Al8xAAEEDG5ld1JlbnRDb3VudAkApAMBCQBkAgkBDXBhcnNlSW50VmFsdWUBBQZyZW50SWQAAQQPdGltZVVuaXRTZWNvbmRzCQENcGFyc2VJbnRWYWx1ZQEKAAFACQD8BwQFCGRBcHBKc29uAg1yZWFkQnlKU09OS2V5CQDMCAIIBQtkZWxldGVSZW50cwJfMgkAzAgCAg90aW1lVW5pdFNlY29uZHMFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwMJAAACBQ90aW1lVW5pdFNlY29uZHMFD3RpbWVVbml0U2Vjb25kcwQIcmVudEpzb24KAAFACQD8BwQFCGRBcHBKc29uAghtYWtlSlNPTgkAzAgCCQDMCAICCGN1c3RvbWVyCQDMCAICDXRpbWVVbml0Q291bnQJAMwIAgIOc3RhcnRUaW1lc3RhbXAJAMwIAgIMZW5kVGltZXN0YW1wCQDMCAICBmNsb3NlZAUDbmlsCQDMCAIJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgIBMAkAzAgCBQ10aW1lVW5pdENvdW50CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBCQBkAggFCWxhc3RCbG9jawl0aW1lc3RhbXAJAGgCBQ90aW1lVW5pdFNlY29uZHMFDXRpbWVVbml0Q291bnQJAMwIAgIBMAUDbmlsBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcDCQAAAgUIcmVudEpzb24FCHJlbnRKc29uBAxuZXdSZW50c0pzb24JAPwHBAUIZEFwcEpzb24CCWFkZFRvSlNPTgkAzAgCCAUPZGVsZXRlUmVudENvdW50Al8yCQDMCAIJAMwIAgUGcmVudElkCQDMCAICCXJlbnRDb3VudAUDbmlsCQDMCAIJAMwIAgUIcmVudEpzb24JAMwIAgUMbmV3UmVudENvdW50BQNuaWwFA25pbAUDbmlsAwkAAAIFDG5ld1JlbnRzSnNvbgUMbmV3UmVudHNKc29uBAtuZXdMZW5kSnNvbgkA/AcEBQhkQXBwSnNvbgIJYWRkVG9KU09OCQDMCAIIBQtkZWxldGVSZW50cwJfMgkAzAgCCQDMCAICBXJlbnRzBQNuaWwJAMwIAgkAzAgCBQxuZXdSZW50c0pzb24FA25pbAUDbmlsBQNuaWwDCQAAAgULbmV3TGVuZEpzb24FC25ld0xlbmRKc29uBAZpbnNlcnQKAAFACQD8BwQFCGRBcHBKc29uAglhZGRUb0pTT04JAMwIAggFCmRlbGV0ZUxlbmQCXzIJAMwIAgkAzAgCBQZsZW5kSWQJAMwIAgIJbGVuZENvdW50BQNuaWwJAMwIAgkAzAgCBQtuZXdMZW5kSnNvbgkAzAgCBQxuZXdMZW5kQ291bnQFA25pbAUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nAwkAAAIFBmluc2VydAUGaW5zZXJ0CQDMCAIJAQtTdHJpbmdFbnRyeQICBUxlbmRzBQZpbnNlcnQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgBbTciA", "height": 2494289, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AiNgrN5Z8DTeANk9oSHSHxGrrTSvfiYuCj5NyUtPAPks Next: Dm7A3MW91DxkKcPe4AxFusKkQ1UV3BmfLbRWRfFbwnSJ Diff:
OldNewDifferences
144144 then @
145145 else throw(($getType(@) + " couldn't be cast to String"))
146146 }
147- let lends = getStringValue("Lends")
148- let delete = {
149- let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
150- if ($isInstanceOf(@, "(String, String)"))
151- then @
152- else throw(($getType(@) + " couldn't be cast to (String, String)"))
153- }
154- let lendId = delete._1
155- let newCount = toString((parseIntValue(lendId) + 1))
156- let make = {
157- let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
158- if ($isInstanceOf(@, "String"))
159- then @
160- else throw(($getType(@) + " couldn't be cast to String"))
161- }
162- if ((make == make))
147+ if ((tokenURI == tokenURI))
163148 then {
164- let insert = {
165- let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
166- if ($isInstanceOf(@, "String"))
149+ let lends = getStringValue("Lends")
150+ let delete = {
151+ let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
152+ if ($isInstanceOf(@, "(String, String)"))
167153 then @
168- else throw(($getType(@) + " couldn't be cast to String"))
154+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
169155 }
170- if ((insert == insert))
171- then [StringEntry("Lends", insert)]
156+ if ((delete == delete))
157+ then {
158+ let lendId = delete._1
159+ let newCount = toString((parseIntValue(lendId) + 1))
160+ let make = {
161+ let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
162+ if ($isInstanceOf(@, "String"))
163+ then @
164+ else throw(($getType(@) + " couldn't be cast to String"))
165+ }
166+ if ((make == make))
167+ then {
168+ let insert = {
169+ let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
170+ if ($isInstanceOf(@, "String"))
171+ then @
172+ else throw(($getType(@) + " couldn't be cast to String"))
173+ }
174+ if ((insert == insert))
175+ then [StringEntry("Lends", insert)]
176+ else throw("Strict value is not equal to itself.")
177+ }
178+ else throw("Strict value is not equal to itself.")
179+ }
172180 else throw("Strict value is not equal to itself.")
173181 }
174182 else throw("Strict value is not equal to itself.")
177185
178186
179187 @Callable(i)
180-func initRent (assetId,timeUnitSeconds,timeUnitPrice,timeUnitCount) = valueOrElse(checkAssetOwner(i.caller, assetId), {
181- let asset = parseIdtoAsset(assetId)
182- let tokenURI = {
183- let @ = invoke(dAppJson, "readByJSONKey", [asset.description, "tokenURI"], nil)
184- if ($isInstanceOf(@, "String"))
185- then @
186- else throw(($getType(@) + " couldn't be cast to String"))
187- }
188+func initRent (lendId,timeUnitCount) = {
189+ let lendIdString = toString(lendId)
188190 let lends = getStringValue("Lends")
189- let delete = {
191+ let deleteLendCount = {
190192 let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
191193 if ($isInstanceOf(@, "(String, String)"))
192194 then @
193195 else throw(($getType(@) + " couldn't be cast to (String, String)"))
194196 }
195- let lendId = delete._1
196- let newCount = toString((parseIntValue(lendId) + 1))
197- let make = {
198- let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
199- if ($isInstanceOf(@, "String"))
200- then @
201- else throw(($getType(@) + " couldn't be cast to String"))
202- }
203- if ((make == make))
197+ if ((deleteLendCount == deleteLendCount))
204198 then {
205- let insert = {
206- let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
207- if ($isInstanceOf(@, "String"))
199+ let deleteLend = {
200+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteLendCount._2, lendIdString], nil)
201+ if ($isInstanceOf(@, "(String, String)"))
208202 then @
209- else throw(($getType(@) + " couldn't be cast to String"))
203+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
210204 }
211- if ((insert == insert))
212- then [StringEntry("Lends", insert)]
205+ if ((deleteLend == deleteLend))
206+ then {
207+ let deleteRents = {
208+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteLend._1, "rents"], nil)
209+ if ($isInstanceOf(@, "(String, String)"))
210+ then @
211+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
212+ }
213+ if ((deleteRents == deleteRents))
214+ then {
215+ let deleteRentCount = {
216+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteRents._1, "rentCount"], nil)
217+ if ($isInstanceOf(@, "(String, String)"))
218+ then @
219+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
220+ }
221+ if ((deleteRentCount == deleteRentCount))
222+ then {
223+ let rentId = deleteRentCount._1
224+ let newLendCount = toString((parseIntValue(deleteLendCount._1) + 1))
225+ let newRentCount = toString((parseIntValue(rentId) + 1))
226+ let timeUnitSeconds = parseIntValue({
227+ let @ = invoke(dAppJson, "readByJSONKey", [deleteRents._2, "timeUnitSeconds"], nil)
228+ if ($isInstanceOf(@, "String"))
229+ then @
230+ else throw(($getType(@) + " couldn't be cast to String"))
231+ })
232+ if ((timeUnitSeconds == timeUnitSeconds))
233+ then {
234+ let rentJson = {
235+ let @ = invoke(dAppJson, "makeJSON", [["customer", "timeUnitCount", "startTimestamp", "endTimestamp", "closed"], [toString(i.caller), "0", timeUnitCount, toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0"]], nil)
236+ if ($isInstanceOf(@, "String"))
237+ then @
238+ else throw(($getType(@) + " couldn't be cast to String"))
239+ }
240+ if ((rentJson == rentJson))
241+ then {
242+ let newRentsJson = invoke(dAppJson, "addToJSON", [deleteRentCount._2, [rentId, "rentCount"], [rentJson, newRentCount]], nil)
243+ if ((newRentsJson == newRentsJson))
244+ then {
245+ let newLendJson = invoke(dAppJson, "addToJSON", [deleteRents._2, ["rents"], [newRentsJson]], nil)
246+ if ((newLendJson == newLendJson))
247+ then {
248+ let insert = {
249+ let @ = invoke(dAppJson, "addToJSON", [deleteLend._2, [lendId, "lendCount"], [newLendJson, newLendCount]], nil)
250+ if ($isInstanceOf(@, "String"))
251+ then @
252+ else throw(($getType(@) + " couldn't be cast to String"))
253+ }
254+ if ((insert == insert))
255+ then [StringEntry("Lends", insert)]
256+ else throw("Strict value is not equal to itself.")
257+ }
258+ else throw("Strict value is not equal to itself.")
259+ }
260+ else throw("Strict value is not equal to itself.")
261+ }
262+ else throw("Strict value is not equal to itself.")
263+ }
264+ else throw("Strict value is not equal to itself.")
265+ }
266+ else throw("Strict value is not equal to itself.")
267+ }
268+ else throw("Strict value is not equal to itself.")
269+ }
213270 else throw("Strict value is not equal to itself.")
214271 }
215272 else throw("Strict value is not equal to itself.")
216- })
273+ }
217274
218275
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let collectionName = getStringValue("collectionName")
55
66 let symbol = getStringValue("symbol")
77
88 let description = getStringValue("description")
99
1010 let totalAmount = getIntegerValue("totalAmount")
1111
1212 let dAppJson = Address(fromBase58String("3MrGaZVRhknEGfHJ19ttUPNnDRoFqcHhVN7"))
1313
1414 let tokenPayment = Address(getBinaryValue("tokenPayment"))
1515
1616 func onlyInternal (caller) = if ((caller == this))
1717 then unit
1818 else throw("Only internal call")
1919
2020
2121 func transferOrNot (to,assetId) = if ((to == this))
2222 then StringEntry("костыль", "костыль")
2323 else ScriptTransfer(to, 1, assetId)
2424
2525
2626 func parseIdtoAsset (assetId) = valueOrErrorMessage(assetInfo(fromBase58String(assetId)), "Can't find asset by asset id")
2727
2828
2929 func checkAssetOwner (caller,assetId) = if ((assetBalance(caller, fromBase58String(assetId)) == 1))
3030 then unit
3131 else throw("Only asset owner")
3232
3333
3434 @Callable(i)
3535 func makeJSONInternal (arrKeys,arrValues) = valueOrElse(onlyInternal(i.caller), {
3636 let res = invoke(dAppJson, "makeJSON", [arrKeys, arrValues], nil)
3737 if ((res == res))
3838 then $Tuple2(nil, res)
3939 else throw("Strict value is not equal to itself.")
4040 })
4141
4242
4343
4444 @Callable(i)
4545 func addToJSONInternal (json,arrKeys,arrValues) = valueOrElse(onlyInternal(i.caller), {
4646 let res = invoke(dAppJson, "addToJSON", [json, arrKeys, arrValues], nil)
4747 if ((res == res))
4848 then $Tuple2(nil, res)
4949 else throw("Strict value is not equal to itself.")
5050 })
5151
5252
5353
5454 @Callable(i)
5555 func readByJSONKeyInternal (json,key) = valueOrElse(onlyInternal(i.caller), {
5656 let res = invoke(dAppJson, "readByJSONKey", [json, key], nil)
5757 if ((res == res))
5858 then $Tuple2(nil, res)
5959 else throw("Strict value is not equal to itself.")
6060 })
6161
6262
6363
6464 @Callable(i)
6565 func deleteByJSONKeyInternal (json,key) = valueOrElse(onlyInternal(i.caller), {
6666 let res = invoke(dAppJson, "deleteByJSONKey", [json, key], nil)
6767 if ((res == res))
6868 then $Tuple2(nil, res)
6969 else throw("Strict value is not equal to itself.")
7070 })
7171
7272
7373
7474 @Callable(i)
7575 func storageJsonInternal (jsonKey,jsonString) = valueOrElse(onlyInternal(i.caller), [StringEntry(jsonKey, jsonString)])
7676
7777
7878
7979 @Callable(i)
8080 func setUser (assetId,user,expires) = {
8181 let res = invoke(dAppJson, "makeJSON", [["user", "expires"], [user, expires]], nil)
8282 if ((res == res))
8383 then $Tuple2([StringEntry(("userOf-" + assetId), {
8484 let @ = res
8585 if ($isInstanceOf(@, "String"))
8686 then @
8787 else throw(($getType(@) + " couldn't be cast to String"))
8888 })], res)
8989 else throw("Strict value is not equal to itself.")
9090 }
9191
9292
9393
9494 @Callable(i)
9595 func setTokenPayment (assetId) = valueOrElse(onlyInternal(i.caller), [BinaryEntry("tokenPayment", assetId)])
9696
9797
9898
9999 @Callable(i)
100100 func deleteValueByKey (key) = valueOrElse(onlyInternal(i.caller), [DeleteEntry(key)])
101101
102102
103103
104104 @Callable(i)
105105 func setString (key,value) = valueOrElse(onlyInternal(i.caller), [StringEntry(key, value)])
106106
107107
108108
109109 @Callable(i)
110110 func init (collectionName,symbol,description) = valueOrElse(onlyInternal(i.caller), [StringEntry("collectionName", collectionName), StringEntry("symbol", symbol), StringEntry("description", description), IntegerEntry("totalAmount", 0)])
111111
112112
113113
114114 @Callable(i)
115115 func mint (to,tokenURI) = {
116116 let tokenId = (totalAmount + 1)
117117 let preName = ((symbol + "#") + toString(tokenId))
118118 let name = if ((16 >= size(preName)))
119119 then preName
120120 else toString(tokenId)
121121 let json = {
122122 let @ = invoke(dAppJson, "makeJSON", [["tokenURI"], [tokenURI]], nil)
123123 if ($isInstanceOf(@, "String"))
124124 then @
125125 else throw(($getType(@) + " couldn't be cast to String"))
126126 }
127127 let asset = Issue(name, json, 1, 0, false, unit, height)
128128 let assetId = calculateAssetId(asset)
129129 let toAddress = Address(fromBase58String(to))
130130 let transfer = transferOrNot(toAddress, assetId)
131131 if ((transfer == transfer))
132132 then [asset, transfer, IntegerEntry("totalAmount", tokenId), StringEntry(name, tokenURI)]
133133 else throw("Strict value is not equal to itself.")
134134 }
135135
136136
137137
138138 @Callable(i)
139139 func initLend (assetId,timeUnitSeconds,timeUnitPrice,timeUnitCount) = valueOrElse(checkAssetOwner(i.caller, assetId), {
140140 let asset = parseIdtoAsset(assetId)
141141 let tokenURI = {
142142 let @ = invoke(dAppJson, "readByJSONKey", [asset.description, "tokenURI"], nil)
143143 if ($isInstanceOf(@, "String"))
144144 then @
145145 else throw(($getType(@) + " couldn't be cast to String"))
146146 }
147- let lends = getStringValue("Lends")
148- let delete = {
149- let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
150- if ($isInstanceOf(@, "(String, String)"))
151- then @
152- else throw(($getType(@) + " couldn't be cast to (String, String)"))
153- }
154- let lendId = delete._1
155- let newCount = toString((parseIntValue(lendId) + 1))
156- let make = {
157- let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
158- if ($isInstanceOf(@, "String"))
159- then @
160- else throw(($getType(@) + " couldn't be cast to String"))
161- }
162- if ((make == make))
147+ if ((tokenURI == tokenURI))
163148 then {
164- let insert = {
165- let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
166- if ($isInstanceOf(@, "String"))
149+ let lends = getStringValue("Lends")
150+ let delete = {
151+ let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
152+ if ($isInstanceOf(@, "(String, String)"))
167153 then @
168- else throw(($getType(@) + " couldn't be cast to String"))
154+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
169155 }
170- if ((insert == insert))
171- then [StringEntry("Lends", insert)]
156+ if ((delete == delete))
157+ then {
158+ let lendId = delete._1
159+ let newCount = toString((parseIntValue(lendId) + 1))
160+ let make = {
161+ let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
162+ if ($isInstanceOf(@, "String"))
163+ then @
164+ else throw(($getType(@) + " couldn't be cast to String"))
165+ }
166+ if ((make == make))
167+ then {
168+ let insert = {
169+ let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
170+ if ($isInstanceOf(@, "String"))
171+ then @
172+ else throw(($getType(@) + " couldn't be cast to String"))
173+ }
174+ if ((insert == insert))
175+ then [StringEntry("Lends", insert)]
176+ else throw("Strict value is not equal to itself.")
177+ }
178+ else throw("Strict value is not equal to itself.")
179+ }
172180 else throw("Strict value is not equal to itself.")
173181 }
174182 else throw("Strict value is not equal to itself.")
175183 })
176184
177185
178186
179187 @Callable(i)
180-func initRent (assetId,timeUnitSeconds,timeUnitPrice,timeUnitCount) = valueOrElse(checkAssetOwner(i.caller, assetId), {
181- let asset = parseIdtoAsset(assetId)
182- let tokenURI = {
183- let @ = invoke(dAppJson, "readByJSONKey", [asset.description, "tokenURI"], nil)
184- if ($isInstanceOf(@, "String"))
185- then @
186- else throw(($getType(@) + " couldn't be cast to String"))
187- }
188+func initRent (lendId,timeUnitCount) = {
189+ let lendIdString = toString(lendId)
188190 let lends = getStringValue("Lends")
189- let delete = {
191+ let deleteLendCount = {
190192 let @ = invoke(dAppJson, "deleteByJSONKey", [lends, "lendCount"], nil)
191193 if ($isInstanceOf(@, "(String, String)"))
192194 then @
193195 else throw(($getType(@) + " couldn't be cast to (String, String)"))
194196 }
195- let lendId = delete._1
196- let newCount = toString((parseIntValue(lendId) + 1))
197- let make = {
198- let @ = invoke(dAppJson, "makeJSON", [["supportedInterface", "assetdId", "tokenURI", "owner", "timeUnitSeconds", "timeUnitPrice", "timeUnitCount", "startTimestamp", "endTimestamp", "deposit", "claimed", "rents"], ["0", assetId, tokenURI, toString(i.caller), toString(timeUnitSeconds), toString(timeUnitPrice), toString(timeUnitCount), toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0", "0", "{\"rentCount\":\"0\"}"]], nil)
199- if ($isInstanceOf(@, "String"))
200- then @
201- else throw(($getType(@) + " couldn't be cast to String"))
202- }
203- if ((make == make))
197+ if ((deleteLendCount == deleteLendCount))
204198 then {
205- let insert = {
206- let @ = invoke(dAppJson, "addToJSON", [delete._2, [lendId, "lendCount"], [make, newCount]], nil)
207- if ($isInstanceOf(@, "String"))
199+ let deleteLend = {
200+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteLendCount._2, lendIdString], nil)
201+ if ($isInstanceOf(@, "(String, String)"))
208202 then @
209- else throw(($getType(@) + " couldn't be cast to String"))
203+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
210204 }
211- if ((insert == insert))
212- then [StringEntry("Lends", insert)]
205+ if ((deleteLend == deleteLend))
206+ then {
207+ let deleteRents = {
208+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteLend._1, "rents"], nil)
209+ if ($isInstanceOf(@, "(String, String)"))
210+ then @
211+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
212+ }
213+ if ((deleteRents == deleteRents))
214+ then {
215+ let deleteRentCount = {
216+ let @ = invoke(dAppJson, "deleteByJSONKey", [deleteRents._1, "rentCount"], nil)
217+ if ($isInstanceOf(@, "(String, String)"))
218+ then @
219+ else throw(($getType(@) + " couldn't be cast to (String, String)"))
220+ }
221+ if ((deleteRentCount == deleteRentCount))
222+ then {
223+ let rentId = deleteRentCount._1
224+ let newLendCount = toString((parseIntValue(deleteLendCount._1) + 1))
225+ let newRentCount = toString((parseIntValue(rentId) + 1))
226+ let timeUnitSeconds = parseIntValue({
227+ let @ = invoke(dAppJson, "readByJSONKey", [deleteRents._2, "timeUnitSeconds"], nil)
228+ if ($isInstanceOf(@, "String"))
229+ then @
230+ else throw(($getType(@) + " couldn't be cast to String"))
231+ })
232+ if ((timeUnitSeconds == timeUnitSeconds))
233+ then {
234+ let rentJson = {
235+ let @ = invoke(dAppJson, "makeJSON", [["customer", "timeUnitCount", "startTimestamp", "endTimestamp", "closed"], [toString(i.caller), "0", timeUnitCount, toString(lastBlock.timestamp), toString((lastBlock.timestamp + (timeUnitSeconds * timeUnitCount))), "0"]], nil)
236+ if ($isInstanceOf(@, "String"))
237+ then @
238+ else throw(($getType(@) + " couldn't be cast to String"))
239+ }
240+ if ((rentJson == rentJson))
241+ then {
242+ let newRentsJson = invoke(dAppJson, "addToJSON", [deleteRentCount._2, [rentId, "rentCount"], [rentJson, newRentCount]], nil)
243+ if ((newRentsJson == newRentsJson))
244+ then {
245+ let newLendJson = invoke(dAppJson, "addToJSON", [deleteRents._2, ["rents"], [newRentsJson]], nil)
246+ if ((newLendJson == newLendJson))
247+ then {
248+ let insert = {
249+ let @ = invoke(dAppJson, "addToJSON", [deleteLend._2, [lendId, "lendCount"], [newLendJson, newLendCount]], nil)
250+ if ($isInstanceOf(@, "String"))
251+ then @
252+ else throw(($getType(@) + " couldn't be cast to String"))
253+ }
254+ if ((insert == insert))
255+ then [StringEntry("Lends", insert)]
256+ else throw("Strict value is not equal to itself.")
257+ }
258+ else throw("Strict value is not equal to itself.")
259+ }
260+ else throw("Strict value is not equal to itself.")
261+ }
262+ else throw("Strict value is not equal to itself.")
263+ }
264+ else throw("Strict value is not equal to itself.")
265+ }
266+ else throw("Strict value is not equal to itself.")
267+ }
268+ else throw("Strict value is not equal to itself.")
269+ }
213270 else throw("Strict value is not equal to itself.")
214271 }
215272 else throw("Strict value is not equal to itself.")
216- })
273+ }
217274
218275

github/deemru/w8io/026f985 
52.34 ms