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:
OldNewDifferences
157157 else ((actionName + "_") + toString(amount))
158158 if (tryGetBoolean(("TASK_" + composedKey)))
159159 then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY")))
160- else nil
160+ else throw(composedKey)
161161 }
162162
163163
184184 else false)
185185 then throw("CAC: admin only")
186186 else if ((amount > 500000))
187- then (recordActionInternal("VEGG50_0000", i, i.originCaller) ++ addCouponsInternal(user, amount))
187+ then (recordActionInternal("VEGG500000", i, i.originCaller) ++ addCouponsInternal(user, amount))
188188 else addCouponsInternal(user, amount)
189189
190190
203203 let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil)
204204 if ((burnCall == burnCall))
205205 then if ((amount > 500000))
206- then ((acc ++ recordActionInternal("VEGG50_0000", i, i.originCaller)) ++ addCouponsInternal(user, amount))
206+ then ((acc ++ recordActionInternal("VEGG500000", i, i.originCaller)) ++ addCouponsInternal(user, amount))
207207 else (acc ++ addCouponsInternal(user, amount))
208208 else throw("Strict value is not equal to itself.")
209209 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func tryGetStringExternal (address,key) = match getString(address, key) {
55 case a: String =>
66 a
77 case _ =>
88 ""
99 }
1010
1111
1212 func tryGetBoolean (key) = match getBoolean(key) {
1313 case b: Boolean =>
1414 b
1515 case _ =>
1616 false
1717 }
1818
1919
2020 func tryGetString (key) = tryGetStringExternal(this, key)
2121
2222
2323 func tryGetInteger (key) = match getInteger(this, key) {
2424 case b: Int =>
2525 b
2626 case _ =>
2727 0
2828 }
2929
3030
3131 func getOracle () = Address(fromBase58String(tryGetString("static_oracleAddress")))
3232
3333
3434 func staticKey_turtleStakingAddress () = "static_turtleStakingAddress"
3535
3636
3737 func staticKey_turtleRebirthAddress () = "static_turtleRebirthAddress"
3838
3939
4040 func staticKey_ropeAddress () = "static_ropeAddress"
4141
4242
4343 func staticKey_levelSystemAddress () = "static_levelSystemAddress"
4444
4545
4646 func staticKey_spiceAssetId () = "static_spiceAssetId"
4747
4848
4949 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_rebirthAddress")))
5050
5151
5252 func getIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_incubatorAddress")))
5353
5454
5555 func getFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_farmingAddress")))
5656
5757
5858 func getGameDappAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_gameDappAddress")))
5959
6060
6161 func getBurnAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_burnAddress")))
6262
6363
6464 func getBabyduckAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_babyDuckAddress")))
6565
6666
6767 func getBreedingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_breederAddress")))
6868
6969
7070 func getMasterAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_cfMasterAddress")))
7171
7272
7373 func getTurtleStakingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleStakingAddress())))
7474
7575
7676 func getTurtleRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleRebirthAddress())))
7777
7878
7979 func getRopeAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_ropeAddress())))
8080
8181
8282 func getSpiceAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_spiceAssetId()))
8383
8484
8585 func getLevelSystemAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_levelSystemAddress())))
8686
8787
8888 let wAccPKey = fromBase58String(valueOrErrorMessage(getString(getOracle(), "static_warsPKey"), "static_warsPKey not defined"))
8989
9090 let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress()]
9191
9292 func couponsUserSpend (user) = (user + "_spend")
9393
9494
9595 func couponsUserActive (user) = (user + "_active")
9696
9797
9898 func couponsUserActiveOld (user) = (couponsUserActive(user) + "_old")
9999
100100
101101 func couponsSpendOnSc (sc) = (sc + "_spend_by_using")
102102
103103
104104 func actionPerAddressPerUserPerDay (user,action,dappAddress,day) = (((((((dappAddress + "_") + action) + "_") + user) + "_") + day) + "_actions")
105105
106106
107107 func actionPerAddressPerUserLastCheckDay (user,action) = (((action + "_") + user) + "_actions_check_day")
108108
109109
110110 func actionPerAddressPerUserAmountInARow (user,action) = (((action + "_") + user) + "_actions_amount_in_row")
111111
112112
113113 func userExperience (user) = (user + "_experience")
114114
115115
116116 func addCouponsInternal (user,amount) = {
117117 let keyOld = couponsUserActiveOld(user)
118118 let key = couponsUserActive(user)
119119 let couponsOld = tryGetInteger(key)
120120 let coupons = (couponsOld + amount)
121121 [IntegerEntry(keyOld, couponsOld), IntegerEntry(key, coupons)]
122122 }
123123
124124
125125 let startTsMs = 1695427200000
126126
127127 func calculateDaysSinceStart () = {
128128 let diff = (lastBlock.timestamp - startTsMs)
129129 let daysPassed = (diff / (86400 * 1000))
130130 daysPassed
131131 }
132132
133133
134134 func hasDoneTask7Days (day,address,actionName,rewardAmount) = {
135135 let userExperienceKey = userExperience(address)
136136 let userExpTilldate = tryGetInteger(userExperienceKey)
137137 let checkDayKey = actionPerAddressPerUserLastCheckDay(address, actionName)
138138 let daysInRowKey = actionPerAddressPerUserAmountInARow(address, actionName)
139139 let lastCheckDay = tryGetInteger(checkDayKey)
140140 let daysInRow = tryGetInteger(daysInRowKey)
141141 let daysInRowUpdate = if ((lastCheckDay == (day - 1)))
142142 then (daysInRow + 1)
143143 else if (((day - 1) > lastCheckDay))
144144 then 1
145145 else 0
146146 let lastCheckDayUpdate = day
147147 let reward = if ((daysInRowUpdate == 7))
148148 then [ScriptTransfer(addressFromStringValue(address), 100000000, getSpiceAssetId()), IntegerEntry(daysInRowKey, 0)]
149149 else [IntegerEntry(daysInRowKey, daysInRowUpdate)]
150150 ([IntegerEntry(checkDayKey, lastCheckDayUpdate), ScriptTransfer(addressFromStringValue(address), rewardAmount, getSpiceAssetId()), IntegerEntry(userExperienceKey, (userExpTilldate + 1))] ++ reward)
151151 }
152152
153153
154154 func payAction (actionName,userAddress,amount,day) = {
155155 let composedKey = if (tryGetBoolean((("TASK_" + actionName) + "_EVERY")))
156156 then actionName
157157 else ((actionName + "_") + toString(amount))
158158 if (tryGetBoolean(("TASK_" + composedKey)))
159159 then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY")))
160- else nil
160+ else throw(composedKey)
161161 }
162162
163163
164164 func recordActionInternal (actionName,i,address) = if (!(containsElement(scCanUseCoupons, i.caller)))
165165 then throw("CRA: Only certain smart contracts can use this reward module!")
166166 else {
167167 let day = calculateDaysSinceStart()
168168 let actionKey = actionPerAddressPerUserPerDay(toString(address), actionName, toString(i.caller), toString(day))
169169 let totalActions = (tryGetInteger(actionKey) + 1)
170170 ([IntegerEntry(actionKey, totalActions)] ++ payAction(actionName, address, totalActions, day))
171171 }
172172
173173
174174 @Callable(i)
175175 func configureOracle (oracle) = if ((i.caller != this))
176176 then throw("CCO: admin only")
177177 else [StringEntry("static_oracleAddress", oracle)]
178178
179179
180180
181181 @Callable(i)
182182 func addCoupons (user,amount) = if (if ((i.caller != this))
183183 then (i.callerPublicKey != wAccPKey)
184184 else false)
185185 then throw("CAC: admin only")
186186 else if ((amount > 500000))
187- then (recordActionInternal("VEGG50_0000", i, i.originCaller) ++ addCouponsInternal(user, amount))
187+ then (recordActionInternal("VEGG500000", i, i.originCaller) ++ addCouponsInternal(user, amount))
188188 else addCouponsInternal(user, amount)
189189
190190
191191
192192 @Callable(i)
193193 func addCouponsBatch (batch) = if (if ((i.caller != this))
194194 then (i.callerPublicKey != wAccPKey)
195195 else false)
196196 then throw("CAC: admin only")
197197 else {
198198 let couponsList = split(batch, ";")
199199 func handleCoupon (acc,coupon) = {
200200 let splitArray = split(coupon, ":")
201201 let user = splitArray[0]
202202 let amount = parseIntValue(splitArray[1])
203203 let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil)
204204 if ((burnCall == burnCall))
205205 then if ((amount > 500000))
206- then ((acc ++ recordActionInternal("VEGG50_0000", i, i.originCaller)) ++ addCouponsInternal(user, amount))
206+ then ((acc ++ recordActionInternal("VEGG500000", i, i.originCaller)) ++ addCouponsInternal(user, amount))
207207 else (acc ++ addCouponsInternal(user, amount))
208208 else throw("Strict value is not equal to itself.")
209209 }
210210
211211 let $l = couponsList
212212 let $s = size($l)
213213 let $acc0 = nil
214214 func $f0_1 ($a,$i) = if (($i >= $s))
215215 then $a
216216 else handleCoupon($a, $l[$i])
217217
218218 func $f0_2 ($a,$i) = if (($i >= $s))
219219 then $a
220220 else throw("List size exceeds 20")
221221
222222 $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)
223223 }
224224
225225
226226
227227 @Callable(i)
228228 func CFRefund (recipient,amount) = {
229229 let cfAddress = getStringValue(i.caller, "CF_ADDRESS")
230230 let key = (("f_" + cfAddress) + "_stake_address")
231231 let stakeAddress = getStringValue(getMasterAddress(), key)
232232 if ((stakeAddress != toString(i.caller)))
233233 then throw("CCR: This is something fishy going on!")
234234 else addCouponsInternal(recipient, amount)
235235 }
236236
237237
238238
239239 @Callable(i)
240240 func useCoupons (amountTryingToPay) = {
241241 let invokingSc = i.caller
242242 if ((0 > amountTryingToPay))
243243 then throw("CUC: Only positive amount of money can be paid!")
244244 else if (!(containsElement(scCanUseCoupons, invokingSc)))
245245 then throw("CUC: Only certain smart contracts can use this coupon module!")
246246 else {
247247 let user = toString(i.originCaller)
248248 let keyActive = couponsUserActive(user)
249249 let availableCoupons = tryGetInteger(keyActive)
250250 if ((0 > availableCoupons))
251251 then throw("CUC: Get rekt!")
252252 else {
253253 let leftToPay = if ((amountTryingToPay > availableCoupons))
254254 then (amountTryingToPay - availableCoupons)
255255 else 0
256256 let amountPaid = (amountTryingToPay - leftToPay)
257257 let availableCouponsLeft = (availableCoupons - amountPaid)
258258 if ((0 > availableCouponsLeft))
259259 then throw("CUC: You try to overspend!")
260260 else {
261261 let keySpend = couponsUserSpend(user)
262262 let keyOld = couponsUserActiveOld(user)
263263 let keySpendSc = couponsSpendOnSc(toString(i.caller))
264264 let totalSpend = (tryGetInteger(keySpend) + amountPaid)
265265 let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
266266 $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
267267 }
268268 }
269269 }
270270 }
271271
272272
273273
274274 @Callable(i)
275275 func recordAction (actionName) = recordActionInternal(actionName, i, i.originCaller)
276276
277277

github/deemru/w8io/3ef1775 
49.51 ms