tx · DpWnhQgmc4JDsXbFbEFTBPGTVvBJB8RyRA24QYBXRFLi

3N3nfqFcxXfd3T18V9icDdh58MJ9wQ2k2xx:  -0.01000000 Waves

2023.08.06 20:25 [2699024] smart account 3N3nfqFcxXfd3T18V9icDdh58MJ9wQ2k2xx > SELF 0.00000000 Waves

{ "type": 13, "id": "DpWnhQgmc4JDsXbFbEFTBPGTVvBJB8RyRA24QYBXRFLi", "fee": 1000000, "feeAssetId": null, "timestamp": 1691342715077, "version": 2, "chainId": 84, "sender": "3N3nfqFcxXfd3T18V9icDdh58MJ9wQ2k2xx", "senderPublicKey": "UGqkWsCpv7xRVXkQRXyLd6pWPDtYGXmPip7FxSd1pAu", "proofs": [ "3YSKhrRN3aNSmHgq5x1PscZTkVqPnPsqr8y2QcwtFuJFkm2dPVn8PT2UvXi6D7h5roxPbT1EYRh3JDZyNNoNYvkp" ], "script": "base64:BgIUCAISBgoEAQEBARIAEgASBAoCCAEzAA9ERUZBVUxUTE9DQVRJT04CD0FmcmljYV9GX0FmcmljYQEUa2V5U3Rha2VkRHVja0J5T3duZXIBCW93bmVyQWRkcgkArAICAhJzdGFrZWREdWNrQnlPd25lcl8FCW93bmVyQWRkcgEPa2V5RHVja0xvY2F0aW9uAQtkdWNrQXNzZXRJZAkArAICAg1kdWNrTG9jYXRpb25fBQtkdWNrQXNzZXRJZAANbGFzdFRvdXJJZEtleQIOJXNfX2xhc3RUb3VySWQBFWtleVRvdXJTdGF0aWNEYXRhQnlJZAEDdElkCQCsAgICFiVzJWRfX3RvdXJTdGF0aWNEYXRhX18JAKQDAQUDdElkARZrZXlUb3VyRHluYW1pY0RhdGFCeUlkAQN0SWQJAKwCAgIXJXMlZF9fdG91ckR5bmFtaWNEYXRhX18JAKQDAQUDdElkARdrZXlBbGxSZWdpc3RyYW5kc0J5VG91cgEDdElkCQCsAgICFiVzJWRfX2FsbFJlZ2lzdHJhbmRzX18JAKQDAQUDdElkAAlpZHhTdGF0aWMAAAAKaWR4RHluYW1pYwABAQtnZXRUb3VyRGF0YQIMdG91ckNvbnRyYWN0A3RJZAQGc3RhdGljCQC1CQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQx0b3VyQ29udHJhY3QJARVrZXlUb3VyU3RhdGljRGF0YUJ5SWQBBQN0SWQJAKwCAgkArAICAhlFcnJvciByZWFkaW5nIHRvdXJuYW1lbnQgCQCkAwEFA3RJZAIFIGRhdGECAl9fBAdkeW5hbWljCQC1CQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQx0b3VyQ29udHJhY3QJARZrZXlUb3VyRHluYW1pY0RhdGFCeUlkAQUDdElkCQCsAgIJAKwCAgIZRXJyb3IgcmVhZGluZyB0b3VybmFtZW50IAkApAMBBQN0SWQCBSBkYXRhAgJfXwkAzAgCBQZzdGF0aWMJAMwIAgUHZHluYW1pYwUDbmlsABN0U3RhdGljUmVnaXN0ZXJDb3N0AAIADHRTdGF0aWNTdGFydAAFAAp0U3RhdGljRW5kAAYADnREeW5hbWljU3RhdHVzAAEAD3REeW5hbWljV2luRHVjawACABF0RHluYW1pY1dpblJlc3VsdAADABV0RHluYW1pY1RvdGFsUmVnQ291bnQABAAVdER5bmFtaWNUb3RhbEF0dGVtcHRzAAUAD2xvY0lkeENvbnRpbmVudAAAAApsb2NJZHhUeXBlAAEACGxvY0lkeElkAAIABWNoYWluCQDJAQIJAMoBAggFBHRoaXMFYnl0ZXMAAQABABVkZWZhdWx0UmVzdEFkZHJlc3NTdHIEByRtYXRjaDAFBWNoYWluAwkAAAIBAVcFByRtYXRjaDACIzNQUUN1dkZidmg0TGtQVW5yblUxejNqbmJBMXA5bTNXTmh2AwkAAAIBAVQFByRtYXRjaDACIzNNdW1rR0d6dENLQVhwV0RxeGtkZG9mcVhTVWJxUWt2U0p5CQACAQINVW5rbm93biBjaGFpbgADU0VQAgJfXwEPZ2V0U3RyaW5nT3JGYWlsAgdhZGRyZXNzA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFB2FkZHJlc3MFA2tleQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQdhZGRyZXNzCQDMCAICAS4JAMwIAgUDa2V5CQDMCAICDyBpcyBub3QgZGVmaW5lZAUDbmlsAgAAEUlkeENmZ1N0YWtpbmdEYXBwAAEADUlkeENmZ1dsZ0RhcHAABAEKa2V5UmVzdENmZwACDiVzX19yZXN0Q29uZmlnAQ5rZXlSZXN0QWRkcmVzcwACDCVzX19yZXN0QWRkcgERcmVhZFJlc3RDZmdPckZhaWwBBHJlc3QJALwJAgkBD2dldFN0cmluZ09yRmFpbAIFBHJlc3QJAQprZXlSZXN0Q2ZnAAUDU0VQARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCB3Jlc3RDZmcDaWR4CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkAkQMCBQdyZXN0Q2ZnBQNpZHgJAKwCAgIqUmVzdCBjZmcgZG9lc24ndCBjb250YWluIGFkZHJlc3MgYXQgaW5kZXggCQCkAwEFA2lkeAAMcmVzdENvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMJAQ5rZXlSZXN0QWRkcmVzcwAFFWRlZmF1bHRSZXN0QWRkcmVzc1N0cgAHcmVzdENmZwkBEXJlYWRSZXN0Q2ZnT3JGYWlsAQUMcmVzdENvbnRyYWN0AA9zdGFraW5nQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQdyZXN0Q2ZnBRFJZHhDZmdTdGFraW5nRGFwcAALd2xnQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQdyZXN0Q2ZnBQ1JZHhDZmdXbGdEYXBwAA13bGdBc3NldElkS2V5Agt3bGdfYXNzZXRJZAAKd2xnQXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCcCAIFC3dsZ0NvbnRyYWN0BQ13bGdBc3NldElkS2V5AhNOb3QgaW5pdGlhbGl6ZWQgeWV0AQhhc1N0cmluZwEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAFAXMJAAIBAhhmYWlsIHRvIGNhc3QgaW50byBTdHJpbmcBBWFzSW50AQF2BAckbWF0Y2gwBQF2AwkAAQIFByRtYXRjaDACA0ludAQBbgUHJG1hdGNoMAUBbgkAAgECFWZhaWwgdG8gY2FzdCBpbnRvIEludAEKZml4ZWRQb2ludAIDdmFsCGRlY2ltYWxzBAZ0ZW5Qb3cJAGwGAAoAAAUIZGVjaW1hbHMAAAAABQRET1dOBAdsb3dQYXJ0CQCkAwEJAGoCBQN2YWwFBnRlblBvdwQGemVyb2VzCQCwAgIJAKQDAQUGdGVuUG93CQBkAgABCQCxAgEFB2xvd1BhcnQJAKwCAgkArAICCQCsAgIJAKQDAQkAaQIFA3ZhbAUGdGVuUG93AgEuBQZ6ZXJvZXMFB2xvd1BhcnQAE01BWFRPVVJOQU1FTlRMRU5HVEgAgJj/zQEABEhPVVIAgN3bAQAKYWRtaW5zTGlzdAkAzAgCCQClCAEFBHRoaXMJAMwIAgQHJG1hdGNoMAUFY2hhaW4DCQAAAgEBVwUHJG1hdGNoMAIjM1BFZTJSRUxVSENGQ0JzbVNDTmNCSjhOM1VSTFZRZW5kZTcDCQAAAgEBVAUHJG1hdGNoMAIjM010QmdKVGFMeFBCM0M3VUpEMVVFOHFqa0h0aGZLdkZRWVkJAAIBAg1Vbmtub3duIGNoYWluBQNuaWwBG2tleUxhc3RSZWdpc3RlcmVkVG91ckJ5RHVjawELZHVja0Fzc2V0SWQJAKwCAgIgJXMlc19fbGFzdFJlZ2lzdGVyZWRUb3VyQnlEdWNrX18FC2R1Y2tBc3NldElkARxrZXlJc1JlZ2lzdGVyZWRCeVRvdXJBbmREdWNrAgN0SWQLZHVja0Fzc2V0SWQJALkJAgkAzAgCAiElcyVkJXNfX2lzUmVnaXN0ZXJlZEJ5VG91ckFuZER1Y2sJAMwIAgkApAMBBQN0SWQJAMwIAgULZHVja0Fzc2V0SWQFA25pbAUDU0VQARtrZXlMYXN0QXR0ZW1wdEJ5VG91ckFuZER1Y2sCA3RJZAtkdWNrQXNzZXRJZAkAuQkCCQDMCAICICVzJWQlc19fbGFzdEF0dGVtcHRCeVRvdXJBbmREdWNrCQDMCAIJAKQDAQUDdElkCQDMCAIFC2R1Y2tBc3NldElkBQNuaWwFA1NFUAEaa2V5QmVzdFJlc3VsdEJ5VG91ckFuZER1Y2sCA3RJZAtkdWNrQXNzZXRJZAkAuQkCCQDMCAICHyVzJWQlc19fYmVzdFJlc3VsdEJ5VG91ckFuZER1Y2sJAMwIAgkApAMBBQN0SWQJAMwIAgULZHVja0Fzc2V0SWQFA25pbAUDU0VQAQpzdGF0aWNEYXRhBgR0eElkDHJlZ2lzdGVyQ29zdAthdHRlbXB0Q29zdAxjcmVhdGlvblRpbWUJc3RhcnRUaW1lB2VuZFRpbWUJALkJAgkAzAgCAgwlcyVkJWQlZCVkJWQJAMwIAgUEdHhJZAkAzAgCCQCkAwEFDHJlZ2lzdGVyQ29zdAkAzAgCCQCkAwEFC2F0dGVtcHRDb3N0CQDMCAIJAKQDAQUMY3JlYXRpb25UaW1lCQDMCAIJAKQDAQUJc3RhcnRUaW1lCQDMCAIJAKQDAQUHZW5kVGltZQUDbmlsBQNTRVABC2R5bmFtaWNEYXRhBQZzdGF0dXMHd2luRHVjawl3aW5SZXN1bHQJdG90YWxSZWdzDXRvdGFsQXR0ZW1wdHMJALkJAgkAzAgCAgolcyVzJWQlZCVkCQDMCAIFBnN0YXR1cwkAzAgCBQd3aW5EdWNrCQDMCAIJAKQDAQUJd2luUmVzdWx0CQDMCAIJAKQDAQUJdG90YWxSZWdzCQDMCAIJAKQDAQUNdG90YWxBdHRlbXB0cwUDbmlsBQNTRVABBnByb2xvZwAJAQVhc0ludAEJAPwHBAUPc3Rha2luZ0NvbnRyYWN0AgpzYXZlTGFzdFR4BQNuaWwFA25pbAEMZHVja0J5Q2FsbGVyAQZjYWxsZXIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ9zdGFraW5nQ29udHJhY3QJARRrZXlTdGFrZWREdWNrQnlPd25lcgEJAKUIAQUGY2FsbGVyAhxZb3UgZG9uJ3QgaGF2ZSBhIGR1Y2sgc3Rha2VkBAFpARBjcmVhdGVUb3VybmFtZW50BAlzdGFydFRpbWUHZW5kVGltZQxyZWdpc3RlckNvc3QLYXR0ZW1wdENvc3QEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQphZG1pbnNMaXN0BQZjYWxsZXIJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAQGbGFzdElkCQCfCAEFDWxhc3RUb3VySWRLZXkEA3RJZAMJAQlpc0RlZmluZWQBBQZsYXN0SWQECmxhc3RUb3VySWQJAQV2YWx1ZQEFBmxhc3RJZAQHZHluYW1pYwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEJARZrZXlUb3VyRHluYW1pY0RhdGFCeUlkAQUKbGFzdFRvdXJJZAkArAICCQCsAgICGUVycm9yIHJlYWRpbmcgdG91cm5hbWVudCAJAKQDAQUKbGFzdFRvdXJJZAIFIGRhdGEEBnN0YXR1cwkAkQMCCQC1CQIFB2R5bmFtaWMFA1NFUAUOdER5bmFtaWNTdGF0dXMDCQECIT0CBQZzdGF0dXMCCEFSQ0hJVkVECQACAQkArAICAixDdXJyZW50IHRvdXJuZW1lbnQgaXMgbm90IGNvbXBsZXRlZCwgc3RhdHVzPQUGc3RhdHVzCQBkAgUKbGFzdFRvdXJJZAABAAEEA25vdwgFCWxhc3RCbG9jawl0aW1lc3RhbXADCQBmAgUDbm93BQlzdGFydFRpbWUJAAIBCQCsAgIJAKwCAgkArAICAgpzdGFydFRpbWU9CQCkAwEFCXN0YXJ0VGltZQIQIDwgY3JlYXRpb25UaW1lPQkApAMBBQNub3cDCQBmAgUJc3RhcnRUaW1lBQdlbmRUaW1lCQACAQkArAICCQCsAgIJAKwCAgIIZW5kVGltZT0JAKQDAQUHZW5kVGltZQINIDwgc3RhcnRUaW1lPQkApAMBBQlzdGFydFRpbWUDCQBmAgkAZQIFB2VuZFRpbWUFCXN0YXJ0VGltZQUTTUFYVE9VUk5BTUVOVExFTkdUSAkAAgEJAKwCAgkArAICCQCsAgICH1RvdXJuYW1lbnQgcGVyaW9kIGV4Y2VlZHMgbWF4OiAJAKQDAQkAZQIFB2VuZFRpbWUFCXN0YXJ0VGltZQIDID4gCQCkAwEFE01BWFRPVVJOQU1FTlRMRU5HVEgDAwkAZwIAAAUMcmVnaXN0ZXJDb3N0BgkAZwIAAAULYXR0ZW1wdENvc3QJAAIBCQCsAgIJAKwCAgkArAICAiRDb3N0IHNob3VsZCBiZSBwb3NpdGl2ZSwgYnV0IHBhc3NlZCAJAKQDAQUMcmVnaXN0ZXJDb3N0AgUgYW5kIAkApAMBBQthdHRlbXB0Q29zdAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ1sYXN0VG91cklkS2V5BQN0SWQJAMwIAgkBC1N0cmluZ0VudHJ5AgkBFWtleVRvdXJTdGF0aWNEYXRhQnlJZAEFA3RJZAkBCnN0YXRpY0RhdGEGCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQFDHJlZ2lzdGVyQ29zdAULYXR0ZW1wdENvc3QFA25vdwUJc3RhcnRUaW1lBQdlbmRUaW1lCQDMCAIJAQtTdHJpbmdFbnRyeQIJARZrZXlUb3VyRHluYW1pY0RhdGFCeUlkAQUDdElkCQELZHluYW1pY0RhdGEFAgdDUkVBVEVEAgAAAAAAAAAFA25pbAUDdElkAWkBCHJlZ2lzdGVyAAQMcHJvbG9nUmVzdWx0CQEGcHJvbG9nAAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABAZ3bGdBbXQIBQNwbXQGYW1vdW50BApwbXRBc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIIBQNwbXQHYXNzZXRJZAIVV0xHT0xEIHBheW1lbnRzIG9ubHkhAwkBAiE9AgUKcG10QXNzZXRJZAUKd2xnQXNzZXRJZAkAAgECFVdMR09MRCBwYXltZW50cyBvbmx5IQQGbGFzdElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUNbGFzdFRvdXJJZEtleQIVTm8gYWN0aXZlIHRvdXJuYW1lbnRzBANub3cIBQlsYXN0QmxvY2sJdGltZXN0YW1wBAV0RGF0YQkBC2dldFRvdXJEYXRhAgUEdGhpcwUGbGFzdElkBAZzdGF0aWMJAJEDAgUFdERhdGEFCWlkeFN0YXRpYwQHZHluYW1pYwkAkQMCBQV0RGF0YQUKaWR4RHluYW1pYwQGc3RhdHVzCQCRAwIFB2R5bmFtaWMFDnREeW5hbWljU3RhdHVzAwkBASEBAwMDCQAAAgUGc3RhdHVzAgdDUkVBVEVECQBmAgUDbm93CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGc3RhdGljBQx0U3RhdGljU3RhcnQHCQBmAgkAZQIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZzdGF0aWMFCnRTdGF0aWNFbmQFBEhPVVIFA25vdwcGAwkAAAIFBnN0YXR1cwIKSU5QUk9HUkVTUwkAZgIJAGUCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGc3RhdGljBQp0U3RhdGljRW5kBQRIT1VSBQNub3cHCQACAQITQ2Fubm90IHJlZ2lzdGVyIG5vdwQHcmVnQ29zdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFBnN0YXRpYwUTdFN0YXRpY1JlZ2lzdGVyQ29zdAMJAQIhPQIFBndsZ0FtdAUHcmVnQ29zdAkAAgEJAKwCAgkArAICAhBOZWVkIHBheW1lbnQgb2YgCQEKZml4ZWRQb2ludAIFB3JlZ0Nvc3QACAIHIFdMR09MRAQLZHVja0Fzc2V0SWQJAQxkdWNrQnlDYWxsZXIBCAUBaQxvcmlnaW5DYWxsZXIEDm9sZFJlZ2lzdHJhbmRzCQELdmFsdWVPckVsc2UCCQCiCAEJARdrZXlBbGxSZWdpc3RyYW5kc0J5VG91cgEFBmxhc3RJZAIABAdyZWdMaXN0AwkAAAIFDm9sZFJlZ2lzdHJhbmRzAgAFA25pbAkAvQkCBQ5vbGRSZWdpc3RyYW5kcwIBXwMDCQELdmFsdWVPckVsc2UCCQCgCAEJARxrZXlJc1JlZ2lzdGVyZWRCeVRvdXJBbmREdWNrAgUGbGFzdElkBQtkdWNrQXNzZXRJZAcGCQEPY29udGFpbnNFbGVtZW50AgUHcmVnTGlzdAULZHVja0Fzc2V0SWQJAAIBCQCsAgIJAKwCAgkArAICAgpZb3VyIGR1Y2sgBQtkdWNrQXNzZXRJZAIlIGlzIGFscmVhZHkgcmVnaXN0ZXJlZCBhdCB0b3VybmFtZW50IAkApAMBBQZsYXN0SWQEEnVwZGF0ZWREeW5hbWljRGF0YQkBC2R5bmFtaWNEYXRhBQIKSU5QUk9HUkVTUwkAkQMCBQdkeW5hbWljBQ90RHluYW1pY1dpbkR1Y2sJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdkeW5hbWljBRF0RHluYW1pY1dpblJlc3VsdAkAZAIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdkeW5hbWljBRV0RHluYW1pY1RvdGFsUmVnQ291bnQAAQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB2R5bmFtaWMFFXREeW5hbWljVG90YWxBdHRlbXB0cwkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEba2V5TGFzdFJlZ2lzdGVyZWRUb3VyQnlEdWNrAQULZHVja0Fzc2V0SWQFBmxhc3RJZAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBHGtleUlzUmVnaXN0ZXJlZEJ5VG91ckFuZER1Y2sCBQZsYXN0SWQFC2R1Y2tBc3NldElkBgkAzAgCCQELU3RyaW5nRW50cnkCCQEXa2V5QWxsUmVnaXN0cmFuZHNCeVRvdXIBBQZsYXN0SWQJALsJAgkAzQgCBQdyZWdMaXN0BQtkdWNrQXNzZXRJZAIBXwkAzAgCCQELU3RyaW5nRW50cnkCCQEWa2V5VG91ckR5bmFtaWNEYXRhQnlJZAEFBmxhc3RJZAUSdXBkYXRlZER5bmFtaWNEYXRhBQNuaWwFDHByb2xvZ1Jlc3VsdAFpAQpuZXdBdHRlbXB0AAQMcHJvbG9nUmVzdWx0CQEGcHJvbG9nAAQLZHVja0Fzc2V0SWQJAQxkdWNrQnlDYWxsZXIBCAUBaQxvcmlnaW5DYWxsZXIEBmxhc3RJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFDWxhc3RUb3VySWRLZXkCFU5vIGFjdGl2ZSB0b3VybmFtZW50cwQDbm93CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQFdERhdGEJAQtnZXRUb3VyRGF0YQIFBHRoaXMFBmxhc3RJZAQGc3RhdGljCQCRAwIFBXREYXRhBQlpZHhTdGF0aWMEB2R5bmFtaWMJAJEDAgUFdERhdGEFCmlkeER5bmFtaWMEBnN0YXR1cwkAkQMCBQdkeW5hbWljBQ50RHluYW1pY1N0YXR1cwMJAQEhAQMJAAACBQZzdGF0dXMCCklOUFJPR1JFU1MJAGYCCQBlAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFBnN0YXRpYwUKdFN0YXRpY0VuZAUESE9VUgUDbm93BwkAAgECF0F0dGVtcHQgaXMgbm90IHBvc3NpYmxlAwkBASEBCQELdmFsdWVPckVsc2UCCQCgCAEJARxrZXlJc1JlZ2lzdGVyZWRCeVRvdXJBbmREdWNrAgUGbGFzdElkBQtkdWNrQXNzZXRJZAcJAAIBCQCsAgIJAKwCAgkArAICAgpZb3VyIGR1Y2sgBQtkdWNrQXNzZXRJZAIhIGlzIG5vdCByZWdpc3RlcmVkIGF0IHRvdXJuYW1lbnQgCQCkAwEFBmxhc3RJZAQTYXR0ZW1wdHNJdGVyYXRvcktleQkBG2tleUxhc3RBdHRlbXB0QnlUb3VyQW5kRHVjawIFBmxhc3RJZAULZHVja0Fzc2V0SWQEC2xhc3RBdHRlbXB0CQCfCAEFE2F0dGVtcHRzSXRlcmF0b3JLZXkECyR0MDY1NTE3MTg0AwkBASEBCQEJaXNEZWZpbmVkAQULbGFzdEF0dGVtcHQJAJQKAgAAAAADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiJleGFjdGx5IDEgcGF5bWVudCBtdXN0IGJlIGF0dGFjaGVkBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAQGd2xnQW10CAUDcG10BmFtb3VudAQKcG10QXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAUDcG10B2Fzc2V0SWQCFVdMR09MRCBwYXltZW50cyBvbmx5IQMJAQIhPQIFCnBtdEFzc2V0SWQFCndsZ0Fzc2V0SWQJAAIBAhVXTEdPTEQgcGF5bWVudHMgb25seSEEB2F0dENvc3QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZzdGF0aWMFE3RTdGF0aWNSZWdpc3RlckNvc3QDCQECIT0CBQZ3bGdBbXQFB2F0dENvc3QJAAIBCQCsAgIJAKwCAgIQTmVlZCBwYXltZW50IG9mIAkBCmZpeGVkUG9pbnQCBQdhdHRDb3N0AAgCByBXTEdPTEQJAJQKAgkAZAIJAQV2YWx1ZQEFC2xhc3RBdHRlbXB0AAEAAQQNcGF5ZWRBdHRlbXB0cwgFCyR0MDY1NTE3MTg0Al8xBAlpbmNyZW1lbnQIBQskdDA2NTUxNzE4NAJfMgQSdXBkYXRlZER5bmFtaWNEYXRhCQELZHluYW1pY0RhdGEFAgpJTlBST0dSRVNTCQCRAwIFB2R5bmFtaWMFD3REeW5hbWljV2luRHVjawkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB2R5bmFtaWMFEXREeW5hbWljV2luUmVzdWx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHZHluYW1pYwUVdER5bmFtaWNUb3RhbFJlZ0NvdW50CQBkAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB2R5bmFtaWMFFXREeW5hbWljVG90YWxBdHRlbXB0cwUJaW5jcmVtZW50BAtjdXJMb2NhdGlvbgkAtQkCCQELdmFsdWVPckVsc2UCCQCdCAIFD3N0YWtpbmdDb250cmFjdAkBD2tleUR1Y2tMb2NhdGlvbgEFC2R1Y2tBc3NldElkBQ9ERUZBVUxUTE9DQVRJT04CAV8EDWJlc3RSZXN1bHRLZXkJARprZXlCZXN0UmVzdWx0QnlUb3VyQW5kRHVjawIFBmxhc3RJZAULZHVja0Fzc2V0SWQEBGJlc3QDAwkAAAIJAJEDAgULY3VyTG9jYXRpb24FCmxvY0lkeFR5cGUCAVQJAAACCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgULY3VyTG9jYXRpb24FD2xvY0lkeENvbnRpbmVudAUGbGFzdElkBwQKYmVzdFJlc3VsdAkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ1iZXN0UmVzdWx0S2V5AAAECWN1clJlc3VsdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFC2N1ckxvY2F0aW9uBQhsb2NJZHhJZAkAlgMBCQDMCAIFCmJlc3RSZXN1bHQJAMwIAgUJY3VyUmVzdWx0BQNuaWwAAAQHdG91ckxvYwkBCGFzU3RyaW5nAQkA/AcEBQ9zdGFraW5nQ29udHJhY3QCE2luaXREdWNrVG91ckF0dGVtcHQJAMwIAgULZHVja0Fzc2V0SWQFA25pbAUDbmlsCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFDWJlc3RSZXN1bHRLZXkFBGJlc3QJAMwIAgkBDEludGVnZXJFbnRyeQIFE2F0dGVtcHRzSXRlcmF0b3JLZXkFDXBheWVkQXR0ZW1wdHMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBFmtleVRvdXJEeW5hbWljRGF0YUJ5SWQBBQZsYXN0SWQFEnVwZGF0ZWREeW5hbWljRGF0YQUDbmlsCQDMCAIFDHByb2xvZ1Jlc3VsdAkAzAgCBQ1wYXllZEF0dGVtcHRzCQDMCAIFB3RvdXJMb2MFA25pbAFpARF1cGRhdGVEeW5hbWljRGF0YQILZHVja0Fzc2V0SWQHbmV3QmVzdAMJAQIhPQIIBQFpBmNhbGxlcgUPc3Rha2luZ0NvbnRyYWN0CQACAQINQWNjZXNzIGRlbmllZAQGbGFzdElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUNbGFzdFRvdXJJZEtleQIVTm8gYWN0aXZlIHRvdXJuYW1lbnRzBAV0RGF0YQkBC2dldFRvdXJEYXRhAgUEdGhpcwUGbGFzdElkBAZzdGF0aWMJAJEDAgUFdERhdGEFCWlkeFN0YXRpYwQHZHluYW1pYwkAkQMCBQV0RGF0YQUKaWR4RHluYW1pYwMDAwkAZwIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdkeW5hbWljBRF0RHluYW1pY1dpblJlc3VsdAUHbmV3QmVzdAYJAQIhPQIJAJEDAgUHZHluYW1pYwUOdER5bmFtaWNTdGF0dXMCCklOUFJPR1JFU1MGCQBmAggFCWxhc3RCbG9jawl0aW1lc3RhbXAJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQZzdGF0aWMFCnRTdGF0aWNFbmQJAJQKAgUDbmlsAAAEEnVwZGF0ZWREeW5hbWljRGF0YQkBC2R5bmFtaWNEYXRhBQIKSU5QUk9HUkVTUwULZHVja0Fzc2V0SWQFB25ld0Jlc3QJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdkeW5hbWljBRV0RHluYW1pY1RvdGFsUmVnQ291bnQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdkeW5hbWljBRV0RHluYW1pY1RvdGFsQXR0ZW1wdHMJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCCQEWa2V5VG91ckR5bmFtaWNEYXRhQnlJZAEFBmxhc3RJZAUSdXBkYXRlZER5bmFtaWNEYXRhBQNuaWwAAABvOkzY", "height": 2699024, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Af8Ya79QSUcKfzfyqHyQrhjgdpXxCb1q9qWUkkmCCmvF Next: 5pWhgbRucrwfVGuWWfGmBaNpxMoWMacRu5K3s4zEfxcx Diff:
OldNewDifferences
308308 }
309309
310310
311+
312+@Callable(aE)
313+func updateDynamicData (e,bd) = if ((aE.caller != S))
314+ then throw("Access denied")
315+ else {
316+ let aF = valueOrErrorMessage(getInteger(f), "No active tournaments")
317+ let aM = m(this, aF)
318+ let o = aM[k]
319+ let p = aM[l]
320+ if (if (if ((parseIntValue(p[v]) >= bd))
321+ then true
322+ else (p[t] != "INPROGRESS"))
323+ then true
324+ else (lastBlock.timestamp > parseIntValue(o[s])))
325+ then $Tuple2(nil, 0)
326+ else {
327+ let aQ = av("INPROGRESS", e, bd, parseIntValue(p[w]), parseIntValue(p[x]))
328+ $Tuple2([StringEntry(i(aF), aQ)], 0)
329+ }
330+ }
331+
332+
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = "Africa_F_Africa"
55
66 func b (c) = ("stakedDuckByOwner_" + c)
77
88
99 func d (e) = ("duckLocation_" + e)
1010
1111
1212 let f = "%s__lastTourId"
1313
1414 func g (h) = ("%s%d__tourStaticData__" + toString(h))
1515
1616
1717 func i (h) = ("%s%d__tourDynamicData__" + toString(h))
1818
1919
2020 func j (h) = ("%s%d__allRegistrands__" + toString(h))
2121
2222
2323 let k = 0
2424
2525 let l = 1
2626
2727 func m (n,h) = {
2828 let o = split(valueOrErrorMessage(getString(n, g(h)), (("Error reading tournament " + toString(h)) + " data")), "__")
2929 let p = split(valueOrErrorMessage(getString(n, i(h)), (("Error reading tournament " + toString(h)) + " data")), "__")
3030 [o, p]
3131 }
3232
3333
3434 let q = 2
3535
3636 let r = 5
3737
3838 let s = 6
3939
4040 let t = 1
4141
4242 let u = 2
4343
4444 let v = 3
4545
4646 let w = 4
4747
4848 let x = 5
4949
5050 let y = 0
5151
5252 let z = 1
5353
5454 let A = 2
5555
5656 let B = take(drop(this.bytes, 1), 1)
5757
5858 let C = {
5959 let D = B
6060 if ((base58'2W' == D))
6161 then "3PQCuvFbvh4LkPUnrnU1z3jnbA1p9m3WNhv"
6262 else if ((base58'2T' == D))
6363 then "3MumkGGztCKAXpWDqxkddofqXSUbqQkvSJy"
6464 else throw("Unknown chain")
6565 }
6666
6767 let E = "__"
6868
6969 func F (G,H) = valueOrErrorMessage(getString(G, H), makeString(["mandatory ", toString(G), ".", H, " is not defined"], ""))
7070
7171
7272 let I = 1
7373
7474 let J = 4
7575
7676 func K () = "%s__restConfig"
7777
7878
7979 func L () = "%s__restAddr"
8080
8181
8282 func M (N) = split_4C(F(N, K()), E)
8383
8484
8585 func O (P,Q) = valueOrErrorMessage(addressFromString(P[Q]), ("Rest cfg doesn't contain address at index " + toString(Q)))
8686
8787
8888 let R = addressFromStringValue(valueOrElse(getString(this, L()), C))
8989
9090 let P = M(R)
9191
9292 let S = O(P, I)
9393
9494 let T = O(P, J)
9595
9696 let U = "wlg_assetId"
9797
9898 let V = valueOrErrorMessage(getBinary(T, U), "Not initialized yet")
9999
100100 func W (X) = {
101101 let D = X
102102 if ($isInstanceOf(D, "String"))
103103 then {
104104 let Y = D
105105 Y
106106 }
107107 else throw("fail to cast into String")
108108 }
109109
110110
111111 func Z (X) = {
112112 let D = X
113113 if ($isInstanceOf(D, "Int"))
114114 then {
115115 let aa = D
116116 aa
117117 }
118118 else throw("fail to cast into Int")
119119 }
120120
121121
122122 func ab (ac,ad) = {
123123 let ae = pow(10, 0, ad, 0, 0, DOWN)
124124 let af = toString((ac % ae))
125125 let ag = drop(toString(ae), (1 + size(af)))
126126 (((toString((ac / ae)) + ".") + ag) + af)
127127 }
128128
129129
130130 let ah = 432000000
131131
132132 let ai = 3600000
133133
134134 let aj = [toString(this), {
135135 let D = B
136136 if ((base58'2W' == D))
137137 then "3PEe2RELUHCFCBsmSCNcBJ8N3URLVQende7"
138138 else if ((base58'2T' == D))
139139 then "3MtBgJTaLxPB3C7UJD1UE8qjkHthfKvFQYY"
140140 else throw("Unknown chain")
141141 }]
142142
143143 func ak (e) = ("%s%s__lastRegisteredTourByDuck__" + e)
144144
145145
146146 func al (h,e) = makeString(["%s%d%s__isRegisteredByTourAndDuck", toString(h), e], E)
147147
148148
149149 func am (h,e) = makeString(["%s%d%s__lastAttemptByTourAndDuck", toString(h), e], E)
150150
151151
152152 func an (h,e) = makeString(["%s%d%s__bestResultByTourAndDuck", toString(h), e], E)
153153
154154
155155 func ao (ap,aq,ar,as,at,au) = makeString(["%s%d%d%d%d%d", ap, toString(aq), toString(ar), toString(as), toString(at), toString(au)], E)
156156
157157
158158 func av (aw,ax,ay,az,aA) = makeString(["%s%s%d%d%d", aw, ax, toString(ay), toString(az), toString(aA)], E)
159159
160160
161161 func aB () = Z(invoke(S, "saveLastTx", nil, nil))
162162
163163
164164 func aC (aD) = valueOrErrorMessage(getString(S, b(toString(aD))), "You don't have a duck staked")
165165
166166
167167 @Callable(aE)
168168 func createTournament (at,au,aq,ar) = {
169169 let aD = toString(aE.caller)
170170 if (!(containsElement(aj, aD)))
171171 then throw("Permission denied")
172172 else {
173173 let aF = getInteger(f)
174174 let h = if (isDefined(aF))
175175 then {
176176 let aG = value(aF)
177177 let p = valueOrErrorMessage(getString(i(aG)), (("Error reading tournament " + toString(aG)) + " data"))
178178 let aw = split(p, E)[t]
179179 if ((aw != "ARCHIVED"))
180180 then throw(("Current tournement is not completed, status=" + aw))
181181 else (aG + 1)
182182 }
183183 else 1
184184 let aH = lastBlock.timestamp
185185 if ((aH > at))
186186 then throw(((("startTime=" + toString(at)) + " < creationTime=") + toString(aH)))
187187 else if ((at > au))
188188 then throw(((("endTime=" + toString(au)) + " < startTime=") + toString(at)))
189189 else if (((au - at) > ah))
190190 then throw(((("Tournament period exceeds max: " + toString((au - at))) + " > ") + toString(ah)))
191191 else if (if ((0 >= aq))
192192 then true
193193 else (0 >= ar))
194194 then throw(((("Cost should be positive, but passed " + toString(aq)) + " and ") + toString(ar)))
195195 else $Tuple2([IntegerEntry(f, h), StringEntry(g(h), ao(toBase58String(aE.transactionId), aq, ar, aH, at, au)), StringEntry(i(h), av("CREATED", "", 0, 0, 0))], h)
196196 }
197197 }
198198
199199
200200
201201 @Callable(aE)
202202 func register () = {
203203 let aI = aB()
204204 if ((size(aE.payments) != 1))
205205 then throw("exactly 1 payment must be attached")
206206 else {
207207 let aJ = aE.payments[0]
208208 let aK = aJ.amount
209209 let aL = valueOrErrorMessage(aJ.assetId, "WLGOLD payments only!")
210210 if ((aL != V))
211211 then throw("WLGOLD payments only!")
212212 else {
213213 let aF = valueOrErrorMessage(getInteger(f), "No active tournaments")
214214 let aH = lastBlock.timestamp
215215 let aM = m(this, aF)
216216 let o = aM[k]
217217 let p = aM[l]
218218 let aw = p[t]
219219 if (!(if (if (if ((aw == "CREATED"))
220220 then (aH > parseIntValue(o[r]))
221221 else false)
222222 then ((parseIntValue(o[s]) - ai) > aH)
223223 else false)
224224 then true
225225 else if ((aw == "INPROGRESS"))
226226 then ((parseIntValue(o[s]) - ai) > aH)
227227 else false))
228228 then throw("Cannot register now")
229229 else {
230230 let aN = parseIntValue(o[q])
231231 if ((aK != aN))
232232 then throw((("Need payment of " + ab(aN, 8)) + " WLGOLD"))
233233 else {
234234 let e = aC(aE.originCaller)
235235 let aO = valueOrElse(getString(j(aF)), "")
236236 let aP = if ((aO == ""))
237237 then nil
238238 else split_51C(aO, "_")
239239 if (if (valueOrElse(getBoolean(al(aF, e)), false))
240240 then true
241241 else containsElement(aP, e))
242242 then throw(((("Your duck " + e) + " is already registered at tournament ") + toString(aF)))
243243 else {
244244 let aQ = av("INPROGRESS", p[u], parseIntValue(p[v]), (parseIntValue(p[w]) + 1), parseIntValue(p[x]))
245245 $Tuple2([IntegerEntry(ak(e), aF), BooleanEntry(al(aF, e), true), StringEntry(j(aF), makeString_11C((aP :+ e), "_")), StringEntry(i(aF), aQ)], aI)
246246 }
247247 }
248248 }
249249 }
250250 }
251251 }
252252
253253
254254
255255 @Callable(aE)
256256 func newAttempt () = {
257257 let aI = aB()
258258 let e = aC(aE.originCaller)
259259 let aF = valueOrErrorMessage(getInteger(f), "No active tournaments")
260260 let aH = lastBlock.timestamp
261261 let aM = m(this, aF)
262262 let o = aM[k]
263263 let p = aM[l]
264264 let aw = p[t]
265265 if (!(if ((aw == "INPROGRESS"))
266266 then ((parseIntValue(o[s]) - ai) > aH)
267267 else false))
268268 then throw("Attempt is not possible")
269269 else if (!(valueOrElse(getBoolean(al(aF, e)), false)))
270270 then throw(((("Your duck " + e) + " is not registered at tournament ") + toString(aF)))
271271 else {
272272 let aR = am(aF, e)
273273 let aS = getInteger(aR)
274274 let aT = if (!(isDefined(aS)))
275275 then $Tuple2(0, 0)
276276 else if ((size(aE.payments) != 1))
277277 then throw("exactly 1 payment must be attached")
278278 else {
279279 let aJ = aE.payments[0]
280280 let aK = aJ.amount
281281 let aL = valueOrErrorMessage(aJ.assetId, "WLGOLD payments only!")
282282 if ((aL != V))
283283 then throw("WLGOLD payments only!")
284284 else {
285285 let aU = parseIntValue(o[q])
286286 if ((aK != aU))
287287 then throw((("Need payment of " + ab(aU, 8)) + " WLGOLD"))
288288 else $Tuple2((value(aS) + 1), 1)
289289 }
290290 }
291291 let aV = aT._1
292292 let aW = aT._2
293293 let aQ = av("INPROGRESS", p[u], parseIntValue(p[v]), parseIntValue(p[w]), (parseIntValue(p[x]) + aW))
294294 let aX = split(valueOrElse(getString(S, d(e)), a), "_")
295295 let aY = an(aF, e)
296296 let aZ = if (if ((aX[z] == "T"))
297297 then (parseIntValue(aX[y]) == aF)
298298 else false)
299299 then {
300300 let ba = valueOrElse(getInteger(aY), 0)
301301 let bb = parseIntValue(aX[A])
302302 max([ba, bb])
303303 }
304304 else 0
305305 let bc = W(invoke(S, "initDuckTourAttempt", [e], nil))
306306 $Tuple2([IntegerEntry(aY, aZ), IntegerEntry(aR, aV), StringEntry(i(aF), aQ)], [aI, aV, bc])
307307 }
308308 }
309309
310310
311+
312+@Callable(aE)
313+func updateDynamicData (e,bd) = if ((aE.caller != S))
314+ then throw("Access denied")
315+ else {
316+ let aF = valueOrErrorMessage(getInteger(f), "No active tournaments")
317+ let aM = m(this, aF)
318+ let o = aM[k]
319+ let p = aM[l]
320+ if (if (if ((parseIntValue(p[v]) >= bd))
321+ then true
322+ else (p[t] != "INPROGRESS"))
323+ then true
324+ else (lastBlock.timestamp > parseIntValue(o[s])))
325+ then $Tuple2(nil, 0)
326+ else {
327+ let aQ = av("INPROGRESS", e, bd, parseIntValue(p[w]), parseIntValue(p[x]))
328+ $Tuple2([StringEntry(i(aF), aQ)], 0)
329+ }
330+ }
331+
332+

github/deemru/w8io/169f3d6 
51.24 ms