tx · GjW8VTNFxiB5gtx45z6SXibfwwsNDBaZZWw5tHFeZ48G 3P7Q9V1kRHf5QLwnCRdPqedtLSbWjsbdyT6: -0.01700000 Waves 2022.10.13 14:07 [3335945] smart account 3P7Q9V1kRHf5QLwnCRdPqedtLSbWjsbdyT6 > SELF 0.00000000 Waves
{ "type": 13, "id": "GjW8VTNFxiB5gtx45z6SXibfwwsNDBaZZWw5tHFeZ48G", "fee": 1700000, "feeAssetId": null, "timestamp": 1665659219264, "version": 2, "chainId": 87, "sender": "3P7Q9V1kRHf5QLwnCRdPqedtLSbWjsbdyT6", "senderPublicKey": "3hg7tWuvw2tmKXMDJ1KvavAQEqFDv3Er4Agkri6WbWmo", "proofs": [ "5qMGCgmLVZvbtr6cTSk3XEmLQTrp2fRGS2sbWU3iR7UeYJsDd7QGSWQMy9mkAiuFNFmRBHCExMLXxdvoYbgjdHtT" ], "script": "base64:BgI/CAISBAoCCAgSCAoGCAEBCAgIEgQKAggBEgQKAggIEgQKAggEEgQKAggEEgASABIDCgEIEgUKAwgICBIDCgEIMwAJdW5kZWZpbmVkAgl1bmRlZmluZWQACXNlcGFyYXRvcgIBOwAQY29uZmlnQWRkcmVzc0tleQIGY29uZmlnABNjb2xsZWN0b3JBZGRyZXNzS2V5AhFjb2xsZWN0b3JfYWRkcmVzcwARaGlzdG9yeUFkZHJlc3NLZXkCD2hpc3RvcnlfYWRkcmVzcwAJYWRtaW5zS2V5AgZhZG1pbnMADWNvbmZpZ0FkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMFEGNvbmZpZ0FkZHJlc3NLZXkAEGNvbGxlY3RvckFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFDWNvbmZpZ0FkZHJlc3MFE2NvbGxlY3RvckFkZHJlc3NLZXkADmhpc3RvcnlBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzBRFoaXN0b3J5QWRkcmVzc0tleQEHaXNBZG1pbgEGY2FsbGVyBAZhZG1Sb3cJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwUJYWRtaW5zS2V5AgADAwkAAAIFBmNhbGxlcgUEdGhpcwYJAQhjb250YWlucwIFBmFkbVJvdwkApQgBBQZjYWxsZXIGBwENZ2V0Q2hlY2tlcktleQEHY2hlY2tlcgkArAICAghjaGVja2VyXwUHY2hlY2tlcgEJaXNDaGVja2VyAQdjaGVja2VyBAhpc0V4aXN0cwkBCWlzRGVmaW5lZAEJAJ0IAgUNY29uZmlnQWRkcmVzcwkBDWdldENoZWNrZXJLZXkBCQClCAEFB2NoZWNrZXIFCGlzRXhpc3RzAARVU0ROASC2JinDBPXOU5GkDkt1JC9kjFGx+t+vVCm9SNIdKrKq0QAJbWluQW1vdW50AICt4gQADGZlZU51bWVyYXRvcgAFAA5mZWVEZW5vbWluYXRvcgBkAA1maXJzdEV2ZW50S2V5AgtmaXJzdF9ldmVudAAMbGFzdEV2ZW50S2V5AgpsYXN0X2V2ZW50ABVmaXNydEZpbmlzaGVkRXZlbnRLZXkCFGZpcnN0X2ZpbmlzaGVkX2V2ZW50ABRsYXN0RmluaXNoZWRFdmVudEtleQITbGFzdF9maW5pc2hlZF9ldmVudAATZmlzcnRBY3RpdmVFdmVudEtleQISZmlyc3RfYWN0aXZlX2V2ZW50ABJsYXN0QWN0aXZlRXZlbnRLZXkCEWxhc3RfYWN0aXZlX2V2ZW50ARBnZXRTdGFydEJsb2NrS2V5AQdldmVudElkCQCsAgIFB2V2ZW50SWQCDF9zdGFydF9ibG9jawEOZ2V0RW5kQmxvY2tLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIKX2VuZF9ibG9jawEOZ2V0RmluaXNoQXRLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIQX2ZpbmlzaF9hdF9ibG9jawEXZ2V0QW5zd2VyRGFwcEFkZHJlc3NLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIMX2Fuc3dlcl9kYXBwARdnZXRBbnN3ZXJGdW5jQWRkcmVzc0tleQEHZXZlbnRJZAkArAICBQdldmVudElkAgxfYW5zd2VyX2Z1bmMBDGdldFJlc3VsdEtleQEHZXZlbnRJZAkArAICBQdldmVudElkAgdfcmVzdWx0AQhnZXRJZEtleQEHZXZlbnRJZAkArAICBQdldmVudElkAgNfaWQBDWdldEFuc3dlck5LZXkCB2V2ZW50SWQBbgkArAICCQCsAgIFB2V2ZW50SWQCCF9hbnN3ZXJfCQCkAwEFAW4BEmdldEFuc3dlcnNDb3VudEtleQEHZXZlbnRJZAkArAICBQdldmVudElkAg5fYW5zd2Vyc19jb3VudAEMZ2V0U3RhdHVzS2V5AQdldmVudElkCQCsAgIFB2V2ZW50SWQCB19zdGF0dXMBCmdldERlc2NLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIMX2Rlc2NyaXB0aW9uAQ9nZXRQcmV2RXZlbnRLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAILX3ByZXZfZXZlbnQBD2dldE5leHRFdmVudEtleQEHZXZlbnRJZAkArAICBQdldmVudElkAgtfbmV4dF9ldmVudAEUZ2V0Q2xhaW1BdmFpbGFibGVLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIQX2NsYWltX2F2YWlsYWJsZQEMZ2V0UGFyYW1zS2V5AQdldmVudElkCQCsAgIFB2V2ZW50SWQCB19wYXJhbXMBEWdldFRvdGFsQW1vdW50S2V5AQdldmVudElkCQCsAgIFB2V2ZW50SWQCDV90b3RhbF9hbW91bnQBGWdldENsYWltZWRXaW5uZXJzQ291bnRLZXkBB2V2ZW50SWQJAKwCAgUHZXZlbnRJZAIWX2NsYWltZWRfd2lubmVyc19jb3VudAENZ2V0QW1vdW50TktleQIHZXZlbnRJZAFuCQCsAgIJAKwCAgkArAICBQdldmVudElkAgFfCQCkAwEFAW4CB19hbW91bnQBDGdldENvdW50TktleQIHZXZlbnRJZAFuCQCsAgIJAKwCAgkArAICBQdldmVudElkAgFfCQCkAwEFAW4CBl9jb3VudAETZ2V0QW1vdW50QWRkcmVzc0tleQIHZXZlbnRJZAdhZGRyZXNzCQCsAgIJAKwCAgkArAICBQdldmVudElkAgFfBQdhZGRyZXNzAgdfYW1vdW50ARNnZXRDaG9pY2VBZGRyZXNzS2V5AgdldmVudElkB2FkZHJlc3MJAKwCAgkArAICCQCsAgIFB2V2ZW50SWQCAV8FB2FkZHJlc3MCB19jaG9pY2UBG2dldEFscmVhZHlDbGFpbWVkQWRkcmVzc0tleQIHZXZlbnRJZAdhZGRyZXNzCQCsAgIJAKwCAgkArAICBQdldmVudElkAgFfBQdhZGRyZXNzAhBfYWxyZWFkeV9jbGFpbWVkAQVhc0ludAEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAFAXgEAXQFByRtYXRjaDAJAAIBAgQjZXJyAQhhc1N0cmluZwEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXgFByRtYXRjaDAFAXgJAAIBAgQjZXJyAQlnZXRTdGF0dXMBB2V2ZW50SWQEBnN0YXR1cwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEMZ2V0U3RhdHVzS2V5AQUHZXZlbnRJZAIBIwMDAwkAAAIFBnN0YXR1cwIIZmluaXNoZWQGCQAAAgUGc3RhdHVzAgEjBgkAAAIFBnN0YXR1cwIFZW5kZWQFBnN0YXR1cwQIZmluaXNoQXQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAQ5nZXRGaW5pc2hBdEtleQEFB2V2ZW50SWQECnN0YXJ0QmxvY2sJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARBnZXRTdGFydEJsb2NrS2V5AQUHZXZlbnRJZAQIZW5kQmxvY2sJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAQ5nZXRFbmRCbG9ja0tleQEFB2V2ZW50SWQDCQBmAgUKc3RhcnRCbG9jawUGaGVpZ2h0Aghhd2FpdGluZwMDCQBnAgUGaGVpZ2h0BQpzdGFydEJsb2NrCQBnAgUIZW5kQmxvY2sFBmhlaWdodAcCBmFjdGl2ZQMDCQBmAgUGaGVpZ2h0BQhlbmRCbG9jawkAZwIFCGZpbmlzaEF0BQZoZWlnaHQHAgxjb25maXJtYXRpb24DCQBmAgUGaGVpZ2h0BQhmaW5pc2hBdAIIZmluaXNoZWQJAAIBAg51bmtub3duIHN0YXR1cwEQaXNDbGFpbUF2YWlsYWJsZQEHZXZlbnRJZAQBcgkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzCQEUZ2V0Q2xhaW1BdmFpbGFibGVLZXkBBQdldmVudElkBwMJAAACBQFyBgYJAAIBAhZjbGFpbSBpcyBub3QgYXZhaWxhYmxlAQ1yZWdpc3RlckV2ZW50CAR0eGlkBGRlc2MKc3RhcnRCbG9jawhlbmRCbG9jawhmaW5pc2hBdAtjaGVja2VyRGFwcAtjaGVja2VyRnVuYwZwYXJhbXMEB2V2ZW50SWQFBHR4aWQEDGFuc3dlclJlc3VsdAkBBWFzSW50AQkA/AcEBQR0aGlzAgVjaGVjawkAzAgCBQtjaGVja2VyRGFwcAkAzAgCBQtjaGVja2VyRnVuYwkAzAgCBQZwYXJhbXMFA25pbAUDbmlsAwkAAAIFDGFuc3dlclJlc3VsdAUMYW5zd2VyUmVzdWx0BAZpbnNlcnQJAPwHBAUEdGhpcwIMaW5zZXJ0VG9MaXN0CQDMCAIFB2V2ZW50SWQJAMwIAgYFA25pbAUDbmlsAwkAAAIFBmluc2VydAUGaW5zZXJ0BAZjb25jYXQJAPwHBAUEdGhpcwILY29uY2F0TGlzdHMFA25pbAUDbmlsAwkAAAIFBmNvbmNhdAUGY29uY2F0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEQZ2V0U3RhcnRCbG9ja0tleQEFB2V2ZW50SWQFCnN0YXJ0QmxvY2sJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ5nZXRFbmRCbG9ja0tleQEFB2V2ZW50SWQFCGVuZEJsb2NrCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOZ2V0RmluaXNoQXRLZXkBBQdldmVudElkBQhmaW5pc2hBdAkAzAgCCQELU3RyaW5nRW50cnkCCQEXZ2V0QW5zd2VyRGFwcEFkZHJlc3NLZXkBBQdldmVudElkBQtjaGVja2VyRGFwcAkAzAgCCQELU3RyaW5nRW50cnkCCQEXZ2V0QW5zd2VyRnVuY0FkZHJlc3NLZXkBBQdldmVudElkBQtjaGVja2VyRnVuYwkAzAgCCQELU3RyaW5nRW50cnkCCQEKZ2V0RGVzY0tleQEFB2V2ZW50SWQFBGRlc2MJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGdldFN0YXR1c0tleQEFB2V2ZW50SWQCBmFjdGl2ZQkAzAgCCQELU3RyaW5nRW50cnkCCQEIZ2V0SWRLZXkBBQdldmVudElkBQdldmVudElkCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ1nZXRBbnN3ZXJOS2V5AgUHZXZlbnRJZAABAgJOTwkAzAgCCQELU3RyaW5nRW50cnkCCQENZ2V0QW5zd2VyTktleQIFB2V2ZW50SWQAAgIDWUVTCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQESZ2V0QW5zd2Vyc0NvdW50S2V5AQUHZXZlbnRJZAACCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEMZ2V0UmVzdWx0S2V5AQUHZXZlbnRJZAABCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQxnZXRQYXJhbXNLZXkBBQdldmVudElkBQZwYXJhbXMFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEHZ2V0SnNvbgEHc3RhcnRJZAQHZXZlbnRJZAkBCGFzU3RyaW5nAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEIZ2V0SWRLZXkBBQdzdGFydElkCQCdCAIFBHRoaXMFDWZpcnN0RXZlbnRLZXkEC25leHRFdmVudElkCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQEPZ2V0TmV4dEV2ZW50S2V5AQUHZXZlbnRJZAQKc3RhcnRCbG9jawkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBEGdldFN0YXJ0QmxvY2tLZXkBBQdldmVudElkBAhlbmRCbG9jawkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBDmdldEVuZEJsb2NrS2V5AQUHZXZlbnRJZAQLZmluaXNoQmxvY2sJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAQ5nZXRGaW5pc2hBdEtleQEFB2V2ZW50SWQEC2NoZWNrZXJEYXBwCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQEXZ2V0QW5zd2VyRGFwcEFkZHJlc3NLZXkBBQdldmVudElkBAtjaGVja2VyRnVuYwkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBF2dldEFuc3dlckZ1bmNBZGRyZXNzS2V5AQUHZXZlbnRJZAQEZGVzYwkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBCmdldERlc2NLZXkBBQdldmVudElkBAZzdGF0dXMJAQlnZXRTdGF0dXMBBQdldmVudElkBAZyZXN1bHQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAQxnZXRSZXN1bHRLZXkBBQdldmVudElkBAxhbnN3ZXJzQ291bnQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARJnZXRBbnN3ZXJzQ291bnRLZXkBBQdldmVudElkBAxhbnN3ZXJzQXJyYXkJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICAVsDCQBnAgUMYW5zd2Vyc0NvdW50AAEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgACBnsidiI6IgkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBDWdldEFuc3dlck5LZXkCBQdldmVudElk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ZXY0Al8xBQl1bmRlZmluZWQJAKwCAgIBLAgFA2V2NQJfMgIAAwkBAiE9AggFA2V2NQJfMQUJdW5kZWZpbmVkCQCsAgICASwIBQNldjYCXzICAAMJAQIhPQIIBQNldjYCXzEFCXVuZGVmaW5lZAkArAICAgEsCAUDZXY3Al8yAgADCQECIT0CCAUDZXY3Al8xBQl1bmRlZmluZWQJAKwCAgIBLAgFA2V2OAJfMgIAAwkBAiE9AggFA2V2OAJfMQUJdW5kZWZpbmVkCQCsAgICASwIBQNldjkCXzICAAIBXQkAlAoCCAUDZXY5Al8xBQVhcnJheQsBaQEEaW5pdAIGY29uZmlnBGRlc2MDCQEBIQEJAQdpc0FkbWluAQgFAWkGY2FsbGVyCQACAQIRb25seSBhZG1pbiBjYW4gZG8ECGlzRXhpc3RzCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzBRBjb25maWdBZGRyZXNzS2V5AwkBASEBBQhpc0V4aXN0cwQDaW52CQD8BwQFDWNvbmZpZ0FkZHJlc3MCCnNldEV2ZW50ZXIJAMwIAgkApQgBBQR0aGlzCQDMCAIFBGRlc2MFA25pbAUDbmlsAwkAAAIFA2ludgUDaW52CQDMCAIJAQtTdHJpbmdFbnRyeQIFEGNvbmZpZ0FkZHJlc3NLZXkFBmNvbmZpZwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIOYWxyZWFkeSBpbml0ZWQBaQERZnVsbFJlZ2lzdGVyRXZlbnQGBGRlc2MKc3RhcnRCbG9jawhkdXJhdGlvbgtjaGVja2VyRGFwcAtjaGVja2VyRnVuYwZwYXJhbXMEDW5ld1N0YXJ0QmxvY2sDCQAAAgUKc3RhcnRCbG9jawAABQZoZWlnaHQFCnN0YXJ0QmxvY2sECGVuZEJsb2NrCQBkAgUNbmV3U3RhcnRCbG9jawUIZHVyYXRpb24ECGZpbmlzaEF0CQBkAgUIZW5kQmxvY2sAoAsDCQEBIQEJAQdpc0FkbWluAQgFAWkGY2FsbGVyCQACAQIRb25seSBhZG1pbiBjYW4gZG8EBHR4aWQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAkBDXJlZ2lzdGVyRXZlbnQIBQR0eGlkBQRkZXNjBQ1uZXdTdGFydEJsb2NrBQhlbmRCbG9jawUIZmluaXNoQXQFC2NoZWNrZXJEYXBwBQtjaGVja2VyRnVuYwUGcGFyYW1zAWkBBmNob2ljZQIHZXZlbnRJZAZjaG9pY2UEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBAVjaGVjawkA/AcEBQR0aGlzAgtjaGVja1Jlc3VsdAkAzAgCBQdldmVudElkBQNuaWwFA25pbAMJAAACBQVjaGVjawUFY2hlY2sEBnN0YXR1cwkBCWdldFN0YXR1cwEFB2V2ZW50SWQDCQAAAgUGc3RhdHVzAgZhY3RpdmUDAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUEVVNETgcEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQDCQBmAgUJbWluQW1vdW50BQZhbW91bnQJAAIBAhthbW91bnQgaXMgbGVzcyB0aGFuIGFsbG93ZWQEDGFuc3dlcnNDb3VudAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBEmdldEFuc3dlcnNDb3VudEtleQEFB2V2ZW50SWQDAwkAAAIFBmNob2ljZQAABgkAZgIFBmNob2ljZQUMYW5zd2Vyc0NvdW50CQACAQIRY2hvaWNlIGlzIGludmFsaWQEDGN1cnJlbnRUb3RhbAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQERZ2V0VG90YWxBbW91bnRLZXkBBQdldmVudElkAAAEC2Nob2ljZVRvdGFsCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ1nZXRBbW91bnROS2V5AgUHZXZlbnRJZAUGY2hvaWNlAAAEC2Nob2ljZUNvdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQxnZXRDb3VudE5LZXkCBQdldmVudElkBQZjaG9pY2UAAAQNYWRkcmVzc0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQETZ2V0QW1vdW50QWRkcmVzc0tleQIFB2V2ZW50SWQFB2FkZHJlc3MAAAMJAQIhPQIFDWFkZHJlc3NBbW91bnQAAAkAAgECI2JldHRpbmcgZnJvbSB0aGlzIGFkZHJlc3MgaXMgZXhpc3RzBARzYXZlCQD8BwQFDmhpc3RvcnlBZGRyZXNzAg1zYXZlVG9IaXN0b3J5CQDMCAIFB2V2ZW50SWQJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwDCQAAAgUEc2F2ZQUEc2F2ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEWdldFRvdGFsQW1vdW50S2V5AQUHZXZlbnRJZAkAZAIFDGN1cnJlbnRUb3RhbAUGYW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQENZ2V0QW1vdW50TktleQIFB2V2ZW50SWQFBmNob2ljZQkAZAIFC2Nob2ljZVRvdGFsBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQxnZXRDb3VudE5LZXkCBQdldmVudElkBQZjaG9pY2UJAGQCBQtjaG9pY2VDb3VudAABCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQETZ2V0Q2hvaWNlQWRkcmVzc0tleQIFB2V2ZW50SWQFB2FkZHJlc3MFBmNob2ljZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBE2dldEFtb3VudEFkZHJlc3NLZXkCBQdldmVudElkBQdhZGRyZXNzBQZhbW91bnQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECC0JhZCBwYXltZW50CQACAQIPWW91IGNhbmB0IGRvIGl0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBWNsYWltAgdldmVudElkCnN0ckFkZHJlc3MDCQEBIQEJARBpc0NsYWltQXZhaWxhYmxlAQUHZXZlbnRJZAkAAgECFmNsYWltIGlzIG5vdCBhdmFpbGFibGUEB2FkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCnN0ckFkZHJlc3MEBnN0YXR1cwkBCWdldFN0YXR1cwEFB2V2ZW50SWQDCQAAAgUGc3RhdHVzAghmaW5pc2hlZAQLdG90YWxBbW91bnQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARFnZXRUb3RhbEFtb3VudEtleQEFB2V2ZW50SWQEDmFscmVhZHlDbGFpbWVkCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJARtnZXRBbHJlYWR5Q2xhaW1lZEFkZHJlc3NLZXkCBQdldmVudElkCQClCAEFB2FkZHJlc3MHAwUOYWxyZWFkeUNsYWltZWQJAAIBAhZSZXdhcmQgYWxyZWFkeSBjbGFpbWVkBA1hZGRyZXNzQ2hvaWNlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQETZ2V0Q2hvaWNlQWRkcmVzc0tleQIFB2V2ZW50SWQJAKUIAQUHYWRkcmVzcwQGcmVzdWx0CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQEMZ2V0UmVzdWx0S2V5AQUHZXZlbnRJZAQLY2hvaWNlVG90YWwJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAQ1nZXRBbW91bnROS2V5AgUHZXZlbnRJZAUGcmVzdWx0BA1hZGRyZXNzQW1vdW50CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQETZ2V0QW1vdW50QWRkcmVzc0tleQIFB2V2ZW50SWQJAKUIAQUHYWRkcmVzcwMJAAACBQ1hZGRyZXNzQ2hvaWNlBQZyZXN1bHQEDWFkZHJlc3NSZXdhcmQJAGsDBQt0b3RhbEFtb3VudAUNYWRkcmVzc0Ftb3VudAULY2hvaWNlVG90YWwEA2ZlZQkAawMFDWFkZHJlc3NSZXdhcmQFDGZlZU51bWVyYXRvcgUOZmVlRGVub21pbmF0b3IEDmNsYWltZWRXaW5uZXJzCQBkAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEZZ2V0Q2xhaW1lZFdpbm5lcnNDb3VudEtleQEFB2V2ZW50SWQAAAABBAtjaG9pY2VDb3VudAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBDGdldENvdW50TktleQIFB2V2ZW50SWQFBnJlc3VsdAMJAAACBQ5jbGFpbWVkV2lubmVycwULY2hvaWNlQ291bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDGdldFN0YXR1c0tleQEFB2V2ZW50SWQCBWVuZGVkCQDMCAIJAQxCb29sZWFuRW50cnkCCQETZ2V0Q2hvaWNlQWRkcmVzc0tleQIFB2V2ZW50SWQJAKUIAQUHYWRkcmVzcwYJAMwIAgkBDEludGVnZXJFbnRyeQIJARlnZXRDbGFpbWVkV2lubmVyc0NvdW50S2V5AQUHZXZlbnRJZAUOY2xhaW1lZFdpbm5lcnMJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwkAZQIFDWFkZHJlc3NSZXdhcmQFA2ZlZQUEVVNETgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRBjb2xsZWN0b3JBZGRyZXNzBQNmZWUFBFVTRE4FA25pbAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBE2dldENob2ljZUFkZHJlc3NLZXkCBQdldmVudElkCQClCAEFB2FkZHJlc3MGCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEZZ2V0Q2xhaW1lZFdpbm5lcnNDb3VudEtleQEFB2V2ZW50SWQFDmNsYWltZWRXaW5uZXJzCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFB2FkZHJlc3MFDWFkZHJlc3NSZXdhcmQFBFVTRE4JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUQY29sbGVjdG9yQWRkcmVzcwUDZmVlBQRVU0ROBQNuaWwJAAIBAhRTb21ldGhpbmcgd2VudCB3cm9uZwkAAgECD1lvdSBjYW5gdCBkbyBpdAFpAQ5kZWxldGVGcm9tTGlzdAIHZXZlbnRJZAhpc0FjdGl2ZQMJAQIhPQIFBHRoaXMIBQFpBmNhbGxlcgkAAgECEG9ubHkgbWFpbiBjYW4gZG8EB2xhc3RLZXkDBQhpc0FjdGl2ZQUSbGFzdEFjdGl2ZUV2ZW50S2V5BRRsYXN0RmluaXNoZWRFdmVudEtleQQIZmlyc3RLZXkDBQhpc0FjdGl2ZQUTZmlzcnRBY3RpdmVFdmVudEtleQUVZmlzcnRGaW5pc2hlZEV2ZW50S2V5BAlwcmV2RXZlbnQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ9nZXRQcmV2RXZlbnRLZXkBBQdldmVudElkBAluZXh0RXZlbnQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ9nZXROZXh0RXZlbnRLZXkBBQdldmVudElkAwMJAAACBQlwcmV2RXZlbnQFCXVuZGVmaW5lZAkAAAIFCW5leHRFdmVudAUJdW5kZWZpbmVkBwkAzAgCCQELU3RyaW5nRW50cnkCBQhmaXJzdEtleQUJdW5kZWZpbmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2xhc3RLZXkFCXVuZGVmaW5lZAUDbmlsAwMJAQIhPQIFCXByZXZFdmVudAUJdW5kZWZpbmVkCQECIT0CBQluZXh0RXZlbnQFCXVuZGVmaW5lZAcJAMwIAgkBC1N0cmluZ0VudHJ5AgkBD2dldFByZXZFdmVudEtleQEFCW5leHRFdmVudAUJcHJldkV2ZW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ9nZXROZXh0RXZlbnRLZXkBBQlwcmV2RXZlbnQFCW5leHRFdmVudAUDbmlsAwkBAiE9AgUJcHJldkV2ZW50BQl1bmRlZmluZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUHbGFzdEtleQUJcHJldkV2ZW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ9nZXROZXh0RXZlbnRLZXkBBQlwcmV2RXZlbnQFCXVuZGVmaW5lZAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIFCGZpcnN0S2V5BQluZXh0RXZlbnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBD2dldFByZXZFdmVudEtleQEFCW5leHRFdmVudAUJdW5kZWZpbmVkBQNuaWwBaQEMaW5zZXJ0VG9MaXN0AgdldmVudElkCGlzQWN0aXZlAwkBAiE9AgUEdGhpcwgFAWkGY2FsbGVyCQACAQIQb25seSBtYWluIGNhbiBkbwQHbGFzdEtleQMFCGlzQWN0aXZlBRJsYXN0QWN0aXZlRXZlbnRLZXkFFGxhc3RGaW5pc2hlZEV2ZW50S2V5BAhmaXJzdEtleQMFCGlzQWN0aXZlBRNmaXNydEFjdGl2ZUV2ZW50S2V5BRVmaXNydEZpbmlzaGVkRXZlbnRLZXkECmZpcnN0RXZlbnQJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUIZmlyc3RLZXkFCXVuZGVmaW5lZAQJbGFzdEV2ZW50CQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFB2xhc3RLZXkFCXVuZGVmaW5lZAQQbmV3TGFzdE9yUHJldktleQMJAAACBQlsYXN0RXZlbnQFCXVuZGVmaW5lZAUHbGFzdEtleQkBD2dldFByZXZFdmVudEtleQEFCmZpcnN0RXZlbnQJAMwIAgkBC1N0cmluZ0VudHJ5AgUIZmlyc3RLZXkFB2V2ZW50SWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUQbmV3TGFzdE9yUHJldktleQUHZXZlbnRJZAkAzAgCCQELU3RyaW5nRW50cnkCCQEPZ2V0TmV4dEV2ZW50S2V5AQUHZXZlbnRJZAUKZmlyc3RFdmVudAUDbmlsAWkBC2NvbmNhdExpc3RzAAMJAQEhAQkBB2lzQWRtaW4BCAUBaQZjYWxsZXIJAAIBAhFvbmx5IGFkbWluIGNhbiBkbwQQZmlyc3RBY3RpdmVFdmVudAkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBRNmaXNydEFjdGl2ZUV2ZW50S2V5BQl1bmRlZmluZWQED2xhc3RBY3RpdmVFdmVudAkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBRJsYXN0QWN0aXZlRXZlbnRLZXkFCXVuZGVmaW5lZAQSZmlyc3RGaW5pc2hlZEV2ZW50CQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFFWZpc3J0RmluaXNoZWRFdmVudEtleQUJdW5kZWZpbmVkBBFsYXN0RmluaXNoZWRFdmVudAkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBRRsYXN0RmluaXNoZWRFdmVudEtleQUJdW5kZWZpbmVkBApmaXJzdEV2ZW50AwkBAiE9AgUQZmlyc3RBY3RpdmVFdmVudAUJdW5kZWZpbmVkBRBmaXJzdEFjdGl2ZUV2ZW50BRJmaXJzdEZpbmlzaGVkRXZlbnQECWxhc3RFdmVudAMJAQIhPQIFEWxhc3RGaW5pc2hlZEV2ZW50BQl1bmRlZmluZWQFEWxhc3RGaW5pc2hlZEV2ZW50BQ9sYXN0QWN0aXZlRXZlbnQDAwkBAiE9AgUSZmlyc3RGaW5pc2hlZEV2ZW50BQl1bmRlZmluZWQJAQIhPQIFD2xhc3RBY3RpdmVFdmVudAUJdW5kZWZpbmVkBwkAzAgCCQELU3RyaW5nRW50cnkCBQ1maXJzdEV2ZW50S2V5BQpmaXJzdEV2ZW50CQDMCAIJAQtTdHJpbmdFbnRyeQIFDGxhc3RFdmVudEtleQUJbGFzdEV2ZW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ9nZXROZXh0RXZlbnRLZXkBBQ9sYXN0QWN0aXZlRXZlbnQFEmZpcnN0RmluaXNoZWRFdmVudAkAzAgCCQELU3RyaW5nRW50cnkCCQEPZ2V0UHJldkV2ZW50S2V5AQUSZmlyc3RGaW5pc2hlZEV2ZW50BQ9sYXN0QWN0aXZlRXZlbnQFA25pbAkAzAgCCQELU3RyaW5nRW50cnkCBQ1maXJzdEV2ZW50S2V5BQpmaXJzdEV2ZW50CQDMCAIJAQtTdHJpbmdFbnRyeQIFDGxhc3RFdmVudEtleQUJbGFzdEV2ZW50BQNuaWwBaQEJcmVzZXRMaXN0AAMJAQEhAQkBB2lzQWRtaW4BCAUBaQZjYWxsZXIJAAIBAhFvbmx5IGFkbWluIGNhbiBkbwkAzAgCCQELU3RyaW5nRW50cnkCBQ1maXJzdEV2ZW50S2V5BQl1bmRlZmluZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUMbGFzdEV2ZW50S2V5BQl1bmRlZmluZWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUTZmlzcnRBY3RpdmVFdmVudEtleQUJdW5kZWZpbmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFEmxhc3RBY3RpdmVFdmVudEtleQUJdW5kZWZpbmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFFWZpc3J0RmluaXNoZWRFdmVudEtleQUJdW5kZWZpbmVkCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGxhc3RGaW5pc2hlZEV2ZW50S2V5BQl1bmRlZmluZWQFA25pbAFpAQphbGxvd0NsYWltAQdldmVudElkAwkBASEBCQEHaXNBZG1pbgEIBQFpBmNhbGxlcgkAAgECEW9ubHkgYWRtaW4gY2FuIGRvCQDMCAIJAQxCb29sZWFuRW50cnkCCQEUZ2V0Q2xhaW1BdmFpbGFibGVLZXkBBQdldmVudElkBgUDbmlsAWkBBWNoZWNrAwRkYXBwCGZ1bmN0aW9uBnBhcmFtcwMJAQIhPQIFBHRoaXMIBQFpBmNhbGxlcgkAAgECEG9ubHkgbWFpbiBjYW4gZG8DCQEBIQEJAQlpc0NoZWNrZXIBCAUBaQZjYWxsZXIJAAIBAg5pcyBub3QgY2hlY2tlcgQMYW5zd2VyUmVzdWx0CQEFYXNJbnQBCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBGRhcHAFCGZ1bmN0aW9uCQDMCAIFBnBhcmFtcwUDbmlsBQNuaWwJAJQKAgUDbmlsBQxhbnN3ZXJSZXN1bHQBaQELY2hlY2tSZXN1bHQBB2V2ZW50SWQEBnN0YXR1cwkBCWdldFN0YXR1cwEFB2V2ZW50SWQDAwkAAAIFBnN0YXR1cwIGYWN0aXZlBgkAAAIFBnN0YXR1cwIMY29uZmlybWF0aW9uBAtjaGVja2VyRGFwcAkAnQgCBQR0aGlzCQEXZ2V0QW5zd2VyRGFwcEFkZHJlc3NLZXkBBQdldmVudElkBAtjaGVja2VyRnVuYwkAnQgCBQR0aGlzCQEXZ2V0QW5zd2VyRnVuY0FkZHJlc3NLZXkBBQdldmVudElkBAZwYXJhbXMJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBDGdldFBhcmFtc0tleQEFB2V2ZW50SWQCAAQNY3VycmVudFJlc3VsdAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBDGdldFJlc3VsdEtleQEFB2V2ZW50SWQEDGFuc3dlclJlc3VsdAkBBWFzSW50AQkA/AcEBQR0aGlzAgVjaGVjawkAzAgCBQtjaGVja2VyRGFwcAkAzAgCBQtjaGVja2VyRnVuYwkAzAgCBQZwYXJhbXMFA25pbAUDbmlsAwkAAAIFDGFuc3dlclJlc3VsdAUMYW5zd2VyUmVzdWx0AwkBAiE9AgUMYW5zd2VyUmVzdWx0BQ1jdXJyZW50UmVzdWx0BAZkZWxldGUJAPwHBAUEdGhpcwIOZGVsZXRlRnJvbUxpc3QJAMwIAgUHZXZlbnRJZAkAzAgCBgUDbmlsBQNuaWwDCQAAAgUGZGVsZXRlBQZkZWxldGUEBmNvbmNhdAkA/AcEBQR0aGlzAgtjb25jYXRMaXN0cwUDbmlsBQNuaWwDCQAAAgUGY29uY2F0BQZjb25jYXQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgMJAAACCAUBaQZjYWxsZXIFBHRoaXMFA25pbAkBBXRocm93AAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECEEV2ZW50IG5vdCBhY3RpdmUAarzOcA==", "height": 3335945, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GM6JjdpY33ZAwWTuRSmgFNVg8nbGJeyq3nvt6pdHx2Ns Next: 9TpvVJc4frA63PnCcgp2n8kpg13L5YwBtxaRaUxsZ7LR Diff:
Old | New | Differences | |
---|---|---|---|
51 | 51 | let lastEventKey = "last_event" | |
52 | 52 | ||
53 | 53 | let fisrtFinishedEventKey = "first_finished_event" | |
54 | + | ||
55 | + | let lastFinishedEventKey = "last_finished_event" | |
56 | + | ||
57 | + | let fisrtActiveEventKey = "first_active_event" | |
58 | + | ||
59 | + | let lastActiveEventKey = "last_active_event" | |
54 | 60 | ||
55 | 61 | func getStartBlockKey (eventId) = (eventId + "_start_block") | |
56 | 62 | ||
173 | 179 | ||
174 | 180 | func registerEvent (txid,desc,startBlock,endBlock,finishAt,checkerDapp,checkerFunc,params) = { | |
175 | 181 | let eventId = txid | |
176 | - | let firstEvent = valueOrElse(getString(this, firstEventKey), undefined) | |
177 | - | let lastEvent = valueOrElse(getString(this, lastEventKey), undefined) | |
178 | - | let firstFinished = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
179 | - | let newFirstEvent = eventId | |
180 | - | if ((newFirstEvent == newFirstEvent)) | |
182 | + | let answerResult = asInt(invoke(this, "check", [checkerDapp, checkerFunc, params], nil)) | |
183 | + | if ((answerResult == answerResult)) | |
181 | 184 | then { | |
182 | - | let newLastOrPrevKey = if ((lastEvent == undefined)) | |
183 | - | then lastEventKey | |
184 | - | else getPrevEventKey(firstEvent) | |
185 | - | if ((newLastOrPrevKey == newLastOrPrevKey)) | |
185 | + | let insert = invoke(this, "insertToList", [eventId, true], nil) | |
186 | + | if ((insert == insert)) | |
186 | 187 | then { | |
187 | - | let newFirstFinishedKey = if (if ((lastEvent == undefined)) | |
188 | - | then (firstFinished != undefined) | |
189 | - | else false) | |
190 | - | then getPrevEventKey(firstFinished) | |
191 | - | else undefined | |
192 | - | if ((newFirstFinishedKey == newFirstFinishedKey)) | |
193 | - | then { | |
194 | - | let newFirstFinishedValue = if (if ((lastEvent == undefined)) | |
195 | - | then (firstFinished != undefined) | |
196 | - | else false) | |
197 | - | then eventId | |
198 | - | else undefined | |
199 | - | if ((newFirstFinishedValue == newFirstFinishedValue)) | |
200 | - | then [IntegerEntry(getStartBlockKey(eventId), startBlock), IntegerEntry(getEndBlockKey(eventId), endBlock), IntegerEntry(getFinishAtKey(eventId), finishAt), StringEntry(getAnswerDappAddressKey(eventId), checkerDapp), StringEntry(getAnswerFuncAddressKey(eventId), checkerFunc), StringEntry(getDescKey(eventId), desc), StringEntry(getStatusKey(eventId), "active"), StringEntry(getIdKey(eventId), eventId), StringEntry(getAnswerNKey(eventId, 1), "NO"), StringEntry(getAnswerNKey(eventId, 2), "YES"), IntegerEntry(getAnswersCountKey(eventId), 2), IntegerEntry(getResultKey(eventId), 1), StringEntry(firstEventKey, newFirstEvent), StringEntry(newLastOrPrevKey, eventId), StringEntry(getNextEventKey(eventId), firstEvent), StringEntry(newFirstFinishedKey, newFirstFinishedValue), StringEntry(getParamsKey(eventId), params)] | |
201 | - | else throw("Strict value is not equal to itself.") | |
202 | - | } | |
188 | + | let concat = invoke(this, "concatLists", nil, nil) | |
189 | + | if ((concat == concat)) | |
190 | + | then [IntegerEntry(getStartBlockKey(eventId), startBlock), IntegerEntry(getEndBlockKey(eventId), endBlock), IntegerEntry(getFinishAtKey(eventId), finishAt), StringEntry(getAnswerDappAddressKey(eventId), checkerDapp), StringEntry(getAnswerFuncAddressKey(eventId), checkerFunc), StringEntry(getDescKey(eventId), desc), StringEntry(getStatusKey(eventId), "active"), StringEntry(getIdKey(eventId), eventId), StringEntry(getAnswerNKey(eventId, 1), "NO"), StringEntry(getAnswerNKey(eventId, 2), "YES"), IntegerEntry(getAnswersCountKey(eventId), 2), IntegerEntry(getResultKey(eventId), 1), StringEntry(getParamsKey(eventId), params)] | |
203 | 191 | else throw("Strict value is not equal to itself.") | |
204 | 192 | } | |
205 | 193 | else throw("Strict value is not equal to itself.") | |
416 | 404 | ||
417 | 405 | ||
418 | 406 | @Callable(i) | |
419 | - | func | |
407 | + | func deleteFromList (eventId,isActive) = if ((this != i.caller)) | |
420 | 408 | then throw("only main can do") | |
421 | 409 | else { | |
422 | - | let prevEvent = valueOrElse(getString(this, getPrevEventKey(eventId)), undefined) | |
423 | - | let nextEvent = valueOrElse(getString(this, getNextEventKey(eventId)), undefined) | |
410 | + | let lastKey = if (isActive) | |
411 | + | then lastActiveEventKey | |
412 | + | else lastFinishedEventKey | |
413 | + | let firstKey = if (isActive) | |
414 | + | then fisrtActiveEventKey | |
415 | + | else fisrtFinishedEventKey | |
416 | + | let prevEvent = getStringValue(this, getPrevEventKey(eventId)) | |
417 | + | let nextEvent = getStringValue(this, getNextEventKey(eventId)) | |
424 | 418 | if (if ((prevEvent == undefined)) | |
425 | 419 | then (nextEvent == undefined) | |
426 | 420 | else false) | |
427 | - | then [StringEntry( | |
421 | + | then [StringEntry(firstKey, undefined), StringEntry(lastKey, undefined)] | |
428 | 422 | else if (if ((prevEvent != undefined)) | |
429 | 423 | then (nextEvent != undefined) | |
430 | 424 | else false) | |
431 | 425 | then [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent)] | |
432 | 426 | else if ((prevEvent != undefined)) | |
433 | - | then [StringEntry( | |
434 | - | else [StringEntry( | |
427 | + | then [StringEntry(lastKey, prevEvent), StringEntry(getNextEventKey(prevEvent), undefined)] | |
428 | + | else [StringEntry(firstKey, nextEvent), StringEntry(getPrevEventKey(nextEvent), undefined)] | |
435 | 429 | } | |
436 | 430 | ||
437 | 431 | ||
438 | 432 | ||
439 | 433 | @Callable(i) | |
440 | - | func | |
434 | + | func insertToList (eventId,isActive) = if ((this != i.caller)) | |
441 | 435 | then throw("only main can do") | |
442 | 436 | else { | |
443 | - | let lastEvent = getStringValue(this, lastEventKey) | |
444 | - | if ((lastEvent == lastEvent)) | |
445 | - | then { | |
446 | - | let prevEvent = valueOrElse(getString(this, getPrevEventKey(eventId)), undefined) | |
447 | - | let nextEvent = valueOrElse(getString(this, getNextEventKey(eventId)), undefined) | |
448 | - | let firstFinishedEvent = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
449 | - | if ((firstFinishedEvent == firstFinishedEvent)) | |
450 | - | then if (if ((prevEvent == undefined)) | |
451 | - | then (nextEvent == undefined) | |
452 | - | else false) | |
453 | - | then [StringEntry(fisrtFinishedEventKey, eventId), StringEntry(lastEventKey, undefined)] | |
454 | - | else if (if ((prevEvent != undefined)) | |
455 | - | then (nextEvent != undefined) | |
456 | - | else false) | |
457 | - | then if ((firstFinishedEvent == undefined)) | |
458 | - | then [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent), StringEntry(getPrevEventKey(eventId), lastEvent), StringEntry(getNextEventKey(lastEvent), eventId), StringEntry(getNextEventKey(eventId), undefined), StringEntry(fisrtFinishedEventKey, eventId)] | |
459 | - | else [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent), StringEntry(getPrevEventKey(eventId), lastEvent), StringEntry(getNextEventKey(eventId), firstFinishedEvent), StringEntry(getPrevEventKey(firstFinishedEvent), eventId), StringEntry(fisrtFinishedEventKey, eventId)] | |
460 | - | else if ((prevEvent != undefined)) | |
461 | - | then [StringEntry(fisrtFinishedEventKey, eventId), StringEntry(lastEventKey, prevEvent)] | |
462 | - | else if ((firstFinishedEvent == undefined)) | |
463 | - | then [StringEntry(firstEventKey, nextEvent), StringEntry(getPrevEventKey(nextEvent), undefined), StringEntry(getNextEventKey(eventId), firstFinishedEvent), StringEntry(fisrtFinishedEventKey, eventId)] | |
464 | - | else [StringEntry(firstEventKey, eventId), StringEntry(lastEventKey, undefined), StringEntry(fisrtFinishedEventKey, eventId)] | |
465 | - | else throw("Strict value is not equal to itself.") | |
466 | - | } | |
467 | - | else throw("Strict value is not equal to itself.") | |
437 | + | let lastKey = if (isActive) | |
438 | + | then lastActiveEventKey | |
439 | + | else lastFinishedEventKey | |
440 | + | let firstKey = if (isActive) | |
441 | + | then fisrtActiveEventKey | |
442 | + | else fisrtFinishedEventKey | |
443 | + | let firstEvent = valueOrElse(getString(this, firstKey), undefined) | |
444 | + | let lastEvent = valueOrElse(getString(this, lastKey), undefined) | |
445 | + | let newLastOrPrevKey = if ((lastEvent == undefined)) | |
446 | + | then lastKey | |
447 | + | else getPrevEventKey(firstEvent) | |
448 | + | [StringEntry(firstKey, eventId), StringEntry(newLastOrPrevKey, eventId), StringEntry(getNextEventKey(eventId), firstEvent)] | |
449 | + | } | |
450 | + | ||
451 | + | ||
452 | + | ||
453 | + | @Callable(i) | |
454 | + | func concatLists () = if (!(isAdmin(i.caller))) | |
455 | + | then throw("only admin can do") | |
456 | + | else { | |
457 | + | let firstActiveEvent = valueOrElse(getString(this, fisrtActiveEventKey), undefined) | |
458 | + | let lastActiveEvent = valueOrElse(getString(this, lastActiveEventKey), undefined) | |
459 | + | let firstFinishedEvent = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
460 | + | let lastFinishedEvent = valueOrElse(getString(this, lastFinishedEventKey), undefined) | |
461 | + | let firstEvent = if ((firstActiveEvent != undefined)) | |
462 | + | then firstActiveEvent | |
463 | + | else firstFinishedEvent | |
464 | + | let lastEvent = if ((lastFinishedEvent != undefined)) | |
465 | + | then lastFinishedEvent | |
466 | + | else lastActiveEvent | |
467 | + | if (if ((firstFinishedEvent != undefined)) | |
468 | + | then (lastActiveEvent != undefined) | |
469 | + | else false) | |
470 | + | then [StringEntry(firstEventKey, firstEvent), StringEntry(lastEventKey, lastEvent), StringEntry(getNextEventKey(lastActiveEvent), firstFinishedEvent), StringEntry(getPrevEventKey(firstFinishedEvent), lastActiveEvent)] | |
471 | + | else [StringEntry(firstEventKey, firstEvent), StringEntry(lastEventKey, lastEvent)] | |
468 | 472 | } | |
469 | 473 | ||
470 | 474 | ||
472 | 476 | @Callable(i) | |
473 | 477 | func resetList () = if (!(isAdmin(i.caller))) | |
474 | 478 | then throw("only admin can do") | |
475 | - | else [StringEntry(firstEventKey, undefined), StringEntry(lastEventKey, undefined), StringEntry(fisrtFinishedEventKey, undefined)] | |
479 | + | else [StringEntry(firstEventKey, undefined), StringEntry(lastEventKey, undefined), StringEntry(fisrtActiveEventKey, undefined), StringEntry(lastActiveEventKey, undefined), StringEntry(fisrtFinishedEventKey, undefined), StringEntry(lastFinishedEventKey, undefined)] | |
476 | 480 | ||
477 | 481 | ||
478 | 482 | ||
510 | 514 | if ((answerResult == answerResult)) | |
511 | 515 | then if ((answerResult != currentResult)) | |
512 | 516 | then { | |
513 | - | let inv = invoke(this, "changeList", [eventId], nil) | |
514 | - | if ((inv == inv)) | |
515 | - | then [StringEntry(getStatusKey(eventId), "finished"), IntegerEntry(getResultKey(eventId), answerResult)] | |
517 | + | let delete = invoke(this, "deleteFromList", [eventId, true], nil) | |
518 | + | if ((delete == delete)) | |
519 | + | then { | |
520 | + | let concat = invoke(this, "concatLists", nil, nil) | |
521 | + | if ((concat == concat)) | |
522 | + | then nil | |
523 | + | else throw("Strict value is not equal to itself.") | |
524 | + | } | |
516 | 525 | else throw("Strict value is not equal to itself.") | |
517 | 526 | } | |
518 | 527 | else if ((i.caller == this)) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let undefined = "undefined" | |
5 | 5 | ||
6 | 6 | let separator = ";" | |
7 | 7 | ||
8 | 8 | let configAddressKey = "config" | |
9 | 9 | ||
10 | 10 | let collectorAddressKey = "collector_address" | |
11 | 11 | ||
12 | 12 | let historyAddressKey = "history_address" | |
13 | 13 | ||
14 | 14 | let adminsKey = "admins" | |
15 | 15 | ||
16 | 16 | let configAddress = addressFromStringValue(getStringValue(this, configAddressKey)) | |
17 | 17 | ||
18 | 18 | let collectorAddress = addressFromStringValue(getStringValue(configAddress, collectorAddressKey)) | |
19 | 19 | ||
20 | 20 | let historyAddress = addressFromStringValue(getStringValue(configAddress, historyAddressKey)) | |
21 | 21 | ||
22 | 22 | func isAdmin (caller) = { | |
23 | 23 | let admRow = valueOrElse(getString(configAddress, adminsKey), "") | |
24 | 24 | if (if ((caller == this)) | |
25 | 25 | then true | |
26 | 26 | else contains(admRow, toString(caller))) | |
27 | 27 | then true | |
28 | 28 | else false | |
29 | 29 | } | |
30 | 30 | ||
31 | 31 | ||
32 | 32 | func getCheckerKey (checker) = ("checker_" + checker) | |
33 | 33 | ||
34 | 34 | ||
35 | 35 | func isChecker (checker) = { | |
36 | 36 | let isExists = isDefined(getString(configAddress, getCheckerKey(toString(checker)))) | |
37 | 37 | isExists | |
38 | 38 | } | |
39 | 39 | ||
40 | 40 | ||
41 | 41 | let USDN = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p' | |
42 | 42 | ||
43 | 43 | let minAmount = 10000000 | |
44 | 44 | ||
45 | 45 | let feeNumerator = 5 | |
46 | 46 | ||
47 | 47 | let feeDenominator = 100 | |
48 | 48 | ||
49 | 49 | let firstEventKey = "first_event" | |
50 | 50 | ||
51 | 51 | let lastEventKey = "last_event" | |
52 | 52 | ||
53 | 53 | let fisrtFinishedEventKey = "first_finished_event" | |
54 | + | ||
55 | + | let lastFinishedEventKey = "last_finished_event" | |
56 | + | ||
57 | + | let fisrtActiveEventKey = "first_active_event" | |
58 | + | ||
59 | + | let lastActiveEventKey = "last_active_event" | |
54 | 60 | ||
55 | 61 | func getStartBlockKey (eventId) = (eventId + "_start_block") | |
56 | 62 | ||
57 | 63 | ||
58 | 64 | func getEndBlockKey (eventId) = (eventId + "_end_block") | |
59 | 65 | ||
60 | 66 | ||
61 | 67 | func getFinishAtKey (eventId) = (eventId + "_finish_at_block") | |
62 | 68 | ||
63 | 69 | ||
64 | 70 | func getAnswerDappAddressKey (eventId) = (eventId + "_answer_dapp") | |
65 | 71 | ||
66 | 72 | ||
67 | 73 | func getAnswerFuncAddressKey (eventId) = (eventId + "_answer_func") | |
68 | 74 | ||
69 | 75 | ||
70 | 76 | func getResultKey (eventId) = (eventId + "_result") | |
71 | 77 | ||
72 | 78 | ||
73 | 79 | func getIdKey (eventId) = (eventId + "_id") | |
74 | 80 | ||
75 | 81 | ||
76 | 82 | func getAnswerNKey (eventId,n) = ((eventId + "_answer_") + toString(n)) | |
77 | 83 | ||
78 | 84 | ||
79 | 85 | func getAnswersCountKey (eventId) = (eventId + "_answers_count") | |
80 | 86 | ||
81 | 87 | ||
82 | 88 | func getStatusKey (eventId) = (eventId + "_status") | |
83 | 89 | ||
84 | 90 | ||
85 | 91 | func getDescKey (eventId) = (eventId + "_description") | |
86 | 92 | ||
87 | 93 | ||
88 | 94 | func getPrevEventKey (eventId) = (eventId + "_prev_event") | |
89 | 95 | ||
90 | 96 | ||
91 | 97 | func getNextEventKey (eventId) = (eventId + "_next_event") | |
92 | 98 | ||
93 | 99 | ||
94 | 100 | func getClaimAvailableKey (eventId) = (eventId + "_claim_available") | |
95 | 101 | ||
96 | 102 | ||
97 | 103 | func getParamsKey (eventId) = (eventId + "_params") | |
98 | 104 | ||
99 | 105 | ||
100 | 106 | func getTotalAmountKey (eventId) = (eventId + "_total_amount") | |
101 | 107 | ||
102 | 108 | ||
103 | 109 | func getClaimedWinnersCountKey (eventId) = (eventId + "_claimed_winners_count") | |
104 | 110 | ||
105 | 111 | ||
106 | 112 | func getAmountNKey (eventId,n) = (((eventId + "_") + toString(n)) + "_amount") | |
107 | 113 | ||
108 | 114 | ||
109 | 115 | func getCountNKey (eventId,n) = (((eventId + "_") + toString(n)) + "_count") | |
110 | 116 | ||
111 | 117 | ||
112 | 118 | func getAmountAddressKey (eventId,address) = (((eventId + "_") + address) + "_amount") | |
113 | 119 | ||
114 | 120 | ||
115 | 121 | func getChoiceAddressKey (eventId,address) = (((eventId + "_") + address) + "_choice") | |
116 | 122 | ||
117 | 123 | ||
118 | 124 | func getAlreadyClaimedAddressKey (eventId,address) = (((eventId + "_") + address) + "_already_claimed") | |
119 | 125 | ||
120 | 126 | ||
121 | 127 | func asInt (v) = match v { | |
122 | 128 | case x: Int => | |
123 | 129 | x | |
124 | 130 | case t => | |
125 | 131 | throw("#err") | |
126 | 132 | } | |
127 | 133 | ||
128 | 134 | ||
129 | 135 | func asString (v) = match v { | |
130 | 136 | case x: String => | |
131 | 137 | x | |
132 | 138 | case _ => | |
133 | 139 | throw("#err") | |
134 | 140 | } | |
135 | 141 | ||
136 | 142 | ||
137 | 143 | func getStatus (eventId) = { | |
138 | 144 | let status = valueOrElse(getString(this, getStatusKey(eventId)), "#") | |
139 | 145 | if (if (if ((status == "finished")) | |
140 | 146 | then true | |
141 | 147 | else (status == "#")) | |
142 | 148 | then true | |
143 | 149 | else (status == "ended")) | |
144 | 150 | then status | |
145 | 151 | else { | |
146 | 152 | let finishAt = getIntegerValue(this, getFinishAtKey(eventId)) | |
147 | 153 | let startBlock = getIntegerValue(this, getStartBlockKey(eventId)) | |
148 | 154 | let endBlock = getIntegerValue(this, getEndBlockKey(eventId)) | |
149 | 155 | if ((startBlock > height)) | |
150 | 156 | then "awaiting" | |
151 | 157 | else if (if ((height >= startBlock)) | |
152 | 158 | then (endBlock >= height) | |
153 | 159 | else false) | |
154 | 160 | then "active" | |
155 | 161 | else if (if ((height > endBlock)) | |
156 | 162 | then (finishAt >= height) | |
157 | 163 | else false) | |
158 | 164 | then "confirmation" | |
159 | 165 | else if ((height > finishAt)) | |
160 | 166 | then "finished" | |
161 | 167 | else throw("unknown status") | |
162 | 168 | } | |
163 | 169 | } | |
164 | 170 | ||
165 | 171 | ||
166 | 172 | func isClaimAvailable (eventId) = { | |
167 | 173 | let r = valueOrElse(getBoolean(this, getClaimAvailableKey(eventId)), false) | |
168 | 174 | if ((r == true)) | |
169 | 175 | then true | |
170 | 176 | else throw("claim is not available") | |
171 | 177 | } | |
172 | 178 | ||
173 | 179 | ||
174 | 180 | func registerEvent (txid,desc,startBlock,endBlock,finishAt,checkerDapp,checkerFunc,params) = { | |
175 | 181 | let eventId = txid | |
176 | - | let firstEvent = valueOrElse(getString(this, firstEventKey), undefined) | |
177 | - | let lastEvent = valueOrElse(getString(this, lastEventKey), undefined) | |
178 | - | let firstFinished = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
179 | - | let newFirstEvent = eventId | |
180 | - | if ((newFirstEvent == newFirstEvent)) | |
182 | + | let answerResult = asInt(invoke(this, "check", [checkerDapp, checkerFunc, params], nil)) | |
183 | + | if ((answerResult == answerResult)) | |
181 | 184 | then { | |
182 | - | let newLastOrPrevKey = if ((lastEvent == undefined)) | |
183 | - | then lastEventKey | |
184 | - | else getPrevEventKey(firstEvent) | |
185 | - | if ((newLastOrPrevKey == newLastOrPrevKey)) | |
185 | + | let insert = invoke(this, "insertToList", [eventId, true], nil) | |
186 | + | if ((insert == insert)) | |
186 | 187 | then { | |
187 | - | let newFirstFinishedKey = if (if ((lastEvent == undefined)) | |
188 | - | then (firstFinished != undefined) | |
189 | - | else false) | |
190 | - | then getPrevEventKey(firstFinished) | |
191 | - | else undefined | |
192 | - | if ((newFirstFinishedKey == newFirstFinishedKey)) | |
193 | - | then { | |
194 | - | let newFirstFinishedValue = if (if ((lastEvent == undefined)) | |
195 | - | then (firstFinished != undefined) | |
196 | - | else false) | |
197 | - | then eventId | |
198 | - | else undefined | |
199 | - | if ((newFirstFinishedValue == newFirstFinishedValue)) | |
200 | - | then [IntegerEntry(getStartBlockKey(eventId), startBlock), IntegerEntry(getEndBlockKey(eventId), endBlock), IntegerEntry(getFinishAtKey(eventId), finishAt), StringEntry(getAnswerDappAddressKey(eventId), checkerDapp), StringEntry(getAnswerFuncAddressKey(eventId), checkerFunc), StringEntry(getDescKey(eventId), desc), StringEntry(getStatusKey(eventId), "active"), StringEntry(getIdKey(eventId), eventId), StringEntry(getAnswerNKey(eventId, 1), "NO"), StringEntry(getAnswerNKey(eventId, 2), "YES"), IntegerEntry(getAnswersCountKey(eventId), 2), IntegerEntry(getResultKey(eventId), 1), StringEntry(firstEventKey, newFirstEvent), StringEntry(newLastOrPrevKey, eventId), StringEntry(getNextEventKey(eventId), firstEvent), StringEntry(newFirstFinishedKey, newFirstFinishedValue), StringEntry(getParamsKey(eventId), params)] | |
201 | - | else throw("Strict value is not equal to itself.") | |
202 | - | } | |
188 | + | let concat = invoke(this, "concatLists", nil, nil) | |
189 | + | if ((concat == concat)) | |
190 | + | then [IntegerEntry(getStartBlockKey(eventId), startBlock), IntegerEntry(getEndBlockKey(eventId), endBlock), IntegerEntry(getFinishAtKey(eventId), finishAt), StringEntry(getAnswerDappAddressKey(eventId), checkerDapp), StringEntry(getAnswerFuncAddressKey(eventId), checkerFunc), StringEntry(getDescKey(eventId), desc), StringEntry(getStatusKey(eventId), "active"), StringEntry(getIdKey(eventId), eventId), StringEntry(getAnswerNKey(eventId, 1), "NO"), StringEntry(getAnswerNKey(eventId, 2), "YES"), IntegerEntry(getAnswersCountKey(eventId), 2), IntegerEntry(getResultKey(eventId), 1), StringEntry(getParamsKey(eventId), params)] | |
203 | 191 | else throw("Strict value is not equal to itself.") | |
204 | 192 | } | |
205 | 193 | else throw("Strict value is not equal to itself.") | |
206 | 194 | } | |
207 | 195 | else throw("Strict value is not equal to itself.") | |
208 | 196 | } | |
209 | 197 | ||
210 | 198 | ||
211 | 199 | func getJson (startId) = { | |
212 | 200 | let eventId = asString(valueOrElse(getString(this, getIdKey(startId)), getString(this, firstEventKey))) | |
213 | 201 | let nextEventId = getStringValue(this, getNextEventKey(eventId)) | |
214 | 202 | let startBlock = getIntegerValue(this, getStartBlockKey(eventId)) | |
215 | 203 | let endBlock = getIntegerValue(this, getEndBlockKey(eventId)) | |
216 | 204 | let finishBlock = getIntegerValue(this, getFinishAtKey(eventId)) | |
217 | 205 | let checkerDapp = getStringValue(this, getAnswerDappAddressKey(eventId)) | |
218 | 206 | let checkerFunc = getStringValue(this, getAnswerFuncAddressKey(eventId)) | |
219 | 207 | let desc = getStringValue(this, getDescKey(eventId)) | |
220 | 208 | let status = getStatus(eventId) | |
221 | 209 | let result = getIntegerValue(this, getResultKey(eventId)) | |
222 | 210 | let answersCount = getIntegerValue(this, getAnswersCountKey(eventId)) | |
223 | 211 | let answersArray = (((((("[" + (if ((answersCount >= 1)) | |
224 | 212 | then ((((("" + "{\"v\":\"") + getStringValue(this, getAnswerNKey(eventId, 1))) + "\", \"a\":") + toString(valueOrElse(getInteger(this, getAmountNKey(eventId, 1)), 0))) + "}") | |
225 | 213 | else "")) + (if ((answersCount >= 2)) | |
226 | 214 | then ((((("," + "{\"v\":\"") + getStringValue(this, getAnswerNKey(eventId, 2))) + "\", \"a\":") + toString(valueOrElse(getInteger(this, getAmountNKey(eventId, 2)), 0))) + "}") | |
227 | 215 | else "")) + (if ((answersCount >= 3)) | |
228 | 216 | then ((((("," + "{\"v\":\"") + getStringValue(this, getAnswerNKey(eventId, 3))) + "\", \"a\":") + toString(valueOrElse(getInteger(this, getAmountNKey(eventId, 3)), 0))) + "}") | |
229 | 217 | else "")) + (if ((answersCount >= 4)) | |
230 | 218 | then ((((("," + "{\"v\":\"") + getStringValue(this, getAnswerNKey(eventId, 4))) + "\", \"a\":") + toString(valueOrElse(getInteger(this, getAmountNKey(eventId, 4)), 0))) + "}") | |
231 | 219 | else "")) + (if ((answersCount >= 5)) | |
232 | 220 | then ((((("," + "{\"v\":\"") + getStringValue(this, getAnswerNKey(eventId, 5))) + "\", \"a\":") + toString(valueOrElse(getInteger(this, getAmountNKey(eventId, 5)), 0))) + "}") | |
233 | 221 | else "")) + "]") | |
234 | 222 | let json = (((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((("{" + "\"") + "id") + "\"") + ":") + "\"") + eventId) + "\"") + ",") + "\"") + "startBlock") + "\"") + ":") + toString(startBlock)) + ",") + "\"") + "endBlock") + "\"") + ":") + toString(endBlock)) + ",") + "\"") + "finishBlock") + "\"") + ":") + toString(finishBlock)) + ",") + "\"") + "checkerDapp") + "\"") + ":") + "\"") + checkerDapp) + "\"") + ",") + "\"") + "checkerFunc") + "\"") + ":") + "\"") + checkerFunc) + "\"") + ",") + "\"") + "desc") + "\"") + ":") + "\"") + desc) + "\"") + ",") + "\"") + "status") + "\"") + ":") + "\"") + status) + "\"") + ",") + "\"") + "result") + "\"") + ":") + toString(result)) + ",") + "\"") + "answersCount") + "\"") + ":") + toString(answersCount)) + ",") + "\"") + "answers") + "\"") + ":") + "") + answersArray) + "") + "}") | |
235 | 223 | $Tuple2(nextEventId, json) | |
236 | 224 | } | |
237 | 225 | ||
238 | 226 | ||
239 | 227 | func getJsonArray (startId,count) = if (if (if ((count != 3)) | |
240 | 228 | then (count != 6) | |
241 | 229 | else false) | |
242 | 230 | then (count != 9) | |
243 | 231 | else false) | |
244 | 232 | then throw(("only 3, 6 and 9 in array. Param = " + toString(count))) | |
245 | 233 | else { | |
246 | 234 | let ev1 = getJson(startId) | |
247 | 235 | let ev2 = if ((ev1._1 != undefined)) | |
248 | 236 | then getJson(ev1._1) | |
249 | 237 | else $Tuple2(undefined, "") | |
250 | 238 | let ev3 = if ((ev2._1 != undefined)) | |
251 | 239 | then getJson(ev2._1) | |
252 | 240 | else $Tuple2(undefined, "") | |
253 | 241 | let ev4 = if (if ((count >= 6)) | |
254 | 242 | then (ev3._1 != undefined) | |
255 | 243 | else false) | |
256 | 244 | then getJson(ev3._1) | |
257 | 245 | else $Tuple2(undefined, "") | |
258 | 246 | let ev5 = if (if ((count >= 6)) | |
259 | 247 | then (ev4._1 != undefined) | |
260 | 248 | else false) | |
261 | 249 | then getJson(ev4._1) | |
262 | 250 | else $Tuple2(undefined, "") | |
263 | 251 | let ev6 = if (if ((count >= 6)) | |
264 | 252 | then (ev5._1 != undefined) | |
265 | 253 | else false) | |
266 | 254 | then getJson(ev5._1) | |
267 | 255 | else $Tuple2(undefined, "") | |
268 | 256 | let ev7 = if (if ((count >= 9)) | |
269 | 257 | then (ev6._1 != undefined) | |
270 | 258 | else false) | |
271 | 259 | then getJson(ev6._1) | |
272 | 260 | else $Tuple2(undefined, "") | |
273 | 261 | let ev8 = if (if ((count >= 9)) | |
274 | 262 | then (ev7._1 != undefined) | |
275 | 263 | else false) | |
276 | 264 | then getJson(ev7._1) | |
277 | 265 | else $Tuple2(undefined, "") | |
278 | 266 | let ev9 = if (if ((count >= 9)) | |
279 | 267 | then (ev8._1 != undefined) | |
280 | 268 | else false) | |
281 | 269 | then getJson(ev8._1) | |
282 | 270 | else $Tuple2(undefined, "") | |
283 | 271 | let array = (((((((((("[" + ev1._2) + (if ((ev1._1 != undefined)) | |
284 | 272 | then ("," + ev2._2) | |
285 | 273 | else "")) + (if ((ev2._1 != undefined)) | |
286 | 274 | then ("," + ev3._2) | |
287 | 275 | else "")) + (if ((ev3._1 != undefined)) | |
288 | 276 | then ("," + ev4._2) | |
289 | 277 | else "")) + (if ((ev4._1 != undefined)) | |
290 | 278 | then ("," + ev5._2) | |
291 | 279 | else "")) + (if ((ev5._1 != undefined)) | |
292 | 280 | then ("," + ev6._2) | |
293 | 281 | else "")) + (if ((ev6._1 != undefined)) | |
294 | 282 | then ("," + ev7._2) | |
295 | 283 | else "")) + (if ((ev7._1 != undefined)) | |
296 | 284 | then ("," + ev8._2) | |
297 | 285 | else "")) + (if ((ev8._1 != undefined)) | |
298 | 286 | then ("," + ev9._2) | |
299 | 287 | else "")) + "]") | |
300 | 288 | $Tuple2(ev9._1, array) | |
301 | 289 | } | |
302 | 290 | ||
303 | 291 | ||
304 | 292 | @Callable(i) | |
305 | 293 | func init (config,desc) = if (!(isAdmin(i.caller))) | |
306 | 294 | then throw("only admin can do") | |
307 | 295 | else { | |
308 | 296 | let isExists = isDefined(getString(this, configAddressKey)) | |
309 | 297 | if (!(isExists)) | |
310 | 298 | then { | |
311 | 299 | let inv = invoke(configAddress, "setEventer", [toString(this), desc], nil) | |
312 | 300 | if ((inv == inv)) | |
313 | 301 | then [StringEntry(configAddressKey, config)] | |
314 | 302 | else throw("Strict value is not equal to itself.") | |
315 | 303 | } | |
316 | 304 | else throw("already inited") | |
317 | 305 | } | |
318 | 306 | ||
319 | 307 | ||
320 | 308 | ||
321 | 309 | @Callable(i) | |
322 | 310 | func fullRegisterEvent (desc,startBlock,duration,checkerDapp,checkerFunc,params) = { | |
323 | 311 | let newStartBlock = if ((startBlock == 0)) | |
324 | 312 | then height | |
325 | 313 | else startBlock | |
326 | 314 | let endBlock = (newStartBlock + duration) | |
327 | 315 | let finishAt = (endBlock + 1440) | |
328 | 316 | if (!(isAdmin(i.caller))) | |
329 | 317 | then throw("only admin can do") | |
330 | 318 | else { | |
331 | 319 | let txid = toBase58String(i.transactionId) | |
332 | 320 | registerEvent(txid, desc, newStartBlock, endBlock, finishAt, checkerDapp, checkerFunc, params) | |
333 | 321 | } | |
334 | 322 | } | |
335 | 323 | ||
336 | 324 | ||
337 | 325 | ||
338 | 326 | @Callable(i) | |
339 | 327 | func choice (eventId,choice) = { | |
340 | 328 | let address = toString(i.caller) | |
341 | 329 | let check = invoke(this, "checkResult", [eventId], nil) | |
342 | 330 | if ((check == check)) | |
343 | 331 | then { | |
344 | 332 | let status = getStatus(eventId) | |
345 | 333 | if ((status == "active")) | |
346 | 334 | then if (if ((size(i.payments) == 1)) | |
347 | 335 | then (i.payments[0].assetId == USDN) | |
348 | 336 | else false) | |
349 | 337 | then { | |
350 | 338 | let amount = i.payments[0].amount | |
351 | 339 | if ((minAmount > amount)) | |
352 | 340 | then throw("amount is less than allowed") | |
353 | 341 | else { | |
354 | 342 | let answersCount = getIntegerValue(this, getAnswersCountKey(eventId)) | |
355 | 343 | if (if ((choice == 0)) | |
356 | 344 | then true | |
357 | 345 | else (choice > answersCount)) | |
358 | 346 | then throw("choice is invalid") | |
359 | 347 | else { | |
360 | 348 | let currentTotal = valueOrElse(getInteger(this, getTotalAmountKey(eventId)), 0) | |
361 | 349 | let choiceTotal = valueOrElse(getInteger(this, getAmountNKey(eventId, choice)), 0) | |
362 | 350 | let choiceCount = valueOrElse(getInteger(this, getCountNKey(eventId, choice)), 0) | |
363 | 351 | let addressAmount = valueOrElse(getInteger(this, getAmountAddressKey(eventId, address)), 0) | |
364 | 352 | if ((addressAmount != 0)) | |
365 | 353 | then throw("betting from this address is exists") | |
366 | 354 | else { | |
367 | 355 | let save = invoke(historyAddress, "saveToHistory", [eventId, address], nil) | |
368 | 356 | if ((save == save)) | |
369 | 357 | then [IntegerEntry(getTotalAmountKey(eventId), (currentTotal + amount)), IntegerEntry(getAmountNKey(eventId, choice), (choiceTotal + amount)), IntegerEntry(getCountNKey(eventId, choice), (choiceCount + 1)), IntegerEntry(getChoiceAddressKey(eventId, address), choice), IntegerEntry(getAmountAddressKey(eventId, address), amount)] | |
370 | 358 | else throw("Strict value is not equal to itself.") | |
371 | 359 | } | |
372 | 360 | } | |
373 | 361 | } | |
374 | 362 | } | |
375 | 363 | else throw("Bad payment") | |
376 | 364 | else throw("You can`t do it") | |
377 | 365 | } | |
378 | 366 | else throw("Strict value is not equal to itself.") | |
379 | 367 | } | |
380 | 368 | ||
381 | 369 | ||
382 | 370 | ||
383 | 371 | @Callable(i) | |
384 | 372 | func claim (eventId,strAddress) = if (!(isClaimAvailable(eventId))) | |
385 | 373 | then throw("claim is not available") | |
386 | 374 | else { | |
387 | 375 | let address = addressFromStringValue(strAddress) | |
388 | 376 | let status = getStatus(eventId) | |
389 | 377 | if ((status == "finished")) | |
390 | 378 | then { | |
391 | 379 | let totalAmount = getIntegerValue(this, getTotalAmountKey(eventId)) | |
392 | 380 | let alreadyClaimed = valueOrElse(getBoolean(this, getAlreadyClaimedAddressKey(eventId, toString(address))), false) | |
393 | 381 | if (alreadyClaimed) | |
394 | 382 | then throw("Reward already claimed") | |
395 | 383 | else { | |
396 | 384 | let addressChoice = getIntegerValue(this, getChoiceAddressKey(eventId, toString(address))) | |
397 | 385 | let result = getIntegerValue(this, getResultKey(eventId)) | |
398 | 386 | let choiceTotal = getIntegerValue(this, getAmountNKey(eventId, result)) | |
399 | 387 | let addressAmount = getIntegerValue(this, getAmountAddressKey(eventId, toString(address))) | |
400 | 388 | if ((addressChoice == result)) | |
401 | 389 | then { | |
402 | 390 | let addressReward = fraction(totalAmount, addressAmount, choiceTotal) | |
403 | 391 | let fee = fraction(addressReward, feeNumerator, feeDenominator) | |
404 | 392 | let claimedWinners = (valueOrElse(getInteger(this, getClaimedWinnersCountKey(eventId)), 0) + 1) | |
405 | 393 | let choiceCount = getIntegerValue(this, getCountNKey(eventId, result)) | |
406 | 394 | if ((claimedWinners == choiceCount)) | |
407 | 395 | then [StringEntry(getStatusKey(eventId), "ended"), BooleanEntry(getChoiceAddressKey(eventId, toString(address)), true), IntegerEntry(getClaimedWinnersCountKey(eventId), claimedWinners), ScriptTransfer(address, (addressReward - fee), USDN), ScriptTransfer(collectorAddress, fee, USDN)] | |
408 | 396 | else [BooleanEntry(getChoiceAddressKey(eventId, toString(address)), true), IntegerEntry(getClaimedWinnersCountKey(eventId), claimedWinners), ScriptTransfer(address, addressReward, USDN), ScriptTransfer(collectorAddress, fee, USDN)] | |
409 | 397 | } | |
410 | 398 | else throw("Something went wrong") | |
411 | 399 | } | |
412 | 400 | } | |
413 | 401 | else throw("You can`t do it") | |
414 | 402 | } | |
415 | 403 | ||
416 | 404 | ||
417 | 405 | ||
418 | 406 | @Callable(i) | |
419 | - | func | |
407 | + | func deleteFromList (eventId,isActive) = if ((this != i.caller)) | |
420 | 408 | then throw("only main can do") | |
421 | 409 | else { | |
422 | - | let prevEvent = valueOrElse(getString(this, getPrevEventKey(eventId)), undefined) | |
423 | - | let nextEvent = valueOrElse(getString(this, getNextEventKey(eventId)), undefined) | |
410 | + | let lastKey = if (isActive) | |
411 | + | then lastActiveEventKey | |
412 | + | else lastFinishedEventKey | |
413 | + | let firstKey = if (isActive) | |
414 | + | then fisrtActiveEventKey | |
415 | + | else fisrtFinishedEventKey | |
416 | + | let prevEvent = getStringValue(this, getPrevEventKey(eventId)) | |
417 | + | let nextEvent = getStringValue(this, getNextEventKey(eventId)) | |
424 | 418 | if (if ((prevEvent == undefined)) | |
425 | 419 | then (nextEvent == undefined) | |
426 | 420 | else false) | |
427 | - | then [StringEntry( | |
421 | + | then [StringEntry(firstKey, undefined), StringEntry(lastKey, undefined)] | |
428 | 422 | else if (if ((prevEvent != undefined)) | |
429 | 423 | then (nextEvent != undefined) | |
430 | 424 | else false) | |
431 | 425 | then [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent)] | |
432 | 426 | else if ((prevEvent != undefined)) | |
433 | - | then [StringEntry( | |
434 | - | else [StringEntry( | |
427 | + | then [StringEntry(lastKey, prevEvent), StringEntry(getNextEventKey(prevEvent), undefined)] | |
428 | + | else [StringEntry(firstKey, nextEvent), StringEntry(getPrevEventKey(nextEvent), undefined)] | |
435 | 429 | } | |
436 | 430 | ||
437 | 431 | ||
438 | 432 | ||
439 | 433 | @Callable(i) | |
440 | - | func | |
434 | + | func insertToList (eventId,isActive) = if ((this != i.caller)) | |
441 | 435 | then throw("only main can do") | |
442 | 436 | else { | |
443 | - | let lastEvent = getStringValue(this, lastEventKey) | |
444 | - | if ((lastEvent == lastEvent)) | |
445 | - | then { | |
446 | - | let prevEvent = valueOrElse(getString(this, getPrevEventKey(eventId)), undefined) | |
447 | - | let nextEvent = valueOrElse(getString(this, getNextEventKey(eventId)), undefined) | |
448 | - | let firstFinishedEvent = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
449 | - | if ((firstFinishedEvent == firstFinishedEvent)) | |
450 | - | then if (if ((prevEvent == undefined)) | |
451 | - | then (nextEvent == undefined) | |
452 | - | else false) | |
453 | - | then [StringEntry(fisrtFinishedEventKey, eventId), StringEntry(lastEventKey, undefined)] | |
454 | - | else if (if ((prevEvent != undefined)) | |
455 | - | then (nextEvent != undefined) | |
456 | - | else false) | |
457 | - | then if ((firstFinishedEvent == undefined)) | |
458 | - | then [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent), StringEntry(getPrevEventKey(eventId), lastEvent), StringEntry(getNextEventKey(lastEvent), eventId), StringEntry(getNextEventKey(eventId), undefined), StringEntry(fisrtFinishedEventKey, eventId)] | |
459 | - | else [StringEntry(getPrevEventKey(nextEvent), prevEvent), StringEntry(getNextEventKey(prevEvent), nextEvent), StringEntry(getPrevEventKey(eventId), lastEvent), StringEntry(getNextEventKey(eventId), firstFinishedEvent), StringEntry(getPrevEventKey(firstFinishedEvent), eventId), StringEntry(fisrtFinishedEventKey, eventId)] | |
460 | - | else if ((prevEvent != undefined)) | |
461 | - | then [StringEntry(fisrtFinishedEventKey, eventId), StringEntry(lastEventKey, prevEvent)] | |
462 | - | else if ((firstFinishedEvent == undefined)) | |
463 | - | then [StringEntry(firstEventKey, nextEvent), StringEntry(getPrevEventKey(nextEvent), undefined), StringEntry(getNextEventKey(eventId), firstFinishedEvent), StringEntry(fisrtFinishedEventKey, eventId)] | |
464 | - | else [StringEntry(firstEventKey, eventId), StringEntry(lastEventKey, undefined), StringEntry(fisrtFinishedEventKey, eventId)] | |
465 | - | else throw("Strict value is not equal to itself.") | |
466 | - | } | |
467 | - | else throw("Strict value is not equal to itself.") | |
437 | + | let lastKey = if (isActive) | |
438 | + | then lastActiveEventKey | |
439 | + | else lastFinishedEventKey | |
440 | + | let firstKey = if (isActive) | |
441 | + | then fisrtActiveEventKey | |
442 | + | else fisrtFinishedEventKey | |
443 | + | let firstEvent = valueOrElse(getString(this, firstKey), undefined) | |
444 | + | let lastEvent = valueOrElse(getString(this, lastKey), undefined) | |
445 | + | let newLastOrPrevKey = if ((lastEvent == undefined)) | |
446 | + | then lastKey | |
447 | + | else getPrevEventKey(firstEvent) | |
448 | + | [StringEntry(firstKey, eventId), StringEntry(newLastOrPrevKey, eventId), StringEntry(getNextEventKey(eventId), firstEvent)] | |
449 | + | } | |
450 | + | ||
451 | + | ||
452 | + | ||
453 | + | @Callable(i) | |
454 | + | func concatLists () = if (!(isAdmin(i.caller))) | |
455 | + | then throw("only admin can do") | |
456 | + | else { | |
457 | + | let firstActiveEvent = valueOrElse(getString(this, fisrtActiveEventKey), undefined) | |
458 | + | let lastActiveEvent = valueOrElse(getString(this, lastActiveEventKey), undefined) | |
459 | + | let firstFinishedEvent = valueOrElse(getString(this, fisrtFinishedEventKey), undefined) | |
460 | + | let lastFinishedEvent = valueOrElse(getString(this, lastFinishedEventKey), undefined) | |
461 | + | let firstEvent = if ((firstActiveEvent != undefined)) | |
462 | + | then firstActiveEvent | |
463 | + | else firstFinishedEvent | |
464 | + | let lastEvent = if ((lastFinishedEvent != undefined)) | |
465 | + | then lastFinishedEvent | |
466 | + | else lastActiveEvent | |
467 | + | if (if ((firstFinishedEvent != undefined)) | |
468 | + | then (lastActiveEvent != undefined) | |
469 | + | else false) | |
470 | + | then [StringEntry(firstEventKey, firstEvent), StringEntry(lastEventKey, lastEvent), StringEntry(getNextEventKey(lastActiveEvent), firstFinishedEvent), StringEntry(getPrevEventKey(firstFinishedEvent), lastActiveEvent)] | |
471 | + | else [StringEntry(firstEventKey, firstEvent), StringEntry(lastEventKey, lastEvent)] | |
468 | 472 | } | |
469 | 473 | ||
470 | 474 | ||
471 | 475 | ||
472 | 476 | @Callable(i) | |
473 | 477 | func resetList () = if (!(isAdmin(i.caller))) | |
474 | 478 | then throw("only admin can do") | |
475 | - | else [StringEntry(firstEventKey, undefined), StringEntry(lastEventKey, undefined), StringEntry(fisrtFinishedEventKey, undefined)] | |
479 | + | else [StringEntry(firstEventKey, undefined), StringEntry(lastEventKey, undefined), StringEntry(fisrtActiveEventKey, undefined), StringEntry(lastActiveEventKey, undefined), StringEntry(fisrtFinishedEventKey, undefined), StringEntry(lastFinishedEventKey, undefined)] | |
476 | 480 | ||
477 | 481 | ||
478 | 482 | ||
479 | 483 | @Callable(i) | |
480 | 484 | func allowClaim (eventId) = if (!(isAdmin(i.caller))) | |
481 | 485 | then throw("only admin can do") | |
482 | 486 | else [BooleanEntry(getClaimAvailableKey(eventId), true)] | |
483 | 487 | ||
484 | 488 | ||
485 | 489 | ||
486 | 490 | @Callable(i) | |
487 | 491 | func check (dapp,function,params) = if ((this != i.caller)) | |
488 | 492 | then throw("only main can do") | |
489 | 493 | else if (!(isChecker(i.caller))) | |
490 | 494 | then throw("is not checker") | |
491 | 495 | else { | |
492 | 496 | let answerResult = asInt(invoke(addressFromStringValue(dapp), function, [params], nil)) | |
493 | 497 | $Tuple2(nil, answerResult) | |
494 | 498 | } | |
495 | 499 | ||
496 | 500 | ||
497 | 501 | ||
498 | 502 | @Callable(i) | |
499 | 503 | func checkResult (eventId) = { | |
500 | 504 | let status = getStatus(eventId) | |
501 | 505 | if (if ((status == "active")) | |
502 | 506 | then true | |
503 | 507 | else (status == "confirmation")) | |
504 | 508 | then { | |
505 | 509 | let checkerDapp = getString(this, getAnswerDappAddressKey(eventId)) | |
506 | 510 | let checkerFunc = getString(this, getAnswerFuncAddressKey(eventId)) | |
507 | 511 | let params = valueOrElse(getString(this, getParamsKey(eventId)), "") | |
508 | 512 | let currentResult = getIntegerValue(this, getResultKey(eventId)) | |
509 | 513 | let answerResult = asInt(invoke(this, "check", [checkerDapp, checkerFunc, params], nil)) | |
510 | 514 | if ((answerResult == answerResult)) | |
511 | 515 | then if ((answerResult != currentResult)) | |
512 | 516 | then { | |
513 | - | let inv = invoke(this, "changeList", [eventId], nil) | |
514 | - | if ((inv == inv)) | |
515 | - | then [StringEntry(getStatusKey(eventId), "finished"), IntegerEntry(getResultKey(eventId), answerResult)] | |
517 | + | let delete = invoke(this, "deleteFromList", [eventId, true], nil) | |
518 | + | if ((delete == delete)) | |
519 | + | then { | |
520 | + | let concat = invoke(this, "concatLists", nil, nil) | |
521 | + | if ((concat == concat)) | |
522 | + | then nil | |
523 | + | else throw("Strict value is not equal to itself.") | |
524 | + | } | |
516 | 525 | else throw("Strict value is not equal to itself.") | |
517 | 526 | } | |
518 | 527 | else if ((i.caller == this)) | |
519 | 528 | then nil | |
520 | 529 | else throw() | |
521 | 530 | else throw("Strict value is not equal to itself.") | |
522 | 531 | } | |
523 | 532 | else throw("Event not active") | |
524 | 533 | } | |
525 | 534 | ||
526 | 535 |
github/deemru/w8io/3ef1775 62.94 ms ◑