tx · 9wNGMqBAEZMB4s6q7p2in54SsXZLdUxhPoz8MBeAoZfU 3P7aVqHv6fXkYuS4sRW2K17ENZMsbXi3sPV: -0.01000000 Waves 2023.10.11 22:39 [3860261] smart account 3P7aVqHv6fXkYuS4sRW2K17ENZMsbXi3sPV > SELF 0.00000000 Waves
{ "type": 13, "id": "9wNGMqBAEZMB4s6q7p2in54SsXZLdUxhPoz8MBeAoZfU", "fee": 1000000, "feeAssetId": null, "timestamp": 1697053299936, "version": 2, "chainId": 87, "sender": "3P7aVqHv6fXkYuS4sRW2K17ENZMsbXi3sPV", "senderPublicKey": "5SevHzYFiymbFWe1GPt6nNYccPnfTbMft1DqZWfRH8GN", "proofs": [ "56ehjC1U396SE8tmEgAgc1oHM9AhBDzW4Dp4drPoc5d3Wu889gcVUz8fJRHgjHwQ32nZrXgZ3vxQPuZswGWtVyfS" ], "script": "base64:BgIiCAISAwoBCBIECgIIARIDCgEIEgQKAggBEgMKAQESAwoBCCcBFHRyeUdldFN0cmluZ0V4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAnQgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABDXRyeUdldEJvb2xlYW4BA2tleQQHJG1hdGNoMAkAoAgBBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBDHRyeUdldFN0cmluZwEDa2V5CQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCBQR0aGlzBQNrZXkBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABCWdldE9yYWNsZQAJAQdBZGRyZXNzAQkA2QQBCQEMdHJ5R2V0U3RyaW5nAQIUc3RhdGljX29yYWNsZUFkZHJlc3MBHnN0YXRpY0tleV90dXJ0bGVTdGFraW5nQWRkcmVzcwACG3N0YXRpY190dXJ0bGVTdGFraW5nQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZVJlYmlydGhBZGRyZXNzAAIbc3RhdGljX3R1cnRsZVJlYmlydGhBZGRyZXNzARVzdGF0aWNLZXlfcm9wZUFkZHJlc3MAAhJzdGF0aWNfcm9wZUFkZHJlc3MBHHN0YXRpY0tleV9sZXZlbFN5c3RlbUFkZHJlc3MAAhlzdGF0aWNfbGV2ZWxTeXN0ZW1BZGRyZXNzARZzdGF0aWNLZXlfc3BpY2VBc3NldElkAAITc3RhdGljX3NwaWNlQXNzZXRJZAERZ2V0UmViaXJ0aEFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFXN0YXRpY19yZWJpcnRoQWRkcmVzcwETZ2V0SW5jdWJhdG9yQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIXc3RhdGljX2luY3ViYXRvckFkZHJlc3MBEWdldEZhcm1pbmdBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhVzdGF0aWNfZmFybWluZ0FkZHJlc3MBEmdldEdhbWVEYXBwQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIWc3RhdGljX2dhbWVEYXBwQWRkcmVzcwEOZ2V0QnVybkFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACEnN0YXRpY19idXJuQWRkcmVzcwESZ2V0QmFieWR1Y2tBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfYmFieUR1Y2tBZGRyZXNzARJnZXRCcmVlZGluZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFXN0YXRpY19icmVlZGVyQWRkcmVzcwEQZ2V0TWFzdGVyQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIWc3RhdGljX2NmTWFzdGVyQWRkcmVzcwEXZ2V0VHVydGxlU3Rha2luZ0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJAR5zdGF0aWNLZXlfdHVydGxlU3Rha2luZ0FkZHJlc3MAARdnZXRUdXJ0bGVSZWJpcnRoQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVSZWJpcnRoQWRkcmVzcwABDmdldFJvcGVBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEVc3RhdGljS2V5X3JvcGVBZGRyZXNzAAEPZ2V0U3BpY2VBc3NldElkAAkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBFnN0YXRpY0tleV9zcGljZUFzc2V0SWQAARVnZXRMZXZlbFN5c3RlbUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARxzdGF0aWNLZXlfbGV2ZWxTeXN0ZW1BZGRyZXNzAAAId0FjY1BLZXkJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQlnZXRPcmFjbGUAAg9zdGF0aWNfd2Fyc1BLZXkCG3N0YXRpY193YXJzUEtleSBub3QgZGVmaW5lZAAPc2NDYW5Vc2VDb3Vwb25zCQDMCAIJARFnZXRSZWJpcnRoQWRkcmVzcwAJAMwIAgkBE2dldEluY3ViYXRvckFkZHJlc3MACQDMCAIJARFnZXRGYXJtaW5nQWRkcmVzcwAJAMwIAgkBEmdldEdhbWVEYXBwQWRkcmVzcwAJAMwIAgkBEmdldEJhYnlkdWNrQWRkcmVzcwAJAMwIAgkBEmdldEJyZWVkaW5nQWRkcmVzcwAJAMwIAgkBF2dldFR1cnRsZVN0YWtpbmdBZGRyZXNzAAkAzAgCCQEXZ2V0VHVydGxlUmViaXJ0aEFkZHJlc3MACQDMCAIJAQ5nZXRSb3BlQWRkcmVzcwAJAMwIAgkBFWdldExldmVsU3lzdGVtQWRkcmVzcwAFA25pbAEQY291cG9uc1VzZXJTcGVuZAEEdXNlcgkArAICBQR1c2VyAgZfc3BlbmQBEWNvdXBvbnNVc2VyQWN0aXZlAQR1c2VyCQCsAgIFBHVzZXICB19hY3RpdmUBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQR1c2VyCQCsAgIJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXICBF9vbGQBEGNvdXBvbnNTcGVuZE9uU2MBAnNjCQCsAgIFAnNjAg9fc3BlbmRfYnlfdXNpbmcBHWFjdGlvblBlckFkZHJlc3NQZXJVc2VyUGVyRGF5BAR1c2VyBmFjdGlvbgtkYXBwQWRkcmVzcwNkYXkJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgULZGFwcEFkZHJlc3MCAV8FBmFjdGlvbgIBXwUEdXNlcgIBXwUDZGF5AghfYWN0aW9ucwEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJMYXN0Q2hlY2tEYXkCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICEl9hY3Rpb25zX2NoZWNrX2RheQEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJBbW91bnRJbkFSb3cCBHVzZXIGYWN0aW9uCQCsAgIJAKwCAgkArAICBQZhY3Rpb24CAV8FBHVzZXICFl9hY3Rpb25zX2Ftb3VudF9pbl9yb3cBDnVzZXJFeHBlcmllbmNlAQR1c2VyCQCsAgIFBHVzZXICC19leHBlcmllbmNlARJhZGRDb3Vwb25zSW50ZXJuYWwCBHVzZXIGYW1vdW50BAZrZXlPbGQJARRjb3Vwb25zVXNlckFjdGl2ZU9sZAEFBHVzZXIEA2tleQkBEWNvdXBvbnNVc2VyQWN0aXZlAQUEdXNlcgQKY291cG9uc09sZAkBDXRyeUdldEludGVnZXIBBQNrZXkEB2NvdXBvbnMJAGQCBQpjb3Vwb25zT2xkBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleU9sZAUKY291cG9uc09sZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BQdjb3Vwb25zBQNuaWwACXN0YXJ0VHNNcwCAiNj6qzEBF2NhbGN1bGF0ZURheXNTaW5jZVN0YXJ0AAQEZGlmZgkAZQIIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQlzdGFydFRzTXMECmRheXNQYXNzZWQJAGkCBQRkaWZmCQBoAgCAowUA6AcFCmRheXNQYXNzZWQBEGhhc0RvbmVUYXNrN0RheXMEA2RheQdhZGRyZXNzCmFjdGlvbk5hbWUMcmV3YXJkQW1vdW50BBF1c2VyRXhwZXJpZW5jZUtleQkBDnVzZXJFeHBlcmllbmNlAQUHYWRkcmVzcwQPdXNlckV4cFRpbGxkYXRlCQENdHJ5R2V0SW50ZWdlcgEFEXVzZXJFeHBlcmllbmNlS2V5BAtjaGVja0RheUtleQkBI2FjdGlvblBlckFkZHJlc3NQZXJVc2VyTGFzdENoZWNrRGF5AgUHYWRkcmVzcwUKYWN0aW9uTmFtZQQMZGF5c0luUm93S2V5CQEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJBbW91bnRJbkFSb3cCBQdhZGRyZXNzBQphY3Rpb25OYW1lBAxsYXN0Q2hlY2tEYXkJAQ10cnlHZXRJbnRlZ2VyAQULY2hlY2tEYXlLZXkECWRheXNJblJvdwkBDXRyeUdldEludGVnZXIBBQxkYXlzSW5Sb3dLZXkED2RheXNJblJvd1VwZGF0ZQMJAAACBQxsYXN0Q2hlY2tEYXkJAGUCBQNkYXkAAQkAZAIFCWRheXNJblJvdwABAwkAZgIJAGUCBQNkYXkAAQUMbGFzdENoZWNrRGF5AAEAAAQSbGFzdENoZWNrRGF5VXBkYXRlBQNkYXkEBnJld2FyZAMJAAACBQ9kYXlzSW5Sb3dVcGRhdGUABwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQdhZGRyZXNzAIDC1y8JAQ9nZXRTcGljZUFzc2V0SWQACQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxkYXlzSW5Sb3dLZXkAAAUDbmlsCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxkYXlzSW5Sb3dLZXkFD2RheXNJblJvd1VwZGF0ZQUDbmlsCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFC2NoZWNrRGF5S2V5BRJsYXN0Q2hlY2tEYXlVcGRhdGUJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUMcmV3YXJkQW1vdW50CQEPZ2V0U3BpY2VBc3NldElkAAkAzAgCCQEMSW50ZWdlckVudHJ5AgURdXNlckV4cGVyaWVuY2VLZXkJAGQCBQ91c2VyRXhwVGlsbGRhdGUAAQUDbmlsBQZyZXdhcmQBCXBheUFjdGlvbgQKYWN0aW9uTmFtZQt1c2VyQWRkcmVzcwZhbW91bnQDZGF5BAtjb21wb3NlZEtleQMJAQ10cnlHZXRCb29sZWFuAQkArAICCQCsAgICBVRBU0tfBQphY3Rpb25OYW1lAgZfRVZFUlkFCmFjdGlvbk5hbWUJAKwCAgkArAICBQphY3Rpb25OYW1lAgFfCQCkAwEFBmFtb3VudAMJAQ10cnlHZXRCb29sZWFuAQkArAICAgVUQVNLXwULY29tcG9zZWRLZXkJARBoYXNEb25lVGFzazdEYXlzBAUDZGF5CQClCAEFC3VzZXJBZGRyZXNzBQtjb21wb3NlZEtleQkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIFVEFTS18FC2NvbXBvc2VkS2V5Ag1fUkVXQVJEX0RBSUxZCQACAQULY29tcG9zZWRLZXkBFHJlY29yZEFjdGlvbkludGVybmFsAwphY3Rpb25OYW1lAWkHYWRkcmVzcwMJAQEhAQkBD2NvbnRhaW5zRWxlbWVudAIFD3NjQ2FuVXNlQ291cG9ucwgFAWkGY2FsbGVyCQACAQI9Q1JBOiBPbmx5IGNlcnRhaW4gc21hcnQgY29udHJhY3RzIGNhbiB1c2UgdGhpcyByZXdhcmQgbW9kdWxlIQQDZGF5CQEXY2FsY3VsYXRlRGF5c1NpbmNlU3RhcnQABAlhY3Rpb25LZXkJAR1hY3Rpb25QZXJBZGRyZXNzUGVyVXNlclBlckRheQQJAKUIAQUHYWRkcmVzcwUKYWN0aW9uTmFtZQkApQgBCAUBaQZjYWxsZXIJAKQDAQUDZGF5BAx0b3RhbEFjdGlvbnMJAGQCCQENdHJ5R2V0SW50ZWdlcgEFCWFjdGlvbktleQABCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFCWFjdGlvbktleQUMdG90YWxBY3Rpb25zBQNuaWwJAQlwYXlBY3Rpb24EBQphY3Rpb25OYW1lBQdhZGRyZXNzBQx0b3RhbEFjdGlvbnMFA2RheQYBaQEPY29uZmlndXJlT3JhY2xlAQZvcmFjbGUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAg9DQ086IGFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgIUc3RhdGljX29yYWNsZUFkZHJlc3MFBm9yYWNsZQUDbmlsAWkBCmFkZENvdXBvbnMCBHVzZXIGYW1vdW50AwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkBAiE9AggFAWkPY2FsbGVyUHVibGljS2V5BQh3QWNjUEtleQcJAAIBAg9DQUM6IGFkbWluIG9ubHkDCQBmAgUGYW1vdW50AKDCHgkAzggCCQEUcmVjb3JkQWN0aW9uSW50ZXJuYWwDAgpWRUdHNTAwMDAwBQFpCAUBaQxvcmlnaW5DYWxsZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQBaQEPYWRkQ291cG9uc0JhdGNoAQViYXRjaAMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpD2NhbGxlclB1YmxpY0tleQUId0FjY1BLZXkHCQACAQIPQ0FDOiBhZG1pbiBvbmx5BAtjb3Vwb25zTGlzdAkAtQkCBQViYXRjaAIBOwoBDGhhbmRsZUNvdXBvbgIDYWNjBmNvdXBvbgQKc3BsaXRBcnJheQkAtQkCBQZjb3Vwb24CAToEBHVzZXIJAJEDAgUKc3BsaXRBcnJheQAABAZhbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpzcGxpdEFycmF5AAEECGJ1cm5DYWxsCQD8BwQJAQ5nZXRCdXJuQWRkcmVzcwACDGJ1cm5CeUludm9rZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFCGJ1cm5DYWxsBQhidXJuQ2FsbAMJAGYCBQZhbW91bnQAoMIeCQDOCAIJAM4IAgUDYWNjCQEUcmVjb3JkQWN0aW9uSW50ZXJuYWwDAgpWRUdHNTAwMDAwBQFpCAUBaQxvcmlnaW5DYWxsZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJAM4IAgUDYWNjCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCgACJGwFC2NvdXBvbnNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQxoYW5kbGVDb3Vwb24CBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAFpAQhDRlJlZnVuZAIJcmVjaXBpZW50BmFtb3VudAQJY2ZBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA1MykCCAUBaQZjYWxsZXICCkNGX0FERFJFU1MEA2tleQkArAICCQCsAgICAmZfBQljZkFkZHJlc3MCDl9zdGFrZV9hZGRyZXNzBAxzdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDUzKQIJARBnZXRNYXN0ZXJBZGRyZXNzAAUDa2V5AwkBAiE9AgUMc3Rha2VBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgkAAgECJkNDUjogVGhpcyBpcyBzb21ldGhpbmcgZmlzaHkgZ29pbmcgb24hCQESYWRkQ291cG9uc0ludGVybmFsAgUJcmVjaXBpZW50BQZhbW91bnQBaQEKdXNlQ291cG9ucwERYW1vdW50VHJ5aW5nVG9QYXkECmludm9raW5nU2MIBQFpBmNhbGxlcgMJAGYCAAAFEWFtb3VudFRyeWluZ1RvUGF5CQACAQIvQ1VDOiBPbmx5IHBvc2l0aXZlIGFtb3VudCBvZiBtb25leSBjYW4gYmUgcGFpZCEDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFCmludm9raW5nU2MJAAIBAj1DVUM6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIGNvdXBvbiBtb2R1bGUhBAR1c2VyCQClCAEIBQFpDG9yaWdpbkNhbGxlcgQJa2V5QWN0aXZlCQERY291cG9uc1VzZXJBY3RpdmUBBQR1c2VyBBBhdmFpbGFibGVDb3Vwb25zCQENdHJ5R2V0SW50ZWdlcgEFCWtleUFjdGl2ZQMJAGYCAAAFEGF2YWlsYWJsZUNvdXBvbnMJAAIBAg5DVUM6IEdldCByZWt0IQQJbGVmdFRvUGF5AwkAZgIFEWFtb3VudFRyeWluZ1RvUGF5BRBhdmFpbGFibGVDb3Vwb25zCQBlAgURYW1vdW50VHJ5aW5nVG9QYXkFEGF2YWlsYWJsZUNvdXBvbnMAAAQKYW1vdW50UGFpZAkAZQIFEWFtb3VudFRyeWluZ1RvUGF5BQlsZWZ0VG9QYXkEFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQBlAgUQYXZhaWxhYmxlQ291cG9ucwUKYW1vdW50UGFpZAMJAGYCAAAFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQACAQIaQ1VDOiBZb3UgdHJ5IHRvIG92ZXJzcGVuZCEECGtleVNwZW5kCQEQY291cG9uc1VzZXJTcGVuZAEFBHVzZXIEBmtleU9sZAkBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQUEdXNlcgQKa2V5U3BlbmRTYwkBEGNvdXBvbnNTcGVuZE9uU2MBCQClCAEIBQFpBmNhbGxlcgQKdG90YWxTcGVuZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUIa2V5U3BlbmQFCmFtb3VudFBhaWQEDHRvdGFsU3BlbmRTYwkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUKa2V5U3BlbmRTYwUKYW1vdW50UGFpZAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQhrZXlTcGVuZAUKdG90YWxTcGVuZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUGa2V5T2xkBRBhdmFpbGFibGVDb3Vwb25zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrZXlBY3RpdmUFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQprZXlTcGVuZFNjBQx0b3RhbFNwZW5kU2MFA25pbAUKYW1vdW50UGFpZAFpAQxyZWNvcmRBY3Rpb24BCmFjdGlvbk5hbWUJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMFCmFjdGlvbk5hbWUFAWkIBQFpDG9yaWdpbkNhbGxlcgC4VVcq", "height": 3860261, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Fo7WAmXBfxQCo6rmNK1LAwUTYQrcn6Kdo8u3BWcujvvB Next: 227cy3YWTUmGYkq3dqsXyohxKy5oGTaqnktmPMJ6LGqd Diff:
Old | New | Differences | |
---|---|---|---|
157 | 157 | else ((actionName + "_") + toString(amount)) | |
158 | 158 | if (tryGetBoolean(("TASK_" + composedKey))) | |
159 | 159 | then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY"))) | |
160 | - | else | |
160 | + | else throw(composedKey) | |
161 | 161 | } | |
162 | 162 | ||
163 | 163 | ||
184 | 184 | else false) | |
185 | 185 | then throw("CAC: admin only") | |
186 | 186 | else if ((amount > 500000)) | |
187 | - | then (recordActionInternal(" | |
187 | + | then (recordActionInternal("VEGG500000", i, i.originCaller) ++ addCouponsInternal(user, amount)) | |
188 | 188 | else addCouponsInternal(user, amount) | |
189 | 189 | ||
190 | 190 | ||
203 | 203 | let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil) | |
204 | 204 | if ((burnCall == burnCall)) | |
205 | 205 | then if ((amount > 500000)) | |
206 | - | then ((acc ++ recordActionInternal(" | |
206 | + | then ((acc ++ recordActionInternal("VEGG500000", i, i.originCaller)) ++ addCouponsInternal(user, amount)) | |
207 | 207 | else (acc ++ addCouponsInternal(user, amount)) | |
208 | 208 | else throw("Strict value is not equal to itself.") | |
209 | 209 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func tryGetStringExternal (address,key) = match getString(address, key) { | |
5 | 5 | case a: String => | |
6 | 6 | a | |
7 | 7 | case _ => | |
8 | 8 | "" | |
9 | 9 | } | |
10 | 10 | ||
11 | 11 | ||
12 | 12 | func tryGetBoolean (key) = match getBoolean(key) { | |
13 | 13 | case b: Boolean => | |
14 | 14 | b | |
15 | 15 | case _ => | |
16 | 16 | false | |
17 | 17 | } | |
18 | 18 | ||
19 | 19 | ||
20 | 20 | func tryGetString (key) = tryGetStringExternal(this, key) | |
21 | 21 | ||
22 | 22 | ||
23 | 23 | func tryGetInteger (key) = match getInteger(this, key) { | |
24 | 24 | case b: Int => | |
25 | 25 | b | |
26 | 26 | case _ => | |
27 | 27 | 0 | |
28 | 28 | } | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | func getOracle () = Address(fromBase58String(tryGetString("static_oracleAddress"))) | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | func staticKey_turtleStakingAddress () = "static_turtleStakingAddress" | |
35 | 35 | ||
36 | 36 | ||
37 | 37 | func staticKey_turtleRebirthAddress () = "static_turtleRebirthAddress" | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func staticKey_ropeAddress () = "static_ropeAddress" | |
41 | 41 | ||
42 | 42 | ||
43 | 43 | func staticKey_levelSystemAddress () = "static_levelSystemAddress" | |
44 | 44 | ||
45 | 45 | ||
46 | 46 | func staticKey_spiceAssetId () = "static_spiceAssetId" | |
47 | 47 | ||
48 | 48 | ||
49 | 49 | func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_rebirthAddress"))) | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | func getIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_incubatorAddress"))) | |
53 | 53 | ||
54 | 54 | ||
55 | 55 | func getFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_farmingAddress"))) | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | func getGameDappAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_gameDappAddress"))) | |
59 | 59 | ||
60 | 60 | ||
61 | 61 | func getBurnAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_burnAddress"))) | |
62 | 62 | ||
63 | 63 | ||
64 | 64 | func getBabyduckAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_babyDuckAddress"))) | |
65 | 65 | ||
66 | 66 | ||
67 | 67 | func getBreedingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_breederAddress"))) | |
68 | 68 | ||
69 | 69 | ||
70 | 70 | func getMasterAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_cfMasterAddress"))) | |
71 | 71 | ||
72 | 72 | ||
73 | 73 | func getTurtleStakingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleStakingAddress()))) | |
74 | 74 | ||
75 | 75 | ||
76 | 76 | func getTurtleRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleRebirthAddress()))) | |
77 | 77 | ||
78 | 78 | ||
79 | 79 | func getRopeAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_ropeAddress()))) | |
80 | 80 | ||
81 | 81 | ||
82 | 82 | func getSpiceAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_spiceAssetId())) | |
83 | 83 | ||
84 | 84 | ||
85 | 85 | func getLevelSystemAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_levelSystemAddress()))) | |
86 | 86 | ||
87 | 87 | ||
88 | 88 | let wAccPKey = fromBase58String(valueOrErrorMessage(getString(getOracle(), "static_warsPKey"), "static_warsPKey not defined")) | |
89 | 89 | ||
90 | 90 | let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress()] | |
91 | 91 | ||
92 | 92 | func couponsUserSpend (user) = (user + "_spend") | |
93 | 93 | ||
94 | 94 | ||
95 | 95 | func couponsUserActive (user) = (user + "_active") | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func couponsUserActiveOld (user) = (couponsUserActive(user) + "_old") | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | func couponsSpendOnSc (sc) = (sc + "_spend_by_using") | |
102 | 102 | ||
103 | 103 | ||
104 | 104 | func actionPerAddressPerUserPerDay (user,action,dappAddress,day) = (((((((dappAddress + "_") + action) + "_") + user) + "_") + day) + "_actions") | |
105 | 105 | ||
106 | 106 | ||
107 | 107 | func actionPerAddressPerUserLastCheckDay (user,action) = (((action + "_") + user) + "_actions_check_day") | |
108 | 108 | ||
109 | 109 | ||
110 | 110 | func actionPerAddressPerUserAmountInARow (user,action) = (((action + "_") + user) + "_actions_amount_in_row") | |
111 | 111 | ||
112 | 112 | ||
113 | 113 | func userExperience (user) = (user + "_experience") | |
114 | 114 | ||
115 | 115 | ||
116 | 116 | func addCouponsInternal (user,amount) = { | |
117 | 117 | let keyOld = couponsUserActiveOld(user) | |
118 | 118 | let key = couponsUserActive(user) | |
119 | 119 | let couponsOld = tryGetInteger(key) | |
120 | 120 | let coupons = (couponsOld + amount) | |
121 | 121 | [IntegerEntry(keyOld, couponsOld), IntegerEntry(key, coupons)] | |
122 | 122 | } | |
123 | 123 | ||
124 | 124 | ||
125 | 125 | let startTsMs = 1695427200000 | |
126 | 126 | ||
127 | 127 | func calculateDaysSinceStart () = { | |
128 | 128 | let diff = (lastBlock.timestamp - startTsMs) | |
129 | 129 | let daysPassed = (diff / (86400 * 1000)) | |
130 | 130 | daysPassed | |
131 | 131 | } | |
132 | 132 | ||
133 | 133 | ||
134 | 134 | func hasDoneTask7Days (day,address,actionName,rewardAmount) = { | |
135 | 135 | let userExperienceKey = userExperience(address) | |
136 | 136 | let userExpTilldate = tryGetInteger(userExperienceKey) | |
137 | 137 | let checkDayKey = actionPerAddressPerUserLastCheckDay(address, actionName) | |
138 | 138 | let daysInRowKey = actionPerAddressPerUserAmountInARow(address, actionName) | |
139 | 139 | let lastCheckDay = tryGetInteger(checkDayKey) | |
140 | 140 | let daysInRow = tryGetInteger(daysInRowKey) | |
141 | 141 | let daysInRowUpdate = if ((lastCheckDay == (day - 1))) | |
142 | 142 | then (daysInRow + 1) | |
143 | 143 | else if (((day - 1) > lastCheckDay)) | |
144 | 144 | then 1 | |
145 | 145 | else 0 | |
146 | 146 | let lastCheckDayUpdate = day | |
147 | 147 | let reward = if ((daysInRowUpdate == 7)) | |
148 | 148 | then [ScriptTransfer(addressFromStringValue(address), 100000000, getSpiceAssetId()), IntegerEntry(daysInRowKey, 0)] | |
149 | 149 | else [IntegerEntry(daysInRowKey, daysInRowUpdate)] | |
150 | 150 | ([IntegerEntry(checkDayKey, lastCheckDayUpdate), ScriptTransfer(addressFromStringValue(address), rewardAmount, getSpiceAssetId()), IntegerEntry(userExperienceKey, (userExpTilldate + 1))] ++ reward) | |
151 | 151 | } | |
152 | 152 | ||
153 | 153 | ||
154 | 154 | func payAction (actionName,userAddress,amount,day) = { | |
155 | 155 | let composedKey = if (tryGetBoolean((("TASK_" + actionName) + "_EVERY"))) | |
156 | 156 | then actionName | |
157 | 157 | else ((actionName + "_") + toString(amount)) | |
158 | 158 | if (tryGetBoolean(("TASK_" + composedKey))) | |
159 | 159 | then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY"))) | |
160 | - | else | |
160 | + | else throw(composedKey) | |
161 | 161 | } | |
162 | 162 | ||
163 | 163 | ||
164 | 164 | func recordActionInternal (actionName,i,address) = if (!(containsElement(scCanUseCoupons, i.caller))) | |
165 | 165 | then throw("CRA: Only certain smart contracts can use this reward module!") | |
166 | 166 | else { | |
167 | 167 | let day = calculateDaysSinceStart() | |
168 | 168 | let actionKey = actionPerAddressPerUserPerDay(toString(address), actionName, toString(i.caller), toString(day)) | |
169 | 169 | let totalActions = (tryGetInteger(actionKey) + 1) | |
170 | 170 | ([IntegerEntry(actionKey, totalActions)] ++ payAction(actionName, address, totalActions, day)) | |
171 | 171 | } | |
172 | 172 | ||
173 | 173 | ||
174 | 174 | @Callable(i) | |
175 | 175 | func configureOracle (oracle) = if ((i.caller != this)) | |
176 | 176 | then throw("CCO: admin only") | |
177 | 177 | else [StringEntry("static_oracleAddress", oracle)] | |
178 | 178 | ||
179 | 179 | ||
180 | 180 | ||
181 | 181 | @Callable(i) | |
182 | 182 | func addCoupons (user,amount) = if (if ((i.caller != this)) | |
183 | 183 | then (i.callerPublicKey != wAccPKey) | |
184 | 184 | else false) | |
185 | 185 | then throw("CAC: admin only") | |
186 | 186 | else if ((amount > 500000)) | |
187 | - | then (recordActionInternal(" | |
187 | + | then (recordActionInternal("VEGG500000", i, i.originCaller) ++ addCouponsInternal(user, amount)) | |
188 | 188 | else addCouponsInternal(user, amount) | |
189 | 189 | ||
190 | 190 | ||
191 | 191 | ||
192 | 192 | @Callable(i) | |
193 | 193 | func addCouponsBatch (batch) = if (if ((i.caller != this)) | |
194 | 194 | then (i.callerPublicKey != wAccPKey) | |
195 | 195 | else false) | |
196 | 196 | then throw("CAC: admin only") | |
197 | 197 | else { | |
198 | 198 | let couponsList = split(batch, ";") | |
199 | 199 | func handleCoupon (acc,coupon) = { | |
200 | 200 | let splitArray = split(coupon, ":") | |
201 | 201 | let user = splitArray[0] | |
202 | 202 | let amount = parseIntValue(splitArray[1]) | |
203 | 203 | let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil) | |
204 | 204 | if ((burnCall == burnCall)) | |
205 | 205 | then if ((amount > 500000)) | |
206 | - | then ((acc ++ recordActionInternal(" | |
206 | + | then ((acc ++ recordActionInternal("VEGG500000", i, i.originCaller)) ++ addCouponsInternal(user, amount)) | |
207 | 207 | else (acc ++ addCouponsInternal(user, amount)) | |
208 | 208 | else throw("Strict value is not equal to itself.") | |
209 | 209 | } | |
210 | 210 | ||
211 | 211 | let $l = couponsList | |
212 | 212 | let $s = size($l) | |
213 | 213 | let $acc0 = nil | |
214 | 214 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
215 | 215 | then $a | |
216 | 216 | else handleCoupon($a, $l[$i]) | |
217 | 217 | ||
218 | 218 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
219 | 219 | then $a | |
220 | 220 | else throw("List size exceeds 20") | |
221 | 221 | ||
222 | 222 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
223 | 223 | } | |
224 | 224 | ||
225 | 225 | ||
226 | 226 | ||
227 | 227 | @Callable(i) | |
228 | 228 | func CFRefund (recipient,amount) = { | |
229 | 229 | let cfAddress = getStringValue(i.caller, "CF_ADDRESS") | |
230 | 230 | let key = (("f_" + cfAddress) + "_stake_address") | |
231 | 231 | let stakeAddress = getStringValue(getMasterAddress(), key) | |
232 | 232 | if ((stakeAddress != toString(i.caller))) | |
233 | 233 | then throw("CCR: This is something fishy going on!") | |
234 | 234 | else addCouponsInternal(recipient, amount) | |
235 | 235 | } | |
236 | 236 | ||
237 | 237 | ||
238 | 238 | ||
239 | 239 | @Callable(i) | |
240 | 240 | func useCoupons (amountTryingToPay) = { | |
241 | 241 | let invokingSc = i.caller | |
242 | 242 | if ((0 > amountTryingToPay)) | |
243 | 243 | then throw("CUC: Only positive amount of money can be paid!") | |
244 | 244 | else if (!(containsElement(scCanUseCoupons, invokingSc))) | |
245 | 245 | then throw("CUC: Only certain smart contracts can use this coupon module!") | |
246 | 246 | else { | |
247 | 247 | let user = toString(i.originCaller) | |
248 | 248 | let keyActive = couponsUserActive(user) | |
249 | 249 | let availableCoupons = tryGetInteger(keyActive) | |
250 | 250 | if ((0 > availableCoupons)) | |
251 | 251 | then throw("CUC: Get rekt!") | |
252 | 252 | else { | |
253 | 253 | let leftToPay = if ((amountTryingToPay > availableCoupons)) | |
254 | 254 | then (amountTryingToPay - availableCoupons) | |
255 | 255 | else 0 | |
256 | 256 | let amountPaid = (amountTryingToPay - leftToPay) | |
257 | 257 | let availableCouponsLeft = (availableCoupons - amountPaid) | |
258 | 258 | if ((0 > availableCouponsLeft)) | |
259 | 259 | then throw("CUC: You try to overspend!") | |
260 | 260 | else { | |
261 | 261 | let keySpend = couponsUserSpend(user) | |
262 | 262 | let keyOld = couponsUserActiveOld(user) | |
263 | 263 | let keySpendSc = couponsSpendOnSc(toString(i.caller)) | |
264 | 264 | let totalSpend = (tryGetInteger(keySpend) + amountPaid) | |
265 | 265 | let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid) | |
266 | 266 | $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid) | |
267 | 267 | } | |
268 | 268 | } | |
269 | 269 | } | |
270 | 270 | } | |
271 | 271 | ||
272 | 272 | ||
273 | 273 | ||
274 | 274 | @Callable(i) | |
275 | 275 | func recordAction (actionName) = recordActionInternal(actionName, i, i.originCaller) | |
276 | 276 | ||
277 | 277 |
github/deemru/w8io/3ef1775 49.51 ms ◑