tx · 6QJENVqWfBiNxmp9p3wSFhtSCNxJ1yiCq2echg6uYU1E 3N7HtrKeFFLz5oy6PfGv1Lg3GwPk4gCPdGy: -0.01500000 Waves 2023.06.19 02:34 [2628736] smart account 3N7HtrKeFFLz5oy6PfGv1Lg3GwPk4gCPdGy > SELF 0.00000000 Waves
{ "type": 13, "id": "6QJENVqWfBiNxmp9p3wSFhtSCNxJ1yiCq2echg6uYU1E", "fee": 1500000, "feeAssetId": null, "timestamp": 1687131286151, "version": 2, "chainId": 84, "sender": "3N7HtrKeFFLz5oy6PfGv1Lg3GwPk4gCPdGy", "senderPublicKey": "FsR18761ZAsUqsTd7TK3XmR6bhihs1UXVmpHYxz5JzQ1", "proofs": [ "5s3BiDCjfs4agd6zctmtNRy6aC3esiKonK3HjzMgaDAdTm7AEiejUGHxo84z7E3zSSokyDcEfg5gmcCZ6Qdj5vom" ], "script": "base64:BgISCAISBQoDCAgIEgASAwoBARIAkwEABWNoYWluCQDJAQIJAMoBAggFBHRoaXMFYnl0ZXMAAQABAAt1c2R0QXNzZXRJZAQHJG1hdGNoMAUFY2hhaW4DCQAAAgEBVwUHJG1hdGNoMAEghNp6sggDP07Ru8qO7ouTvMmC3Qtd+geWqNQj+agP/7kDCQAAAgEBVAUHJG1hdGNoMAEgVbHYn3KHgu/l41uNrAWrZd6aQ6EvFrsF8xq3h6XxxRgJAAIBAg1Vbmtub3duIGNoYWluABVkZWZhdWx0UmVzdEFkZHJlc3NTdHIEByRtYXRjaDAFBWNoYWluAwkAAAIBAVcFByRtYXRjaDACIzNQUUN1dkZidmg0TGtQVW5yblUxejNqbmJBMXA5bTNXTmh2AwkAAAIBAVQFByRtYXRjaDACIzNNdW1rR0d6dENLQVhwV0RxeGtkZG9mcVhTVWJxUWt2U0p5CQACAQINVW5rbm93biBjaGFpbgARSW5mcmFVcGdyYWRlQ29zdFMEByRtYXRjaDAFBWNoYWluAwkAAAIBAVcFByRtYXRjaDAAgMivoCUDCQAAAgEBVAUHJG1hdGNoMACAwtcvCQACAQINVW5rbm93biBjaGFpbgADU0VQAgJfXwAFTVVMVDYAwIQ9AAVNVUxUNwCAreIEAAVNVUxUOACAwtcvAAZNVUxUMTAAgMivoCUACkxBTkRQUkVGSVgCBExBTkQACkRVQ0tQUkVGSVgCBERVQ0sACkFSVFBSRVNBTEUCB1BSRVNBTEUABk5VTVJFUwAGAAVTU0laRQAZAAVNU0laRQBkAAVMU0laRQDhAQAGWExTSVpFAJADAAdYWExTSVpFAPEEAA9EQUlMWVJFU0JZUElFQ0UAgPjSAQAJREFZTUlMTElTAIC4mSkADFdITVVMVElQTElFUgCAyK+gJQAPREVGQVVMVExPQ0FUSU9OAg9BZnJpY2FfRl9BZnJpY2EAEFJFU09VUkNFUFJJQ0VNSU4A1bUCAA1FU01BWFBBQ0tBR0VTAAMACUVTQlVZQ09FRgAEAApFU1NFTExDT0VGAAoABU1BWEhQAGQACHJlc1R5cGVzCQDMCAICA09pbAkAzAgCAgNPcmUJAMwIAgIEV29vZAkAzAgCAgRTYW5kCQDMCAICBENsYXkJAMwIAgIHT3JnYW5pYwUDbmlsAAhtYXRUeXBlcwkAzAgCAgRGdWVsCQDMCAICBU1ldGFsCQDMCAICBVBsYW5rCQDMCAICBUdsYXNzCQDMCAICB1BsYXN0aWMJAMwIAgIHUHJvdGVpbgUDbmlsAAlwcm9kVHlwZXMJAMwIAgIQRmlyc3QgQWlkIEtpdCBMMQkAzAgCAhBGaXJzdCBBaWQgS2l0IEwyCQDMCAICEEZpcnN0IEFpZCBLaXQgTDMJAMwIAgILQmFja3BhY2sgTDEJAMwIAgILQmFja3BhY2sgTDIJAMwIAgILQmFja3BhY2sgTDMJAMwIAgIORm9vZCBSYXRpb24gTDEJAMwIAgIORm9vZCBSYXRpb24gTDIJAMwIAgIORm9vZCBSYXRpb24gTDMJAMwIAgILSmV0IFBhY2sgTDEJAMwIAgILSmV0IFBhY2sgTDIJAMwIAgILSmV0IFBhY2sgTDMJAMwIAgIJU2hpZWxkIEwxCQDMCAICCVNoaWVsZCBMMgkAzAgCAglTaGllbGQgTDMFA25pbAAKY29udGluZW50cwkAzAgCAghBbWVyaWNhcwkAzAgCAgZFdXJvcGUJAMwIAgIEQXNpYQkAzAgCAgZBZnJpY2EJAMwIAgIHT2NlYW5pYQUDbmlsABBwcm9kdWN0aW9uTWF0cml4CQDMCAICEjFfMV8xXzJfMl81XzFfMTBfMAkAzAgCAhMyXzJfMl80XzRfMTBfMV8xMF8wCQDMCAICEzNfM18zXzZfNl8xNV8xXzEwXzAJAMwIAgITMl81XzVfMl83XzVfMl8xMDBfMQkAzAgCAhc0XzEwXzEwXzRfMTRfMTBfMl8xMDBfMQkAzAgCAhc2XzE1XzE1XzZfMjFfMTVfMl8xMDBfMQkAzAgCAhIxXzFfMV8xXzFfOF8xXzEwXzIJAMwIAgITMl8yXzJfMl8yXzE2XzFfMTBfMgkAzAgCAhMzXzNfM18zXzNfMjRfMV8xMF8yCQDMCAICEzlfOV8xXzVfNV8xXzVfMTAwXzMJAMwIAgIXMThfMThfMl8xMF8xMF8yXzVfMTAwXzMJAMwIAgIXMjdfMjdfM18xNV8xNV8zXzVfMTAwXzMJAMwIAgISMl8yXzFfMl8yXzJfMV8xMF80CQDMCAICEjRfNF8yXzRfNF80XzFfMTBfNAkAzAgCAhI2XzZfM182XzZfNl8xXzEwXzQFA25pbAAPY29udElkeEFtZXJpY2FzAAAADWNvbnRJZHhFdXJvcGUAAQALY29udElkeEFzaWEAAgANY29udElkeEFmcmljYQADAA5jb250SWR4T2NlYW5pYQAEAA1yZWNpcGVJZHhGdWVsAAAADnJlY2lwZUlkeE1ldGFsAAEADnJlY2lwZUlkeFBsYW5rAAIADnJlY2lwZUlkeEdsYXNzAAMAEHJlY2lwZUlkeFBsYXN0aWMABAAQcmVjaXBlSWR4UHJvdGVpbgAFAA9yZWNpcGVJZHhXZWlnaHQABgARcmVjaXBlSWR4UGFja3NpemUABwAScmVjaXBlSWR4Q29udGluZW50AAgACnJlY0xhbmROdW0AAAALcmVjTGFuZFNpemUAAQALcmVjVGVycmFpbnMAAgAMcmVjQ29udGluZW50AAMAC3doSWR4TGV2ZWxzAAAACHdoSWR4UmVzAAEACHdoSWR4TWF0AAIACXdoSWR4UHJvZAADAAl3aElkeExPRlQABAAJdm9sTG9ja2VkAAAAC3ZvbE9jY3VwaWVkAAEAB3ZvbEZyZWUAAgAIdm9sVG90YWwAAwAKYnBJZHhMZXZlbAAAAAhicElkeFJlcwABAAhicElkeE1hdAACAAlicElkeFByb2QAAwEKZ2V0UGtnU2l6ZQEHcHJvZElkeAkBDXBhcnNlSW50VmFsdWUBCQCRAwIJALUJAgkAkQMCBRBwcm9kdWN0aW9uTWF0cml4BQdwcm9kSWR4AgFfBRFyZWNpcGVJZHhQYWNrc2l6ZQEPZ2V0U3RyaW5nT3JGYWlsAgdhZGRyZXNzA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFB2FkZHJlc3MFA2tleQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQdhZGRyZXNzCQDMCAICAS4JAMwIAgUDa2V5CQDMCAICDyBpcyBub3QgZGVmaW5lZAUDbmlsAgABDGdldEludE9yRWxzZQIDa2V5CmRlZmF1bHRWYWwJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUDa2V5BQpkZWZhdWx0VmFsABFJZHhDZmdTdGFraW5nRGFwcAABABFJZHhDZmdFY29ub215RGFwcAACABRJZHhDZmdHb3Zlcm5hbmNlRGFwcAADAA1JZHhDZmdXbGdEYXBwAAQBCmtleVJlc3RDZmcAAg4lc19fcmVzdENvbmZpZwEOa2V5UmVzdEFkZHJlc3MAAgwlc19fcmVzdEFkZHIBEXJlYWRSZXN0Q2ZnT3JGYWlsAQRyZXN0CQC8CQIJAQ9nZXRTdHJpbmdPckZhaWwCBQRyZXN0CQEKa2V5UmVzdENmZwAFA1NFUAEYZ2V0Q29udHJhY3RBZGRyZXNzT3JGYWlsAgdyZXN0Q2ZnA2lkeAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgUHcmVzdENmZwUDaWR4CQCsAgICKlJlc3QgY2ZnIGRvZXNuJ3QgY29udGFpbiBhZGRyZXNzIGF0IGluZGV4IAkApAMBBQNpZHgADHJlc3RDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEOa2V5UmVzdEFkZHJlc3MABRVkZWZhdWx0UmVzdEFkZHJlc3NTdHIAB3Jlc3RDZmcJARFyZWFkUmVzdENmZ09yRmFpbAEFDHJlc3RDb250cmFjdAAPc3Rha2luZ0NvbnRyYWN0CQEYZ2V0Q29udHJhY3RBZGRyZXNzT3JGYWlsAgUHcmVzdENmZwURSWR4Q2ZnU3Rha2luZ0RhcHAAD2Vjb25vbXlDb250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFB3Jlc3RDZmcFEUlkeENmZ0Vjb25vbXlEYXBwAAtnb3ZDb250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFB3Jlc3RDZmcFFElkeENmZ0dvdmVybmFuY2VEYXBwAAt3bGdDb250cmFjdAkBGGdldENvbnRyYWN0QWRkcmVzc09yRmFpbAIFB3Jlc3RDZmcFDUlkeENmZ1dsZ0RhcHABEWtleUxhc3RUeElkQnlVc2VyAQRhZGRyCQCsAgICD2xhc3RUeElkQnlVc2VyXwUEYWRkcgEVa2V5TGFuZEFzc2V0SWRUb093bmVyAQdhc3NldElkCQCsAgICCW5mdE93bmVyXwUHYXNzZXRJZAEaa2V5TGFuZEFzc2V0SWRUb0N1c3RvbU5hbWUBB2Fzc2V0SWQJAKwCAgIYbGFuZEN1c3RvbU5hbWVCeUFzc2V0SWRfBQdhc3NldElkARZrZXlTdGFrZWRUaW1lQnlBc3NldElkAQdhc3NldElkCQCsAgICC3N0YWtlZFRpbWVfBQdhc3NldElkARZrZXlJbmZyYUxldmVsQnlBc3NldElkAQdhc3NldElkCQCsAgICC2luZnJhTGV2ZWxfBQdhc3NldElkASBrZXlMYW5kQXJ0U3RhdHVzQnlUeXBlQW5kQXNzZXRJZAIEdHlwZQdhc3NldElkCQC5CQIJAMwIAgINbGFuZEFydFN0YXR1cwkAzAgCBQR0eXBlCQDMCAIFB2Fzc2V0SWQFA25pbAIBXwEia2V5U3Rha2VkVGltZUJ5VHlwZUFzc2V0SWRBbmRPd25lcgMHbmZ0VHlwZQdhc3NldElkCW93bmVyQWRkcgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICIHN0YWtlZFRpbWVCeVR5cGVBc3NldElkQW5kT3duZXJfBQduZnRUeXBlAgFfBQdhc3NldElkAgFfBQlvd25lckFkZHIBEmtleVdhcmVob3VzZUJ5TGFuZAELbGFuZEFzc2V0SWQJAKwCAgIKd2FyZUhvdXNlXwULbGFuZEFzc2V0SWQBFWtleVN0YWtlZExhbmRzQnlPd25lcgEJb3duZXJBZGRyCQCsAgICE3N0YWtlZExhbmRzQnlPd25lcl8FCW93bmVyQWRkcgEWa2V5U3Rha2VkUGllY2VzQnlPd25lcgEJb3duZXJBZGRyCQCsAgICFHN0YWtlZFBpZWNlc0J5T3duZXJfBQlvd25lckFkZHIBGmtleUR1Y2tBc3NldElkVG9DdXN0b21OYW1lAQdhc3NldElkCQCsAgICGGR1Y2tDdXN0b21OYW1lQnlBc3NldElkXwUHYXNzZXRJZAEWa2V5QWRkcmVzc1RvQ3VzdG9tTmFtZQEEYWRkcgkArAICAhhhY2NvdW50Q3VzdG9tTmFtZUJ5QWRkcl8FBGFkZHIBD2tleUFkZHJlc3NSZWZCeQEEYWRkcgkArAICAglhY2NSZWZCeV8FBGFkZHIBE2tleUFkZHJlc3NSZWZlcnJhbHMBBGFkZHIJAKwCAgINYWNjUmVmZXJyYWxzXwUEYWRkcgEQa2V5RHVja0lkVG9Pd25lcgEHYXNzZXRJZAkArAICAgpkdWNrT3duZXJfBQdhc3NldElkARRrZXlTdGFrZWREdWNrQnlPd25lcgEJb3duZXJBZGRyCQCsAgICEnN0YWtlZER1Y2tCeU93bmVyXwUJb3duZXJBZGRyARFrZXlCYWNrcGFja0J5RHVjawELZHVja0Fzc2V0SWQJAKwCAgIJYmFja1BhY2tfBQtkdWNrQXNzZXRJZAEPa2V5RHVja0xvY2F0aW9uAQtkdWNrQXNzZXRJZAkArAICAg1kdWNrTG9jYXRpb25fBQtkdWNrQXNzZXRJZAENa2V5RHVja0hlYWx0aAELZHVja0Fzc2V0SWQJAKwCAgILZHVja0hlYWx0aF8FC2R1Y2tBc3NldElkARFrZXlSZXNQcm9wb3J0aW9ucwACE3Jlc1R5cGVzUHJvcG9ydGlvbnMBCmtleUJsb2NrZWQAAhBjb250cmFjdHNCbG9ja2VkARVrZXlVc2VyR3dsUmVsZWFzZVRpbWUBCHVzZXJBZGRyCQCsAgICGiVzJXNfX3VzZXJHd2xSZWxlYXNlVGltZV9fBQh1c2VyQWRkcgEOa2V5T3JkZXJCeUxhbmQBC2xhbmRBc3NldElkCQCsAgICCmxhbmRPcmRlcl8FC2xhbmRBc3NldElkAQ5rZXlFc1dhcmVob3VzZQACGmVtZXJnZW5jeVdhcmVob3VzZVByb2R1Y3RzAA9sb2NJZHhDb250aW5lbnQAAAAKbG9jSWR4VHlwZQABAAhsb2NJZHhJZAACAQhhc1N0cmluZwEBdgQHJG1hdGNoMAUBdgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAFAXMJAAIBAhhmYWlsIHRvIGNhc3QgaW50byBTdHJpbmcBBWFzSW50AQF2BAckbWF0Y2gwBQF2AwkAAQIFByRtYXRjaDACA0ludAQBbgUHJG1hdGNoMAUBbgkAAgECFWZhaWwgdG8gY2FzdCBpbnRvIEludAEJYXNBbnlMaXN0AQF2BAckbWF0Y2gwBQF2AwkAAQIFByRtYXRjaDACCUxpc3RbQW55XQQBbAUHJG1hdGNoMAUBbAkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEJYXNCb29sZWFuAQF2BAckbWF0Y2gwBQF2AwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EAXMFByRtYXRjaDAFAXMJAAIBAhlmYWlsIHRvIGNhc3QgaW50byBCb29sZWFuAQ9udW1QaWVjZXNCeVNpemUBCGxhbmRTaXplBAckbWF0Y2gwBQhsYW5kU2l6ZQMJAAACAgFTBQckbWF0Y2gwBQVTU0laRQMJAAACAgFNBQckbWF0Y2gwBQVNU0laRQMJAAACAgFMBQckbWF0Y2gwBQVMU0laRQMJAAACAgJYTAUHJG1hdGNoMAUGWExTSVpFAwkAAAICA1hYTAUHJG1hdGNoMAUHWFhMU0laRQkAAgECEVVua25vd24gbGFuZCBzaXplAAtJZHhFZmZUb3RhbAAAAApJZHhFZmZVc2VyAAEBDmdldFZvdGluZ1Bvd2VyARJ1c2VyQWRkclN0ck9yRW1wdHkEBXByb3BzCQC1CQIJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUPc3Rha2luZ0NvbnRyYWN0CQERa2V5UmVzUHJvcG9ydGlvbnMAAgswXzBfMF8wXzBfMAIBXwoBBWFkZGVyAgNhY2MEaXRlbQkAZAIFA2FjYwkBDXBhcnNlSW50VmFsdWUBBQRpdGVtBAp0b3RhbFBvd2VyCgACJGwFBXByb3BzCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQVhZGRlcgIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgNgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgQKdXNlcnNQb3dlcgMJAAACBRJ1c2VyQWRkclN0ck9yRW1wdHkCAAAABAhsYW5kc1N0cgkAnQgCBQ9zdGFraW5nQ29udHJhY3QJARVrZXlTdGFrZWRMYW5kc0J5T3duZXIBBRJ1c2VyQWRkclN0ck9yRW1wdHkEBWxhbmRzAwkBCWlzRGVmaW5lZAEFCGxhbmRzU3RyCQC9CQIJAQV2YWx1ZQEFCGxhbmRzU3RyAgFfBQNuaWwKAQdvbmVMYW5kAgNhY2MLbGFuZEFzc2V0SWQEBWFzc2V0CQEFdmFsdWUBCQDsBwEJANkEAQULbGFuZEFzc2V0SWQECGxhbmRTaXpl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QVJFAMCaDAANQUNUSVZJVFlTSEFSRQCgjQYAC1BMQVlFUlNIQVJFAIC1GAAKWUVBUk1JTExJUwCAhuvHdQAKV0VFS01JTExJUwCAiLKgAgAJTUFYUEVSSU9EAJwBABBURU5NSU5VVEVTTUlMTElTAMDPJAACQTYAgMLXLwACQjgAgOHrFwANd2xnQXNzZXRJZEtleQILd2xnX2Fzc2V0SWQAD3dsZ0lzc3VlVGltZUtleQINd2xnX2lzc3VlVGltZQASd2xnSXNzdWVkQW1vdW50S2V5AhB3bGdfaXNzdWVkQW1vdW50ABBtYXJrZXRpbmdBZGRyS2V5Ag1tYXJrZXRpbmdBZGRyAAt0ZWFtQWRkcktleQIIdGVhbUFkZHIAFGxhc3RNYXJrZXRpbmdUaW1lS2V5AhlsYXN0Q2xhaW1lZFRpbWVfbWFya2V0aW5nAA9sYXN0VGVhbVRpbWVLZXkCFGxhc3RDbGFpbWVkVGltZV90ZWFtABVsYXN0QWN0aXZpdGllc1RpbWVLZXkCGmxhc3RDbGFpbWVkVGltZV9hY3Rpdml0aWVzARhrZXlMYXN0Q2xhaW1lZFRpbWVCeVVzZXIBBGFkZHIJAKwCAgIUbGFzdENsYWltZWRUaW1lVXNlcl8FBGFkZHIBFGtleUxhc3RBcmJUaW1lQnlVc2VyAQRhZGRyCQCsAgICEGxhc3RBcmJUaW1lVXNlcl8FBGFkZHIAFHN0YWtlcnNBbW91bnRMZWZ0S2V5AhFzdGFrZXJzQW1vdW50TGVmdAAZc3Rha2Vyc0Ftb3VudFBhaWRUb3RhbEtleQIWc3Rha2Vyc0Ftb3VudFBhaWRUb3RhbAEYa2V5U3Rha2Vyc0Ftb3VudFBhaWRVc2VyAQRhZGRyCQCsAgICFnN0YWtlcnNBbW91bnRQYWlkVXNlcl8FBGFkZHIADGlkeFdsZ0Ftb3VudAAAAAtpZHhXbGdQcmljZQABAAtpZHhXbGdGdW5kcwACAAp3bGdBc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKEIAQUNd2xnQXNzZXRJZEtleQITTm90IGluaXRpYWxpemVkIHlldAEGcHJvbG9nAAMJAQt2YWx1ZU9yRWxzZQIJAJsIAgUPc3Rha2luZ0NvbnRyYWN0CQEKa2V5QmxvY2tlZAAHCQACAQIfQ29udHJhY3RzIGFyZSB1bmRlciBtYWludGVuYW5jZQkBBWFzSW50AQkA/AcEBQ9zdGFraW5nQ29udHJhY3QCCnNhdmVMYXN0VHgFA25pbAUDbmlsAQtnZXRXbGdTdGF0cwAEDGlzc3VlZEFtb3VudAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFEndsZ0lzc3VlZEFtb3VudEtleQIYV0xHT0xEIGlzIG5vdCBpc3N1ZWQgeWV0BAVmdW5kcwkAZAIJAGQCCQDwBwIFD2Vjb25vbXlDb250cmFjdAULdXNkdEFzc2V0SWQJAPAHAgUMcmVzdENvbnRyYWN0BQt1c2R0QXNzZXRJZAkA8AcCBQR0aGlzBQt1c2R0QXNzZXRJZAkAzAgCBQxpc3N1ZWRBbW91bnQJAMwIAgkAawMFBWZ1bmRzBQVNVUxUOAUMaXNzdWVkQW1vdW50CQDMCAIFBWZ1bmRzBQNuaWwBDGdldFN3YXBMaW1pdAEEYWRkcgQIbGFzdFRpbWUJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBFGtleUxhc3RBcmJUaW1lQnlVc2VyAQUEYWRkcgAABANub3cIBQlsYXN0QmxvY2sJdGltZXN0YW1wAwkAZgIFEFRFTk1JTlVURVNNSUxMSVMJAGUCBQNub3cFCGxhc3RUaW1lCQACAQIpQXJiaXRyYWdlcyBhcmUgcG9zc2libGUgb25jZSBhIDEwIG1pbnV0ZXMEBnBpZWNlcwkAkQMCCQEOZ2V0Vm90aW5nUG93ZXIBBQRhZGRyBQpJZHhFZmZVc2VyBARwb3c4CQBsBgUGcGllY2VzAAAFAkI4AAgACAUHQ0VJTElORwkAawMFAkE2BQRwb3c4BQVNVUxUOAQBaQENY29uc3RydWN0b3JWMQMIcmVzdEFkZHINbWFya2V0aW5nQWRkcgh0ZWFtQWRkcgMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEVBlcm1pc3Npb24gZGVuaWVkAwkBCWlzRGVmaW5lZAEJAKEIAQUNd2xnQXNzZXRJZEtleQkAAgECE0FscmVhZHkgaW5pdGlhbGl6ZWQEDGlzc3VlZEFtb3VudAUGTVVMVDE0BAVpc3N1ZQkAwwgHAgZXTEdPTEQCIFdhdmVzTGFuZHMgR29sZCBpbnZlc3RtZW50IHRva2VuBQxpc3N1ZWRBbW91bnQACAYFBHVuaXQAAAQHYXNzZXRJZAkAuAgBBQVpc3N1ZQkAzAgCBQVpc3N1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUPd2xnSXNzdWVUaW1lS2V5CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgUSd2xnSXNzdWVkQW1vdW50S2V5BQxpc3N1ZWRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFGXN0YWtlcnNBbW91bnRQYWlkVG90YWxLZXkAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgUUc3Rha2Vyc0Ftb3VudExlZnRLZXkJAGsDBQZNVUxUMTQFC1BMQVlFUlNIQVJFBQVNVUxUNgkAzAgCCQELQmluYXJ5RW50cnkCBQ13bGdBc3NldElkS2V5BQdhc3NldElkCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ5rZXlSZXN0QWRkcmVzcwAFCHJlc3RBZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFEG1hcmtldGluZ0FkZHJLZXkFDW1hcmtldGluZ0FkZHIJAMwIAgkBC1N0cmluZ0VudHJ5AgULdGVhbUFkZHJLZXkFCHRlYW1BZGRyBQNuaWwBaQEGYnV5V2xnAAQMcHJvbG9nUmVzdWx0CQEGcHJvbG9nAAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECImV4YWN0bHkgMSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQEA3BtdAkAkQMCCAUBaQhwYXltZW50cwAABAd1c2R0QW10CAUDcG10BmFtb3VudAQKcG10QXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAUDcG10B2Fzc2V0SWQCHldBVkVTIGNhbid0IGJlIHVzZWQgYXMgcGF5bWVudAMJAQIhPQIFCnBtdEFzc2V0SWQFC3VzZHRBc3NldElkCQACAQITVVNEVCBwYXltZW50cyBvbmx5IQQGY2FsbGVyCAUBaQZjYWxsZXIEBGFkZHIJAKUIAQUGY2FsbGVyBAdtYXhVc2R0CQEMZ2V0U3dhcExpbWl0AQUEYWRkcgMJAGYCBQd1c2R0QW10BQdtYXhVc2R0CQACAQkArAICCQCsAgICEllvdSBjYW4gc3BlbmQgbWF4IAkApAMBBQdtYXhVc2R0AgUgVVNEVAQIY3VyU3RhdHMJAQtnZXRXbGdTdGF0cwAECWN1ckFtb3VudAkAkQMCBQhjdXJTdGF0cwUMaWR4V2xnQW1vdW50BAhidXlQcmljZQkAawMJAJEDAgUIY3VyU3RhdHMFC2lkeFdsZ1ByaWNlAAYABQQJd2xnQW1vdW50CQBrAwUHdXNkdEFtdAUFTVVMVDgFCGJ1eVByaWNlBAhyZWlzc3VlZAkAawMFB3VzZHRBbXQFCWN1ckFtb3VudAkAZQIJAJEDAgUIY3VyU3RhdHMFC2lkeFdsZ0Z1bmRzBQd1c2R0QW10CQCUCgIJAMwIAgkBB1JlaXNzdWUDBQp3bGdBc3NldElkBQhyZWlzc3VlZAYJAMwIAgkBDEludGVnZXJFbnRyeQIFEndsZ0lzc3VlZEFtb3VudEtleQkAZAIFCWN1ckFtb3VudAUIcmVpc3N1ZWQJAMwIAgkBDEludGVnZXJFbnRyeQIJARRrZXlMYXN0QXJiVGltZUJ5VXNlcgEFBGFkZHIIBQlsYXN0QmxvY2sJdGltZXN0YW1wCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFBmNhbGxlcgUJd2xnQW1vdW50BQp3bGdBc3NldElkBQNuaWwFDHByb2xvZ1Jlc3VsdAFpAQdzZWxsV2xnAQZhbW91bnQEDHByb2xvZ1Jlc3VsdAkBBnByb2xvZwADCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiJleGFjdGx5IDEgcGF5bWVudCBtdXN0IGJlIGF0dGFjaGVkBANwbXQJAJEDAggFAWkIcGF5bWVudHMAAAQGd2xnQW10CAUDcG10BmFtb3VudAQKcG10QXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAUDcG10B2Fzc2V0SWQCHldBVkVTIGNhbid0IGJlIHVzZWQgYXMgcGF5bWVudAMJAQIhPQIFCnBtdEFzc2V0SWQFCndsZ0Fzc2V0SWQJAAIBAhVXTEdPTEQgcGF5bWVudHMgb25seSEEBmNhbGxlcggFAWkGY2FsbGVyBARhZGRyCQClCAEFBmNhbGxlcgQHbWF4VXNkdAkBDGdldFN3YXBMaW1pdAEFBGFkZHIECGN1clN0YXRzCQELZ2V0V2xnU3RhdHMABAljdXJBbW91bnQJAGUCCQCRAwIFCGN1clN0YXRzBQxpZHhXbGdBbW91bnQFBndsZ0FtdAQIY3VyUHJpY2UJAJEDAgUIY3VyU3RhdHMFC2lkeFdsZ1ByaWNlBAlzZWxsUHJpY2UJAGUCBQhjdXJQcmljZQkAaQIFCGN1clByaWNlAAUECnVzZHRBbW91bnQJAGsDBQZ3bGdBbXQFCXNlbGxQcmljZQUFTVVMVDgDCQBmAgUKdXNkdEFtb3VudAUHbWF4VXNkdAkAAgEJAKwCAgkArAICAhBZb3UgY2FuIGdldCBtYXggCQCkAwEFB21heFVzZHQCBSBVU0RUBAZidXJuZWQJAGsDBQp1c2R0QW1vdW50BQljdXJBbW91bnQJAJEDAgUIY3VyU3RhdHMFC2lkeFdsZ0Z1bmRzCQCUCgIJAMwIAgkBBEJ1cm4CBQp3bGdBc3NldElkBQZidXJuZWQJAMwIAgkBDEludGVnZXJFbnRyeQIFEndsZ0lzc3VlZEFtb3VudEtleQkAZQIFCWN1ckFtb3VudAUGYnVybmVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEUa2V5TGFzdEFyYlRpbWVCeVVzZXIBBQRhZGRyCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQZjYWxsZXIFCnVzZHRBbW91bnQFC3VzZHRBc3NldElkBQNuaWwFDHByb2xvZ1Jlc3VsdAFpAQVjbGFpbQAEDHByb2xvZ1Jlc3VsdAkBBnByb2xvZwAEBmNhbGxlcggFAWkGY2FsbGVyBApjYWxsZXJBZGRyCQClCAEFBmNhbGxlcgQDbm93CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQJaXNzdWVUaW1lCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQUPd2xnSXNzdWVUaW1lS2V5Ag9Ob3QgaW5pdGlhbGl6ZWQEEWxhc3RNYXJrZXRpbmdUaW1lCQELdmFsdWVPckVsc2UCCQCfCAEFFGxhc3RNYXJrZXRpbmdUaW1lS2V5BQlpc3N1ZVRpbWUEDW1hcmtldGluZ0FkZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEJAKIIAQUQbWFya2V0aW5nQWRkcktleQQPbWFya2V0aW5nQW1vdW50CQBrAwkAawMFBk1VTFQxNAUOTUFSS0VUSU5HU0hBUkUFBU1VTFQ2CQBlAgUDbm93BRFsYXN0TWFya2V0aW5nVGltZQUKWUVBUk1JTExJUwQMbGFzdFRlYW1UaW1lCQELdmFsdWVPckVsc2UCCQCfCAEFD2xhc3RUZWFtVGltZUtleQUJaXNzdWVUaW1lBAh0ZWFtQWRkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQkAoggBBQt0ZWFtQWRkcktleQQKdGVhbUFtb3VudAkAawMJAGsDBQZNVUxUMTQFCVRFQU1TSEFSRQUFTVVMVDYJAGUCBQNub3cFDGxhc3RUZWFtVGltZQkAaAIAAwUKWUVBUk1JTExJUwQSbGFzdEFjdGl2aXRpZXNUaW1lCQELdmFsdWVPckVsc2UCCQCfCAEFFWxhc3RBY3Rpdml0aWVzVGltZUtleQUJaXNzdWVUaW1lBAlhY3RBbW91bnQJAGsDCQBrAwUGTVVMVDE0BQ1BQ1RJVklUWVNIQVJFBQVNVUxUNgkAZQIFA25vdwUSbGFzdEFjdGl2aXRpZXNUaW1lCQBoAgADBQpZRUFSTUlMTElTBAljdXJQZXJpb2QJAGkCCQBlAgUDbm93BQlpc3N1ZVRpbWUFCldFRUtNSUxMSVMDCQBmAgUJY3VyUGVyaW9kCQBpAgUJTUFYUEVSSU9EAAIJAAIBAj1QbGVhc2UgbW9kaWZ5IGNvbnRyYWN0IGZvciBuZXh0IDEuNSB5ZWFycywgYWNjb3JkaW5nIHRvIHN0YXRzBANlZmYJAQ5nZXRWb3RpbmdQb3dlcgEFCmNhbGxlckFkZHIEC3RvdGFsUGllY2VzCQCRAwIFA2VmZgULSWR4RWZmVG90YWwED2Ftb3VudExlZnRUb3RhbAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRRzdGFrZXJzQW1vdW50TGVmdEtleQAABBVjdXJQZXJpb2REaXN0cmlidXRpb24JAGsDBQ9hbW91bnRMZWZ0VG90YWwJAGgCAAIFC3RvdGFsUGllY2VzCQBkAgULdG90YWxQaWVjZXMJAGgCCQCWAwEJAMwIAgCgjQYJAMwIAgULdG90YWxQaWVjZXMFA25pbAkAZQIFCU1BWFBFUklPRAUJY3VyUGVyaW9kBAt1c2VyVGltZUtleQkBGGtleUxhc3RDbGFpbWVkVGltZUJ5VXNlcgEFCmNhbGxlckFkZHIEDGxhc3RVc2VyVGltZQkBC3ZhbHVlT3JFbHNlAgkAnwgBBQt1c2VyVGltZUtleQUJaXNzdWVUaW1lBAp1c2VyQW1vdW50CQBrAwkAawMFFWN1clBlcmlvZERpc3RyaWJ1dGlvbgkAkQMCBQNlZmYFCklkeEVmZlVzZXIFC3RvdGFsUGllY2VzCQBlAgUDbm93BQxsYXN0VXNlclRpbWUJAGgCAAMFCllFQVJNSUxMSVMEB3VzZXJLZXkJARhrZXlTdGFrZXJzQW1vdW50UGFpZFVzZXIBBQpjYWxsZXJBZGRyCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUNbWFya2V0aW5nQWRkcgUPbWFya2V0aW5nQW1vdW50BQp3bGdBc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCHRlYW1BZGRyBQp0ZWFtQW1vdW50BQp3bGdBc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFDHJlc3RDb250cmFjdAUJYWN0QW1vdW50BQp3bGdBc3NldElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFBmNhbGxlcgUKdXNlckFtb3VudAUKd2xnQXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUHdXNlcktleQkAZAIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUHdXNlcktleQAABQp1c2VyQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRlzdGFrZXJzQW1vdW50UGFpZFRvdGFsS2V5CQBkAgkBC3ZhbHVlT3JFbHNlAgkAnwgBBRlzdGFrZXJzQW1vdW50UGFpZFRvdGFsS2V5AAAFCnVzZXJBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIFFHN0YWtlcnNBbW91bnRMZWZ0S2V5CQBlAgUPYW1vdW50TGVmdFRvdGFsBQp1c2VyQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRRsYXN0TWFya2V0aW5nVGltZUtleQUDbm93CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9sYXN0VGVhbVRpbWVLZXkFA25vdwkAzAgCCQEMSW50ZWdlckVudHJ5AgUVbGFzdEFjdGl2aXRpZXNUaW1lS2V5BQNub3cJAMwIAgkBDEludGVnZXJFbnRyeQIFC3VzZXJUaW1lS2V5BQNub3cFA25pbAUMcHJvbG9nUmVzdWx0ADO5uMQ=", "height": 2628736, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: CdqR3XTDofvQ9yRXju6iewBEpyHWM6VUcn8jhg3Eb3Tq Next: ButLAkeJDdpehchQ3czV3PWrdeoC1MXvUhvUh1xcaMZX Diff:
Old | New | Differences | |
---|---|---|---|
216 | 216 | func keyStakedLandsByOwner (ownerAddr) = ("stakedLandsByOwner_" + ownerAddr) | |
217 | 217 | ||
218 | 218 | ||
219 | + | func keyStakedPiecesByOwner (ownerAddr) = ("stakedPiecesByOwner_" + ownerAddr) | |
220 | + | ||
221 | + | ||
219 | 222 | func keyDuckAssetIdToCustomName (assetId) = ("duckCustomNameByAssetId_" + assetId) | |
220 | 223 | ||
221 | 224 | ||
394 | 397 | ||
395 | 398 | let YEARMILLIS = 31557600000 | |
396 | 399 | ||
400 | + | let WEEKMILLIS = 604800000 | |
401 | + | ||
402 | + | let MAXPERIOD = 156 | |
403 | + | ||
404 | + | let TENMINUTESMILLIS = 600000 | |
405 | + | ||
406 | + | let A6 = 100000000 | |
407 | + | ||
408 | + | let B8 = 50000000 | |
409 | + | ||
397 | 410 | let wlgAssetIdKey = "wlg_assetId" | |
398 | 411 | ||
399 | 412 | let wlgIssueTimeKey = "wlg_issueTime" | |
413 | + | ||
414 | + | let wlgIssuedAmountKey = "wlg_issuedAmount" | |
400 | 415 | ||
401 | 416 | let marketingAddrKey = "marketingAddr" | |
402 | 417 | ||
408 | 423 | ||
409 | 424 | let lastActivitiesTimeKey = "lastClaimedTime_activities" | |
410 | 425 | ||
411 | - | func keyLastClaimedTimeByUser (addr) = "lastClaimedTimeUser_ + addr" | |
426 | + | func keyLastClaimedTimeByUser (addr) = ("lastClaimedTimeUser_" + addr) | |
427 | + | ||
428 | + | ||
429 | + | func keyLastArbTimeByUser (addr) = ("lastArbTimeUser_" + addr) | |
430 | + | ||
431 | + | ||
432 | + | let stakersAmountLeftKey = "stakersAmountLeft" | |
433 | + | ||
434 | + | let stakersAmountPaidTotalKey = "stakersAmountPaidTotal" | |
435 | + | ||
436 | + | func keyStakersAmountPaidUser (addr) = ("stakersAmountPaidUser_" + addr) | |
437 | + | ||
438 | + | ||
439 | + | let idxWlgAmount = 0 | |
440 | + | ||
441 | + | let idxWlgPrice = 1 | |
442 | + | ||
443 | + | let idxWlgFunds = 2 | |
444 | + | ||
445 | + | let wlgAssetId = valueOrErrorMessage(getBinary(wlgAssetIdKey), "Not initialized yet") | |
446 | + | ||
447 | + | func prolog () = if (valueOrElse(getBoolean(stakingContract, keyBlocked()), false)) | |
448 | + | then throw("Contracts are under maintenance") | |
449 | + | else asInt(invoke(stakingContract, "saveLastTx", nil, nil)) | |
450 | + | ||
451 | + | ||
452 | + | func getWlgStats () = { | |
453 | + | let issuedAmount = valueOrErrorMessage(getInteger(wlgIssuedAmountKey), "WLGOLD is not issued yet") | |
454 | + | let funds = ((assetBalance(economyContract, usdtAssetId) + assetBalance(restContract, usdtAssetId)) + assetBalance(this, usdtAssetId)) | |
455 | + | [issuedAmount, fraction(funds, MULT8, issuedAmount), funds] | |
456 | + | } | |
457 | + | ||
458 | + | ||
459 | + | func getSwapLimit (addr) = { | |
460 | + | let lastTime = valueOrElse(getInteger(keyLastArbTimeByUser(addr)), 0) | |
461 | + | let now = lastBlock.timestamp | |
462 | + | if ((TENMINUTESMILLIS > (now - lastTime))) | |
463 | + | then throw("Arbitrages are possible once a 10 minutes") | |
464 | + | else { | |
465 | + | let pieces = getVotingPower(addr)[IdxEffUser] | |
466 | + | let pow8 = pow(pieces, 0, B8, 8, 8, CEILING) | |
467 | + | fraction(A6, pow8, MULT8) | |
468 | + | } | |
469 | + | } | |
412 | 470 | ||
413 | 471 | ||
414 | 472 | @Callable(i) | |
415 | 473 | func constructorV1 (restAddr,marketingAddr,teamAddr) = if ((i.caller != this)) | |
416 | 474 | then throw("Permission denied") | |
417 | - | else if (isDefined( | |
475 | + | else if (isDefined(getBinary(wlgAssetIdKey))) | |
418 | 476 | then throw("Already initialized") | |
419 | 477 | else { | |
420 | - | let issue = Issue("WLGOLD", "WavesLands Gold investment token", MULT14, 8, true, unit, 0) | |
478 | + | let issuedAmount = MULT14 | |
479 | + | let issue = Issue("WLGOLD", "WavesLands Gold investment token", issuedAmount, 8, true, unit, 0) | |
421 | 480 | let assetId = calculateAssetId(issue) | |
422 | - | [issue, IntegerEntry(wlgIssueTimeKey, lastBlock.timestamp), BinaryEntry(wlgAssetIdKey, assetId), StringEntry(keyRestAddress(), restAddr), StringEntry(marketingAddrKey, marketingAddr), StringEntry(teamAddrKey, teamAddr)] | |
481 | + | [issue, IntegerEntry(wlgIssueTimeKey, lastBlock.timestamp), IntegerEntry(wlgIssuedAmountKey, issuedAmount), IntegerEntry(stakersAmountPaidTotalKey, 0), IntegerEntry(stakersAmountLeftKey, fraction(MULT14, PLAYERSHARE, MULT6)), BinaryEntry(wlgAssetIdKey, assetId), StringEntry(keyRestAddress(), restAddr), StringEntry(marketingAddrKey, marketingAddr), StringEntry(teamAddrKey, teamAddr)] | |
423 | 482 | } | |
424 | 483 | ||
425 | 484 | ||
426 | 485 | ||
427 | 486 | @Callable(i) | |
428 | - | func buyWlg (amount) = nil | |
487 | + | func buyWlg () = { | |
488 | + | let prologResult = prolog() | |
489 | + | if ((size(i.payments) != 1)) | |
490 | + | then throw("exactly 1 payment must be attached") | |
491 | + | else { | |
492 | + | let pmt = i.payments[0] | |
493 | + | let usdtAmt = pmt.amount | |
494 | + | let pmtAssetId = valueOrErrorMessage(pmt.assetId, "WAVES can't be used as payment") | |
495 | + | if ((pmtAssetId != usdtAssetId)) | |
496 | + | then throw("USDT payments only!") | |
497 | + | else { | |
498 | + | let caller = i.caller | |
499 | + | let addr = toString(caller) | |
500 | + | let maxUsdt = getSwapLimit(addr) | |
501 | + | if ((usdtAmt > maxUsdt)) | |
502 | + | then throw((("You can spend max " + toString(maxUsdt)) + " USDT")) | |
503 | + | else { | |
504 | + | let curStats = getWlgStats() | |
505 | + | let curAmount = curStats[idxWlgAmount] | |
506 | + | let buyPrice = fraction(curStats[idxWlgPrice], 6, 5) | |
507 | + | let wlgAmount = fraction(usdtAmt, MULT8, buyPrice) | |
508 | + | let reissued = fraction(usdtAmt, curAmount, (curStats[idxWlgFunds] - usdtAmt)) | |
509 | + | $Tuple2([Reissue(wlgAssetId, reissued, true), IntegerEntry(wlgIssuedAmountKey, (curAmount + reissued)), IntegerEntry(keyLastArbTimeByUser(addr), lastBlock.timestamp), ScriptTransfer(caller, wlgAmount, wlgAssetId)], prologResult) | |
510 | + | } | |
511 | + | } | |
512 | + | } | |
513 | + | } | |
429 | 514 | ||
430 | 515 | ||
431 | 516 | ||
432 | 517 | @Callable(i) | |
433 | - | func sellWlg (amount) = nil | |
518 | + | func sellWlg (amount) = { | |
519 | + | let prologResult = prolog() | |
520 | + | if ((size(i.payments) != 1)) | |
521 | + | then throw("exactly 1 payment must be attached") | |
522 | + | else { | |
523 | + | let pmt = i.payments[0] | |
524 | + | let wlgAmt = pmt.amount | |
525 | + | let pmtAssetId = valueOrErrorMessage(pmt.assetId, "WAVES can't be used as payment") | |
526 | + | if ((pmtAssetId != wlgAssetId)) | |
527 | + | then throw("WLGOLD payments only!") | |
528 | + | else { | |
529 | + | let caller = i.caller | |
530 | + | let addr = toString(caller) | |
531 | + | let maxUsdt = getSwapLimit(addr) | |
532 | + | let curStats = getWlgStats() | |
533 | + | let curAmount = (curStats[idxWlgAmount] - wlgAmt) | |
534 | + | let curPrice = curStats[idxWlgPrice] | |
535 | + | let sellPrice = (curPrice - (curPrice / 5)) | |
536 | + | let usdtAmount = fraction(wlgAmt, sellPrice, MULT8) | |
537 | + | if ((usdtAmount > maxUsdt)) | |
538 | + | then throw((("You can get max " + toString(maxUsdt)) + " USDT")) | |
539 | + | else { | |
540 | + | let burned = fraction(usdtAmount, curAmount, curStats[idxWlgFunds]) | |
541 | + | $Tuple2([Burn(wlgAssetId, burned), IntegerEntry(wlgIssuedAmountKey, (curAmount - burned)), IntegerEntry(keyLastArbTimeByUser(addr), lastBlock.timestamp), ScriptTransfer(caller, usdtAmount, usdtAssetId)], prologResult) | |
542 | + | } | |
543 | + | } | |
544 | + | } | |
545 | + | } | |
434 | 546 | ||
435 | 547 | ||
436 | 548 | ||
437 | 549 | @Callable(i) | |
438 | 550 | func claim () = { | |
551 | + | let prologResult = prolog() | |
439 | 552 | let caller = i.caller | |
440 | 553 | let callerAddr = toString(caller) | |
441 | 554 | let now = lastBlock.timestamp | |
442 | 555 | let issueTime = valueOrErrorMessage(getInteger(wlgIssueTimeKey), "Not initialized") | |
443 | - | let wlgAssetId = value(getBinary(wlgAssetIdKey)) | |
444 | 556 | let lastMarketingTime = valueOrElse(getInteger(lastMarketingTimeKey), issueTime) | |
445 | 557 | let marketingAddr = addressFromStringValue(value(getString(marketingAddrKey))) | |
446 | 558 | let marketingAmount = fraction(fraction(MULT14, MARKETINGSHARE, MULT6), (now - lastMarketingTime), YEARMILLIS) | |
449 | 561 | let teamAmount = fraction(fraction(MULT14, TEAMSHARE, MULT6), (now - lastTeamTime), (3 * YEARMILLIS)) | |
450 | 562 | let lastActivitiesTime = valueOrElse(getInteger(lastActivitiesTimeKey), issueTime) | |
451 | 563 | let actAmount = fraction(fraction(MULT14, ACTIVITYSHARE, MULT6), (now - lastActivitiesTime), (3 * YEARMILLIS)) | |
452 | - | let userTimeKey = keyLastClaimedTimeByUser(callerAddr) | |
453 | - | let lastUserTime = valueOrElse(getInteger(userTimeKey), issueTime) | |
454 | - | let eff = getVotingPower(callerAddr) | |
455 | - | let userAmount = fraction(fraction(fraction(MULT14, PLAYERSHARE, MULT6), eff[IdxEffUser], eff[IdxEffTotal]), (now - lastUserTime), (3 * YEARMILLIS)) | |
456 | - | [ScriptTransfer(marketingAddr, marketingAmount, wlgAssetId), ScriptTransfer(teamAddr, teamAmount, wlgAssetId), ScriptTransfer(restContract, actAmount, wlgAssetId), ScriptTransfer(caller, userAmount, wlgAssetId), IntegerEntry(lastMarketingTimeKey, now), IntegerEntry(lastTeamTimeKey, now), IntegerEntry(lastActivitiesTimeKey, now), IntegerEntry(userTimeKey, now)] | |
564 | + | let curPeriod = ((now - issueTime) / WEEKMILLIS) | |
565 | + | if ((curPeriod > (MAXPERIOD / 2))) | |
566 | + | then throw("Please modify contract for next 1.5 years, according to stats") | |
567 | + | else { | |
568 | + | let eff = getVotingPower(callerAddr) | |
569 | + | let totalPieces = eff[IdxEffTotal] | |
570 | + | let amountLeftTotal = valueOrElse(getInteger(stakersAmountLeftKey), 0) | |
571 | + | let curPeriodDistribution = fraction(amountLeftTotal, (2 * totalPieces), (totalPieces + (max([100000, totalPieces]) * (MAXPERIOD - curPeriod)))) | |
572 | + | let userTimeKey = keyLastClaimedTimeByUser(callerAddr) | |
573 | + | let lastUserTime = valueOrElse(getInteger(userTimeKey), issueTime) | |
574 | + | let userAmount = fraction(fraction(curPeriodDistribution, eff[IdxEffUser], totalPieces), (now - lastUserTime), (3 * YEARMILLIS)) | |
575 | + | let userKey = keyStakersAmountPaidUser(callerAddr) | |
576 | + | $Tuple2([ScriptTransfer(marketingAddr, marketingAmount, wlgAssetId), ScriptTransfer(teamAddr, teamAmount, wlgAssetId), ScriptTransfer(restContract, actAmount, wlgAssetId), ScriptTransfer(caller, userAmount, wlgAssetId), IntegerEntry(userKey, (valueOrElse(getInteger(userKey), 0) + userAmount)), IntegerEntry(stakersAmountPaidTotalKey, (valueOrElse(getInteger(stakersAmountPaidTotalKey), 0) + userAmount)), IntegerEntry(stakersAmountLeftKey, (amountLeftTotal - userAmount)), IntegerEntry(lastMarketingTimeKey, now), IntegerEntry(lastTeamTimeKey, now), IntegerEntry(lastActivitiesTimeKey, now), IntegerEntry(userTimeKey, now)], prologResult) | |
577 | + | } | |
457 | 578 | } | |
458 | 579 | ||
459 | 580 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let chain = take(drop(this.bytes, 1), 1) | |
5 | 5 | ||
6 | 6 | let usdtAssetId = match chain { | |
7 | 7 | case _ => | |
8 | 8 | if ((base58'2W' == $match0)) | |
9 | 9 | then base58'9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi' | |
10 | 10 | else if ((base58'2T' == $match0)) | |
11 | 11 | then base58'6mWwf9mZBjVgkC54idpyaZLQfAosD914wT8fGf2iiY63' | |
12 | 12 | else throw("Unknown chain") | |
13 | 13 | } | |
14 | 14 | ||
15 | 15 | let defaultRestAddressStr = match chain { | |
16 | 16 | case _ => | |
17 | 17 | if ((base58'2W' == $match0)) | |
18 | 18 | then "3PQCuvFbvh4LkPUnrnU1z3jnbA1p9m3WNhv" | |
19 | 19 | else if ((base58'2T' == $match0)) | |
20 | 20 | then "3MumkGGztCKAXpWDqxkddofqXSUbqQkvSJy" | |
21 | 21 | else throw("Unknown chain") | |
22 | 22 | } | |
23 | 23 | ||
24 | 24 | let InfraUpgradeCostS = match chain { | |
25 | 25 | case _ => | |
26 | 26 | if ((base58'2W' == $match0)) | |
27 | 27 | then 10000000000 | |
28 | 28 | else if ((base58'2T' == $match0)) | |
29 | 29 | then 100000000 | |
30 | 30 | else throw("Unknown chain") | |
31 | 31 | } | |
32 | 32 | ||
33 | 33 | let SEP = "__" | |
34 | 34 | ||
35 | 35 | let MULT6 = 1000000 | |
36 | 36 | ||
37 | 37 | let MULT7 = 10000000 | |
38 | 38 | ||
39 | 39 | let MULT8 = 100000000 | |
40 | 40 | ||
41 | 41 | let MULT10 = 10000000000 | |
42 | 42 | ||
43 | 43 | let LANDPREFIX = "LAND" | |
44 | 44 | ||
45 | 45 | let DUCKPREFIX = "DUCK" | |
46 | 46 | ||
47 | 47 | let ARTPRESALE = "PRESALE" | |
48 | 48 | ||
49 | 49 | let NUMRES = 6 | |
50 | 50 | ||
51 | 51 | let SSIZE = 25 | |
52 | 52 | ||
53 | 53 | let MSIZE = 100 | |
54 | 54 | ||
55 | 55 | let LSIZE = 225 | |
56 | 56 | ||
57 | 57 | let XLSIZE = 400 | |
58 | 58 | ||
59 | 59 | let XXLSIZE = 625 | |
60 | 60 | ||
61 | 61 | let DAILYRESBYPIECE = 3456000 | |
62 | 62 | ||
63 | 63 | let DAYMILLIS = 86400000 | |
64 | 64 | ||
65 | 65 | let WHMULTIPLIER = 10000000000 | |
66 | 66 | ||
67 | 67 | let DEFAULTLOCATION = "Africa_F_Africa" | |
68 | 68 | ||
69 | 69 | let RESOURCEPRICEMIN = 39637 | |
70 | 70 | ||
71 | 71 | let ESMAXPACKAGES = 3 | |
72 | 72 | ||
73 | 73 | let ESBUYCOEF = 4 | |
74 | 74 | ||
75 | 75 | let ESSELLCOEF = 10 | |
76 | 76 | ||
77 | 77 | let MAXHP = 100 | |
78 | 78 | ||
79 | 79 | let resTypes = ["Oil", "Ore", "Wood", "Sand", "Clay", "Organic"] | |
80 | 80 | ||
81 | 81 | let matTypes = ["Fuel", "Metal", "Plank", "Glass", "Plastic", "Protein"] | |
82 | 82 | ||
83 | 83 | let prodTypes = ["First Aid Kit L1", "First Aid Kit L2", "First Aid Kit L3", "Backpack L1", "Backpack L2", "Backpack L3", "Food Ration L1", "Food Ration L2", "Food Ration L3", "Jet Pack L1", "Jet Pack L2", "Jet Pack L3", "Shield L1", "Shield L2", "Shield L3"] | |
84 | 84 | ||
85 | 85 | let continents = ["Americas", "Europe", "Asia", "Africa", "Oceania"] | |
86 | 86 | ||
87 | 87 | let productionMatrix = ["1_1_1_2_2_5_1_10_0", "2_2_2_4_4_10_1_10_0", "3_3_3_6_6_15_1_10_0", "2_5_5_2_7_5_2_100_1", "4_10_10_4_14_10_2_100_1", "6_15_15_6_21_15_2_100_1", "1_1_1_1_1_8_1_10_2", "2_2_2_2_2_16_1_10_2", "3_3_3_3_3_24_1_10_2", "9_9_1_5_5_1_5_100_3", "18_18_2_10_10_2_5_100_3", "27_27_3_15_15_3_5_100_3", "2_2_1_2_2_2_1_10_4", "4_4_2_4_4_4_1_10_4", "6_6_3_6_6_6_1_10_4"] | |
88 | 88 | ||
89 | 89 | let contIdxAmericas = 0 | |
90 | 90 | ||
91 | 91 | let contIdxEurope = 1 | |
92 | 92 | ||
93 | 93 | let contIdxAsia = 2 | |
94 | 94 | ||
95 | 95 | let contIdxAfrica = 3 | |
96 | 96 | ||
97 | 97 | let contIdxOceania = 4 | |
98 | 98 | ||
99 | 99 | let recipeIdxFuel = 0 | |
100 | 100 | ||
101 | 101 | let recipeIdxMetal = 1 | |
102 | 102 | ||
103 | 103 | let recipeIdxPlank = 2 | |
104 | 104 | ||
105 | 105 | let recipeIdxGlass = 3 | |
106 | 106 | ||
107 | 107 | let recipeIdxPlastic = 4 | |
108 | 108 | ||
109 | 109 | let recipeIdxProtein = 5 | |
110 | 110 | ||
111 | 111 | let recipeIdxWeight = 6 | |
112 | 112 | ||
113 | 113 | let recipeIdxPacksize = 7 | |
114 | 114 | ||
115 | 115 | let recipeIdxContinent = 8 | |
116 | 116 | ||
117 | 117 | let recLandNum = 0 | |
118 | 118 | ||
119 | 119 | let recLandSize = 1 | |
120 | 120 | ||
121 | 121 | let recTerrains = 2 | |
122 | 122 | ||
123 | 123 | let recContinent = 3 | |
124 | 124 | ||
125 | 125 | let whIdxLevels = 0 | |
126 | 126 | ||
127 | 127 | let whIdxRes = 1 | |
128 | 128 | ||
129 | 129 | let whIdxMat = 2 | |
130 | 130 | ||
131 | 131 | let whIdxProd = 3 | |
132 | 132 | ||
133 | 133 | let whIdxLOFT = 4 | |
134 | 134 | ||
135 | 135 | let volLocked = 0 | |
136 | 136 | ||
137 | 137 | let volOccupied = 1 | |
138 | 138 | ||
139 | 139 | let volFree = 2 | |
140 | 140 | ||
141 | 141 | let volTotal = 3 | |
142 | 142 | ||
143 | 143 | let bpIdxLevel = 0 | |
144 | 144 | ||
145 | 145 | let bpIdxRes = 1 | |
146 | 146 | ||
147 | 147 | let bpIdxMat = 2 | |
148 | 148 | ||
149 | 149 | let bpIdxProd = 3 | |
150 | 150 | ||
151 | 151 | func getPkgSize (prodIdx) = parseIntValue(split(productionMatrix[prodIdx], "_")[recipeIdxPacksize]) | |
152 | 152 | ||
153 | 153 | ||
154 | 154 | func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), makeString(["mandatory ", toString(address), ".", key, " is not defined"], "")) | |
155 | 155 | ||
156 | 156 | ||
157 | 157 | func getIntOrElse (key,defaultVal) = valueOrElse(getInteger(this, key), defaultVal) | |
158 | 158 | ||
159 | 159 | ||
160 | 160 | let IdxCfgStakingDapp = 1 | |
161 | 161 | ||
162 | 162 | let IdxCfgEconomyDapp = 2 | |
163 | 163 | ||
164 | 164 | let IdxCfgGovernanceDapp = 3 | |
165 | 165 | ||
166 | 166 | let IdxCfgWlgDapp = 4 | |
167 | 167 | ||
168 | 168 | func keyRestCfg () = "%s__restConfig" | |
169 | 169 | ||
170 | 170 | ||
171 | 171 | func keyRestAddress () = "%s__restAddr" | |
172 | 172 | ||
173 | 173 | ||
174 | 174 | func readRestCfgOrFail (rest) = split_4C(getStringOrFail(rest, keyRestCfg()), SEP) | |
175 | 175 | ||
176 | 176 | ||
177 | 177 | func getContractAddressOrFail (restCfg,idx) = valueOrErrorMessage(addressFromString(restCfg[idx]), ("Rest cfg doesn't contain address at index " + toString(idx))) | |
178 | 178 | ||
179 | 179 | ||
180 | 180 | let restContract = addressFromStringValue(valueOrElse(getString(this, keyRestAddress()), defaultRestAddressStr)) | |
181 | 181 | ||
182 | 182 | let restCfg = readRestCfgOrFail(restContract) | |
183 | 183 | ||
184 | 184 | let stakingContract = getContractAddressOrFail(restCfg, IdxCfgStakingDapp) | |
185 | 185 | ||
186 | 186 | let economyContract = getContractAddressOrFail(restCfg, IdxCfgEconomyDapp) | |
187 | 187 | ||
188 | 188 | let govContract = getContractAddressOrFail(restCfg, IdxCfgGovernanceDapp) | |
189 | 189 | ||
190 | 190 | let wlgContract = getContractAddressOrFail(restCfg, IdxCfgWlgDapp) | |
191 | 191 | ||
192 | 192 | func keyLastTxIdByUser (addr) = ("lastTxIdByUser_" + addr) | |
193 | 193 | ||
194 | 194 | ||
195 | 195 | func keyLandAssetIdToOwner (assetId) = ("nftOwner_" + assetId) | |
196 | 196 | ||
197 | 197 | ||
198 | 198 | func keyLandAssetIdToCustomName (assetId) = ("landCustomNameByAssetId_" + assetId) | |
199 | 199 | ||
200 | 200 | ||
201 | 201 | func keyStakedTimeByAssetId (assetId) = ("stakedTime_" + assetId) | |
202 | 202 | ||
203 | 203 | ||
204 | 204 | func keyInfraLevelByAssetId (assetId) = ("infraLevel_" + assetId) | |
205 | 205 | ||
206 | 206 | ||
207 | 207 | func keyLandArtStatusByTypeAndAssetId (type,assetId) = makeString(["landArtStatus", type, assetId], "_") | |
208 | 208 | ||
209 | 209 | ||
210 | 210 | func keyStakedTimeByTypeAssetIdAndOwner (nftType,assetId,ownerAddr) = ((((("stakedTimeByTypeAssetIdAndOwner_" + nftType) + "_") + assetId) + "_") + ownerAddr) | |
211 | 211 | ||
212 | 212 | ||
213 | 213 | func keyWarehouseByLand (landAssetId) = ("wareHouse_" + landAssetId) | |
214 | 214 | ||
215 | 215 | ||
216 | 216 | func keyStakedLandsByOwner (ownerAddr) = ("stakedLandsByOwner_" + ownerAddr) | |
217 | 217 | ||
218 | 218 | ||
219 | + | func keyStakedPiecesByOwner (ownerAddr) = ("stakedPiecesByOwner_" + ownerAddr) | |
220 | + | ||
221 | + | ||
219 | 222 | func keyDuckAssetIdToCustomName (assetId) = ("duckCustomNameByAssetId_" + assetId) | |
220 | 223 | ||
221 | 224 | ||
222 | 225 | func keyAddressToCustomName (addr) = ("accountCustomNameByAddr_" + addr) | |
223 | 226 | ||
224 | 227 | ||
225 | 228 | func keyAddressRefBy (addr) = ("accRefBy_" + addr) | |
226 | 229 | ||
227 | 230 | ||
228 | 231 | func keyAddressReferrals (addr) = ("accReferrals_" + addr) | |
229 | 232 | ||
230 | 233 | ||
231 | 234 | func keyDuckIdToOwner (assetId) = ("duckOwner_" + assetId) | |
232 | 235 | ||
233 | 236 | ||
234 | 237 | func keyStakedDuckByOwner (ownerAddr) = ("stakedDuckByOwner_" + ownerAddr) | |
235 | 238 | ||
236 | 239 | ||
237 | 240 | func keyBackpackByDuck (duckAssetId) = ("backPack_" + duckAssetId) | |
238 | 241 | ||
239 | 242 | ||
240 | 243 | func keyDuckLocation (duckAssetId) = ("duckLocation_" + duckAssetId) | |
241 | 244 | ||
242 | 245 | ||
243 | 246 | func keyDuckHealth (duckAssetId) = ("duckHealth_" + duckAssetId) | |
244 | 247 | ||
245 | 248 | ||
246 | 249 | func keyResProportions () = "resTypesProportions" | |
247 | 250 | ||
248 | 251 | ||
249 | 252 | func keyBlocked () = "contractsBlocked" | |
250 | 253 | ||
251 | 254 | ||
252 | 255 | func keyUserGwlReleaseTime (userAddr) = ("%s%s__userGwlReleaseTime__" + userAddr) | |
253 | 256 | ||
254 | 257 | ||
255 | 258 | func keyOrderByLand (landAssetId) = ("landOrder_" + landAssetId) | |
256 | 259 | ||
257 | 260 | ||
258 | 261 | func keyEsWarehouse () = "emergencyWarehouseProducts" | |
259 | 262 | ||
260 | 263 | ||
261 | 264 | let locIdxContinent = 0 | |
262 | 265 | ||
263 | 266 | let locIdxType = 1 | |
264 | 267 | ||
265 | 268 | let locIdxId = 2 | |
266 | 269 | ||
267 | 270 | func asString (v) = match v { | |
268 | 271 | case s: String => | |
269 | 272 | s | |
270 | 273 | case _ => | |
271 | 274 | throw("fail to cast into String") | |
272 | 275 | } | |
273 | 276 | ||
274 | 277 | ||
275 | 278 | func asInt (v) = match v { | |
276 | 279 | case n: Int => | |
277 | 280 | n | |
278 | 281 | case _ => | |
279 | 282 | throw("fail to cast into Int") | |
280 | 283 | } | |
281 | 284 | ||
282 | 285 | ||
283 | 286 | func asAnyList (v) = match v { | |
284 | 287 | case l: List[Any] => | |
285 | 288 | l | |
286 | 289 | case _ => | |
287 | 290 | throw("fail to cast into List[Any]") | |
288 | 291 | } | |
289 | 292 | ||
290 | 293 | ||
291 | 294 | func asBoolean (v) = match v { | |
292 | 295 | case s: Boolean => | |
293 | 296 | s | |
294 | 297 | case _ => | |
295 | 298 | throw("fail to cast into Boolean") | |
296 | 299 | } | |
297 | 300 | ||
298 | 301 | ||
299 | 302 | func numPiecesBySize (landSize) = match landSize { | |
300 | 303 | case _ => | |
301 | 304 | if (("S" == $match0)) | |
302 | 305 | then SSIZE | |
303 | 306 | else if (("M" == $match0)) | |
304 | 307 | then MSIZE | |
305 | 308 | else if (("L" == $match0)) | |
306 | 309 | then LSIZE | |
307 | 310 | else if (("XL" == $match0)) | |
308 | 311 | then XLSIZE | |
309 | 312 | else if (("XXL" == $match0)) | |
310 | 313 | then XXLSIZE | |
311 | 314 | else throw("Unknown land size") | |
312 | 315 | } | |
313 | 316 | ||
314 | 317 | ||
315 | 318 | let IdxEffTotal = 0 | |
316 | 319 | ||
317 | 320 | let IdxEffUser = 1 | |
318 | 321 | ||
319 | 322 | func getVotingPower (userAddrStrOrEmpty) = { | |
320 | 323 | let props = split(valueOrElse(getString(stakingContract, keyResProportions()), "0_0_0_0_0_0"), "_") | |
321 | 324 | func adder (acc,item) = (acc + parseIntValue(item)) | |
322 | 325 | ||
323 | 326 | let totalPower = { | |
324 | 327 | let $l = props | |
325 | 328 | let $s = size($l) | |
326 | 329 | let $acc0 = 0 | |
327 | 330 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
328 | 331 | then $a | |
329 | 332 | else adder($a, $l[$i]) | |
330 | 333 | ||
331 | 334 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
332 | 335 | then $a | |
333 | 336 | else throw("List size exceeds 6") | |
334 | 337 | ||
335 | 338 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6) | |
336 | 339 | } | |
337 | 340 | let usersPower = if ((userAddrStrOrEmpty == "")) | |
338 | 341 | then 0 | |
339 | 342 | else { | |
340 | 343 | let landsStr = getString(stakingContract, keyStakedLandsByOwner(userAddrStrOrEmpty)) | |
341 | 344 | let lands = if (isDefined(landsStr)) | |
342 | 345 | then split_51C(value(landsStr), "_") | |
343 | 346 | else nil | |
344 | 347 | func oneLand (acc,landAssetId) = { | |
345 | 348 | let asset = value(assetInfo(fromBase58String(landAssetId))) | |
346 | 349 | let landSize = split(asset.description, "_")[recLandSize] | |
347 | 350 | (acc + numPiecesBySize(landSize)) | |
348 | 351 | } | |
349 | 352 | ||
350 | 353 | let $l = lands | |
351 | 354 | let $s = size($l) | |
352 | 355 | let $acc0 = 0 | |
353 | 356 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
354 | 357 | then $a | |
355 | 358 | else oneLand($a, $l[$i]) | |
356 | 359 | ||
357 | 360 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
358 | 361 | then $a | |
359 | 362 | else throw("List size exceeds 100") | |
360 | 363 | ||
361 | 364 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40), 41), 42), 43), 44), 45), 46), 47), 48), 49), 50), 51), 52), 53), 54), 55), 56), 57), 58), 59), 60), 61), 62), 63), 64), 65), 66), 67), 68), 69), 70), 71), 72), 73), 74), 75), 76), 77), 78), 79), 80), 81), 82), 83), 84), 85), 86), 87), 88), 89), 90), 91), 92), 93), 94), 95), 96), 97), 98), 99), 100) | |
362 | 365 | } | |
363 | 366 | [totalPower, usersPower] | |
364 | 367 | } | |
365 | 368 | ||
366 | 369 | ||
367 | 370 | func getRecipeMaterials (recipe) = { | |
368 | 371 | func addMat (ac,j) = (ac + parseIntValue(recipe[j])) | |
369 | 372 | ||
370 | 373 | let $l = [0, 1, 2, 3, 4, 5] | |
371 | 374 | let $s = size($l) | |
372 | 375 | let $acc0 = 0 | |
373 | 376 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
374 | 377 | then $a | |
375 | 378 | else addMat($a, $l[$i]) | |
376 | 379 | ||
377 | 380 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
378 | 381 | then $a | |
379 | 382 | else throw("List size exceeds 6") | |
380 | 383 | ||
381 | 384 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6) | |
382 | 385 | } | |
383 | 386 | ||
384 | 387 | ||
385 | 388 | let MULT14 = 100000000000000 | |
386 | 389 | ||
387 | 390 | let MARKETINGSHARE = 100000 | |
388 | 391 | ||
389 | 392 | let TEAMSHARE = 200000 | |
390 | 393 | ||
391 | 394 | let ACTIVITYSHARE = 100000 | |
392 | 395 | ||
393 | 396 | let PLAYERSHARE = 400000 | |
394 | 397 | ||
395 | 398 | let YEARMILLIS = 31557600000 | |
396 | 399 | ||
400 | + | let WEEKMILLIS = 604800000 | |
401 | + | ||
402 | + | let MAXPERIOD = 156 | |
403 | + | ||
404 | + | let TENMINUTESMILLIS = 600000 | |
405 | + | ||
406 | + | let A6 = 100000000 | |
407 | + | ||
408 | + | let B8 = 50000000 | |
409 | + | ||
397 | 410 | let wlgAssetIdKey = "wlg_assetId" | |
398 | 411 | ||
399 | 412 | let wlgIssueTimeKey = "wlg_issueTime" | |
413 | + | ||
414 | + | let wlgIssuedAmountKey = "wlg_issuedAmount" | |
400 | 415 | ||
401 | 416 | let marketingAddrKey = "marketingAddr" | |
402 | 417 | ||
403 | 418 | let teamAddrKey = "teamAddr" | |
404 | 419 | ||
405 | 420 | let lastMarketingTimeKey = "lastClaimedTime_marketing" | |
406 | 421 | ||
407 | 422 | let lastTeamTimeKey = "lastClaimedTime_team" | |
408 | 423 | ||
409 | 424 | let lastActivitiesTimeKey = "lastClaimedTime_activities" | |
410 | 425 | ||
411 | - | func keyLastClaimedTimeByUser (addr) = "lastClaimedTimeUser_ + addr" | |
426 | + | func keyLastClaimedTimeByUser (addr) = ("lastClaimedTimeUser_" + addr) | |
427 | + | ||
428 | + | ||
429 | + | func keyLastArbTimeByUser (addr) = ("lastArbTimeUser_" + addr) | |
430 | + | ||
431 | + | ||
432 | + | let stakersAmountLeftKey = "stakersAmountLeft" | |
433 | + | ||
434 | + | let stakersAmountPaidTotalKey = "stakersAmountPaidTotal" | |
435 | + | ||
436 | + | func keyStakersAmountPaidUser (addr) = ("stakersAmountPaidUser_" + addr) | |
437 | + | ||
438 | + | ||
439 | + | let idxWlgAmount = 0 | |
440 | + | ||
441 | + | let idxWlgPrice = 1 | |
442 | + | ||
443 | + | let idxWlgFunds = 2 | |
444 | + | ||
445 | + | let wlgAssetId = valueOrErrorMessage(getBinary(wlgAssetIdKey), "Not initialized yet") | |
446 | + | ||
447 | + | func prolog () = if (valueOrElse(getBoolean(stakingContract, keyBlocked()), false)) | |
448 | + | then throw("Contracts are under maintenance") | |
449 | + | else asInt(invoke(stakingContract, "saveLastTx", nil, nil)) | |
450 | + | ||
451 | + | ||
452 | + | func getWlgStats () = { | |
453 | + | let issuedAmount = valueOrErrorMessage(getInteger(wlgIssuedAmountKey), "WLGOLD is not issued yet") | |
454 | + | let funds = ((assetBalance(economyContract, usdtAssetId) + assetBalance(restContract, usdtAssetId)) + assetBalance(this, usdtAssetId)) | |
455 | + | [issuedAmount, fraction(funds, MULT8, issuedAmount), funds] | |
456 | + | } | |
457 | + | ||
458 | + | ||
459 | + | func getSwapLimit (addr) = { | |
460 | + | let lastTime = valueOrElse(getInteger(keyLastArbTimeByUser(addr)), 0) | |
461 | + | let now = lastBlock.timestamp | |
462 | + | if ((TENMINUTESMILLIS > (now - lastTime))) | |
463 | + | then throw("Arbitrages are possible once a 10 minutes") | |
464 | + | else { | |
465 | + | let pieces = getVotingPower(addr)[IdxEffUser] | |
466 | + | let pow8 = pow(pieces, 0, B8, 8, 8, CEILING) | |
467 | + | fraction(A6, pow8, MULT8) | |
468 | + | } | |
469 | + | } | |
412 | 470 | ||
413 | 471 | ||
414 | 472 | @Callable(i) | |
415 | 473 | func constructorV1 (restAddr,marketingAddr,teamAddr) = if ((i.caller != this)) | |
416 | 474 | then throw("Permission denied") | |
417 | - | else if (isDefined( | |
475 | + | else if (isDefined(getBinary(wlgAssetIdKey))) | |
418 | 476 | then throw("Already initialized") | |
419 | 477 | else { | |
420 | - | let issue = Issue("WLGOLD", "WavesLands Gold investment token", MULT14, 8, true, unit, 0) | |
478 | + | let issuedAmount = MULT14 | |
479 | + | let issue = Issue("WLGOLD", "WavesLands Gold investment token", issuedAmount, 8, true, unit, 0) | |
421 | 480 | let assetId = calculateAssetId(issue) | |
422 | - | [issue, IntegerEntry(wlgIssueTimeKey, lastBlock.timestamp), BinaryEntry(wlgAssetIdKey, assetId), StringEntry(keyRestAddress(), restAddr), StringEntry(marketingAddrKey, marketingAddr), StringEntry(teamAddrKey, teamAddr)] | |
481 | + | [issue, IntegerEntry(wlgIssueTimeKey, lastBlock.timestamp), IntegerEntry(wlgIssuedAmountKey, issuedAmount), IntegerEntry(stakersAmountPaidTotalKey, 0), IntegerEntry(stakersAmountLeftKey, fraction(MULT14, PLAYERSHARE, MULT6)), BinaryEntry(wlgAssetIdKey, assetId), StringEntry(keyRestAddress(), restAddr), StringEntry(marketingAddrKey, marketingAddr), StringEntry(teamAddrKey, teamAddr)] | |
423 | 482 | } | |
424 | 483 | ||
425 | 484 | ||
426 | 485 | ||
427 | 486 | @Callable(i) | |
428 | - | func buyWlg (amount) = nil | |
487 | + | func buyWlg () = { | |
488 | + | let prologResult = prolog() | |
489 | + | if ((size(i.payments) != 1)) | |
490 | + | then throw("exactly 1 payment must be attached") | |
491 | + | else { | |
492 | + | let pmt = i.payments[0] | |
493 | + | let usdtAmt = pmt.amount | |
494 | + | let pmtAssetId = valueOrErrorMessage(pmt.assetId, "WAVES can't be used as payment") | |
495 | + | if ((pmtAssetId != usdtAssetId)) | |
496 | + | then throw("USDT payments only!") | |
497 | + | else { | |
498 | + | let caller = i.caller | |
499 | + | let addr = toString(caller) | |
500 | + | let maxUsdt = getSwapLimit(addr) | |
501 | + | if ((usdtAmt > maxUsdt)) | |
502 | + | then throw((("You can spend max " + toString(maxUsdt)) + " USDT")) | |
503 | + | else { | |
504 | + | let curStats = getWlgStats() | |
505 | + | let curAmount = curStats[idxWlgAmount] | |
506 | + | let buyPrice = fraction(curStats[idxWlgPrice], 6, 5) | |
507 | + | let wlgAmount = fraction(usdtAmt, MULT8, buyPrice) | |
508 | + | let reissued = fraction(usdtAmt, curAmount, (curStats[idxWlgFunds] - usdtAmt)) | |
509 | + | $Tuple2([Reissue(wlgAssetId, reissued, true), IntegerEntry(wlgIssuedAmountKey, (curAmount + reissued)), IntegerEntry(keyLastArbTimeByUser(addr), lastBlock.timestamp), ScriptTransfer(caller, wlgAmount, wlgAssetId)], prologResult) | |
510 | + | } | |
511 | + | } | |
512 | + | } | |
513 | + | } | |
429 | 514 | ||
430 | 515 | ||
431 | 516 | ||
432 | 517 | @Callable(i) | |
433 | - | func sellWlg (amount) = nil | |
518 | + | func sellWlg (amount) = { | |
519 | + | let prologResult = prolog() | |
520 | + | if ((size(i.payments) != 1)) | |
521 | + | then throw("exactly 1 payment must be attached") | |
522 | + | else { | |
523 | + | let pmt = i.payments[0] | |
524 | + | let wlgAmt = pmt.amount | |
525 | + | let pmtAssetId = valueOrErrorMessage(pmt.assetId, "WAVES can't be used as payment") | |
526 | + | if ((pmtAssetId != wlgAssetId)) | |
527 | + | then throw("WLGOLD payments only!") | |
528 | + | else { | |
529 | + | let caller = i.caller | |
530 | + | let addr = toString(caller) | |
531 | + | let maxUsdt = getSwapLimit(addr) | |
532 | + | let curStats = getWlgStats() | |
533 | + | let curAmount = (curStats[idxWlgAmount] - wlgAmt) | |
534 | + | let curPrice = curStats[idxWlgPrice] | |
535 | + | let sellPrice = (curPrice - (curPrice / 5)) | |
536 | + | let usdtAmount = fraction(wlgAmt, sellPrice, MULT8) | |
537 | + | if ((usdtAmount > maxUsdt)) | |
538 | + | then throw((("You can get max " + toString(maxUsdt)) + " USDT")) | |
539 | + | else { | |
540 | + | let burned = fraction(usdtAmount, curAmount, curStats[idxWlgFunds]) | |
541 | + | $Tuple2([Burn(wlgAssetId, burned), IntegerEntry(wlgIssuedAmountKey, (curAmount - burned)), IntegerEntry(keyLastArbTimeByUser(addr), lastBlock.timestamp), ScriptTransfer(caller, usdtAmount, usdtAssetId)], prologResult) | |
542 | + | } | |
543 | + | } | |
544 | + | } | |
545 | + | } | |
434 | 546 | ||
435 | 547 | ||
436 | 548 | ||
437 | 549 | @Callable(i) | |
438 | 550 | func claim () = { | |
551 | + | let prologResult = prolog() | |
439 | 552 | let caller = i.caller | |
440 | 553 | let callerAddr = toString(caller) | |
441 | 554 | let now = lastBlock.timestamp | |
442 | 555 | let issueTime = valueOrErrorMessage(getInteger(wlgIssueTimeKey), "Not initialized") | |
443 | - | let wlgAssetId = value(getBinary(wlgAssetIdKey)) | |
444 | 556 | let lastMarketingTime = valueOrElse(getInteger(lastMarketingTimeKey), issueTime) | |
445 | 557 | let marketingAddr = addressFromStringValue(value(getString(marketingAddrKey))) | |
446 | 558 | let marketingAmount = fraction(fraction(MULT14, MARKETINGSHARE, MULT6), (now - lastMarketingTime), YEARMILLIS) | |
447 | 559 | let lastTeamTime = valueOrElse(getInteger(lastTeamTimeKey), issueTime) | |
448 | 560 | let teamAddr = addressFromStringValue(value(getString(teamAddrKey))) | |
449 | 561 | let teamAmount = fraction(fraction(MULT14, TEAMSHARE, MULT6), (now - lastTeamTime), (3 * YEARMILLIS)) | |
450 | 562 | let lastActivitiesTime = valueOrElse(getInteger(lastActivitiesTimeKey), issueTime) | |
451 | 563 | let actAmount = fraction(fraction(MULT14, ACTIVITYSHARE, MULT6), (now - lastActivitiesTime), (3 * YEARMILLIS)) | |
452 | - | let userTimeKey = keyLastClaimedTimeByUser(callerAddr) | |
453 | - | let lastUserTime = valueOrElse(getInteger(userTimeKey), issueTime) | |
454 | - | let eff = getVotingPower(callerAddr) | |
455 | - | let userAmount = fraction(fraction(fraction(MULT14, PLAYERSHARE, MULT6), eff[IdxEffUser], eff[IdxEffTotal]), (now - lastUserTime), (3 * YEARMILLIS)) | |
456 | - | [ScriptTransfer(marketingAddr, marketingAmount, wlgAssetId), ScriptTransfer(teamAddr, teamAmount, wlgAssetId), ScriptTransfer(restContract, actAmount, wlgAssetId), ScriptTransfer(caller, userAmount, wlgAssetId), IntegerEntry(lastMarketingTimeKey, now), IntegerEntry(lastTeamTimeKey, now), IntegerEntry(lastActivitiesTimeKey, now), IntegerEntry(userTimeKey, now)] | |
564 | + | let curPeriod = ((now - issueTime) / WEEKMILLIS) | |
565 | + | if ((curPeriod > (MAXPERIOD / 2))) | |
566 | + | then throw("Please modify contract for next 1.5 years, according to stats") | |
567 | + | else { | |
568 | + | let eff = getVotingPower(callerAddr) | |
569 | + | let totalPieces = eff[IdxEffTotal] | |
570 | + | let amountLeftTotal = valueOrElse(getInteger(stakersAmountLeftKey), 0) | |
571 | + | let curPeriodDistribution = fraction(amountLeftTotal, (2 * totalPieces), (totalPieces + (max([100000, totalPieces]) * (MAXPERIOD - curPeriod)))) | |
572 | + | let userTimeKey = keyLastClaimedTimeByUser(callerAddr) | |
573 | + | let lastUserTime = valueOrElse(getInteger(userTimeKey), issueTime) | |
574 | + | let userAmount = fraction(fraction(curPeriodDistribution, eff[IdxEffUser], totalPieces), (now - lastUserTime), (3 * YEARMILLIS)) | |
575 | + | let userKey = keyStakersAmountPaidUser(callerAddr) | |
576 | + | $Tuple2([ScriptTransfer(marketingAddr, marketingAmount, wlgAssetId), ScriptTransfer(teamAddr, teamAmount, wlgAssetId), ScriptTransfer(restContract, actAmount, wlgAssetId), ScriptTransfer(caller, userAmount, wlgAssetId), IntegerEntry(userKey, (valueOrElse(getInteger(userKey), 0) + userAmount)), IntegerEntry(stakersAmountPaidTotalKey, (valueOrElse(getInteger(stakersAmountPaidTotalKey), 0) + userAmount)), IntegerEntry(stakersAmountLeftKey, (amountLeftTotal - userAmount)), IntegerEntry(lastMarketingTimeKey, now), IntegerEntry(lastTeamTimeKey, now), IntegerEntry(lastActivitiesTimeKey, now), IntegerEntry(userTimeKey, now)], prologResult) | |
577 | + | } | |
457 | 578 | } | |
458 | 579 | ||
459 | 580 |
github/deemru/w8io/169f3d6 104.23 ms ◑