tx · n6Nb3gfYDFdrUW1uLVVzQGXZcsbNPymDn9WVSZMztvZ 3N7UuYar6264P58FBhVWKPQAh4Yua2hgngv: -0.01400000 Waves 2024.09.13 04:46 [3281211] smart account 3N7UuYar6264P58FBhVWKPQAh4Yua2hgngv > SELF 0.00000000 Waves
{ "type": 13, "id": "n6Nb3gfYDFdrUW1uLVVzQGXZcsbNPymDn9WVSZMztvZ", "fee": 1400000, "feeAssetId": null, "timestamp": 1726191979348, "version": 2, "chainId": 84, "sender": "3N7UuYar6264P58FBhVWKPQAh4Yua2hgngv", "senderPublicKey": "2fNSk5gmWbXBDTkSYSKd66xSgVvAYzrJnP9YSAFNvTwC", "proofs": [ "5edBsyqZL95QH9UAXJHy6gxfdt1qGD35NjCbo8ihydd9zivZoH7TejjerKoRxoqH76mouNkDVZNcP6bypaF6VJif" ], "script": "base64:BgIWCAISAwoBGBIDCgEIEgMKAQgSAwoBCFsAA1NFUAICX18ABWNoYWluCQDJAQIJAMoBAggFBHRoaXMFYnl0ZXMAAQABAAt1c2R0QXNzZXRJZAQHJG1hdGNoMAUFY2hhaW4DCQAAAgEBVwUHJG1hdGNoMAEghNp6sggDP07Ru8qO7ouTvMmC3Qtd+geWqNQj+agP/7kDCQAAAgEBVAUHJG1hdGNoMAEgVbHYn3KHgu/l41uNrAWrZd6aQ6EvFrsF8xq3h6XxxRgJAAIBAg1Vbmtub3duIGNoYWluABZkZWZhdWx0UmVzdDJBZGRyZXNzU3RyBAckbWF0Y2gwBQVjaGFpbgMJAAACAQFXBQckbWF0Y2gwAiMzUEZ3WXRhOGJpRXozMXpwZUZlNURKSzh3RTV0clNwUVZGOAMJAAACAQFUBQckbWF0Y2gwAiMzTjdVdVlhcjYyNjRQNThGQmhWV0tQUUFoNFl1YTJoZ25ndgkAAgECDVVua25vd24gY2hhaW4AFW9sZFN0YWtpbmdDb250cmFjdFN0cgQHJG1hdGNoMAUFY2hhaW4DCQAAAgEBVwUHJG1hdGNoMAIjM1BMbmNYdFMxVTgzRDZjUWJGRDNIOHJCSFBMZ3p4U0ZLWjEDCQAAAgEBVAUHJG1hdGNoMAIjM05EQ3lCRzVxODVKdWFSaWlnVWVFdGFpbnlqQ1FUM1hwWm0JAAIBAg1Vbmtub3duIGNoYWluAQ9nZXRTdHJpbmdPckZhaWwCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQC5CQIJAMwIAgIKbWFuZGF0b3J5IAkAzAgCCQClCAEFB2FkZHJlc3MJAMwIAgIBLgkAzAgCBQNrZXkJAMwIAgIPIGlzIG5vdCBkZWZpbmVkBQNuaWwCAAAQSWR4Q2ZnQWNyZXMyRGFwcAABAA1JZHhDZmdXbGdEYXBwAAIAFElkeENmZ1B1enpsZVBvb2xEYXBwAAQAFElkeENmZ0ludmVzdEZ1bmREYXBwAAUBCmtleVJlc3RDZmcAAg4lc19fcmVzdENvbmZpZwEPa2V5UmVzdDJBZGRyZXNzAAINJXNfX3Jlc3QyQWRkcgERcmVhZFJlc3RDZmdPckZhaWwBBHJlc3QJALwJAgkBD2dldFN0cmluZ09yRmFpbAIFBHJlc3QJAQprZXlSZXN0Q2ZnAAUDU0VQARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCCHJlc3QyQ2ZnA2lkeAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgUIcmVzdDJDZmcFA2lkeAkArAICAipSZXN0IGNmZyBkb2Vzbid0IGNvbnRhaW4gYWRkcmVzcyBhdCBpbmRleCAJAKQDAQUDaWR4AA1yZXN0MkNvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMJAQ9rZXlSZXN0MkFkZHJlc3MABRZkZWZhdWx0UmVzdDJBZGRyZXNzU3RyAAhyZXN0MkNmZwkBEXJlYWRSZXN0Q2ZnT3JGYWlsAQUNcmVzdDJDb250cmFjdAAOYWNyZXMyQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQhyZXN0MkNmZwUQSWR4Q2ZnQWNyZXMyRGFwcAALd2xnQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQhyZXN0MkNmZwUNSWR4Q2ZnV2xnRGFwcAAScHV6emxlUG9vbENvbnRyYWN0CQEYZ2V0Q29udHJhY3RBZGRyZXNzT3JGYWlsAgUIcmVzdDJDZmcFFElkeENmZ1B1enpsZVBvb2xEYXBwABJpbnZlc3RGdW5kQ29udHJhY3QJARhnZXRDb250cmFjdEFkZHJlc3NPckZhaWwCBQhyZXN0MkNmZwUUSWR4Q2ZnSW52ZXN0RnVuZERhcHAAE29sZEFjcmVzQ29udHJhY3RLZXkCEG9sZEFjcmVzQ29udHJhY3QBEWtleUxhc3RUeElkQnlVc2VyAQRhZGRyCQCsAgICD2xhc3RUeElkQnlVc2VyXwUEYWRkcgANd2xnQXNzZXRJZEtleQILd2xnX2Fzc2V0SWQACndsZ0Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnAgCBQt3bGdDb250cmFjdAUNd2xnQXNzZXRJZEtleQIYV0xHT0xEIGlzIG5vdCBpc3N1ZWQgeWV0AA9hY3Jlc0Fzc2V0SWRLZXkCDGFjcmVzQXNzZXRJZAAMYWNyZXNBc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJwIAgUOYWNyZXMyQ29udHJhY3QFD2FjcmVzQXNzZXRJZEtleQIXQUNSRVMgaXMgbm90IGlzc3VlZCB5ZXQBFGtleVN0YWtlZER1Y2tCeU93bmVyAQlvd25lckFkZHIJAKwCAgISc3Rha2VkRHVja0J5T3duZXJfBQlvd25lckFkZHIBFmtleUFkZHJlc3NUb0N1c3RvbU5hbWUBBGFkZHIJAKwCAgIYYWNjb3VudEN1c3RvbU5hbWVCeUFkZHJfBQRhZGRyAQ9rZXlBZGRyZXNzUmVmQnkBBGFkZHIJAKwCAgIJYWNjUmVmQnlfBQRhZGRyARNrZXlBZGRyZXNzUmVmZXJyYWxzAQRhZGRyCQCsAgICDWFjY1JlZmVycmFsc18FBGFkZHIBDGFzVHVwbGU0SW50cwEDdmFsBAckbWF0Y2gwBQN2YWwDCQABAgUHJG1hdGNoMAIUKEludCwgSW50LCBJbnQsIEludCkEAXQFByRtYXRjaDAFAXQJAAIBAiZmYWlsIHRvIGNhc3QgaW50byAoSW50LCBJbnQsIEludCwgSW50KQEMYXNUdXBsZTNJbnRzAQN2YWwEByRtYXRjaDAFA3ZhbAMJAAECBQckbWF0Y2gwAg8oSW50LCBJbnQsIEludCkEAXQFByRtYXRjaDAFAXQJAAIBAiFmYWlsIHRvIGNhc3QgaW50byAoSW50LCBJbnQsIEludCkBDGFzVHVwbGUySW50cwEDdmFsBAckbWF0Y2gwBQN2YWwDCQABAgUHJG1hdGNoMAIKKEludCwgSW50KQQBdAUHJG1hdGNoMAUBdAkAAgECHGZhaWwgdG8gY2FzdCBpbnRvIChJbnQsIEludCkAA002XwDAhD0AA004XwCAwtcvAAVNSUxMNgCAgOmDsd4WAApURUFNX1NIQVJFAMCaDAAOQUNUSVZJVFlfU0hBUkUAoI0GAAxQTEFZRVJfU0hBUkUAgLUYAAtZRUFSX01JTExJUwCAhuvHdQADY2huCQDJAQIJAMoBAggFBHRoaXMFYnl0ZXMAAQABAA1VU0RUX1RWTF9DT1JSBAckbWF0Y2gwBQNjaG4DCQAAAgEBVwUHJG1hdGNoMADw9ajABAMJAAACAQFUBQckbWF0Y2gwAAAJAAIBAg1Vbmtub3duIGNoYWluAAp0ZWFtQWRyS2V5Agh0ZWFtQWRkcgAObGFzdFRlYW1UaW1LZXkCFGxhc3RDbGFpbWVkVGltZV90ZWFtAA50ZWFtQW10TGVmdEtleQIOdGVhbUFtb3VudExlZnQAFGxhc3RBY3Rpdml0aWVzVGltS2V5AhpsYXN0Q2xhaW1lZFRpbWVfYWN0aXZpdGllcwANYWN0QW10TGVmdEtleQIUYWN0aXZpdGllc0Ftb3VudExlZnQAEXN0YWtlcnNBbXRMZWZ0S2V5AhFzdGFrZXJzQW1vdW50TGVmdAEWa2V5TGFzdENsYWltVGltZUJ5VXNlcgEEYWRkcgkArAICAhRsYXN0Q2xhaW1lZFRpbWVVc2VyXwUEYWRkcgENZGlzdHJCeVBlcmlvZAEGcGVyaW9kCQBrAwUFTUlMTDYJAGgCBQxQTEFZRVJfU0hBUkUJAGQCBQZwZXJpb2QAAQkAaAIABgUDTTZfAA53bGdJc3N1ZVRpbUtleQINd2xnX2lzc3VlVGltZQAPd2xnSXNzdWVkQW10S2V5AhB3bGdfaXNzdWVkQW1vdW50AA56Yklzc3VlZEFtdEtleQISemJpbGxfaXNzdWVkQW1vdW50ARdrZXlBY3Jlc1N0YWtlZEFtdEJ5VXNlcgEEYWRkcgkArAICAhhhY3Jlc1N0YWtlZEFtb3VudEJ5VXNlcl8FBGFkZHIAEmFjcmVzU3Rha2RUb3RhbEtleQIWYWNyZXNTdGFrZWRBbW91bnRUb3RhbAAJZGFwcDJSZXN0AAAADGRhcHAyU3Rha2luZwABAAhkYXBwMldsZwACAAtkYXBwMlB1enpsZQADAA9kYXBwMkludmVzdEZ1bmQABAAGbGV2ZWxzCQDMCAIACgkAzAgCABQJAMwIAgAoCQDMCAIAUAkAzAgCAJYBCQDMCAIA+gEJAMwIAgCQAwkAzAgCALwFCQDMCAIA6AcFA25pbAEPZ2V0TGV2ZWxCeUFjcmVzAQVhY3JlcwQDYWNyCQBpAgUFYWNyZXMFA004XwoBB2NoZWNrZXICA2FjYwRpdGVtAwkAZgIFBGl0ZW0FA2FjcgUDYWNjCQBkAgUDYWNjAAEEA2lkeAoAAiRsBQZsZXZlbHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBB2NoZWNrZXICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoJAGQCBQNpZHgAAQEWZ2V0RmFybWluZ1Bvd2VyQnlBY3JlcwEFYWNyZXMJAGgCCQBoAgUFYWNyZXMAFAkAZAIJAQ9nZXRMZXZlbEJ5QWNyZXMBBQVhY3JlcwAEARBnZXRGYXJtaW5nUG93ZXJzAhJ1c2VyQWRkclN0ck9yRW1wdHkPc3Rha2luZ0NvbnRyYWN0BAp0b3RhbEFjcmVzCQELdmFsdWVPckVsc2UCCQCaCAIFD3N0YWtpbmdDb250cmFjdAUSYWNyZXNTdGFrZFRvdGFsS2V5AAAEB3RvdGFsRlAJARZnZXRGYXJtaW5nUG93ZXJCeUFjcmVzAQUKdG90YWxBY3JlcwQJdXNlckFjcmVzCQELdmFsdWVPckVsc2UCCQCaCAIFD3N0YWtpbmdDb250cmFjdAkBF2tleUFjcmVzU3Rha2VkQW10QnlVc2VyAQUSdXNlckFkZHJTdHJPckVtcHR5AAAEBnVzZXJGUAkBFmdldEZhcm1pbmdQb3dlckJ5QWNyZXMBBQl1c2VyQWNyZXMJAMwIAgUHdG90YWxGUAkAzAgCBQZ1c2VyRlAFA25pbAAKaWR4VG90YWxGUAAAAAlpZHhVc2VyRlAAAQALaXhXbGdBbW91bnQAAAAKaXhXbGdQcmljZQABAAppeFdsZ0Z1bmRzAAIADWl4V2xnQWN0aXZpdHkAAwAOaXhXbGdBcmJpdHJhZ2UABAAJaXhXbGdQb29sAAUADml4V2xnSXNzdWVUaW1lAAYAFGl4V2xnTGFzdFRlYW1BY3RUaW1lAAcADml4V2xnVGVhbVRvdGFsAAgAD2l4V2xnVGVhbUFtTGVmdAAJABNpeFdsZ1RlYW1BbUF2YWlsTm93AAoAD2l4V2xnVGVhbVdsZ29sZAALAA1peFdsZ0FjdFRvdGFsAAwADml4V2xnQWN0QW1MZWZ0AA0AEml4V2xnQWN0QW1BdmFpbE5vdwAOAA5peFdsZ0FjdFdsZ29sZAAPAA5peFdsZ0N1clBlcmlvZAAQABBpeFdsZ0FtTGVmdFRvdGFsABEAGml4V2xnQ3VyUGVyaW9kRGlzdHJpYnV0aW9uABIAEWl4V2xnTGFzdFVzZXJUaW1lABMAFWl4V2xnSW52ZXN0RnVuZEFtb3VudAAUABNpeFdsZ1VzZXJBbUF2YWlsTm93ABUAEGl4V2xnRWZmVXNlclRpbWUAFgEMZ2V0V2xnU3RhdHMyBAt1c2VyQWRkck9wdAljb250cmFjdHMGdXNkdElkFXVzZHRCYWxhbmNlQ29ycmVjdGlvbgQMaXNzdWVkQW1vdW50CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnBQ93bGdJc3N1ZWRBbXRLZXkCGFdMR09MRCBpcyBub3QgaXNzdWVkIHlldAQHcmVzdFVzZAkA8AcCCQCRAwIFCWNvbnRyYWN0cwUJZGFwcDJSZXN0BQZ1c2R0SWQEBndsZ1VzZAkAZQIJAPAHAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnBQZ1c2R0SWQFFXVzZHRCYWxhbmNlQ29ycmVjdGlvbgQJcHV6emxlVXNkCQDwBwIJAJEDAgUJY29udHJhY3RzBQtkYXBwMlB1enpsZQUGdXNkdElkBBFpbnZlc3RGbmRDb250cmFjdAkAkQMCBQljb250cmFjdHMFD2RhcHAySW52ZXN0RnVuZAQPaW52ZXN0RnVuZFRvdGFsCQBkAgkA8AcCBRFpbnZlc3RGbmRDb250cmFjdAUGdXNkdElkCQELdmFsdWVPckVsc2UCCQCaCAIFEWludmVzdEZuZENvbnRyYWN0BQ56Yklzc3VlZEFtdEtleQAABA10b3RhbEZ1bmRzVXNkCQBkAgUGd2xnVXNkBQ9pbnZlc3RGdW5kVG90YWwEBXdsZ0lkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJwIAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnAgt3bGdfYXNzZXRJZAITTm90IGluaXRpYWxpemVkIHlldAQDbm93CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQJaXNzdWVUaW1lCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnBQ53bGdJc3N1ZVRpbUtleQIPTm90IGluaXRpYWxpemVkBAl0ZWFtVG90YWwJAGsDBQVNSUxMNgUKVEVBTV9TSEFSRQUDTTZfBA50ZWFtQW1vdW50TGVmdAkBC3ZhbHVlT3JFbHNlAgkAmggCCQCRAwIFCWNvbnRyYWN0cwUIZGFwcDJXbGcFDnRlYW1BbXRMZWZ0S2V5BQl0ZWFtVG90YWwEDGxhc3RUZWFtVGltZQkBC3ZhbHVlT3JFbHNlAgkAmggCCQCRAwIFCWNvbnRyYWN0cwUIZGFwcDJXbGcFDmxhc3RUZWFtVGltS2V5BQlpc3N1ZVRpbWUECHRlYW1BZGRyCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBCQCdCAIJAJEDAgUJY29udHJhY3RzBQhkYXBwMldsZwUKdGVhbUFkcktleQQWdGVhbUFtb3VudEF2YWlsYWJsZU5vdwkAlwMBCQDMCAIJAGsDBQl0ZWFtVG90YWwJAGUCBQNub3cFDGxhc3RUZWFtVGltZQkAaAIAAwULWUVBUl9NSUxMSVMJAMwIAgUOdGVhbUFtb3VudExlZnQFA25pbAQKdGVhbVdsZ29sZAkA8AcCBQh0ZWFtQWRkcgUFd2xnSWQECGFjdFRvdGFsCQBrAwUFTUlMTDYFDkFDVElWSVRZX1NIQVJFBQNNNl8EDWFjdEFtb3VudExlZnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnBQ1hY3RBbXRMZWZ0S2V5BQhhY3RUb3RhbAQSbGFzdEFjdGl2aXRpZXNUaW1lCQELdmFsdWVPckVsc2UCCQCaCAIJAJEDAgUJY29udHJhY3RzBQhkYXBwMldsZwUUbGFzdEFjdGl2aXRpZXNUaW1LZXkFCWlzc3VlVGltZQQVYWN0QW1vdW50QXZhaWxhYmxlTm93CQCXAwEJAMwIAgkAawMFCGFjdFRvdGFsCQBlAgUDbm93BRJsYXN0QWN0aXZpdGllc1RpbWUJAGgCAAMFC1lFQVJfTUlMTElTCQDMCAIFDWFjdEFtb3VudExlZnQFA25pbAQJYWN0V2xnb2xkCQDwBwIJAJEDAgUJY29udHJhY3RzBQlkYXBwMlJlc3QFBXdsZ0lkBAxsYXN0VXNlclRpbWUJAQt2YWx1ZU9yRWxzZQIJAJoIAgkAkQMCBQljb250cmFjdHMFCGRhcHAyV2xnCQEWa2V5TGFzdENsYWltVGltZUJ5VXNlcgEFC3VzZXJBZGRyT3B0BQlpc3N1ZVRpbWUEDmxhc3RVc2VyUGVyaW9kCQBpAgkAZQIFDGxhc3RVc2VyVGltZQUJaXNzdWVUaW1lBQtZRUFSX01JTExJUwQKbm93TGltaXRlZAkAlwMBCQDMCAIFA25vdwkAzAgCCQBkAgUJaXNzdWVUaW1lCQBoAgADBQtZRUFSX01JTExJUwUDbmlsBAljdXJQZXJpb2QJAJcDAQkAzAgCCQBpAgkAZQIFA25vdwUJaXNzdWVUaW1lBQtZRUFSX01JTExJUwkAzAgCAAIFA25pbAQDZWZmCQEQZ2V0RmFybWluZ1Bvd2VycwIFC3VzZXJBZGRyT3B0CQCRAwIFCWNvbnRyYWN0cwUMZGFwcDJTdGFraW5nBBVjdXJQZXJpb2REaXN0cmlidXRpb24JAQ1kaXN0ckJ5UGVyaW9kAQUJY3VyUGVyaW9kBAgkdDA3OTExOQMJAAACBQ5sYXN0VXNlclBlcmlvZAUJY3VyUGVyaW9kBAJhMAkAawMFFWN1clBlcmlvZERpc3RyaWJ1dGlvbgkAZQIFCm5vd0xpbWl0ZWQFDGxhc3RVc2VyVGltZQULWUVBUl9NSUxMSVMEB2VmZlRpbWUJAGUCCQBkAgUMbGFzdFVzZXJUaW1lBQpub3dMaW1pdGVkBQxsYXN0VXNlclRpbWUJAJQKAgUCYTAFB2VmZlRpbWUDCQAAAgUObGFzdFVzZXJQZXJpb2QJAGUCBQljdXJQZXJpb2QAAQQCYTEJAGsDCQENZGlzdHJCeVBlcmlvZAEJAGUCBQljdXJQZXJpb2QAAQkAZQIJAGQCBQlpc3N1ZVRpbWUJAGgCBQtZRUFSX01JTExJUwUJY3VyUGVyaW9kBQxsYXN0VXNlclRpbWUFC1lFQVJfTUlMTElTBAJhMAkAawMFFWN1clBlcmlvZERpc3RyaWJ1dGlvbgkAZQIFCm5vd0xpbWl0ZWQJAGQCBQlpc3N1ZVRpbWUJAGgCBQtZRUFSX01JTExJUwUJY3VyUGVyaW9kBQtZRUFSX01JTExJUwQFYXZhaWwJAGQCBQJhMQUCYTAEB2VmZlRpbWUDCQBnAgUCYTEFBWF2YWlsCQBkAgUMbGFzdFVzZXJUaW1lCQBrAwULWUVBUl9NSUxMSVMFBWF2YWlsCQENZGlzdHJCeVBlcmlvZAEJAGUCBQljdXJQZXJpb2QAAQkAZAIJAGQCBQlpc3N1ZVRpbWUJAGgCBQtZRUFSX01JTExJUwUJY3VyUGVyaW9kCQBrAwULWUVBUl9NSUxMSVMJAGUCBQVhdmFpbAUCYTEFFWN1clBlcmlvZERpc3RyaWJ1dGlvbgkAlAoCBQVhdmFpbAUHZWZmVGltZQQCYTIJAGsDCQENZGlzdHJCeVBlcmlvZAEJAGUCBQljdXJQZXJpb2QAAgkAZQIJAGQCBQlpc3N1ZVRpbWUJAGgCBQtZRUFSX01JTExJUwkAZQIFCWN1clBlcmlvZAABBQxsYXN0VXNlclRpbWUFC1lFQVJfTUlMTElTBAJhMQkBDWRpc3RyQnlQZXJpb2QBCQBlAgUJY3VyUGVyaW9kAAEEAmEwCQBrAwUVY3VyUGVyaW9kRGlzdHJpYnV0aW9uCQBlAgUKbm93TGltaXRlZAkAZAIFCWlzc3VlVGltZQkAaAIFC1lFQVJfTUlMTElTBQljdXJQZXJpb2QFC1lFQVJfTUlMTElTBAVhdmFpbAkAZAIJAGQCBQJhMgUCYTEFAmEwBAdlZmZUaW1lAwkAZwIFAmEyBQVhdmFpbAkAZAIFDGxhc3RVc2VyVGltZQkAawMFC1lFQVJfTUlMTElTBQVhdmFpbAkBDWRpc3RyQnlQZXJpb2QBCQBlAgUJY3VyUGVyaW9kAAIDCQBnAgkAZAIFAmEyBQJhMQUFYXZhaWwJAGQCCQBkAgUJaXNzdWVUaW1lCQBoAgULWUVBUl9NSUxMSVMJAGUCBQljdXJQZXJpb2QAAQkAawMFC1lFQVJfTUlMTElTCQBlAgUFYXZhaWwFAmEyCQENZGlzdHJCeVBlcmlvZAEJAGUCBQljdXJQZXJpb2QAAQkAZAIJAGQCBQlpc3N1ZVRpbWUJAGgCBQtZRUFSX01JTExJUwUJY3VyUGVyaW9kCQBrAwULWUVBUl9NSUxMSVMJAGUCCQBlAgUFYXZhaWwFAmEyBQJhMQUVY3VyUGVyaW9kRGlzdHJpYnV0aW9uCQCUCgIFBWF2YWlsBQdlZmZUaW1lBA11c2VyQXZhaWxhYmxlCAUIJHQwNzkxMTkCXzEEC2VmZkxhc3RUaW1lCAUIJHQwNzkxMTkCXzIED2Ftb3VudExlZnRUb3RhbAkBC3ZhbHVlT3JFbHNlAgkAmggCCQCRAwIFCWNvbnRyYWN0cwUIZGFwcDJXbGcFEXN0YWtlcnNBbXRMZWZ0S2V5AAAEDHVucm9iYmVkVXNlcgkAawMFDXVzZXJBdmFpbGFibGUJAJEDAgUDZWZmBQlpZHhVc2VyRlAJAJEDAgUDZWZmBQppZHhUb3RhbEZQCQDMCAIFDGlzc3VlZEFtb3VudAkAzAgCCQBrAwkAZQIFDXRvdGFsRnVuZHNVc2QFDVVTRFRfVFZMX0NPUlIFA004XwUMaXNzdWVkQW1vdW50CQDMCAIFDXRvdGFsRnVuZHNVc2QJAMwIAgUHcmVzdFVzZAkAzAgCBQZ3bGdVc2QJAMwIAgUJcHV6emxlVXNkCQDMCAIFCWlzc3VlVGltZQkAzAgCBQxsYXN0VGVhbVRpbWUJAMwIAgUJdGVhbVRvdGFsCQDMCAIFDnRlYW1BbW91bnRMZWZ0CQDMCAIFFnRlYW1BbW91bnRBdmFpbGFibGVOb3cJAMwIAgUKdGVhbVdsZ29sZAkAzAgCBQhhY3RUb3RhbAkAzAgCBQ1hY3RBbW91bnRMZWZ0CQDMCAIFFWFjdEFtb3VudEF2YWlsYWJsZU5vdwkAzAgCBQlhY3RXbGdvbGQJAMwIAgUJY3VyUGVyaW9kCQDMCAIFD2Ftb3VudExlZnRUb3RhbAkAzAgCBRVjdXJQZXJpb2REaXN0cmlidXRpb24JAMwIAgUMbGFzdFVzZXJUaW1lCQDMCAIFD2ludmVzdEZ1bmRUb3RhbAkAzAgCBQx1bnJvYmJlZFVzZXIJAMwIAgULZWZmTGFzdFRpbWUFA25pbAEOd2FsbGV0SW50ZXJuYWwBDnVzZXJBZGRyZXNzT3B0BARhZGRyCQCmCAEFDnVzZXJBZGRyZXNzT3B0BAdiYWxhbmNlAwkBCWlzRGVmaW5lZAEFBGFkZHIJAO8HAQkBBXZhbHVlAQUEYWRkcgkBDkJhbGFuY2VEZXRhaWxzBAAAAAAAAAAABA13bGdvbGRCYWxhbmNlAwkBCWlzRGVmaW5lZAEFBGFkZHIJAPAHAgkBBXZhbHVlAQUEYWRkcgUKd2xnQXNzZXRJZAAABApjdXN0b21OYW1lCQELdmFsdWVPckVsc2UCCQCdCAIFDmFjcmVzMkNvbnRyYWN0CQEWa2V5QWRkcmVzc1RvQ3VzdG9tTmFtZQEFDnVzZXJBZGRyZXNzT3B0BQ51c2VyQWRkcmVzc09wdAQIcmVmQnlLZXkJAQ9rZXlBZGRyZXNzUmVmQnkBBQ51c2VyQWRkcmVzc09wdAQFcmVmQnkJAJ0IAgUOYWNyZXMyQ29udHJhY3QFCHJlZkJ5S2V5BARyZWZzCQELdmFsdWVPckVsc2UCCQCdCAIFDmFjcmVzMkNvbnRyYWN0CQETa2V5QWRkcmVzc1JlZmVycmFscwEFDnVzZXJBZGRyZXNzT3B0AgAECGxhc3RUeElkCQELdmFsdWVPckVsc2UCCQCdCAIFDmFjcmVzMkNvbnRyYWN0CQERa2V5TGFzdFR4SWRCeVVzZXIBBQ51c2VyQWRkcmVzc09wdAIABAxhY3Jlc0JhbGFuY2UDCQEJaXNEZWZpbmVkAQUEYWRkcgkA8AcCCQEFdmFsdWUBBQRhZGRyBQxhY3Jlc0Fzc2V0SWQAAAQLc3Rha2VkQWNyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOYWNyZXMyQ29udHJhY3QJARdrZXlBY3Jlc1N0YWtlZEFtdEJ5VXNlcgEFDnVzZXJBZGRyZXNzT3B0AAAEA2x2bAkBD2dldExldmVsQnlBY3JlcwEFDGFjcmVzQmFsYW5jZQkAzAgCCQCsAgICEiVzJXNfX2N1c3RvbU5hbWVfXwUKY3VzdG9tTmFtZQkAzAgCCQCsAgICEiVzJXNfX3JlZmVycmVkQnlfXwkBC3ZhbHVlT3JFbHNlAgUFcmVmQnkCAAkAzAgCCQCsAgICESVzJXNfX3JlZmVycmFsc19fBQRyZWZzCQDMCAIJAKwCAgIQJXMlc19fbGFzdFR4SWRfXwUIbGFzdFR4SWQJAMwIAgkArAICAhQlcyVkX193YXZlc0JhbGFuY2VfXwkApAMBCAUHYmFsYW5jZQlhdmFpbGFibGUJAMwIAgkArAICAhUlcyVkX193bGdvbGRCYWxhbmNlX18JAKQDAQUNd2xnb2xkQmFsYW5jZQkAzAgCCQCsAgICFCVzJWRfX2FjcmVzQmFsYW5jZV9fCQCkAwEFDGFjcmVzQmFsYW5jZQkAzAgCCQCsAgICEyVzJWRfX3N0YWtlZEFjcmVzX18JAKQDAQULc3Rha2VkQWNyZXMJAMwIAgkArAICAhIlcyVkX19jdXJyZW50THZsX18JAKQDAQUDbHZsBQNuaWwEAWkBDWNvbnN0cnVjdG9yVjEBCWNvbnRyYWN0cwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEnBlcm1pc3Npb25zIGRlbmllZAoBCmRlc2NyaXB0b3ICA2FjYwtpZ25vcmVkSXRlbQkArAICBQNhY2MCAiVzBAVkZXNjcgoAAiRsBQljb250cmFjdHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwAgAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCmRlc2NyaXB0b3ICBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoJAMwIAgkBC1N0cmluZ0VudHJ5AgkBCmtleVJlc3RDZmcACQC5CQIJAMwIAgUFZGVzY3IFCWNvbnRyYWN0cwUDU0VQCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ9rZXlSZXN0MkFkZHJlc3MACQClCAEFBHRoaXMFA25pbAFpARJ3YWxsZXRJbmZvUkVBRE9OTFkBDnVzZXJBZGRyZXNzT3B0CQCUCgIFA25pbAkBDndhbGxldEludGVybmFsAQUOdXNlckFkZHJlc3NPcHQBaQEWY29udmVyc2lvbkluZm9SRUFET05MWQEOdXNlckFkZHJlc3NPcHQED29sZEFjcmVzQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUOYWNyZXMyQ29udHJhY3QFE29sZEFjcmVzQ29udHJhY3RLZXkECyR0MDQwNTA0MTcyCQEMYXNUdXBsZTJJbnRzAQkA/AcEBQ9vbGRBY3Jlc0FkZHJlc3MCF3Vuc3Rha2VBbGxBY3Jlc1JFQURPTkxZCQDMCAIFDnVzZXJBZGRyZXNzT3B0BQNuaWwFA25pbAQNdW5zdGFrZWRBY3JlcwgFCyR0MDQwNTA0MTcyAl8xBAxjbGFpbWVkQWNyZXMIBQskdDA0MDUwNDE3MgJfMgQLJHQwNDE3NTQzMjQJAQxhc1R1cGxlNEludHMBCQD8BwQFDmFjcmVzMkNvbnRyYWN0AhR1bnN0YWtlTGFuZHNSRUFET05MWQkAzAgCBQ51c2VyQWRkcmVzc09wdAUDbmlsBQNuaWwED2FjcmVzRnJvbVBpZWNlcwgFCyR0MDQxNzU0MzI0Al8xBAxhY3Jlc0Zyb21SZXMIBQskdDA0MTc1NDMyNAJfMgQMYWNyZXNGcm9tTWF0CAULJHQwNDE3NTQzMjQCXzMEDWFjcmVzRnJvbVByb2QIBQskdDA0MTc1NDMyNAJfNAQRb2xkU3Rha2luZ0FkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFFW9sZFN0YWtpbmdDb250cmFjdFN0cgQLZHVja0Fzc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAJ0IAgURb2xkU3Rha2luZ0FkZHJlc3MJARRrZXlTdGFrZWREdWNrQnlPd25lcgEFDnVzZXJBZGRyZXNzT3B0AgAECyR0MDQ1MDI0NzI0AwkBAiE9AgULZHVja0Fzc2V0SWQCAAkBDGFzVHVwbGUzSW50cwEJAPwHBAURb2xkU3Rha2luZ0FkZHJlc3MCE3Vuc3Rha2VEdWNrUkVBRE9OTFkJAMwIAgULZHVja0Fzc2V0SWQJAMwIAgUOdXNlckFkZHJlc3NPcHQFA25pbAUDbmlsCQCVCgMAAAAAAAAEEGFjcmVzRnJvbUR1Y2tSZXMIBQskdDA0NTAyNDcyNAJfMQQQYWNyZXNGcm9tRHVja01hdAgFCyR0MDQ1MDI0NzI0Al8yBBFhY3Jlc0Zyb21EdWNrUHJvZAgFCyR0MDQ1MDI0NzI0Al8zCQCUCgIFA25pbAkAzAgCCQCsAgICFSVzJWRfX3Vuc3Rha2VkQWNyZXNfXwkApAMBBQ11bnN0YWtlZEFjcmVzCQDMCAIJAKwCAgIUJXMlZF9fY2xhaW1lZEFjcmVzX18JAKQDAQUMY2xhaW1lZEFjcmVzCQDMCAIJAKwCAgIXJXMlZF9fYWNyZXNGcm9tUGllY2VzX18JAKQDAQUPYWNyZXNGcm9tUGllY2VzCQDMCAIJAKwCAgIUJXMlZF9fYWNyZXNGcm9tUmVzX18JAKQDAQUMYWNyZXNGcm9tUmVzCQDMCAIJAKwCAgIUJXMlZF9fYWNyZXNGcm9tTWF0X18JAKQDAQUMYWNyZXNGcm9tTWF0CQDMCAIJAKwCAgIVJXMlZF9fYWNyZXNGcm9tUHJvZF9fCQCkAwEFDWFjcmVzRnJvbVByb2QJAMwIAgkArAICAhglcyVkX19hY3Jlc0Zyb21EdWNrUmVzX18JAKQDAQUQYWNyZXNGcm9tRHVja1JlcwkAzAgCCQCsAgICGCVzJWRfX2FjcmVzRnJvbUR1Y2tNYXRfXwkApAMBBRBhY3Jlc0Zyb21EdWNrTWF0CQDMCAIJAKwCAgIZJXMlZF9fYWNyZXNGcm9tRHVja1Byb2RfXwkApAMBBRFhY3Jlc0Zyb21EdWNrUHJvZAUDbmlsAWkBEHdsZ1N0YXRzUkVBRE9OTFkBC3VzZXJBZGRyT3B0BAhjdXJTdGF0cwkBDGdldFdsZ1N0YXRzMgQFC3VzZXJBZGRyT3B0CQDMCAIFDXJlc3QyQ29udHJhY3QJAMwIAgUOYWNyZXMyQ29udHJhY3QJAMwIAgULd2xnQ29udHJhY3QJAMwIAgUScHV6emxlUG9vbENvbnRyYWN0CQDMCAIFEmludmVzdEZ1bmRDb250cmFjdAUDbmlsBQt1c2R0QXNzZXRJZAAACQCUCgIFA25pbAkAzAgCCQCsAgICESVzJWRfX3dsZ0Ftb3VudF9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFC2l4V2xnQW1vdW50CQDMCAIJAKwCAgIQJXMlZF9fd2xnUHJpY2VfXwkApAMBCQCRAwIFCGN1clN0YXRzBQppeFdsZ1ByaWNlCQDMCAIJAKwCAgIRJXMlZF9fdXNkdEZ1bmRzX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUKaXhXbGdGdW5kcwkAzAgCCQCsAgICFCVzJWRfX3VzZHRBY3Rpdml0eV9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFDWl4V2xnQWN0aXZpdHkJAMwIAgkArAICAhUlcyVkX191c2R0QXJiaXRyYWdlX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUOaXhXbGdBcmJpdHJhZ2UJAMwIAgkArAICAhAlcyVkX191c2R0UG9vbF9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFCWl4V2xnUG9vbAkAzAgCCQCsAgICFCVzJWRfX3dsZ0lzc3VlVGltZV9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFDml4V2xnSXNzdWVUaW1lCQDMCAIJAKwCAgIjJXMlZF9fd2xnTGFzdE1hcmtldGluZ1RlYW1BY3RUaW1lX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUUaXhXbGdMYXN0VGVhbUFjdFRpbWUJAMwIAgkArAICAhQlcyVkX193bGdUZWFtVG90YWxfXwkApAMBCQCRAwIFCGN1clN0YXRzBQ5peFdsZ1RlYW1Ub3RhbAkAzAgCCQCsAgICFSVzJWRfX3dsZ1RlYW1BbUxlZnRfXwkApAMBCQCRAwIFCGN1clN0YXRzBQ9peFdsZ1RlYW1BbUxlZnQJAMwIAgkArAICAhklcyVkX193bGdUZWFtQW1BdmFpbE5vd19fCQCkAwEJAJEDAgUIY3VyU3RhdHMFE2l4V2xnVGVhbUFtQXZhaWxOb3cJAMwIAgkArAICAhUlcyVkX193bGdUZWFtV2xnb2xkX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUPaXhXbGdUZWFtV2xnb2xkCQDMCAIJAKwCAgITJXMlZF9fd2xnQWN0VG90YWxfXwkApAMBCQCRAwIFCGN1clN0YXRzBQ1peFdsZ0FjdFRvdGFsCQDMCAIJAKwCAgIUJXMlZF9fd2xnQWN0QW1MZWZ0X18JAKQDAQkAkQMCBQhjdXJTdGF0cwUOaXhXbGdBY3RBbUxlZnQJAMwIAgkArAICAhglcyVkX193bGdBY3RBbUF2YWlsTm93X18JAKQDAQkAkQMCBQhjdXJTdGF0cwUSaXhXbGdBY3RBbUF2YWlsTm93CQDMCAIJAKwCAgIUJXMlZF9fd2xnQWN0V2xnb2xkX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUOaXhXbGdBY3RXbGdvbGQJAMwIAgkArAICAhQlcyVkX193bGdDdXJQZXJpb2RfXwkApAMBCQCRAwIFCGN1clN0YXRzBQ5peFdsZ0N1clBlcmlvZAkAzAgCCQCsAgICFiVzJWRfX3dsZ0FtTGVmdFRvdGFsX18JAKQDAQkAkQMCBQhjdXJTdGF0cwUQaXhXbGdBbUxlZnRUb3RhbAkAzAgCCQCsAgICICVzJWRfX3dsZ0N1clBlcmlvZERpc3RyaWJ1dGlvbl9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFGml4V2xnQ3VyUGVyaW9kRGlzdHJpYnV0aW9uCQDMCAIJAKwCAgIXJXMlZF9fd2xnTGFzdFVzZXJUaW1lX18JAKQDAQkAkQMCBQhjdXJTdGF0cwURaXhXbGdMYXN0VXNlclRpbWUJAMwIAgkArAICAholcyVkX193bGdJbnZlc3RGdW5kVG90YWxfXwkApAMBCQCRAwIFCGN1clN0YXRzBRVpeFdsZ0ludmVzdEZ1bmRBbW91bnQJAMwIAgkArAICAhklcyVkX193bGdVc2VyQW1BdmFpbE5vd19fCQCkAwEJAJEDAgUIY3VyU3RhdHMFE2l4V2xnVXNlckFtQXZhaWxOb3cJAMwIAgkArAICAhYlcyVkX193bGdFZmZVc2VyVGltZV9fCQCkAwEJAJEDAgUIY3VyU3RhdHMFEGl4V2xnRWZmVXNlclRpbWUFA25pbAAvnDpZ", "height": 3281211, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6QoWLHuwmreHtGSqvVqffhK3ycJ1mAynKFhPt2eA5Yt Next: G2mdREjNEm7rvRZHwiL82oYnhVh3Eu1rkoBAopBkocoS Diff:
Old | New | Differences | |
---|---|---|---|
4 | 4 | let SEP = "__" | |
5 | 5 | ||
6 | 6 | let chain = take(drop(this.bytes, 1), 1) | |
7 | + | ||
8 | + | let usdtAssetId = match chain { | |
9 | + | case _ => | |
10 | + | if ((base58'2W' == $match0)) | |
11 | + | then base58'9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi' | |
12 | + | else if ((base58'2T' == $match0)) | |
13 | + | then base58'6mWwf9mZBjVgkC54idpyaZLQfAosD914wT8fGf2iiY63' | |
14 | + | else throw("Unknown chain") | |
15 | + | } | |
7 | 16 | ||
8 | 17 | let defaultRest2AddressStr = match chain { | |
9 | 18 | case _ => | |
30 | 39 | ||
31 | 40 | let IdxCfgWlgDapp = 2 | |
32 | 41 | ||
42 | + | let IdxCfgPuzzlePoolDapp = 4 | |
43 | + | ||
44 | + | let IdxCfgInvestFundDapp = 5 | |
45 | + | ||
33 | 46 | func keyRestCfg () = "%s__restConfig" | |
34 | 47 | ||
35 | 48 | ||
49 | 62 | let acres2Contract = getContractAddressOrFail(rest2Cfg, IdxCfgAcres2Dapp) | |
50 | 63 | ||
51 | 64 | let wlgContract = getContractAddressOrFail(rest2Cfg, IdxCfgWlgDapp) | |
65 | + | ||
66 | + | let puzzlePoolContract = getContractAddressOrFail(rest2Cfg, IdxCfgPuzzlePoolDapp) | |
67 | + | ||
68 | + | let investFundContract = getContractAddressOrFail(rest2Cfg, IdxCfgInvestFundDapp) | |
52 | 69 | ||
53 | 70 | let oldAcresContractKey = "oldAcresContract" | |
54 | 71 | ||
99 | 116 | } | |
100 | 117 | ||
101 | 118 | ||
119 | + | let M6_ = 1000000 | |
120 | + | ||
102 | 121 | let M8_ = 100000000 | |
122 | + | ||
123 | + | let MILL6 = 100000000000000 | |
124 | + | ||
125 | + | let TEAM_SHARE = 200000 | |
126 | + | ||
127 | + | let ACTIVITY_SHARE = 100000 | |
128 | + | ||
129 | + | let PLAYER_SHARE = 400000 | |
130 | + | ||
131 | + | let YEAR_MILLIS = 31557600000 | |
132 | + | ||
133 | + | let chn = take(drop(this.bytes, 1), 1) | |
134 | + | ||
135 | + | let USDT_TVL_CORR = match chn { | |
136 | + | case _ => | |
137 | + | if ((base58'2W' == $match0)) | |
138 | + | then 1208630000 | |
139 | + | else if ((base58'2T' == $match0)) | |
140 | + | then 0 | |
141 | + | else throw("Unknown chain") | |
142 | + | } | |
143 | + | ||
144 | + | let teamAdrKey = "teamAddr" | |
145 | + | ||
146 | + | let lastTeamTimKey = "lastClaimedTime_team" | |
147 | + | ||
148 | + | let teamAmtLeftKey = "teamAmountLeft" | |
149 | + | ||
150 | + | let lastActivitiesTimKey = "lastClaimedTime_activities" | |
151 | + | ||
152 | + | let actAmtLeftKey = "activitiesAmountLeft" | |
153 | + | ||
154 | + | let stakersAmtLeftKey = "stakersAmountLeft" | |
155 | + | ||
156 | + | func keyLastClaimTimeByUser (addr) = ("lastClaimedTimeUser_" + addr) | |
157 | + | ||
158 | + | ||
159 | + | func distrByPeriod (period) = fraction(MILL6, (PLAYER_SHARE * (period + 1)), (6 * M6_)) | |
160 | + | ||
161 | + | ||
162 | + | let wlgIssueTimKey = "wlg_issueTime" | |
163 | + | ||
164 | + | let wlgIssuedAmtKey = "wlg_issuedAmount" | |
165 | + | ||
166 | + | let zbIssuedAmtKey = "zbill_issuedAmount" | |
103 | 167 | ||
104 | 168 | func keyAcresStakedAmtByUser (addr) = ("acresStakedAmountByUser_" + addr) | |
105 | 169 | ||
170 | + | ||
171 | + | let acresStakdTotalKey = "acresStakedAmountTotal" | |
172 | + | ||
173 | + | let dapp2Rest = 0 | |
174 | + | ||
175 | + | let dapp2Staking = 1 | |
176 | + | ||
177 | + | let dapp2Wlg = 2 | |
178 | + | ||
179 | + | let dapp2Puzzle = 3 | |
180 | + | ||
181 | + | let dapp2InvestFund = 4 | |
106 | 182 | ||
107 | 183 | let levels = [10, 20, 40, 80, 150, 250, 400, 700, 1000] | |
108 | 184 | ||
127 | 203 | $f0_2($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) | |
128 | 204 | } | |
129 | 205 | (idx + 1) | |
206 | + | } | |
207 | + | ||
208 | + | ||
209 | + | func getFarmingPowerByAcres (acres) = ((acres * 20) * (getLevelByAcres(acres) + 4)) | |
210 | + | ||
211 | + | ||
212 | + | func getFarmingPowers (userAddrStrOrEmpty,stakingContract) = { | |
213 | + | let totalAcres = valueOrElse(getInteger(stakingContract, acresStakdTotalKey), 0) | |
214 | + | let totalFP = getFarmingPowerByAcres(totalAcres) | |
215 | + | let userAcres = valueOrElse(getInteger(stakingContract, keyAcresStakedAmtByUser(userAddrStrOrEmpty)), 0) | |
216 | + | let userFP = getFarmingPowerByAcres(userAcres) | |
217 | + | [totalFP, userFP] | |
218 | + | } | |
219 | + | ||
220 | + | ||
221 | + | let idxTotalFP = 0 | |
222 | + | ||
223 | + | let idxUserFP = 1 | |
224 | + | ||
225 | + | let ixWlgAmount = 0 | |
226 | + | ||
227 | + | let ixWlgPrice = 1 | |
228 | + | ||
229 | + | let ixWlgFunds = 2 | |
230 | + | ||
231 | + | let ixWlgActivity = 3 | |
232 | + | ||
233 | + | let ixWlgArbitrage = 4 | |
234 | + | ||
235 | + | let ixWlgPool = 5 | |
236 | + | ||
237 | + | let ixWlgIssueTime = 6 | |
238 | + | ||
239 | + | let ixWlgLastTeamActTime = 7 | |
240 | + | ||
241 | + | let ixWlgTeamTotal = 8 | |
242 | + | ||
243 | + | let ixWlgTeamAmLeft = 9 | |
244 | + | ||
245 | + | let ixWlgTeamAmAvailNow = 10 | |
246 | + | ||
247 | + | let ixWlgTeamWlgold = 11 | |
248 | + | ||
249 | + | let ixWlgActTotal = 12 | |
250 | + | ||
251 | + | let ixWlgActAmLeft = 13 | |
252 | + | ||
253 | + | let ixWlgActAmAvailNow = 14 | |
254 | + | ||
255 | + | let ixWlgActWlgold = 15 | |
256 | + | ||
257 | + | let ixWlgCurPeriod = 16 | |
258 | + | ||
259 | + | let ixWlgAmLeftTotal = 17 | |
260 | + | ||
261 | + | let ixWlgCurPeriodDistribution = 18 | |
262 | + | ||
263 | + | let ixWlgLastUserTime = 19 | |
264 | + | ||
265 | + | let ixWlgInvestFundAmount = 20 | |
266 | + | ||
267 | + | let ixWlgUserAmAvailNow = 21 | |
268 | + | ||
269 | + | let ixWlgEffUserTime = 22 | |
270 | + | ||
271 | + | func getWlgStats2 (userAddrOpt,contracts,usdtId,usdtBalanceCorrection) = { | |
272 | + | let issuedAmount = valueOrErrorMessage(getInteger(contracts[dapp2Wlg], wlgIssuedAmtKey), "WLGOLD is not issued yet") | |
273 | + | let restUsd = assetBalance(contracts[dapp2Rest], usdtId) | |
274 | + | let wlgUsd = (assetBalance(contracts[dapp2Wlg], usdtId) - usdtBalanceCorrection) | |
275 | + | let puzzleUsd = assetBalance(contracts[dapp2Puzzle], usdtId) | |
276 | + | let investFndContract = contracts[dapp2InvestFund] | |
277 | + | let investFundTotal = (assetBalance(investFndContract, usdtId) + valueOrElse(getInteger(investFndContract, zbIssuedAmtKey), 0)) | |
278 | + | let totalFundsUsd = (wlgUsd + investFundTotal) | |
279 | + | let wlgId = valueOrErrorMessage(getBinary(contracts[dapp2Wlg], "wlg_assetId"), "Not initialized yet") | |
280 | + | let now = lastBlock.timestamp | |
281 | + | let issueTime = valueOrErrorMessage(getInteger(contracts[dapp2Wlg], wlgIssueTimKey), "Not initialized") | |
282 | + | let teamTotal = fraction(MILL6, TEAM_SHARE, M6_) | |
283 | + | let teamAmountLeft = valueOrElse(getInteger(contracts[dapp2Wlg], teamAmtLeftKey), teamTotal) | |
284 | + | let lastTeamTime = valueOrElse(getInteger(contracts[dapp2Wlg], lastTeamTimKey), issueTime) | |
285 | + | let teamAddr = addressFromStringValue(value(getString(contracts[dapp2Wlg], teamAdrKey))) | |
286 | + | let teamAmountAvailableNow = min([fraction(teamTotal, (now - lastTeamTime), (3 * YEAR_MILLIS)), teamAmountLeft]) | |
287 | + | let teamWlgold = assetBalance(teamAddr, wlgId) | |
288 | + | let actTotal = fraction(MILL6, ACTIVITY_SHARE, M6_) | |
289 | + | let actAmountLeft = valueOrElse(getInteger(contracts[dapp2Wlg], actAmtLeftKey), actTotal) | |
290 | + | let lastActivitiesTime = valueOrElse(getInteger(contracts[dapp2Wlg], lastActivitiesTimKey), issueTime) | |
291 | + | let actAmountAvailableNow = min([fraction(actTotal, (now - lastActivitiesTime), (3 * YEAR_MILLIS)), actAmountLeft]) | |
292 | + | let actWlgold = assetBalance(contracts[dapp2Rest], wlgId) | |
293 | + | let lastUserTime = valueOrElse(getInteger(contracts[dapp2Wlg], keyLastClaimTimeByUser(userAddrOpt)), issueTime) | |
294 | + | let lastUserPeriod = ((lastUserTime - issueTime) / YEAR_MILLIS) | |
295 | + | let nowLimited = min([now, (issueTime + (3 * YEAR_MILLIS))]) | |
296 | + | let curPeriod = min([((now - issueTime) / YEAR_MILLIS), 2]) | |
297 | + | let eff = getFarmingPowers(userAddrOpt, contracts[dapp2Staking]) | |
298 | + | let curPeriodDistribution = distrByPeriod(curPeriod) | |
299 | + | let $t079119 = if ((lastUserPeriod == curPeriod)) | |
300 | + | then { | |
301 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - lastUserTime), YEAR_MILLIS) | |
302 | + | let effTime = ((lastUserTime + nowLimited) - lastUserTime) | |
303 | + | $Tuple2(a0, effTime) | |
304 | + | } | |
305 | + | else if ((lastUserPeriod == (curPeriod - 1))) | |
306 | + | then { | |
307 | + | let a1 = fraction(distrByPeriod((curPeriod - 1)), ((issueTime + (YEAR_MILLIS * curPeriod)) - lastUserTime), YEAR_MILLIS) | |
308 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - (issueTime + (YEAR_MILLIS * curPeriod))), YEAR_MILLIS) | |
309 | + | let avail = (a1 + a0) | |
310 | + | let effTime = if ((a1 >= avail)) | |
311 | + | then (lastUserTime + fraction(YEAR_MILLIS, avail, distrByPeriod((curPeriod - 1)))) | |
312 | + | else ((issueTime + (YEAR_MILLIS * curPeriod)) + fraction(YEAR_MILLIS, (avail - a1), curPeriodDistribution)) | |
313 | + | $Tuple2(avail, effTime) | |
314 | + | } | |
315 | + | else { | |
316 | + | let a2 = fraction(distrByPeriod((curPeriod - 2)), ((issueTime + (YEAR_MILLIS * (curPeriod - 1))) - lastUserTime), YEAR_MILLIS) | |
317 | + | let a1 = distrByPeriod((curPeriod - 1)) | |
318 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - (issueTime + (YEAR_MILLIS * curPeriod))), YEAR_MILLIS) | |
319 | + | let avail = ((a2 + a1) + a0) | |
320 | + | let effTime = if ((a2 >= avail)) | |
321 | + | then (lastUserTime + fraction(YEAR_MILLIS, avail, distrByPeriod((curPeriod - 2)))) | |
322 | + | else if (((a2 + a1) >= avail)) | |
323 | + | then ((issueTime + (YEAR_MILLIS * (curPeriod - 1))) + fraction(YEAR_MILLIS, (avail - a2), distrByPeriod((curPeriod - 1)))) | |
324 | + | else ((issueTime + (YEAR_MILLIS * curPeriod)) + fraction(YEAR_MILLIS, ((avail - a2) - a1), curPeriodDistribution)) | |
325 | + | $Tuple2(avail, effTime) | |
326 | + | } | |
327 | + | let userAvailable = $t079119._1 | |
328 | + | let effLastTime = $t079119._2 | |
329 | + | let amountLeftTotal = valueOrElse(getInteger(contracts[dapp2Wlg], stakersAmtLeftKey), 0) | |
330 | + | let unrobbedUser = fraction(userAvailable, eff[idxUserFP], eff[idxTotalFP]) | |
331 | + | [issuedAmount, fraction((totalFundsUsd - USDT_TVL_CORR), M8_, issuedAmount), totalFundsUsd, restUsd, wlgUsd, puzzleUsd, issueTime, lastTeamTime, teamTotal, teamAmountLeft, teamAmountAvailableNow, teamWlgold, actTotal, actAmountLeft, actAmountAvailableNow, actWlgold, curPeriod, amountLeftTotal, curPeriodDistribution, lastUserTime, investFundTotal, unrobbedUser, effLastTime] | |
130 | 332 | } | |
131 | 333 | ||
132 | 334 | ||
205 | 407 | } | |
206 | 408 | ||
207 | 409 | ||
410 | + | ||
411 | + | @Callable(i) | |
412 | + | func wlgStatsREADONLY (userAddrOpt) = { | |
413 | + | let curStats = getWlgStats2(userAddrOpt, [rest2Contract, acres2Contract, wlgContract, puzzlePoolContract, investFundContract], usdtAssetId, 0) | |
414 | + | $Tuple2(nil, [("%s%d__wlgAmount__" + toString(curStats[ixWlgAmount])), ("%s%d__wlgPrice__" + toString(curStats[ixWlgPrice])), ("%s%d__usdtFunds__" + toString(curStats[ixWlgFunds])), ("%s%d__usdtActivity__" + toString(curStats[ixWlgActivity])), ("%s%d__usdtArbitrage__" + toString(curStats[ixWlgArbitrage])), ("%s%d__usdtPool__" + toString(curStats[ixWlgPool])), ("%s%d__wlgIssueTime__" + toString(curStats[ixWlgIssueTime])), ("%s%d__wlgLastMarketingTeamActTime__" + toString(curStats[ixWlgLastTeamActTime])), ("%s%d__wlgTeamTotal__" + toString(curStats[ixWlgTeamTotal])), ("%s%d__wlgTeamAmLeft__" + toString(curStats[ixWlgTeamAmLeft])), ("%s%d__wlgTeamAmAvailNow__" + toString(curStats[ixWlgTeamAmAvailNow])), ("%s%d__wlgTeamWlgold__" + toString(curStats[ixWlgTeamWlgold])), ("%s%d__wlgActTotal__" + toString(curStats[ixWlgActTotal])), ("%s%d__wlgActAmLeft__" + toString(curStats[ixWlgActAmLeft])), ("%s%d__wlgActAmAvailNow__" + toString(curStats[ixWlgActAmAvailNow])), ("%s%d__wlgActWlgold__" + toString(curStats[ixWlgActWlgold])), ("%s%d__wlgCurPeriod__" + toString(curStats[ixWlgCurPeriod])), ("%s%d__wlgAmLeftTotal__" + toString(curStats[ixWlgAmLeftTotal])), ("%s%d__wlgCurPeriodDistribution__" + toString(curStats[ixWlgCurPeriodDistribution])), ("%s%d__wlgLastUserTime__" + toString(curStats[ixWlgLastUserTime])), ("%s%d__wlgInvestFundTotal__" + toString(curStats[ixWlgInvestFundAmount])), ("%s%d__wlgUserAmAvailNow__" + toString(curStats[ixWlgUserAmAvailNow])), ("%s%d__wlgEffUserTime__" + toString(curStats[ixWlgEffUserTime]))]) | |
415 | + | } | |
416 | + | ||
417 | + |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let SEP = "__" | |
5 | 5 | ||
6 | 6 | let chain = take(drop(this.bytes, 1), 1) | |
7 | + | ||
8 | + | let usdtAssetId = match chain { | |
9 | + | case _ => | |
10 | + | if ((base58'2W' == $match0)) | |
11 | + | then base58'9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi' | |
12 | + | else if ((base58'2T' == $match0)) | |
13 | + | then base58'6mWwf9mZBjVgkC54idpyaZLQfAosD914wT8fGf2iiY63' | |
14 | + | else throw("Unknown chain") | |
15 | + | } | |
7 | 16 | ||
8 | 17 | let defaultRest2AddressStr = match chain { | |
9 | 18 | case _ => | |
10 | 19 | if ((base58'2W' == $match0)) | |
11 | 20 | then "3PFwYta8biEz31zpeFe5DJK8wE5trSpQVF8" | |
12 | 21 | else if ((base58'2T' == $match0)) | |
13 | 22 | then "3N7UuYar6264P58FBhVWKPQAh4Yua2hgngv" | |
14 | 23 | else throw("Unknown chain") | |
15 | 24 | } | |
16 | 25 | ||
17 | 26 | let oldStakingContractStr = match chain { | |
18 | 27 | case _ => | |
19 | 28 | if ((base58'2W' == $match0)) | |
20 | 29 | then "3PLncXtS1U83D6cQbFD3H8rBHPLgzxSFKZ1" | |
21 | 30 | else if ((base58'2T' == $match0)) | |
22 | 31 | then "3NDCyBG5q85JuaRiigUeEtainyjCQT3XpZm" | |
23 | 32 | else throw("Unknown chain") | |
24 | 33 | } | |
25 | 34 | ||
26 | 35 | func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), makeString(["mandatory ", toString(address), ".", key, " is not defined"], "")) | |
27 | 36 | ||
28 | 37 | ||
29 | 38 | let IdxCfgAcres2Dapp = 1 | |
30 | 39 | ||
31 | 40 | let IdxCfgWlgDapp = 2 | |
32 | 41 | ||
42 | + | let IdxCfgPuzzlePoolDapp = 4 | |
43 | + | ||
44 | + | let IdxCfgInvestFundDapp = 5 | |
45 | + | ||
33 | 46 | func keyRestCfg () = "%s__restConfig" | |
34 | 47 | ||
35 | 48 | ||
36 | 49 | func keyRest2Address () = "%s__rest2Addr" | |
37 | 50 | ||
38 | 51 | ||
39 | 52 | func readRestCfgOrFail (rest) = split_4C(getStringOrFail(rest, keyRestCfg()), SEP) | |
40 | 53 | ||
41 | 54 | ||
42 | 55 | func getContractAddressOrFail (rest2Cfg,idx) = valueOrErrorMessage(addressFromString(rest2Cfg[idx]), ("Rest cfg doesn't contain address at index " + toString(idx))) | |
43 | 56 | ||
44 | 57 | ||
45 | 58 | let rest2Contract = addressFromStringValue(valueOrElse(getString(this, keyRest2Address()), defaultRest2AddressStr)) | |
46 | 59 | ||
47 | 60 | let rest2Cfg = readRestCfgOrFail(rest2Contract) | |
48 | 61 | ||
49 | 62 | let acres2Contract = getContractAddressOrFail(rest2Cfg, IdxCfgAcres2Dapp) | |
50 | 63 | ||
51 | 64 | let wlgContract = getContractAddressOrFail(rest2Cfg, IdxCfgWlgDapp) | |
65 | + | ||
66 | + | let puzzlePoolContract = getContractAddressOrFail(rest2Cfg, IdxCfgPuzzlePoolDapp) | |
67 | + | ||
68 | + | let investFundContract = getContractAddressOrFail(rest2Cfg, IdxCfgInvestFundDapp) | |
52 | 69 | ||
53 | 70 | let oldAcresContractKey = "oldAcresContract" | |
54 | 71 | ||
55 | 72 | func keyLastTxIdByUser (addr) = ("lastTxIdByUser_" + addr) | |
56 | 73 | ||
57 | 74 | ||
58 | 75 | let wlgAssetIdKey = "wlg_assetId" | |
59 | 76 | ||
60 | 77 | let wlgAssetId = valueOrErrorMessage(getBinary(wlgContract, wlgAssetIdKey), "WLGOLD is not issued yet") | |
61 | 78 | ||
62 | 79 | let acresAssetIdKey = "acresAssetId" | |
63 | 80 | ||
64 | 81 | let acresAssetId = valueOrErrorMessage(getBinary(acres2Contract, acresAssetIdKey), "ACRES is not issued yet") | |
65 | 82 | ||
66 | 83 | func keyStakedDuckByOwner (ownerAddr) = ("stakedDuckByOwner_" + ownerAddr) | |
67 | 84 | ||
68 | 85 | ||
69 | 86 | func keyAddressToCustomName (addr) = ("accountCustomNameByAddr_" + addr) | |
70 | 87 | ||
71 | 88 | ||
72 | 89 | func keyAddressRefBy (addr) = ("accRefBy_" + addr) | |
73 | 90 | ||
74 | 91 | ||
75 | 92 | func keyAddressReferrals (addr) = ("accReferrals_" + addr) | |
76 | 93 | ||
77 | 94 | ||
78 | 95 | func asTuple4Ints (val) = match val { | |
79 | 96 | case t: (Int, Int, Int, Int) => | |
80 | 97 | t | |
81 | 98 | case _ => | |
82 | 99 | throw("fail to cast into (Int, Int, Int, Int)") | |
83 | 100 | } | |
84 | 101 | ||
85 | 102 | ||
86 | 103 | func asTuple3Ints (val) = match val { | |
87 | 104 | case t: (Int, Int, Int) => | |
88 | 105 | t | |
89 | 106 | case _ => | |
90 | 107 | throw("fail to cast into (Int, Int, Int)") | |
91 | 108 | } | |
92 | 109 | ||
93 | 110 | ||
94 | 111 | func asTuple2Ints (val) = match val { | |
95 | 112 | case t: (Int, Int) => | |
96 | 113 | t | |
97 | 114 | case _ => | |
98 | 115 | throw("fail to cast into (Int, Int)") | |
99 | 116 | } | |
100 | 117 | ||
101 | 118 | ||
119 | + | let M6_ = 1000000 | |
120 | + | ||
102 | 121 | let M8_ = 100000000 | |
122 | + | ||
123 | + | let MILL6 = 100000000000000 | |
124 | + | ||
125 | + | let TEAM_SHARE = 200000 | |
126 | + | ||
127 | + | let ACTIVITY_SHARE = 100000 | |
128 | + | ||
129 | + | let PLAYER_SHARE = 400000 | |
130 | + | ||
131 | + | let YEAR_MILLIS = 31557600000 | |
132 | + | ||
133 | + | let chn = take(drop(this.bytes, 1), 1) | |
134 | + | ||
135 | + | let USDT_TVL_CORR = match chn { | |
136 | + | case _ => | |
137 | + | if ((base58'2W' == $match0)) | |
138 | + | then 1208630000 | |
139 | + | else if ((base58'2T' == $match0)) | |
140 | + | then 0 | |
141 | + | else throw("Unknown chain") | |
142 | + | } | |
143 | + | ||
144 | + | let teamAdrKey = "teamAddr" | |
145 | + | ||
146 | + | let lastTeamTimKey = "lastClaimedTime_team" | |
147 | + | ||
148 | + | let teamAmtLeftKey = "teamAmountLeft" | |
149 | + | ||
150 | + | let lastActivitiesTimKey = "lastClaimedTime_activities" | |
151 | + | ||
152 | + | let actAmtLeftKey = "activitiesAmountLeft" | |
153 | + | ||
154 | + | let stakersAmtLeftKey = "stakersAmountLeft" | |
155 | + | ||
156 | + | func keyLastClaimTimeByUser (addr) = ("lastClaimedTimeUser_" + addr) | |
157 | + | ||
158 | + | ||
159 | + | func distrByPeriod (period) = fraction(MILL6, (PLAYER_SHARE * (period + 1)), (6 * M6_)) | |
160 | + | ||
161 | + | ||
162 | + | let wlgIssueTimKey = "wlg_issueTime" | |
163 | + | ||
164 | + | let wlgIssuedAmtKey = "wlg_issuedAmount" | |
165 | + | ||
166 | + | let zbIssuedAmtKey = "zbill_issuedAmount" | |
103 | 167 | ||
104 | 168 | func keyAcresStakedAmtByUser (addr) = ("acresStakedAmountByUser_" + addr) | |
105 | 169 | ||
170 | + | ||
171 | + | let acresStakdTotalKey = "acresStakedAmountTotal" | |
172 | + | ||
173 | + | let dapp2Rest = 0 | |
174 | + | ||
175 | + | let dapp2Staking = 1 | |
176 | + | ||
177 | + | let dapp2Wlg = 2 | |
178 | + | ||
179 | + | let dapp2Puzzle = 3 | |
180 | + | ||
181 | + | let dapp2InvestFund = 4 | |
106 | 182 | ||
107 | 183 | let levels = [10, 20, 40, 80, 150, 250, 400, 700, 1000] | |
108 | 184 | ||
109 | 185 | func getLevelByAcres (acres) = { | |
110 | 186 | let acr = (acres / M8_) | |
111 | 187 | func checker (acc,item) = if ((item > acr)) | |
112 | 188 | then acc | |
113 | 189 | else (acc + 1) | |
114 | 190 | ||
115 | 191 | let idx = { | |
116 | 192 | let $l = levels | |
117 | 193 | let $s = size($l) | |
118 | 194 | let $acc0 = 0 | |
119 | 195 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
120 | 196 | then $a | |
121 | 197 | else checker($a, $l[$i]) | |
122 | 198 | ||
123 | 199 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
124 | 200 | then $a | |
125 | 201 | else throw("List size exceeds 10") | |
126 | 202 | ||
127 | 203 | $f0_2($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) | |
128 | 204 | } | |
129 | 205 | (idx + 1) | |
206 | + | } | |
207 | + | ||
208 | + | ||
209 | + | func getFarmingPowerByAcres (acres) = ((acres * 20) * (getLevelByAcres(acres) + 4)) | |
210 | + | ||
211 | + | ||
212 | + | func getFarmingPowers (userAddrStrOrEmpty,stakingContract) = { | |
213 | + | let totalAcres = valueOrElse(getInteger(stakingContract, acresStakdTotalKey), 0) | |
214 | + | let totalFP = getFarmingPowerByAcres(totalAcres) | |
215 | + | let userAcres = valueOrElse(getInteger(stakingContract, keyAcresStakedAmtByUser(userAddrStrOrEmpty)), 0) | |
216 | + | let userFP = getFarmingPowerByAcres(userAcres) | |
217 | + | [totalFP, userFP] | |
218 | + | } | |
219 | + | ||
220 | + | ||
221 | + | let idxTotalFP = 0 | |
222 | + | ||
223 | + | let idxUserFP = 1 | |
224 | + | ||
225 | + | let ixWlgAmount = 0 | |
226 | + | ||
227 | + | let ixWlgPrice = 1 | |
228 | + | ||
229 | + | let ixWlgFunds = 2 | |
230 | + | ||
231 | + | let ixWlgActivity = 3 | |
232 | + | ||
233 | + | let ixWlgArbitrage = 4 | |
234 | + | ||
235 | + | let ixWlgPool = 5 | |
236 | + | ||
237 | + | let ixWlgIssueTime = 6 | |
238 | + | ||
239 | + | let ixWlgLastTeamActTime = 7 | |
240 | + | ||
241 | + | let ixWlgTeamTotal = 8 | |
242 | + | ||
243 | + | let ixWlgTeamAmLeft = 9 | |
244 | + | ||
245 | + | let ixWlgTeamAmAvailNow = 10 | |
246 | + | ||
247 | + | let ixWlgTeamWlgold = 11 | |
248 | + | ||
249 | + | let ixWlgActTotal = 12 | |
250 | + | ||
251 | + | let ixWlgActAmLeft = 13 | |
252 | + | ||
253 | + | let ixWlgActAmAvailNow = 14 | |
254 | + | ||
255 | + | let ixWlgActWlgold = 15 | |
256 | + | ||
257 | + | let ixWlgCurPeriod = 16 | |
258 | + | ||
259 | + | let ixWlgAmLeftTotal = 17 | |
260 | + | ||
261 | + | let ixWlgCurPeriodDistribution = 18 | |
262 | + | ||
263 | + | let ixWlgLastUserTime = 19 | |
264 | + | ||
265 | + | let ixWlgInvestFundAmount = 20 | |
266 | + | ||
267 | + | let ixWlgUserAmAvailNow = 21 | |
268 | + | ||
269 | + | let ixWlgEffUserTime = 22 | |
270 | + | ||
271 | + | func getWlgStats2 (userAddrOpt,contracts,usdtId,usdtBalanceCorrection) = { | |
272 | + | let issuedAmount = valueOrErrorMessage(getInteger(contracts[dapp2Wlg], wlgIssuedAmtKey), "WLGOLD is not issued yet") | |
273 | + | let restUsd = assetBalance(contracts[dapp2Rest], usdtId) | |
274 | + | let wlgUsd = (assetBalance(contracts[dapp2Wlg], usdtId) - usdtBalanceCorrection) | |
275 | + | let puzzleUsd = assetBalance(contracts[dapp2Puzzle], usdtId) | |
276 | + | let investFndContract = contracts[dapp2InvestFund] | |
277 | + | let investFundTotal = (assetBalance(investFndContract, usdtId) + valueOrElse(getInteger(investFndContract, zbIssuedAmtKey), 0)) | |
278 | + | let totalFundsUsd = (wlgUsd + investFundTotal) | |
279 | + | let wlgId = valueOrErrorMessage(getBinary(contracts[dapp2Wlg], "wlg_assetId"), "Not initialized yet") | |
280 | + | let now = lastBlock.timestamp | |
281 | + | let issueTime = valueOrErrorMessage(getInteger(contracts[dapp2Wlg], wlgIssueTimKey), "Not initialized") | |
282 | + | let teamTotal = fraction(MILL6, TEAM_SHARE, M6_) | |
283 | + | let teamAmountLeft = valueOrElse(getInteger(contracts[dapp2Wlg], teamAmtLeftKey), teamTotal) | |
284 | + | let lastTeamTime = valueOrElse(getInteger(contracts[dapp2Wlg], lastTeamTimKey), issueTime) | |
285 | + | let teamAddr = addressFromStringValue(value(getString(contracts[dapp2Wlg], teamAdrKey))) | |
286 | + | let teamAmountAvailableNow = min([fraction(teamTotal, (now - lastTeamTime), (3 * YEAR_MILLIS)), teamAmountLeft]) | |
287 | + | let teamWlgold = assetBalance(teamAddr, wlgId) | |
288 | + | let actTotal = fraction(MILL6, ACTIVITY_SHARE, M6_) | |
289 | + | let actAmountLeft = valueOrElse(getInteger(contracts[dapp2Wlg], actAmtLeftKey), actTotal) | |
290 | + | let lastActivitiesTime = valueOrElse(getInteger(contracts[dapp2Wlg], lastActivitiesTimKey), issueTime) | |
291 | + | let actAmountAvailableNow = min([fraction(actTotal, (now - lastActivitiesTime), (3 * YEAR_MILLIS)), actAmountLeft]) | |
292 | + | let actWlgold = assetBalance(contracts[dapp2Rest], wlgId) | |
293 | + | let lastUserTime = valueOrElse(getInteger(contracts[dapp2Wlg], keyLastClaimTimeByUser(userAddrOpt)), issueTime) | |
294 | + | let lastUserPeriod = ((lastUserTime - issueTime) / YEAR_MILLIS) | |
295 | + | let nowLimited = min([now, (issueTime + (3 * YEAR_MILLIS))]) | |
296 | + | let curPeriod = min([((now - issueTime) / YEAR_MILLIS), 2]) | |
297 | + | let eff = getFarmingPowers(userAddrOpt, contracts[dapp2Staking]) | |
298 | + | let curPeriodDistribution = distrByPeriod(curPeriod) | |
299 | + | let $t079119 = if ((lastUserPeriod == curPeriod)) | |
300 | + | then { | |
301 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - lastUserTime), YEAR_MILLIS) | |
302 | + | let effTime = ((lastUserTime + nowLimited) - lastUserTime) | |
303 | + | $Tuple2(a0, effTime) | |
304 | + | } | |
305 | + | else if ((lastUserPeriod == (curPeriod - 1))) | |
306 | + | then { | |
307 | + | let a1 = fraction(distrByPeriod((curPeriod - 1)), ((issueTime + (YEAR_MILLIS * curPeriod)) - lastUserTime), YEAR_MILLIS) | |
308 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - (issueTime + (YEAR_MILLIS * curPeriod))), YEAR_MILLIS) | |
309 | + | let avail = (a1 + a0) | |
310 | + | let effTime = if ((a1 >= avail)) | |
311 | + | then (lastUserTime + fraction(YEAR_MILLIS, avail, distrByPeriod((curPeriod - 1)))) | |
312 | + | else ((issueTime + (YEAR_MILLIS * curPeriod)) + fraction(YEAR_MILLIS, (avail - a1), curPeriodDistribution)) | |
313 | + | $Tuple2(avail, effTime) | |
314 | + | } | |
315 | + | else { | |
316 | + | let a2 = fraction(distrByPeriod((curPeriod - 2)), ((issueTime + (YEAR_MILLIS * (curPeriod - 1))) - lastUserTime), YEAR_MILLIS) | |
317 | + | let a1 = distrByPeriod((curPeriod - 1)) | |
318 | + | let a0 = fraction(curPeriodDistribution, (nowLimited - (issueTime + (YEAR_MILLIS * curPeriod))), YEAR_MILLIS) | |
319 | + | let avail = ((a2 + a1) + a0) | |
320 | + | let effTime = if ((a2 >= avail)) | |
321 | + | then (lastUserTime + fraction(YEAR_MILLIS, avail, distrByPeriod((curPeriod - 2)))) | |
322 | + | else if (((a2 + a1) >= avail)) | |
323 | + | then ((issueTime + (YEAR_MILLIS * (curPeriod - 1))) + fraction(YEAR_MILLIS, (avail - a2), distrByPeriod((curPeriod - 1)))) | |
324 | + | else ((issueTime + (YEAR_MILLIS * curPeriod)) + fraction(YEAR_MILLIS, ((avail - a2) - a1), curPeriodDistribution)) | |
325 | + | $Tuple2(avail, effTime) | |
326 | + | } | |
327 | + | let userAvailable = $t079119._1 | |
328 | + | let effLastTime = $t079119._2 | |
329 | + | let amountLeftTotal = valueOrElse(getInteger(contracts[dapp2Wlg], stakersAmtLeftKey), 0) | |
330 | + | let unrobbedUser = fraction(userAvailable, eff[idxUserFP], eff[idxTotalFP]) | |
331 | + | [issuedAmount, fraction((totalFundsUsd - USDT_TVL_CORR), M8_, issuedAmount), totalFundsUsd, restUsd, wlgUsd, puzzleUsd, issueTime, lastTeamTime, teamTotal, teamAmountLeft, teamAmountAvailableNow, teamWlgold, actTotal, actAmountLeft, actAmountAvailableNow, actWlgold, curPeriod, amountLeftTotal, curPeriodDistribution, lastUserTime, investFundTotal, unrobbedUser, effLastTime] | |
130 | 332 | } | |
131 | 333 | ||
132 | 334 | ||
133 | 335 | func walletInternal (userAddressOpt) = { | |
134 | 336 | let addr = addressFromString(userAddressOpt) | |
135 | 337 | let balance = if (isDefined(addr)) | |
136 | 338 | then wavesBalance(value(addr)) | |
137 | 339 | else BalanceDetails(0, 0, 0, 0) | |
138 | 340 | let wlgoldBalance = if (isDefined(addr)) | |
139 | 341 | then assetBalance(value(addr), wlgAssetId) | |
140 | 342 | else 0 | |
141 | 343 | let customName = valueOrElse(getString(acres2Contract, keyAddressToCustomName(userAddressOpt)), userAddressOpt) | |
142 | 344 | let refByKey = keyAddressRefBy(userAddressOpt) | |
143 | 345 | let refBy = getString(acres2Contract, refByKey) | |
144 | 346 | let refs = valueOrElse(getString(acres2Contract, keyAddressReferrals(userAddressOpt)), "") | |
145 | 347 | let lastTxId = valueOrElse(getString(acres2Contract, keyLastTxIdByUser(userAddressOpt)), "") | |
146 | 348 | let acresBalance = if (isDefined(addr)) | |
147 | 349 | then assetBalance(value(addr), acresAssetId) | |
148 | 350 | else 0 | |
149 | 351 | let stakedAcres = valueOrElse(getInteger(acres2Contract, keyAcresStakedAmtByUser(userAddressOpt)), 0) | |
150 | 352 | let lvl = getLevelByAcres(acresBalance) | |
151 | 353 | [("%s%s__customName__" + customName), ("%s%s__referredBy__" + valueOrElse(refBy, "")), ("%s%s__referrals__" + refs), ("%s%s__lastTxId__" + lastTxId), ("%s%d__wavesBalance__" + toString(balance.available)), ("%s%d__wlgoldBalance__" + toString(wlgoldBalance)), ("%s%d__acresBalance__" + toString(acresBalance)), ("%s%d__stakedAcres__" + toString(stakedAcres)), ("%s%d__currentLvl__" + toString(lvl))] | |
152 | 354 | } | |
153 | 355 | ||
154 | 356 | ||
155 | 357 | @Callable(i) | |
156 | 358 | func constructorV1 (contracts) = if ((i.caller != this)) | |
157 | 359 | then throw("permissions denied") | |
158 | 360 | else { | |
159 | 361 | func descriptor (acc,ignoredItem) = (acc + "%s") | |
160 | 362 | ||
161 | 363 | let descr = { | |
162 | 364 | let $l = contracts | |
163 | 365 | let $s = size($l) | |
164 | 366 | let $acc0 = "" | |
165 | 367 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
166 | 368 | then $a | |
167 | 369 | else descriptor($a, $l[$i]) | |
168 | 370 | ||
169 | 371 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
170 | 372 | then $a | |
171 | 373 | else throw("List size exceeds 10") | |
172 | 374 | ||
173 | 375 | $f0_2($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) | |
174 | 376 | } | |
175 | 377 | [StringEntry(keyRestCfg(), makeString(descr :: contracts, SEP)), StringEntry(keyRest2Address(), toString(this))] | |
176 | 378 | } | |
177 | 379 | ||
178 | 380 | ||
179 | 381 | ||
180 | 382 | @Callable(i) | |
181 | 383 | func walletInfoREADONLY (userAddressOpt) = $Tuple2(nil, walletInternal(userAddressOpt)) | |
182 | 384 | ||
183 | 385 | ||
184 | 386 | ||
185 | 387 | @Callable(i) | |
186 | 388 | func conversionInfoREADONLY (userAddressOpt) = { | |
187 | 389 | let oldAcresAddress = addressFromStringValue(getStringValue(acres2Contract, oldAcresContractKey)) | |
188 | 390 | let $t040504172 = asTuple2Ints(invoke(oldAcresAddress, "unstakeAllAcresREADONLY", [userAddressOpt], nil)) | |
189 | 391 | let unstakedAcres = $t040504172._1 | |
190 | 392 | let claimedAcres = $t040504172._2 | |
191 | 393 | let $t041754324 = asTuple4Ints(invoke(acres2Contract, "unstakeLandsREADONLY", [userAddressOpt], nil)) | |
192 | 394 | let acresFromPieces = $t041754324._1 | |
193 | 395 | let acresFromRes = $t041754324._2 | |
194 | 396 | let acresFromMat = $t041754324._3 | |
195 | 397 | let acresFromProd = $t041754324._4 | |
196 | 398 | let oldStakingAddress = addressFromStringValue(oldStakingContractStr) | |
197 | 399 | let duckAssetId = valueOrElse(getString(oldStakingAddress, keyStakedDuckByOwner(userAddressOpt)), "") | |
198 | 400 | let $t045024724 = if ((duckAssetId != "")) | |
199 | 401 | then asTuple3Ints(invoke(oldStakingAddress, "unstakeDuckREADONLY", [duckAssetId, userAddressOpt], nil)) | |
200 | 402 | else $Tuple3(0, 0, 0) | |
201 | 403 | let acresFromDuckRes = $t045024724._1 | |
202 | 404 | let acresFromDuckMat = $t045024724._2 | |
203 | 405 | let acresFromDuckProd = $t045024724._3 | |
204 | 406 | $Tuple2(nil, [("%s%d__unstakedAcres__" + toString(unstakedAcres)), ("%s%d__claimedAcres__" + toString(claimedAcres)), ("%s%d__acresFromPieces__" + toString(acresFromPieces)), ("%s%d__acresFromRes__" + toString(acresFromRes)), ("%s%d__acresFromMat__" + toString(acresFromMat)), ("%s%d__acresFromProd__" + toString(acresFromProd)), ("%s%d__acresFromDuckRes__" + toString(acresFromDuckRes)), ("%s%d__acresFromDuckMat__" + toString(acresFromDuckMat)), ("%s%d__acresFromDuckProd__" + toString(acresFromDuckProd))]) | |
205 | 407 | } | |
206 | 408 | ||
207 | 409 | ||
410 | + | ||
411 | + | @Callable(i) | |
412 | + | func wlgStatsREADONLY (userAddrOpt) = { | |
413 | + | let curStats = getWlgStats2(userAddrOpt, [rest2Contract, acres2Contract, wlgContract, puzzlePoolContract, investFundContract], usdtAssetId, 0) | |
414 | + | $Tuple2(nil, [("%s%d__wlgAmount__" + toString(curStats[ixWlgAmount])), ("%s%d__wlgPrice__" + toString(curStats[ixWlgPrice])), ("%s%d__usdtFunds__" + toString(curStats[ixWlgFunds])), ("%s%d__usdtActivity__" + toString(curStats[ixWlgActivity])), ("%s%d__usdtArbitrage__" + toString(curStats[ixWlgArbitrage])), ("%s%d__usdtPool__" + toString(curStats[ixWlgPool])), ("%s%d__wlgIssueTime__" + toString(curStats[ixWlgIssueTime])), ("%s%d__wlgLastMarketingTeamActTime__" + toString(curStats[ixWlgLastTeamActTime])), ("%s%d__wlgTeamTotal__" + toString(curStats[ixWlgTeamTotal])), ("%s%d__wlgTeamAmLeft__" + toString(curStats[ixWlgTeamAmLeft])), ("%s%d__wlgTeamAmAvailNow__" + toString(curStats[ixWlgTeamAmAvailNow])), ("%s%d__wlgTeamWlgold__" + toString(curStats[ixWlgTeamWlgold])), ("%s%d__wlgActTotal__" + toString(curStats[ixWlgActTotal])), ("%s%d__wlgActAmLeft__" + toString(curStats[ixWlgActAmLeft])), ("%s%d__wlgActAmAvailNow__" + toString(curStats[ixWlgActAmAvailNow])), ("%s%d__wlgActWlgold__" + toString(curStats[ixWlgActWlgold])), ("%s%d__wlgCurPeriod__" + toString(curStats[ixWlgCurPeriod])), ("%s%d__wlgAmLeftTotal__" + toString(curStats[ixWlgAmLeftTotal])), ("%s%d__wlgCurPeriodDistribution__" + toString(curStats[ixWlgCurPeriodDistribution])), ("%s%d__wlgLastUserTime__" + toString(curStats[ixWlgLastUserTime])), ("%s%d__wlgInvestFundTotal__" + toString(curStats[ixWlgInvestFundAmount])), ("%s%d__wlgUserAmAvailNow__" + toString(curStats[ixWlgUserAmAvailNow])), ("%s%d__wlgEffUserTime__" + toString(curStats[ixWlgEffUserTime]))]) | |
415 | + | } | |
416 | + | ||
417 | + |
github/deemru/w8io/169f3d6 51.35 ms ◑