tx · J6KuXWv2Mt4wtEAXdPSwCzNnBr2HQHSRiTdSuJBmf2wn

3P5W1D4UuSZrNfeZFJZcD5wT2avfbHbzTvS:  -0.01000000 Waves

2023.10.20 17:23 [3872888] smart account 3P5W1D4UuSZrNfeZFJZcD5wT2avfbHbzTvS > SELF 0.00000000 Waves

{ "type": 13, "id": "J6KuXWv2Mt4wtEAXdPSwCzNnBr2HQHSRiTdSuJBmf2wn", "fee": 1000000, "feeAssetId": null, "timestamp": 1697811870878, "version": 2, "chainId": 87, "sender": "3P5W1D4UuSZrNfeZFJZcD5wT2avfbHbzTvS", "senderPublicKey": "F2V8KEm5DoCEa97hZZENCMkMcD1fkdkCizYx6fVAk65F", "proofs": [ "9yij4Y5dApZN53drrrrdKBT3JdDwuSMVJB5Q6rUrgumg392yzfNpaCmoAkxiW9S1PrWT5HtHNRdZuqMJmvkLh1X" ], "script": "base64:BgIiCAISAwoBCBIECgIIARIDCgEIEgQKAggBEgMKAQESAwoBCCsBFHRyeUdldFN0cmluZ0V4dGVybmFsAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAnQgCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwBQFhAgABDXRyeUdldEJvb2xlYW4BA2tleQQHJG1hdGNoMAkAoAgBBQNrZXkDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAUBYgcBDHRyeUdldFN0cmluZwEDa2V5CQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCBQR0aGlzBQNrZXkBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABCWdldE9yYWNsZQAJAQdBZGRyZXNzAQkA2QQBCQEMdHJ5R2V0U3RyaW5nAQIUc3RhdGljX29yYWNsZUFkZHJlc3MBHnN0YXRpY0tleV90dXJ0bGVTdGFraW5nQWRkcmVzcwACG3N0YXRpY190dXJ0bGVTdGFraW5nQWRkcmVzcwEec3RhdGljS2V5X3R1cnRsZVJlYmlydGhBZGRyZXNzAAIbc3RhdGljX3R1cnRsZVJlYmlydGhBZGRyZXNzARVzdGF0aWNLZXlfcm9wZUFkZHJlc3MAAhJzdGF0aWNfcm9wZUFkZHJlc3MBHHN0YXRpY0tleV9sZXZlbFN5c3RlbUFkZHJlc3MAAhlzdGF0aWNfbGV2ZWxTeXN0ZW1BZGRyZXNzARZzdGF0aWNLZXlfc3BpY2VBc3NldElkAAITc3RhdGljX3NwaWNlQXNzZXRJZAEVc3RhdGljS2V5X21hcmtldHBsYWNlAAIZc3RhdGljX21hcmtldHBsYWNlQWRkcmVzcwEZc3RhdGljS2V5X2NhcGFjaXR5QWRkcmVzcwACFnN0YXRpY19jYXBhY2l0eUFkZHJlc3MBEWdldFJlYmlydGhBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhVzdGF0aWNfcmViaXJ0aEFkZHJlc3MBE2dldEluY3ViYXRvckFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACF3N0YXRpY19pbmN1YmF0b3JBZGRyZXNzARFnZXRGYXJtaW5nQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIVc3RhdGljX2Zhcm1pbmdBZGRyZXNzARJnZXRHYW1lRGFwcEFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFnN0YXRpY19nYW1lRGFwcEFkZHJlc3MBEmdldENhcGFjaXR5QWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBGXN0YXRpY0tleV9jYXBhY2l0eUFkZHJlc3MAAQ5nZXRCdXJuQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAISc3RhdGljX2J1cm5BZGRyZXNzARJnZXRCYWJ5ZHVja0FkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQACFnN0YXRpY19iYWJ5RHVja0FkZHJlc3MBEmdldEJyZWVkaW5nQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAIVc3RhdGljX2JyZWVkZXJBZGRyZXNzARBnZXRNYXN0ZXJBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUAAhZzdGF0aWNfY2ZNYXN0ZXJBZGRyZXNzARdnZXRUdXJ0bGVTdGFraW5nQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHnN0YXRpY0tleV90dXJ0bGVTdGFraW5nQWRkcmVzcwABF2dldFR1cnRsZVJlYmlydGhBZGRyZXNzAAkBB0FkZHJlc3MBCQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEec3RhdGljS2V5X3R1cnRsZVJlYmlydGhBZGRyZXNzAAEOZ2V0Um9wZUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARVzdGF0aWNLZXlfcm9wZUFkZHJlc3MAAQ9nZXRTcGljZUFzc2V0SWQACQDZBAEJARR0cnlHZXRTdHJpbmdFeHRlcm5hbAIJAQlnZXRPcmFjbGUACQEWc3RhdGljS2V5X3NwaWNlQXNzZXRJZAABFWdldExldmVsU3lzdGVtQWRkcmVzcwAJAQdBZGRyZXNzAQkA2QQBCQEUdHJ5R2V0U3RyaW5nRXh0ZXJuYWwCCQEJZ2V0T3JhY2xlAAkBHHN0YXRpY0tleV9sZXZlbFN5c3RlbUFkZHJlc3MAARVnZXRNYXJrZXRQbGFjZUFkZHJlc3MACQEHQWRkcmVzcwEJANkEAQkBFHRyeUdldFN0cmluZ0V4dGVybmFsAgkBCWdldE9yYWNsZQAJARVzdGF0aWNLZXlfbWFya2V0cGxhY2UAAAh3QWNjUEtleQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBCWdldE9yYWNsZQACD3N0YXRpY193YXJzUEtleQIbc3RhdGljX3dhcnNQS2V5IG5vdCBkZWZpbmVkAA9zY0NhblVzZUNvdXBvbnMJAMwIAgkBEWdldFJlYmlydGhBZGRyZXNzAAkAzAgCCQETZ2V0SW5jdWJhdG9yQWRkcmVzcwAJAMwIAgkBEWdldEZhcm1pbmdBZGRyZXNzAAkAzAgCCQESZ2V0R2FtZURhcHBBZGRyZXNzAAkAzAgCCQESZ2V0QmFieWR1Y2tBZGRyZXNzAAkAzAgCCQESZ2V0QnJlZWRpbmdBZGRyZXNzAAkAzAgCCQEXZ2V0VHVydGxlU3Rha2luZ0FkZHJlc3MACQDMCAIJARdnZXRUdXJ0bGVSZWJpcnRoQWRkcmVzcwAJAMwIAgkBDmdldFJvcGVBZGRyZXNzAAkAzAgCCQEVZ2V0TGV2ZWxTeXN0ZW1BZGRyZXNzAAkAzAgCCQEVZ2V0TWFya2V0UGxhY2VBZGRyZXNzAAkAzAgCCQESZ2V0Q2FwYWNpdHlBZGRyZXNzAAkAzAgCBQR0aGlzBQNuaWwBEGNvdXBvbnNVc2VyU3BlbmQBBHVzZXIJAKwCAgUEdXNlcgIGX3NwZW5kARFjb3Vwb25zVXNlckFjdGl2ZQEEdXNlcgkArAICBQR1c2VyAgdfYWN0aXZlARRjb3Vwb25zVXNlckFjdGl2ZU9sZAEEdXNlcgkArAICCQERY291cG9uc1VzZXJBY3RpdmUBBQR1c2VyAgRfb2xkARBjb3Vwb25zU3BlbmRPblNjAQJzYwkArAICBQJzYwIPX3NwZW5kX2J5X3VzaW5nAR1hY3Rpb25QZXJBZGRyZXNzUGVyVXNlclBlckRheQQEdXNlcgZhY3Rpb24LZGFwcEFkZHJlc3MDZGF5CQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFC2RhcHBBZGRyZXNzAgFfBQZhY3Rpb24CAV8FBHVzZXICAV8FA2RheQIIX2FjdGlvbnMBI2FjdGlvblBlckFkZHJlc3NQZXJVc2VyTGFzdENoZWNrRGF5AgR1c2VyBmFjdGlvbgkArAICCQCsAgIJAKwCAgUGYWN0aW9uAgFfBQR1c2VyAhJfYWN0aW9uc19jaGVja19kYXkBI2FjdGlvblBlckFkZHJlc3NQZXJVc2VyQW1vdW50SW5BUm93AgR1c2VyBmFjdGlvbgkArAICCQCsAgIJAKwCAgUGYWN0aW9uAgFfBQR1c2VyAhZfYWN0aW9uc19hbW91bnRfaW5fcm93AQ51c2VyRXhwZXJpZW5jZQEEdXNlcgkArAICBQR1c2VyAgtfZXhwZXJpZW5jZQESYWRkQ291cG9uc0ludGVybmFsAgR1c2VyBmFtb3VudAQGa2V5T2xkCQEUY291cG9uc1VzZXJBY3RpdmVPbGQBBQR1c2VyBANrZXkJARFjb3Vwb25zVXNlckFjdGl2ZQEFBHVzZXIECmNvdXBvbnNPbGQJAQ10cnlHZXRJbnRlZ2VyAQUDa2V5BAdjb3Vwb25zCQBkAgUKY291cG9uc09sZAUGYW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQZrZXlPbGQFCmNvdXBvbnNPbGQJAMwIAgkBDEludGVnZXJFbnRyeQIFA2tleQUHY291cG9ucwUDbmlsAAlzdGFydFRzTXMAgIjY+qsxARdjYWxjdWxhdGVEYXlzU2luY2VTdGFydAAEBGRpZmYJAGUCCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUJc3RhcnRUc01zBApkYXlzUGFzc2VkCQBpAgUEZGlmZgkAaAIAgKMFAOgHBQpkYXlzUGFzc2VkARBoYXNEb25lVGFzazdEYXlzBQNkYXkHYWRkcmVzcwphY3Rpb25OYW1lDHJld2FyZEFtb3VudBJyZXdhcmRBbW91bnRXZWVrbHkEEXVzZXJFeHBlcmllbmNlS2V5CQEOdXNlckV4cGVyaWVuY2UBBQdhZGRyZXNzBA91c2VyRXhwVGlsbGRhdGUJAQ10cnlHZXRJbnRlZ2VyAQURdXNlckV4cGVyaWVuY2VLZXkEC2NoZWNrRGF5S2V5CQEjYWN0aW9uUGVyQWRkcmVzc1BlclVzZXJMYXN0Q2hlY2tEYXkCBQdhZGRyZXNzBQphY3Rpb25OYW1lBAxkYXlzSW5Sb3dLZXkJASNhY3Rpb25QZXJBZGRyZXNzUGVyVXNlckFtb3VudEluQVJvdwIFB2FkZHJlc3MFCmFjdGlvbk5hbWUEDGxhc3RDaGVja0RheQkBDXRyeUdldEludGVnZXIBBQtjaGVja0RheUtleQQJZGF5c0luUm93CQENdHJ5R2V0SW50ZWdlcgEFDGRheXNJblJvd0tleQQPZGF5c0luUm93VXBkYXRlAwkAAAIFDGxhc3RDaGVja0RheQkAZQIFA2RheQABCQBkAgUJZGF5c0luUm93AAEDCQBmAgkAZQIFA2RheQABBQxsYXN0Q2hlY2tEYXkAAQAABBJsYXN0Q2hlY2tEYXlVcGRhdGUFA2RheQQGcmV3YXJkAwkAAAIFD2RheXNJblJvd1VwZGF0ZQAHCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFB2FkZHJlc3MFEnJld2FyZEFtb3VudFdlZWtseQkBD2dldFNwaWNlQXNzZXRJZAAJAMwIAgkBDEludGVnZXJFbnRyeQIFDGRheXNJblJvd0tleQAABQNuaWwJAMwIAgkBDEludGVnZXJFbnRyeQIFDGRheXNJblJvd0tleQUPZGF5c0luUm93VXBkYXRlBQNuaWwJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgULY2hlY2tEYXlLZXkFEmxhc3RDaGVja0RheVVwZGF0ZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQERQGV4dHJOYXRpdmUoMTA2MikBBQdhZGRyZXNzBQxyZXdhcmRBbW91bnQJAQ9nZXRTcGljZUFzc2V0SWQACQDMCAIJAQxJbnRlZ2VyRW50cnkCBRF1c2VyRXhwZXJpZW5jZUtleQkAZAIFD3VzZXJFeHBUaWxsZGF0ZQABBQNuaWwFBnJld2FyZAEJcGF5QWN0aW9uBAphY3Rpb25OYW1lC3VzZXJBZGRyZXNzBmFtb3VudANkYXkEC2NvbXBvc2VkS2V5AwkBDXRyeUdldEJvb2xlYW4BCQCsAgIJAKwCAgIFVEFTS18FCmFjdGlvbk5hbWUCBl9FVkVSWQUKYWN0aW9uTmFtZQkArAICCQCsAgIFCmFjdGlvbk5hbWUCAV8JAKQDAQUGYW1vdW50AwkBDXRyeUdldEJvb2xlYW4BCQCsAgICBVRBU0tfBQtjb21wb3NlZEtleQkBEGhhc0RvbmVUYXNrN0RheXMFBQNkYXkJAKUIAQULdXNlckFkZHJlc3MFC2NvbXBvc2VkS2V5CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgVUQVNLXwULY29tcG9zZWRLZXkCDV9SRVdBUkRfREFJTFkJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICBVRBU0tfBQtjb21wb3NlZEtleQIOX1JFV0FSRF9XRUVLTFkFA25pbAEUcmVjb3JkQWN0aW9uSW50ZXJuYWwDCmFjdGlvbk5hbWUNYWRkcmVzc0NhbGxlcgdhZGRyZXNzAwkBASEBCQEPY29udGFpbnNFbGVtZW50AgUPc2NDYW5Vc2VDb3Vwb25zBQ1hZGRyZXNzQ2FsbGVyCQACAQI9Q1JBOiBPbmx5IGNlcnRhaW4gc21hcnQgY29udHJhY3RzIGNhbiB1c2UgdGhpcyByZXdhcmQgbW9kdWxlIQQDZGF5CQEXY2FsY3VsYXRlRGF5c1NpbmNlU3RhcnQABAlhY3Rpb25LZXkJAR1hY3Rpb25QZXJBZGRyZXNzUGVyVXNlclBlckRheQQJAKUIAQUHYWRkcmVzcwUKYWN0aW9uTmFtZQkApQgBBQ1hZGRyZXNzQ2FsbGVyCQCkAwEFA2RheQQMdG90YWxBY3Rpb25zCQBkAgkBDXRyeUdldEludGVnZXIBBQlhY3Rpb25LZXkAAQkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlhY3Rpb25LZXkFDHRvdGFsQWN0aW9ucwUDbmlsCQEJcGF5QWN0aW9uBAUKYWN0aW9uTmFtZQUHYWRkcmVzcwUMdG90YWxBY3Rpb25zBQNkYXkGAWkBD2NvbmZpZ3VyZU9yYWNsZQEGb3JhY2xlAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIPQ0NPOiBhZG1pbiBvbmx5CQDMCAIJAQtTdHJpbmdFbnRyeQICFHN0YXRpY19vcmFjbGVBZGRyZXNzBQZvcmFjbGUFA25pbAFpAQphZGRDb3Vwb25zAgR1c2VyBmFtb3VudAMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpD2NhbGxlclB1YmxpY0tleQUId0FjY1BLZXkHCQACAQIPQ0FDOiBhZG1pbiBvbmx5AwkAZwIFBmFtb3VudACAreIECQDOCAIJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMCDFZFR0cxMDAwMDAwMAUEdGhpcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUEdXNlcgkBEmFkZENvdXBvbnNJbnRlcm5hbAIFBHVzZXIFBmFtb3VudAMJAGcCBQZhbW91bnQAoMIeCQDOCAIJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMCClZFR0c1MDAwMDAFBHRoaXMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHVzZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQBaQEPYWRkQ291cG9uc0JhdGNoAQViYXRjaAMDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAQIhPQIIBQFpD2NhbGxlclB1YmxpY0tleQUId0FjY1BLZXkHCQACAQIPQ0FDOiBhZG1pbiBvbmx5BAtjb3Vwb25zTGlzdAkAtQkCBQViYXRjaAIBOwoBDGhhbmRsZUNvdXBvbgIDYWNjBmNvdXBvbgQKc3BsaXRBcnJheQkAtQkCBQZjb3Vwb24CAToEBHVzZXIJAJEDAgUKc3BsaXRBcnJheQAABAZhbW91bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpzcGxpdEFycmF5AAEECGJ1cm5DYWxsCQD8BwQJAQ5nZXRCdXJuQWRkcmVzcwACDGJ1cm5CeUludm9rZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFCGJ1cm5DYWxsBQhidXJuQ2FsbAMJAGcCBQZhbW91bnQAgK3iBAkAzggCCQDOCAIFA2FjYwkBFHJlY29yZEFjdGlvbkludGVybmFsAwIMVkVHRzEwMDAwMDAwBQR0aGlzCQERQGV4dHJOYXRpdmUoMTA2MikBBQR1c2VyCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50AwkAZwIFBmFtb3VudACgwh4JAM4IAgkAzggCBQNhY2MJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMCClZFR0c1MDAwMDAFBHRoaXMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHVzZXIJARJhZGRDb3Vwb25zSW50ZXJuYWwCBQR1c2VyBQZhbW91bnQJAM4IAgUDYWNjCQESYWRkQ291cG9uc0ludGVybmFsAgUEdXNlcgUGYW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCgACJGwFC2NvdXBvbnNMaXN0CgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQxoYW5kbGVDb3Vwb24CBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAFpAQhDRlJlZnVuZAIJcmVjaXBpZW50BmFtb3VudAQJY2ZBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA1MykCCAUBaQZjYWxsZXICCkNGX0FERFJFU1MEA2tleQkArAICCQCsAgICAmZfBQljZkFkZHJlc3MCDl9zdGFrZV9hZGRyZXNzBAxzdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDUzKQIJARBnZXRNYXN0ZXJBZGRyZXNzAAUDa2V5AwkBAiE9AgUMc3Rha2VBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgkAAgECJkNDUjogVGhpcyBpcyBzb21ldGhpbmcgZmlzaHkgZ29pbmcgb24hCQESYWRkQ291cG9uc0ludGVybmFsAgUJcmVjaXBpZW50BQZhbW91bnQBaQEKdXNlQ291cG9ucwERYW1vdW50VHJ5aW5nVG9QYXkECmludm9raW5nU2MIBQFpBmNhbGxlcgMJAGYCAAAFEWFtb3VudFRyeWluZ1RvUGF5CQACAQIvQ1VDOiBPbmx5IHBvc2l0aXZlIGFtb3VudCBvZiBtb25leSBjYW4gYmUgcGFpZCEDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQ9zY0NhblVzZUNvdXBvbnMFCmludm9raW5nU2MJAAIBAj1DVUM6IE9ubHkgY2VydGFpbiBzbWFydCBjb250cmFjdHMgY2FuIHVzZSB0aGlzIGNvdXBvbiBtb2R1bGUhBAR1c2VyCQClCAEIBQFpDG9yaWdpbkNhbGxlcgQJa2V5QWN0aXZlCQERY291cG9uc1VzZXJBY3RpdmUBBQR1c2VyBBBhdmFpbGFibGVDb3Vwb25zCQENdHJ5R2V0SW50ZWdlcgEFCWtleUFjdGl2ZQMJAGYCAAAFEGF2YWlsYWJsZUNvdXBvbnMJAAIBAg5DVUM6IEdldCByZWt0IQQJbGVmdFRvUGF5AwkAZgIFEWFtb3VudFRyeWluZ1RvUGF5BRBhdmFpbGFibGVDb3Vwb25zCQBlAgURYW1vdW50VHJ5aW5nVG9QYXkFEGF2YWlsYWJsZUNvdXBvbnMAAAQKYW1vdW50UGFpZAkAZQIFEWFtb3VudFRyeWluZ1RvUGF5BQlsZWZ0VG9QYXkEFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQBlAgUQYXZhaWxhYmxlQ291cG9ucwUKYW1vdW50UGFpZAMJAGYCAAAFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQACAQIaQ1VDOiBZb3UgdHJ5IHRvIG92ZXJzcGVuZCEECGtleVNwZW5kCQEQY291cG9uc1VzZXJTcGVuZAEFBHVzZXIEBmtleU9sZAkBFGNvdXBvbnNVc2VyQWN0aXZlT2xkAQUEdXNlcgQKa2V5U3BlbmRTYwkBEGNvdXBvbnNTcGVuZE9uU2MBCQClCAEIBQFpBmNhbGxlcgQKdG90YWxTcGVuZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUIa2V5U3BlbmQFCmFtb3VudFBhaWQEDHRvdGFsU3BlbmRTYwkAZAIJAQ10cnlHZXRJbnRlZ2VyAQUKa2V5U3BlbmRTYwUKYW1vdW50UGFpZAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQhrZXlTcGVuZAUKdG90YWxTcGVuZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUGa2V5T2xkBRBhdmFpbGFibGVDb3Vwb25zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrZXlBY3RpdmUFFGF2YWlsYWJsZUNvdXBvbnNMZWZ0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQprZXlTcGVuZFNjBQx0b3RhbFNwZW5kU2MFA25pbAUKYW1vdW50UGFpZAFpAQxyZWNvcmRBY3Rpb24BCmFjdGlvbk5hbWUJARRyZWNvcmRBY3Rpb25JbnRlcm5hbAMFCmFjdGlvbk5hbWUIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyAE5EMNQ=", "height": 3872888, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 5qAyCPZjcuXtsx9MNCrS2bPPTnCUNGwyvQU2SML1E5gb Next: DhghD584tDX4tGx1C9e2dMfV9kAt6W7irQMsAaN4TTnZ Diff:
OldNewDifferences
4949 func staticKey_marketplace () = "static_marketplaceAddress"
5050
5151
52+func staticKey_capacityAddress () = "static_capacityAddress"
53+
54+
5255 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_rebirthAddress")))
5356
5457
5962
6063
6164 func getGameDappAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_gameDappAddress")))
65+
66+
67+func getCapacityAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_capacityAddress())))
6268
6369
6470 func getBurnAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_burnAddress")))
9399
94100 let wAccPKey = fromBase58String(valueOrErrorMessage(getString(getOracle(), "static_warsPKey"), "static_warsPKey not defined"))
95101
96-let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress(), getMarketPlaceAddress(), this]
102+let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress(), getMarketPlaceAddress(), getCapacityAddress(), this]
97103
98104 func couponsUserSpend (user) = (user + "_spend")
99105
189195 then (i.callerPublicKey != wAccPKey)
190196 else false)
191197 then throw("CAC: admin only")
192- else if ((amount >= 500000))
193- then (recordActionInternal("VEGG500000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
194- else addCouponsInternal(user, amount)
198+ else if ((amount >= 10000000))
199+ then (recordActionInternal("VEGG10000000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
200+ else if ((amount >= 500000))
201+ then (recordActionInternal("VEGG500000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
202+ else addCouponsInternal(user, amount)
195203
196204
197205
208216 let amount = parseIntValue(splitArray[1])
209217 let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil)
210218 if ((burnCall == burnCall))
211- then if ((amount >= 500000))
212- then ((acc ++ recordActionInternal("VEGG500000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
213- else (acc ++ addCouponsInternal(user, amount))
219+ then if ((amount >= 10000000))
220+ then ((acc ++ recordActionInternal("VEGG10000000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
221+ else if ((amount >= 500000))
222+ then ((acc ++ recordActionInternal("VEGG500000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
223+ else (acc ++ addCouponsInternal(user, amount))
214224 else throw("Strict value is not equal to itself.")
215225 }
216226
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 staticKey_marketplace () = "static_marketplaceAddress"
5050
5151
52+func staticKey_capacityAddress () = "static_capacityAddress"
53+
54+
5255 func getRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_rebirthAddress")))
5356
5457
5558 func getIncubatorAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_incubatorAddress")))
5659
5760
5861 func getFarmingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_farmingAddress")))
5962
6063
6164 func getGameDappAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_gameDappAddress")))
65+
66+
67+func getCapacityAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_capacityAddress())))
6268
6369
6470 func getBurnAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_burnAddress")))
6571
6672
6773 func getBabyduckAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_babyDuckAddress")))
6874
6975
7076 func getBreedingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_breederAddress")))
7177
7278
7379 func getMasterAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), "static_cfMasterAddress")))
7480
7581
7682 func getTurtleStakingAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleStakingAddress())))
7783
7884
7985 func getTurtleRebirthAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_turtleRebirthAddress())))
8086
8187
8288 func getRopeAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_ropeAddress())))
8389
8490
8591 func getSpiceAssetId () = fromBase58String(tryGetStringExternal(getOracle(), staticKey_spiceAssetId()))
8692
8793
8894 func getLevelSystemAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_levelSystemAddress())))
8995
9096
9197 func getMarketPlaceAddress () = Address(fromBase58String(tryGetStringExternal(getOracle(), staticKey_marketplace())))
9298
9399
94100 let wAccPKey = fromBase58String(valueOrErrorMessage(getString(getOracle(), "static_warsPKey"), "static_warsPKey not defined"))
95101
96-let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress(), getMarketPlaceAddress(), this]
102+let scCanUseCoupons = [getRebirthAddress(), getIncubatorAddress(), getFarmingAddress(), getGameDappAddress(), getBabyduckAddress(), getBreedingAddress(), getTurtleStakingAddress(), getTurtleRebirthAddress(), getRopeAddress(), getLevelSystemAddress(), getMarketPlaceAddress(), getCapacityAddress(), this]
97103
98104 func couponsUserSpend (user) = (user + "_spend")
99105
100106
101107 func couponsUserActive (user) = (user + "_active")
102108
103109
104110 func couponsUserActiveOld (user) = (couponsUserActive(user) + "_old")
105111
106112
107113 func couponsSpendOnSc (sc) = (sc + "_spend_by_using")
108114
109115
110116 func actionPerAddressPerUserPerDay (user,action,dappAddress,day) = (((((((dappAddress + "_") + action) + "_") + user) + "_") + day) + "_actions")
111117
112118
113119 func actionPerAddressPerUserLastCheckDay (user,action) = (((action + "_") + user) + "_actions_check_day")
114120
115121
116122 func actionPerAddressPerUserAmountInARow (user,action) = (((action + "_") + user) + "_actions_amount_in_row")
117123
118124
119125 func userExperience (user) = (user + "_experience")
120126
121127
122128 func addCouponsInternal (user,amount) = {
123129 let keyOld = couponsUserActiveOld(user)
124130 let key = couponsUserActive(user)
125131 let couponsOld = tryGetInteger(key)
126132 let coupons = (couponsOld + amount)
127133 [IntegerEntry(keyOld, couponsOld), IntegerEntry(key, coupons)]
128134 }
129135
130136
131137 let startTsMs = 1695427200000
132138
133139 func calculateDaysSinceStart () = {
134140 let diff = (lastBlock.timestamp - startTsMs)
135141 let daysPassed = (diff / (86400 * 1000))
136142 daysPassed
137143 }
138144
139145
140146 func hasDoneTask7Days (day,address,actionName,rewardAmount,rewardAmountWeekly) = {
141147 let userExperienceKey = userExperience(address)
142148 let userExpTilldate = tryGetInteger(userExperienceKey)
143149 let checkDayKey = actionPerAddressPerUserLastCheckDay(address, actionName)
144150 let daysInRowKey = actionPerAddressPerUserAmountInARow(address, actionName)
145151 let lastCheckDay = tryGetInteger(checkDayKey)
146152 let daysInRow = tryGetInteger(daysInRowKey)
147153 let daysInRowUpdate = if ((lastCheckDay == (day - 1)))
148154 then (daysInRow + 1)
149155 else if (((day - 1) > lastCheckDay))
150156 then 1
151157 else 0
152158 let lastCheckDayUpdate = day
153159 let reward = if ((daysInRowUpdate == 7))
154160 then [ScriptTransfer(addressFromStringValue(address), rewardAmountWeekly, getSpiceAssetId()), IntegerEntry(daysInRowKey, 0)]
155161 else [IntegerEntry(daysInRowKey, daysInRowUpdate)]
156162 ([IntegerEntry(checkDayKey, lastCheckDayUpdate), ScriptTransfer(addressFromStringValue(address), rewardAmount, getSpiceAssetId()), IntegerEntry(userExperienceKey, (userExpTilldate + 1))] ++ reward)
157163 }
158164
159165
160166 func payAction (actionName,userAddress,amount,day) = {
161167 let composedKey = if (tryGetBoolean((("TASK_" + actionName) + "_EVERY")))
162168 then actionName
163169 else ((actionName + "_") + toString(amount))
164170 if (tryGetBoolean(("TASK_" + composedKey)))
165171 then hasDoneTask7Days(day, toString(userAddress), composedKey, tryGetInteger((("TASK_" + composedKey) + "_REWARD_DAILY")), tryGetInteger((("TASK_" + composedKey) + "_REWARD_WEEKLY")))
166172 else nil
167173 }
168174
169175
170176 func recordActionInternal (actionName,addressCaller,address) = if (!(containsElement(scCanUseCoupons, addressCaller)))
171177 then throw("CRA: Only certain smart contracts can use this reward module!")
172178 else {
173179 let day = calculateDaysSinceStart()
174180 let actionKey = actionPerAddressPerUserPerDay(toString(address), actionName, toString(addressCaller), toString(day))
175181 let totalActions = (tryGetInteger(actionKey) + 1)
176182 ([IntegerEntry(actionKey, totalActions)] ++ payAction(actionName, address, totalActions, day))
177183 }
178184
179185
180186 @Callable(i)
181187 func configureOracle (oracle) = if ((i.caller != this))
182188 then throw("CCO: admin only")
183189 else [StringEntry("static_oracleAddress", oracle)]
184190
185191
186192
187193 @Callable(i)
188194 func addCoupons (user,amount) = if (if ((i.caller != this))
189195 then (i.callerPublicKey != wAccPKey)
190196 else false)
191197 then throw("CAC: admin only")
192- else if ((amount >= 500000))
193- then (recordActionInternal("VEGG500000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
194- else addCouponsInternal(user, amount)
198+ else if ((amount >= 10000000))
199+ then (recordActionInternal("VEGG10000000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
200+ else if ((amount >= 500000))
201+ then (recordActionInternal("VEGG500000", this, addressFromStringValue(user)) ++ addCouponsInternal(user, amount))
202+ else addCouponsInternal(user, amount)
195203
196204
197205
198206 @Callable(i)
199207 func addCouponsBatch (batch) = if (if ((i.caller != this))
200208 then (i.callerPublicKey != wAccPKey)
201209 else false)
202210 then throw("CAC: admin only")
203211 else {
204212 let couponsList = split(batch, ";")
205213 func handleCoupon (acc,coupon) = {
206214 let splitArray = split(coupon, ":")
207215 let user = splitArray[0]
208216 let amount = parseIntValue(splitArray[1])
209217 let burnCall = invoke(getBurnAddress(), "burnByInvoke", [amount], nil)
210218 if ((burnCall == burnCall))
211- then if ((amount >= 500000))
212- then ((acc ++ recordActionInternal("VEGG500000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
213- else (acc ++ addCouponsInternal(user, amount))
219+ then if ((amount >= 10000000))
220+ then ((acc ++ recordActionInternal("VEGG10000000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
221+ else if ((amount >= 500000))
222+ then ((acc ++ recordActionInternal("VEGG500000", this, addressFromStringValue(user))) ++ addCouponsInternal(user, amount))
223+ else (acc ++ addCouponsInternal(user, amount))
214224 else throw("Strict value is not equal to itself.")
215225 }
216226
217227 let $l = couponsList
218228 let $s = size($l)
219229 let $acc0 = nil
220230 func $f0_1 ($a,$i) = if (($i >= $s))
221231 then $a
222232 else handleCoupon($a, $l[$i])
223233
224234 func $f0_2 ($a,$i) = if (($i >= $s))
225235 then $a
226236 else throw("List size exceeds 20")
227237
228238 $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)
229239 }
230240
231241
232242
233243 @Callable(i)
234244 func CFRefund (recipient,amount) = {
235245 let cfAddress = getStringValue(i.caller, "CF_ADDRESS")
236246 let key = (("f_" + cfAddress) + "_stake_address")
237247 let stakeAddress = getStringValue(getMasterAddress(), key)
238248 if ((stakeAddress != toString(i.caller)))
239249 then throw("CCR: This is something fishy going on!")
240250 else addCouponsInternal(recipient, amount)
241251 }
242252
243253
244254
245255 @Callable(i)
246256 func useCoupons (amountTryingToPay) = {
247257 let invokingSc = i.caller
248258 if ((0 > amountTryingToPay))
249259 then throw("CUC: Only positive amount of money can be paid!")
250260 else if (!(containsElement(scCanUseCoupons, invokingSc)))
251261 then throw("CUC: Only certain smart contracts can use this coupon module!")
252262 else {
253263 let user = toString(i.originCaller)
254264 let keyActive = couponsUserActive(user)
255265 let availableCoupons = tryGetInteger(keyActive)
256266 if ((0 > availableCoupons))
257267 then throw("CUC: Get rekt!")
258268 else {
259269 let leftToPay = if ((amountTryingToPay > availableCoupons))
260270 then (amountTryingToPay - availableCoupons)
261271 else 0
262272 let amountPaid = (amountTryingToPay - leftToPay)
263273 let availableCouponsLeft = (availableCoupons - amountPaid)
264274 if ((0 > availableCouponsLeft))
265275 then throw("CUC: You try to overspend!")
266276 else {
267277 let keySpend = couponsUserSpend(user)
268278 let keyOld = couponsUserActiveOld(user)
269279 let keySpendSc = couponsSpendOnSc(toString(i.caller))
270280 let totalSpend = (tryGetInteger(keySpend) + amountPaid)
271281 let totalSpendSc = (tryGetInteger(keySpendSc) + amountPaid)
272282 $Tuple2([IntegerEntry(keySpend, totalSpend), IntegerEntry(keyOld, availableCoupons), IntegerEntry(keyActive, availableCouponsLeft), IntegerEntry(keySpendSc, totalSpendSc)], amountPaid)
273283 }
274284 }
275285 }
276286 }
277287
278288
279289
280290 @Callable(i)
281291 func recordAction (actionName) = recordActionInternal(actionName, i.caller, i.originCaller)
282292
283293

github/deemru/w8io/3ef1775 
44.29 ms