tx · HnEUQqHvawjULLrEGSZJV6MK1ZHHTjCp92pBGUB55RTX 3MyV4kyqTBPdJuTrj8AZwCdKtSEVR9C184D: -0.01400000 Waves 2021.04.14 10:55 [1481852] smart account 3MyV4kyqTBPdJuTrj8AZwCdKtSEVR9C184D > SELF 0.00000000 Waves
{ "type": 13, "id": "HnEUQqHvawjULLrEGSZJV6MK1ZHHTjCp92pBGUB55RTX", "fee": 1400000, "feeAssetId": null, "timestamp": 1618386964858, "version": 1, "sender": "3MyV4kyqTBPdJuTrj8AZwCdKtSEVR9C184D", "senderPublicKey": "7Cdo8ZZJERB2jJgenVaGSpdHMFLsegs4rK7AwdugaDeD", "proofs": [ "5TZ8UR8fdRBXHX6gbrvkkPq8aqh5KHHsDxTQNXvmaq7RgF965S8RvkCWWZTNUrhFQWhAGQeYXXNKcRHqLVPM47HV" ], "script": "base64:AAIEAAAAAAAAAAgIAhIECgIIAQAAABwAAAAADGFkbWluUHViS2V5MQEAAAAgugnXO4lZpNFdoP/xuzPQquE5aQ/L4r2R1jvuT16o4BMAAAAADGFkbWluUHViS2V5MgEAAAAgwpFEmbPSsLQNIqWRWL2IvKE3uwjL/92M5pTvWxYOfkAAAAAADGFkbWluUHViS2V5MwEAAAAgjh4XLnixBzv0SE56Myhgdih3/JnlkjCjIMLPqKvpDlUAAAAAEWtVc2VyUG9vbFZvdGVTV09QAgAAAAVfdm90ZQAAAAAOa1VzZXJQb29sU3RydWMCAAAAEF91c2VyX3Bvb2xfc3RydWMAAAAAEmtVc2VyVG90YWxWb3RlU1dPUAIAAAAVX3VzZXJfdG90YWxfU1dPUF92b3RlAAAAAA9rVXNlclRvdGFsU3RydWMCAAAAEV91c2VyX3RvdGFsX3N0cnVjAAAAAA1rUG9vbFZvdGVTV09QAgAAAApfdm90ZV9TV09QAAAAAAprUG9vbFN0cnVjAgAAAAtfcG9vbF9zdHJ1YwAAAAAOa1RvdGFsVm90ZVNXT1ACAAAAD3RvdGFsX3ZvdGVfU1dPUAAAAAALa1RvdGFsU3RydWMCAAAAC3RvdGFsX3N0cnVjAAAAAAxrU3RhcnRIZWlnaHQCAAAADHN0YXJ0X2hlaWdodAAAAAALa0Jhc2VQZXJpb2QCAAAAC2Jhc2VfcGVyaW9kAAAAAA1rUGVyaW9kTGVuZ3RoAgAAAA1wZXJpb2RfbGVuZ3RoAAAAABZrRHVyYXRpb25GdWxsVm90ZVBvd2VyAgAAABhkdXJhdGlvbl9mdWxsX3ZvdGVfcG93ZXIAAAAADWtNaW5Wb3RlUG93ZXICAAAADm1pbl92b3RlX3Bvd2VyAAAAAAZzY2FsZTgAAAAAAAX14QAAAAAACmJhc2VQZXJpb2QJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABBoAAAACBQAAAAR0aGlzBQAAAAtrQmFzZVBlcmlvZAIAAAARRW1wdHkga0Jhc2VQZXJpb2QAAAAAC3N0YXJ0SGVpZ2h0CQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwUAAAAMa1N0YXJ0SGVpZ2h0AgAAABJFbXB0eSBrU3RhcnRIZWlnaHQAAAAADHBlcmlvZExlbmd0aAkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAADWtQZXJpb2RMZW5ndGgCAAAAE0VtcHR5IGtQZXJpb2RMZW5ndGgAAAAAFWR1cmF0aW9uRnVsbFZvdGVQb3dlcgkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAAFmtEdXJhdGlvbkZ1bGxWb3RlUG93ZXICAAAAHEVtcHR5IGtEdXJhdGlvbkZ1bGxWb3RlUG93ZXIAAAAADG1pblZvdGVQb3dlcgkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAADWtNaW5Wb3RlUG93ZXICAAAAE0VtcHR5IGtNaW5Wb3RlUG93ZXIAAAAAB2dvdkFkZHIJAQAAAAdBZGRyZXNzAAAAAQEAAAAaAVTN4HqQ2q/Cl0VFAz7iKwK3sh5Y0DNKbswAAAAACmN1cnJQZXJpb2QJAABkAAAAAgUAAAAKYmFzZVBlcmlvZAkAAGkAAAACCQAAZQAAAAIFAAAABmhlaWdodAUAAAALc3RhcnRIZWlnaHQFAAAADHBlcmlvZExlbmd0aAEAAAAUaXNDYWxsZXJJbkdvdmVybmFuY2UAAAABAAAABHVzZXIDCQAAZgAAAAIJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAHZ292QWRkcgkAASwAAAACCQAEJQAAAAEFAAAABHVzZXICAAAADF9TV09QX2Ftb3VudAAAAAAAAAAAAAAAAAAAAAAAAAYHAQAAABJpc1Bvb2xJbkdvdmVybmFuY2UAAAABAAAAC3Bvb2xBZGRyZXNzCQEAAAAJaXNEZWZpbmVkAAAAAQkABBoAAAACBQAAAAdnb3ZBZGRyCQABLAAAAAIFAAAAC3Bvb2xBZGRyZXNzAgAAAB1fY3VycmVudF9wb29sX2ZyYWN0aW9uX3Jld2FyZAEAAAAKdm90aW5nQ29lZgAAAAAEAAAADnZvdGluZ0R1cmF0aW9uCQAAZQAAAAIFAAAABmhlaWdodAkAAGQAAAACBQAAAAtzdGFydEhlaWdodAkAAGgAAAACBQAAAApjdXJyUGVyaW9kBQAAAAxwZXJpb2RMZW5ndGgDCQAAZgAAAAIFAAAAFWR1cmF0aW9uRnVsbFZvdGVQb3dlcgUAAAAOdm90aW5nRHVyYXRpb24FAAAABnNjYWxlOAQAAAACeDEFAAAAFWR1cmF0aW9uRnVsbFZvdGVQb3dlcgQAAAACeTEFAAAABnNjYWxlOAQAAAACeDIFAAAADHBlcmlvZExlbmd0aAQAAAACeTIFAAAADG1pblZvdGVQb3dlcgQAAAABawkAAGkAAAACCQAAaAAAAAIJAABlAAAAAgUAAAACeTIFAAAAAnkxBQAAAAZzY2FsZTgJAABlAAAAAgUAAAACeDIFAAAAAngxBAAAAAFiCQAAZQAAAAIJAABoAAAAAgUAAAACeTEFAAAABnNjYWxlOAkAAGgAAAACBQAAAAFrBQAAAAJ4MQkAAGQAAAACCQAAaQAAAAIJAABoAAAAAgUAAAAOdm90aW5nRHVyYXRpb24FAAAAAWsFAAAABnNjYWxlOAkAAGkAAAACBQAAAAFiBQAAAAZzY2FsZTgBAAAAD2NhbGNEZWxldGVFbnRyeQAAAAMAAAAGY2FsbGVyAAAAC3Bvb2xBZGRyZXNzAAAAE3VzZXJQb29sVm90ZVNXT1BuZXcEAAAAGWRlbGV0ZUtleVVzZXJQb29sVm90ZVNXT1ADCQEAAAAJaXNEZWZpbmVkAAAAAQkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAAZjYWxsZXICAAAAAV8FAAAAC3Bvb2xBZGRyZXNzBQAAABFrVXNlclBvb2xWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACCQABLAAAAAIJAAEsAAAAAgUAAAAGY2FsbGVyAgAAAAFfBQAAAAtwb29sQWRkcmVzcwUAAAARa1VzZXJQb29sVm90ZVNXT1AJAQAAAAtEZWxldGVFbnRyeQAAAAECAAAAAS4EAAAAGmRlbGV0ZUtleVVzZXJUb3RhbFZvdGVTV09QAwkBAAAACWlzRGVmaW5lZAAAAAEJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAAZjYWxsZXIFAAAAEmtVc2VyVG90YWxWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACBQAAAAZjYWxsZXIFAAAAEmtVc2VyVG90YWxWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQIAAAABLgQAAAAVZGVsZXRlS2V5UG9vbFZvdGVTV09QAwkBAAAACWlzRGVmaW5lZAAAAAEJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAAtwb29sQWRkcmVzcwUAAAANa1Bvb2xWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQkAASwAAAACBQAAAAtwb29sQWRkcmVzcwUAAAANa1Bvb2xWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQIAAAABLgQAAAAWZGVsZXRlS2V5VG90YWxWb3RlU1dPUAMJAQAAAAlpc0RlZmluZWQAAAABCQAEGgAAAAIFAAAABHRoaXMFAAAADmtUb3RhbFZvdGVTV09QCQEAAAALRGVsZXRlRW50cnkAAAABBQAAAA5rVG90YWxWb3RlU1dPUAkBAAAAC0RlbGV0ZUVudHJ5AAAAAQIAAAABLgkABEwAAAACBQAAABlkZWxldGVLZXlVc2VyUG9vbFZvdGVTV09QCQAETAAAAAIFAAAAGmRlbGV0ZUtleVVzZXJUb3RhbFZvdGVTV09QCQAETAAAAAIFAAAAFWRlbGV0ZUtleVBvb2xWb3RlU1dPUAkABEwAAAACBQAAABZkZWxldGVLZXlUb3RhbFZvdGVTV09QBQAAAANuaWwAAAABAAAAAWkBAAAADnZvdGVQb29sV2VpZ2h0AAAAAgAAAAtwb29sQWRkcmVzcwAAABN1c2VyUG9vbFZvdGVTV09QbmV3AwYJAAACAAAAAQkAASwAAAACAgAAAA13ZSBhcmUgaGVyZSAgCQABpAAAAAEFAAAADG1pblZvdGVQb3dlcgQAAAAUdXNlclNXT1BpbkdvdmVybmFuY2UJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABBoAAAACBQAAAAdnb3ZBZGRyCQABLAAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyAgAAAAxfU1dPUF9hbW91bnQCAAAAIkVtcHR5IF9TV09QX2Ftb3VudCBhdCBnb3YuIGFkZHJlc3MEAAAACyR0MDQxNjI0ODA0AwkBAAAACWlzRGVmaW5lZAAAAAEJAAQdAAAAAgUAAAAEdGhpcwkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXICAAAAAV8FAAAAC3Bvb2xBZGRyZXNzBQAAAA5rVXNlclBvb2xTdHJ1YwQAAAAEZGF0YQkABLUAAAACCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQdAAAAAgUAAAAEdGhpcwkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXICAAAAAV8FAAAAC3Bvb2xBZGRyZXNzBQAAAA5rVXNlclBvb2xTdHJ1YwIAAAAURW1wdHkga1VzZXJQb29sU3RydWMCAAAAAV8JAAUWAAAABAkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAAJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAARkYXRhAAAAAAAAAAABCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAAEZGF0YQAAAAAAAAAAAgkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAMEAAAADXVQb29sVm90ZVNXT1AJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXICAAAAAV8FAAAAC3Bvb2xBZGRyZXNzBQAAABFrVXNlclBvb2xWb3RlU1dPUAAAAAAAAAAAAAkABRYAAAAEBQAAAA11UG9vbFZvdGVTV09QBQAAAA11UG9vbFZvdGVTV09QBQAAAApjdXJyUGVyaW9kAAAAAAAAAAAABAAAABB1c2VyUG9vbFZvdGVTV09QCAUAAAALJHQwNDE2MjQ4MDQAAAACXzEEAAAAFnVzZXJQb29sQWN0aXZlVm90ZVNXT1AIBQAAAAskdDA0MTYyNDgwNAAAAAJfMgQAAAASdXNlclBvb2xWb3RlUGVyaW9kCAUAAAALJHQwNDE2MjQ4MDQAAAACXzMEAAAAEnVzZXJQb29sRnJlZXplU1dPUAgFAAAACyR0MDQxNjI0ODA0AAAAAl80BAAAAAskdDA0ODEwNTMyNwMJAQAAAAlpc0RlZmluZWQAAAABCQAEHQAAAAIFAAAABHRoaXMJAAEsAAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAAD2tVc2VyVG90YWxTdHJ1YwQAAAAEZGF0YQkABLUAAAACCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAQdAAAAAgUAAAAEdGhpcwkAASwAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAPa1VzZXJUb3RhbFN0cnVjAgAAABVFbXB0eSBrVXNlclRvdGFsU3RydWMCAAAAAV8JAAUVAAAAAwkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAAJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAARkYXRhAAAAAAAAAAABCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAAEZGF0YQAAAAAAAAAAAgQAAAAOdVBvb2xUb3RhbFNXT1AJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAASa1VzZXJUb3RhbFZvdGVTV09QAAAAAAAAAAAACQAFFQAAAAMFAAAADnVQb29sVG90YWxTV09QAAAAAAAAAAAABQAAAApjdXJyUGVyaW9kBAAAABF1c2VyVG90YWxWb3RlU1dPUAgFAAAACyR0MDQ4MTA1MzI3AAAAAl8xBAAAAAt1c2VyVW52b3RlZAgFAAAACyR0MDQ4MTA1MzI3AAAAAl8yBAAAABF1c2VyVW52b3RlZFBlcmlvZAgFAAAACyR0MDQ4MTA1MzI3AAAAAl8zBAAAAAskdDA1MzMyNTgzOQMJAQAAAAlpc0RlZmluZWQAAAABCQAEHQAAAAIFAAAABHRoaXMJAAEsAAAAAgUAAAALcG9vbEFkZHJlc3MFAAAACmtQb29sU3RydWMEAAAABGRhdGEJAAS1AAAAAgkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEHQAAAAIFAAAABHRoaXMJAAEsAAAAAgUAAAALcG9vbEFkZHJlc3MFAAAACmtQb29sU3RydWMCAAAAEEVtcHR5IGtQb29sU3RydWMCAAAAAV8JAAUWAAAABAkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAAJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAARkYXRhAAAAAAAAAAABCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAAEZGF0YQAAAAAAAAAAAgkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAMEAAAADXVQb29sVm90ZVNXT1AJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAAtwb29sQWRkcmVzcwUAAAANa1Bvb2xWb3RlU1dPUAAAAAAAAAAAAAkABRYAAAAEBQAAAA11UG9vbFZvdGVTV09QBQAAAA11UG9vbFZvdGVTV09QAAAAAAAAAAAAAAAAAAAAAAAABAAAAAxwb29sVm90ZVNXT1AIBQAAAAskdDA1MzMyNTgzOQAAAAJfMQQAAAAOcG9vbEFjdGl2ZVNXT1AIBQAAAAskdDA1MzMyNTgzOQAAAAJfMgQAAAAKcG9vbFBlcmlvZAgFAAAACyR0MDUzMzI1ODM5AAAAAl8zBAAAAA5wb29sRnJlZXplU1dPUAgFAAAACyR0MDUzMzI1ODM5AAAAAl80BAAAAAskdDA1ODQ1NjMyMQMJAQAAAAlpc0RlZmluZWQAAAABCQAEHQAAAAIFAAAABHRoaXMFAAAAC2tUb3RhbFN0cnVjBAAAAARkYXRhCQAEtQAAAAIJAQAAABN2YWx1ZU9yRXJyb3JNZXNzYWdlAAAAAgkABB0AAAACBQAAAAR0aGlzBQAAAAtrVG90YWxTdHJ1YwIAAAARRW1wdHkga1RvdGFsU3RydWMCAAAAAV8JAAUWAAAABAkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAAJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAARkYXRhAAAAAAAAAAABCQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAAEZGF0YQAAAAAAAAAAAgkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAABGRhdGEAAAAAAAAAAAMEAAAADnVUb3RhbFZvdGVTV09QCQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAADmtUb3RhbFZvdGVTV09QAAAAAAAAAAAACQAFFgAAAAQFAAAADnVUb3RhbFZvdGVTV09QBQAAAA51VG90YWxWb3RlU1dPUAAAAAAAAAAAAAAAAAAAAAAAAAQAAAANdG90YWxWb3RlU1dPUAgFAAAACyR0MDU4NDU2MzIxAAAAAl8xBAAAAA90b3RhbEFjdGl2ZVNXT1AIBQAAAAskdDA1ODQ1NjMyMQAAAAJfMgQAAAALdG90YWxQZXJpb2QIBQAAAAskdDA1ODQ1NjMyMQAAAAJfMwQAAAAPdG90YWxGcmVlemVTV09QCAUAAAALJHQwNTg0NTYzMjEAAAACXzQEAAAAEHBvb2xWb3RlRGlmZlNXT1AJAABlAAAAAgUAAAATdXNlclBvb2xWb3RlU1dPUG5ldwUAAAAQdXNlclBvb2xWb3RlU1dPUAQAAAAUdXNlclRvdGFsVm90ZVNXT1BuZXcJAABkAAAAAgUAAAARdXNlclRvdGFsVm90ZVNXT1AFAAAAEHBvb2xWb3RlRGlmZlNXT1ADCQEAAAABIQAAAAEJAQAAABRpc0NhbGxlckluR292ZXJuYW5jZQAAAAEIBQAAAAFpAAAABmNhbGxlcgkAAAIAAAABAgAAACpUaGlzIGFkZHJlc3MgaGFzIDAgU1dPUCBpbiBHb3Zlcm5hbmNlIGRBcHADCQAAZgAAAAIFAAAAFHVzZXJUb3RhbFZvdGVTV09QbmV3BQAAABR1c2VyU1dPUGluR292ZXJuYW5jZQkAAAIAAAABCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAQlAAAAAQUAAAAEdGhpcwIAAAAFIGhhcyAJAAGkAAAAAQUAAAAUdXNlclNXT1BpbkdvdmVybmFuY2UCAAAAKCBTV09QIGluIGdvdmVybmFuY2UuIE5ldyBTV09QIGluIHZvdGluZyAJAAGkAAAAAQUAAAAUdXNlclRvdGFsVm90ZVNXT1BuZXcDCQAAZgAAAAIAAAAAAAAAAAAFAAAAFHVzZXJUb3RhbFZvdGVTV09QbmV3CQAAAgAAAAECAAAAG05ldyB1c2VyUG9vbFZvdGVTV09QbmV3IDwgMAMJAABnAAAAAgUAAAATdXNlclBvb2xWb3RlU1dPUG5ldwUAAAAQdXNlclBvb2xWb3RlU1dPUAQAAAAEY29lZgkBAAAACnZvdGluZ0NvZWYAAAAABAAAABl1c2VyUG9vbEFjdGl2ZVZvdGVTV09QbmV3AwkAAAAAAAACBQAAABJ1c2VyUG9vbFZvdGVQZXJpb2QFAAAACmN1cnJQZXJpb2QJAABkAAAAAgUAAAAWdXNlclBvb2xBY3RpdmVWb3RlU1dPUAkAAGkAAAACCQAAaAAAAAIFAAAAEHBvb2xWb3RlRGlmZlNXT1AFAAAABGNvZWYFAAAABnNjYWxlOAkAAGQAAAACBQAAABB1c2VyUG9vbFZvdGVTV09QCQAAaQAAAAIJAABoAAAAAgUAAAAQcG9vbFZvdGVEaWZmU1dPUAUAAAAEY29lZgUAAAAGc2NhbGU4BAAAABV1c2VyUG9vbEZyZWV6ZVNXT1BuZXcDCQAAAAAAAAIFAAAAEnVzZXJQb29sVm90ZVBlcmlvZAUAAAAKY3VyclBlcmlvZAUAAAASdXNlclBvb2xGcmVlemVTV09QBQAAABB1c2VyUG9vbFZvdGVTV09QBAAAAA51c2VyVW52b3RlZE5ldwMJAAAAAAAAAgUAAAALdXNlclVudm90ZWQFAAAACmN1cnJQZXJpb2QFAAAAC3VzZXJVbnZvdGVkCQABlgAAAAEJAARMAAAAAgAAAAAAAAAAAAkABEwAAAACCQAAZQAAAAIFAAAAC3VzZXJVbnZvdGVkBQAAABBwb29sVm90ZURpZmZTV09QBQAAAANuaWwEAAAAEHVzZXJQb29sU3RydWNOZXcJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAGkAAAAAQUAAAATdXNlclBvb2xWb3RlU1dPUG5ldwIAAAABXwkAAaQAAAABBQAAABl1c2VyUG9vbEFjdGl2ZVZvdGVTV09QbmV3AgAAAAFfCQABpAAAAAEFAAAACmN1cnJQZXJpb2QCAAAAAV8JAAGkAAAAAQUAAAAVdXNlclBvb2xGcmVlemVTV09QbmV3BAAAAA11c2VyUG9vbEVudHJ5CQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIJ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TgAAAAIFAAAADXVzZXJQb29sRW50cnkFAAAADnVzZXJUb3RhbEVudHJ5BQAAAAlwb29sRW50cnkFAAAACnRvdGFsRW50cnkJAQAAAA9jYWxjRGVsZXRlRW50cnkAAAADCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAALcG9vbEFkZHJlc3MFAAAAE3VzZXJQb29sVm90ZVNXT1BuZXcEAAAADnJlbW92ZVBvb2xWb3RlCQEAAAABLQAAAAEFAAAAEHBvb2xWb3RlRGlmZlNXT1AEAAAAFXVzZXJQb29sRnJlZXplU1dPUG5ldwMJAAAAAAAAAgUAAAASdXNlclBvb2xWb3RlUGVyaW9kBQAAAApjdXJyUGVyaW9kCQABlwAAAAEJAARMAAAAAgUAAAASdXNlclBvb2xGcmVlemVTV09QCQAETAAAAAIFAAAAE3VzZXJQb29sVm90ZVNXT1BuZXcFAAAAA25pbAUAAAATdXNlclBvb2xWb3RlU1dPUG5ldwQAAAAZdXNlclBvb2xBY3RpdmVWb3RlU1dPUG5ldwMJAAAAAAAAAgkAAGUAAAACBQAAABB1c2VyUG9vbFZvdGVTV09QBQAAABJ1c2VyUG9vbEZyZWV6ZVNXT1AAAAAAAAAAAAAAAAAAAAAAAAAJAABkAAAAAgUAAAAVdXNlclBvb2xGcmVlemVTV09QbmV3CQAAaQAAAAIJAABoAAAAAgkAAGUAAAACBQAAABZ1c2VyUG9vbEFjdGl2ZVZvdGVTV09QBQAAABJ1c2VyUG9vbEZyZWV6ZVNXT1AJAABlAAAAAgUAAAATdXNlclBvb2xWb3RlU1dPUG5ldwUAAAAVdXNlclBvb2xGcmVlemVTV09QbmV3CQAAZQAAAAIFAAAAEHVzZXJQb29sVm90ZVNXT1AFAAAAEnVzZXJQb29sRnJlZXplU1dPUAQAAAAKbmV3VW52b3RlZAkAAZYAAAABCQAETAAAAAIAAAAAAAAAAAAJAARMAAAAAgkAAGUAAAACBQAAAA5yZW1vdmVQb29sVm90ZQMJAAAAAAAAAgUAAAARdXNlclVudm90ZWRQZXJpb2QFAAAACmN1cnJQZXJpb2QJAABlAAAAAgUAAAAQdXNlclBvb2xWb3RlU1dPUAUAAAASdXNlclBvb2xGcmVlemVTV09QAAAAAAAAAAAABQAAAANuaWwEAAAADnVzZXJVbnZvdGVkTmV3AwkAAAAAAAACBQAAABF1c2VyVW52b3RlZFBlcmlvZAUAAAAKY3VyclBlcmlvZAUAAAALdXNlclVudm90ZWQJAABkAAAAAgAAAAAAAAAAAAUAAAAKbmV3VW52b3RlZAQAAAAUdXNlclVudm90ZWRQZXJpb2ROZXcDCQAAZgAAAAIFAAAACm5ld1Vudm90ZWQAAAAAAAAAAAAFAAAACmN1cnJQZXJpb2QFAAAAEXVzZXJVbnZvdGVkUGVyaW9kBAAAABB1c2VyUG9vbFN0cnVjTmV3CQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABpAAAAAEFAAAAE3VzZXJQb29sVm90ZVNXT1BuZXcCAAAAAV8JAAGkAAAAAQUAAAAZdXNlclBvb2xBY3RpdmVWb3RlU1dPUG5ldwIAAAABXwkAAaQAAAABBQAAAApjdXJyUGVyaW9kAgAAAAFfCQABpAAAAAEFAAAAFXVzZXJQb29sRnJlZXplU1dPUG5ldwQAAAANdXNlclBvb2xFbnRyeQkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgIAAAABXwUAAAALcG9vbEFkZHJlc3MFAAAADmtVc2VyUG9vbFN0cnVjBQAAABB1c2VyUG9vbFN0cnVjTmV3BQAAAANuaWwEAAAAEXVzZXJUb3RhbFN0cnVjTmV3CQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAGkAAAAAQUAAAAUdXNlclRvdGFsVm90ZVNXT1BuZXcCAAAAAV8JAAGkAAAAAQUAAAAOdXNlclVudm90ZWROZXcCAAAAAV8JAAGkAAAAAQUAAAAKY3VyclBlcmlvZAQAAAAOdXNlclRvdGFsRW50cnkJAARMAAAAAgkBAAAAC1N0cmluZ0VudHJ5AAAAAgkAASwAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAPa1VzZXJUb3RhbFN0cnVjBQAAABF1c2VyVG90YWxTdHJ1Y05ldwUAAAADbmlsBAAAAA9wb29sVm90ZVNXT1BuZXcJAABlAAAAAgUAAAAMcG9vbFZvdGVTV09QBQAAAA5yZW1vdmVQb29sVm90ZQQAAAARcG9vbEZyZWV6ZVNXT1BuZXcDCQAAAAAAAAIFAAAACnBvb2xQZXJpb2QFAAAACmN1cnJQZXJpb2QJAAGXAAAAAQkABEwAAAACBQAAAA5wb29sRnJlZXplU1dPUAkABEwAAAACBQAAAA9wb29sVm90ZVNXT1BuZXcFAAAAA25pbAUAAAAPcG9vbFZvdGVTV09QbmV3BAAAABFwb29sQWN0aXZlU1dPUG5ldwMJAAAAAAAAAgkAAGUAAAACBQAAAAxwb29sVm90ZVNXT1AFAAAADnBvb2xGcmVlemVTV09QAAAAAAAAAAAAAAAAAAAAAAAACQAAZAAAAAIFAAAAEXBvb2xGcmVlemVTV09QbmV3CQAAaQAAAAIJAABoAAAAAgkAAGUAAAACBQAAAA5wb29sQWN0aXZlU1dPUAUAAAAOcG9vbEZyZWV6ZVNXT1AJAABlAAAAAgUAAAAPcG9vbFZvdGVTV09QbmV3BQAAABFwb29sRnJlZXplU1dPUG5ldwkAAGUAAAACBQAAAAxwb29sVm90ZVNXT1AFAAAADnBvb2xGcmVlemVTV09QBAAAAAxwb29sU3RydWNOZXcJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAGkAAAAAQUAAAAPcG9vbFZvdGVTV09QbmV3AgAAAAFfCQABpAAAAAEFAAAAEXBvb2xBY3RpdmVTV09QbmV3AgAAAAFfCQABpAAAAAEFAAAACmN1cnJQZXJpb2QCAAAAAV8JAAGkAAAAAQUAAAARcG9vbEZyZWV6ZVNXT1BuZXcEAAAACXBvb2xFbnRyeQkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQABLAAAAAIFAAAAC3Bvb2xBZGRyZXNzBQAAAAprUG9vbFN0cnVjBQAAAAxwb29sU3RydWNOZXcFAAAAA25pbAQAAAAQdG90YWxWb3RlU1dPUG5ldwkAAGUAAAACBQAAAA10b3RhbFZvdGVTV09QBQAAAA5yZW1vdmVQb29sVm90ZQQAAAASdG90YWxGcmVlemVTV09QbmV3AwkAAAAAAAACBQAAAAt0b3RhbFBlcmlvZAUAAAAKY3VyclBlcmlvZAkAAZcAAAABCQAETAAAAAIFAAAAD3RvdGFsRnJlZXplU1dPUAkABEwAAAACBQAAABB0b3RhbFZvdGVTV09QbmV3BQAAAANuaWwFAAAAEHRvdGFsVm90ZVNXT1BuZXcEAAAAEnRvdGFsQWN0aXZlU1dPUG5ldwMJAAAAAAAAAgkAAGUAAAACBQAAAA10b3RhbFZvdGVTV09QBQAAAA90b3RhbEZyZWV6ZVNXT1AAAAAAAAAAAAAAAAAAAAAAAAAJAABkAAAAAgUAAAASdG90YWxGcmVlemVTV09QbmV3CQAAaQAAAAIJAABoAAAAAgkAAGUAAAACBQAAAA90b3RhbEFjdGl2ZVNXT1AFAAAAD3RvdGFsRnJlZXplU1dPUAkAAGUAAAACBQAAABB0b3RhbFZvdGVTV09QbmV3BQAAABJ0b3RhbEZyZWV6ZVNXT1BuZXcJAABlAAAAAgUAAAANdG90YWxWb3RlU1dPUAUAAAAPdG90YWxGcmVlemVTV09QBAAAAA10b3RhbFN0cnVjTmV3CQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABpAAAAAEFAAAAEHRvdGFsVm90ZVNXT1BuZXcCAAAAAV8JAAGkAAAAAQUAAAASdG90YWxBY3RpdmVTV09QbmV3AgAAAAFfCQABpAAAAAEFAAAAC3RvdGFsUGVyaW9kAgAAAAFfCQABpAAAAAEFAAAAEnRvdGFsRnJlZXplU1dPUG5ldwQAAAAKdG90YWxFbnRyeQkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACBQAAAAtrVG90YWxTdHJ1YwUAAAANdG90YWxTdHJ1Y05ldwUAAAADbmlsCQAETgAAAAIJAAROAAAAAgkABE4AAAACCQAETgAAAAIFAAAADXVzZXJQb29sRW50cnkFAAAADnVzZXJUb3RhbEVudHJ5BQAAAAlwb29sRW50cnkFAAAACnRvdGFsRW50cnkJAQAAAA9jYWxjRGVsZXRlRW50cnkAAAADCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAALcG9vbEFkZHJlc3MFAAAAE3VzZXJQb29sVm90ZVNXT1BuZXcAAAAAXP9Khg==", "chainId": 84, "height": 1481852, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AbnKoXwGY7B3mDGHwjNQSp7NAcjUGFjAwB7fNxxk8z6B Next: none Diff:
Old | New | Differences | |
---|---|---|---|
91 | 91 | ||
92 | 92 | ||
93 | 93 | @Callable(i) | |
94 | - | func votePoolWeight (poolAddress,userPoolVoteSWOPnew) = { | |
95 | - | let userSWOPinGovernance = valueOrErrorMessage(getInteger(govAddr, (toString(i.caller) + "_SWOP_amount")), "Empty _SWOP_amount at gov. address") | |
96 | - | let $t040924734 = if (isDefined(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)))) | |
97 | - | then { | |
98 | - | let data = split(valueOrErrorMessage(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)), "Empty kUserPoolStruc"), "_") | |
99 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
100 | - | } | |
101 | - | else { | |
102 | - | let uPoolVoteSWOP = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolVoteSWOP)), 0) | |
103 | - | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, currPeriod, 0) | |
104 | - | } | |
105 | - | let userPoolVoteSWOP = $t040924734._1 | |
106 | - | let userPoolActiveVoteSWOP = $t040924734._2 | |
107 | - | let userPoolVotePeriod = $t040924734._3 | |
108 | - | let userPoolFreezeSWOP = $t040924734._4 | |
109 | - | let $t047405257 = if (isDefined(getString(this, (toString(i.caller) + kUserTotalStruc)))) | |
110 | - | then { | |
111 | - | let data = split(valueOrErrorMessage(getString(this, (toString(i.caller) + kUserTotalStruc)), "Empty kUserTotalStruc"), "_") | |
112 | - | $Tuple3(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2])) | |
113 | - | } | |
114 | - | else { | |
115 | - | let uPoolTotalSWOP = valueOrElse(getInteger(this, (toString(i.caller) + kUserTotalVoteSWOP)), 0) | |
116 | - | $Tuple3(uPoolTotalSWOP, 0, currPeriod) | |
117 | - | } | |
118 | - | let userTotalVoteSWOP = $t047405257._1 | |
119 | - | let userUnvoted = $t047405257._2 | |
120 | - | let userUnvotedPeriod = $t047405257._3 | |
121 | - | let $t052625769 = if (isDefined(getString(this, (poolAddress + kPoolStruc)))) | |
122 | - | then { | |
123 | - | let data = split(valueOrErrorMessage(getString(this, (poolAddress + kPoolStruc)), "Empty kPoolStruc"), "_") | |
124 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
125 | - | } | |
126 | - | else { | |
127 | - | let uPoolVoteSWOP = valueOrElse(getInteger(this, (poolAddress + kPoolVoteSWOP)), 0) | |
128 | - | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, 0, 0) | |
129 | - | } | |
130 | - | let poolVoteSWOP = $t052625769._1 | |
131 | - | let poolActiveSWOP = $t052625769._2 | |
132 | - | let poolPeriod = $t052625769._3 | |
133 | - | let poolFreezeSWOP = $t052625769._4 | |
134 | - | let $t057756251 = if (isDefined(getString(this, kTotalStruc))) | |
135 | - | then { | |
136 | - | let data = split(valueOrErrorMessage(getString(this, kTotalStruc), "Empty kTotalStruc"), "_") | |
137 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
138 | - | } | |
139 | - | else { | |
140 | - | let uTotalVoteSWOP = valueOrElse(getInteger(this, kTotalVoteSWOP), 0) | |
141 | - | $Tuple4(uTotalVoteSWOP, uTotalVoteSWOP, 0, 0) | |
142 | - | } | |
143 | - | let totalVoteSWOP = $t057756251._1 | |
144 | - | let totalActiveSWOP = $t057756251._2 | |
145 | - | let totalPeriod = $t057756251._3 | |
146 | - | let totalFreezeSWOP = $t057756251._4 | |
147 | - | let poolVoteDiffSWOP = (userPoolVoteSWOPnew - userPoolVoteSWOP) | |
148 | - | let userTotalVoteSWOPnew = (userTotalVoteSWOP + poolVoteDiffSWOP) | |
149 | - | if (!(isCallerInGovernance(i.caller))) | |
150 | - | then throw("This address has 0 SWOP in Governance dApp") | |
151 | - | else if ((userTotalVoteSWOPnew > userSWOPinGovernance)) | |
152 | - | then throw(((((toString(this) + " has ") + toString(userSWOPinGovernance)) + " SWOP in governance. New SWOP in voting ") + toString(userTotalVoteSWOPnew))) | |
153 | - | else if ((0 > userTotalVoteSWOPnew)) | |
154 | - | then throw("New userPoolVoteSWOPnew < 0") | |
155 | - | else if ((userPoolVoteSWOPnew >= userPoolVoteSWOP)) | |
156 | - | then { | |
157 | - | let coef = votingCoef() | |
158 | - | let userPoolActiveVoteSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
159 | - | then (userPoolActiveVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
160 | - | else (userPoolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
161 | - | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
162 | - | then userPoolFreezeSWOP | |
163 | - | else userPoolVoteSWOP | |
164 | - | let userUnvotedNew = if ((userUnvoted == currPeriod)) | |
165 | - | then userUnvoted | |
166 | - | else max([0, (userUnvoted - poolVoteDiffSWOP)]) | |
167 | - | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
168 | - | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
169 | - | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
170 | - | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
171 | - | let poolVoteSWOPnew = (poolVoteSWOP + poolVoteDiffSWOP) | |
172 | - | let poolActiveSWOPnew = if ((poolPeriod == currPeriod)) | |
173 | - | then (poolActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
174 | - | else (poolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
175 | - | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
176 | - | then poolFreezeSWOP | |
177 | - | else poolVoteSWOP | |
178 | - | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
179 | - | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
180 | - | let totalVoteSWOPnew = (totalVoteSWOP + poolVoteDiffSWOP) | |
181 | - | let totalActiveSWOPnew = if ((totalPeriod == currPeriod)) | |
182 | - | then (totalActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
183 | - | else (totalVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
184 | - | let totalFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
185 | - | then totalFreezeSWOP | |
186 | - | else totalVoteSWOP | |
187 | - | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
188 | - | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
189 | - | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
190 | - | } | |
191 | - | else { | |
192 | - | let removePoolVote = -(poolVoteDiffSWOP) | |
193 | - | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
194 | - | then min([userPoolFreezeSWOP, userPoolVoteSWOPnew]) | |
195 | - | else userPoolVoteSWOPnew | |
196 | - | let userPoolActiveVoteSWOPnew = if (((userPoolVoteSWOP - userPoolFreezeSWOP) == 0)) | |
197 | - | then 0 | |
198 | - | else (userPoolFreezeSWOPnew + (((userPoolActiveVoteSWOP - userPoolFreezeSWOP) * (userPoolVoteSWOPnew - userPoolFreezeSWOPnew)) / (userPoolVoteSWOP - userPoolFreezeSWOP))) | |
199 | - | let newUnvoted = max([0, (removePoolVote - (if ((userUnvotedPeriod == currPeriod)) | |
200 | - | then (userPoolVoteSWOP - userPoolFreezeSWOP) | |
201 | - | else 0))]) | |
202 | - | let userUnvotedNew = if ((userUnvotedPeriod == currPeriod)) | |
203 | - | then userUnvoted | |
204 | - | else (0 + newUnvoted) | |
205 | - | let userUnvotedPeriodNew = if ((newUnvoted > 0)) | |
206 | - | then currPeriod | |
207 | - | else userUnvotedPeriod | |
208 | - | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
209 | - | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
210 | - | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
211 | - | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
212 | - | let poolVoteSWOPnew = (poolVoteSWOP - removePoolVote) | |
213 | - | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
214 | - | then min([poolFreezeSWOP, poolVoteSWOPnew]) | |
215 | - | else poolVoteSWOPnew | |
216 | - | let poolActiveSWOPnew = if (((poolVoteSWOP - poolFreezeSWOP) == 0)) | |
217 | - | then 0 | |
218 | - | else (poolFreezeSWOPnew + (((poolActiveSWOP - poolFreezeSWOP) * (poolVoteSWOPnew - poolFreezeSWOPnew)) / (poolVoteSWOP - poolFreezeSWOP))) | |
219 | - | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
220 | - | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
221 | - | let totalVoteSWOPnew = (totalVoteSWOP - removePoolVote) | |
222 | - | let totalFreezeSWOPnew = if ((totalPeriod == currPeriod)) | |
223 | - | then min([totalFreezeSWOP, totalVoteSWOPnew]) | |
224 | - | else totalVoteSWOPnew | |
225 | - | let totalActiveSWOPnew = if (((totalVoteSWOP - totalFreezeSWOP) == 0)) | |
226 | - | then 0 | |
227 | - | else (totalFreezeSWOPnew + (((totalActiveSWOP - totalFreezeSWOP) * (totalVoteSWOPnew - totalFreezeSWOPnew)) / (totalVoteSWOP - totalFreezeSWOP))) | |
228 | - | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
229 | - | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
230 | - | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
231 | - | } | |
232 | - | } | |
94 | + | func votePoolWeight (poolAddress,userPoolVoteSWOPnew) = if (true) | |
95 | + | then throw(("we are here " + toString(minVotePower))) | |
96 | + | else { | |
97 | + | let userSWOPinGovernance = valueOrErrorMessage(getInteger(govAddr, (toString(i.caller) + "_SWOP_amount")), "Empty _SWOP_amount at gov. address") | |
98 | + | let $t041624804 = if (isDefined(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)))) | |
99 | + | then { | |
100 | + | let data = split(valueOrErrorMessage(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)), "Empty kUserPoolStruc"), "_") | |
101 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
102 | + | } | |
103 | + | else { | |
104 | + | let uPoolVoteSWOP = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolVoteSWOP)), 0) | |
105 | + | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, currPeriod, 0) | |
106 | + | } | |
107 | + | let userPoolVoteSWOP = $t041624804._1 | |
108 | + | let userPoolActiveVoteSWOP = $t041624804._2 | |
109 | + | let userPoolVotePeriod = $t041624804._3 | |
110 | + | let userPoolFreezeSWOP = $t041624804._4 | |
111 | + | let $t048105327 = if (isDefined(getString(this, (toString(i.caller) + kUserTotalStruc)))) | |
112 | + | then { | |
113 | + | let data = split(valueOrErrorMessage(getString(this, (toString(i.caller) + kUserTotalStruc)), "Empty kUserTotalStruc"), "_") | |
114 | + | $Tuple3(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2])) | |
115 | + | } | |
116 | + | else { | |
117 | + | let uPoolTotalSWOP = valueOrElse(getInteger(this, (toString(i.caller) + kUserTotalVoteSWOP)), 0) | |
118 | + | $Tuple3(uPoolTotalSWOP, 0, currPeriod) | |
119 | + | } | |
120 | + | let userTotalVoteSWOP = $t048105327._1 | |
121 | + | let userUnvoted = $t048105327._2 | |
122 | + | let userUnvotedPeriod = $t048105327._3 | |
123 | + | let $t053325839 = if (isDefined(getString(this, (poolAddress + kPoolStruc)))) | |
124 | + | then { | |
125 | + | let data = split(valueOrErrorMessage(getString(this, (poolAddress + kPoolStruc)), "Empty kPoolStruc"), "_") | |
126 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
127 | + | } | |
128 | + | else { | |
129 | + | let uPoolVoteSWOP = valueOrElse(getInteger(this, (poolAddress + kPoolVoteSWOP)), 0) | |
130 | + | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, 0, 0) | |
131 | + | } | |
132 | + | let poolVoteSWOP = $t053325839._1 | |
133 | + | let poolActiveSWOP = $t053325839._2 | |
134 | + | let poolPeriod = $t053325839._3 | |
135 | + | let poolFreezeSWOP = $t053325839._4 | |
136 | + | let $t058456321 = if (isDefined(getString(this, kTotalStruc))) | |
137 | + | then { | |
138 | + | let data = split(valueOrErrorMessage(getString(this, kTotalStruc), "Empty kTotalStruc"), "_") | |
139 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
140 | + | } | |
141 | + | else { | |
142 | + | let uTotalVoteSWOP = valueOrElse(getInteger(this, kTotalVoteSWOP), 0) | |
143 | + | $Tuple4(uTotalVoteSWOP, uTotalVoteSWOP, 0, 0) | |
144 | + | } | |
145 | + | let totalVoteSWOP = $t058456321._1 | |
146 | + | let totalActiveSWOP = $t058456321._2 | |
147 | + | let totalPeriod = $t058456321._3 | |
148 | + | let totalFreezeSWOP = $t058456321._4 | |
149 | + | let poolVoteDiffSWOP = (userPoolVoteSWOPnew - userPoolVoteSWOP) | |
150 | + | let userTotalVoteSWOPnew = (userTotalVoteSWOP + poolVoteDiffSWOP) | |
151 | + | if (!(isCallerInGovernance(i.caller))) | |
152 | + | then throw("This address has 0 SWOP in Governance dApp") | |
153 | + | else if ((userTotalVoteSWOPnew > userSWOPinGovernance)) | |
154 | + | then throw(((((toString(this) + " has ") + toString(userSWOPinGovernance)) + " SWOP in governance. New SWOP in voting ") + toString(userTotalVoteSWOPnew))) | |
155 | + | else if ((0 > userTotalVoteSWOPnew)) | |
156 | + | then throw("New userPoolVoteSWOPnew < 0") | |
157 | + | else if ((userPoolVoteSWOPnew >= userPoolVoteSWOP)) | |
158 | + | then { | |
159 | + | let coef = votingCoef() | |
160 | + | let userPoolActiveVoteSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
161 | + | then (userPoolActiveVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
162 | + | else (userPoolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
163 | + | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
164 | + | then userPoolFreezeSWOP | |
165 | + | else userPoolVoteSWOP | |
166 | + | let userUnvotedNew = if ((userUnvoted == currPeriod)) | |
167 | + | then userUnvoted | |
168 | + | else max([0, (userUnvoted - poolVoteDiffSWOP)]) | |
169 | + | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
170 | + | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
171 | + | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
172 | + | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
173 | + | let poolVoteSWOPnew = (poolVoteSWOP + poolVoteDiffSWOP) | |
174 | + | let poolActiveSWOPnew = if ((poolPeriod == currPeriod)) | |
175 | + | then (poolActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
176 | + | else (poolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
177 | + | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
178 | + | then poolFreezeSWOP | |
179 | + | else poolVoteSWOP | |
180 | + | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
181 | + | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
182 | + | let totalVoteSWOPnew = (totalVoteSWOP + poolVoteDiffSWOP) | |
183 | + | let totalActiveSWOPnew = if ((totalPeriod == currPeriod)) | |
184 | + | then (totalActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
185 | + | else (totalVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
186 | + | let totalFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
187 | + | then totalFreezeSWOP | |
188 | + | else totalVoteSWOP | |
189 | + | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
190 | + | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
191 | + | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
192 | + | } | |
193 | + | else { | |
194 | + | let removePoolVote = -(poolVoteDiffSWOP) | |
195 | + | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
196 | + | then min([userPoolFreezeSWOP, userPoolVoteSWOPnew]) | |
197 | + | else userPoolVoteSWOPnew | |
198 | + | let userPoolActiveVoteSWOPnew = if (((userPoolVoteSWOP - userPoolFreezeSWOP) == 0)) | |
199 | + | then 0 | |
200 | + | else (userPoolFreezeSWOPnew + (((userPoolActiveVoteSWOP - userPoolFreezeSWOP) * (userPoolVoteSWOPnew - userPoolFreezeSWOPnew)) / (userPoolVoteSWOP - userPoolFreezeSWOP))) | |
201 | + | let newUnvoted = max([0, (removePoolVote - (if ((userUnvotedPeriod == currPeriod)) | |
202 | + | then (userPoolVoteSWOP - userPoolFreezeSWOP) | |
203 | + | else 0))]) | |
204 | + | let userUnvotedNew = if ((userUnvotedPeriod == currPeriod)) | |
205 | + | then userUnvoted | |
206 | + | else (0 + newUnvoted) | |
207 | + | let userUnvotedPeriodNew = if ((newUnvoted > 0)) | |
208 | + | then currPeriod | |
209 | + | else userUnvotedPeriod | |
210 | + | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
211 | + | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
212 | + | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
213 | + | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
214 | + | let poolVoteSWOPnew = (poolVoteSWOP - removePoolVote) | |
215 | + | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
216 | + | then min([poolFreezeSWOP, poolVoteSWOPnew]) | |
217 | + | else poolVoteSWOPnew | |
218 | + | let poolActiveSWOPnew = if (((poolVoteSWOP - poolFreezeSWOP) == 0)) | |
219 | + | then 0 | |
220 | + | else (poolFreezeSWOPnew + (((poolActiveSWOP - poolFreezeSWOP) * (poolVoteSWOPnew - poolFreezeSWOPnew)) / (poolVoteSWOP - poolFreezeSWOP))) | |
221 | + | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
222 | + | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
223 | + | let totalVoteSWOPnew = (totalVoteSWOP - removePoolVote) | |
224 | + | let totalFreezeSWOPnew = if ((totalPeriod == currPeriod)) | |
225 | + | then min([totalFreezeSWOP, totalVoteSWOPnew]) | |
226 | + | else totalVoteSWOPnew | |
227 | + | let totalActiveSWOPnew = if (((totalVoteSWOP - totalFreezeSWOP) == 0)) | |
228 | + | then 0 | |
229 | + | else (totalFreezeSWOPnew + (((totalActiveSWOP - totalFreezeSWOP) * (totalVoteSWOPnew - totalFreezeSWOPnew)) / (totalVoteSWOP - totalFreezeSWOP))) | |
230 | + | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
231 | + | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
232 | + | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
233 | + | } | |
234 | + | } | |
233 | 235 | ||
234 | 236 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 4 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let adminPubKey1 = base58'DXDY2itiEcYBtGkVLnkpHtDFyWQUkoLJz79uJ7ECbMrA' | |
5 | 5 | ||
6 | 6 | let adminPubKey2 = base58'E6Wa1SGoktYcjHjsKrvjMiqJY3SWmGKcD8Q5L8kxSPS7' | |
7 | 7 | ||
8 | 8 | let adminPubKey3 = base58'AZmWJtuy4GeVrMmJH4hfFBRApe1StvhJSk4jcbT6bArQ' | |
9 | 9 | ||
10 | 10 | let kUserPoolVoteSWOP = "_vote" | |
11 | 11 | ||
12 | 12 | let kUserPoolStruc = "_user_pool_struc" | |
13 | 13 | ||
14 | 14 | let kUserTotalVoteSWOP = "_user_total_SWOP_vote" | |
15 | 15 | ||
16 | 16 | let kUserTotalStruc = "_user_total_struc" | |
17 | 17 | ||
18 | 18 | let kPoolVoteSWOP = "_vote_SWOP" | |
19 | 19 | ||
20 | 20 | let kPoolStruc = "_pool_struc" | |
21 | 21 | ||
22 | 22 | let kTotalVoteSWOP = "total_vote_SWOP" | |
23 | 23 | ||
24 | 24 | let kTotalStruc = "total_struc" | |
25 | 25 | ||
26 | 26 | let kStartHeight = "start_height" | |
27 | 27 | ||
28 | 28 | let kBasePeriod = "base_period" | |
29 | 29 | ||
30 | 30 | let kPeriodLength = "period_length" | |
31 | 31 | ||
32 | 32 | let kDurationFullVotePower = "duration_full_vote_power" | |
33 | 33 | ||
34 | 34 | let kMinVotePower = "min_vote_power" | |
35 | 35 | ||
36 | 36 | let scale8 = 100000000 | |
37 | 37 | ||
38 | 38 | let basePeriod = valueOrErrorMessage(getInteger(this, kBasePeriod), "Empty kBasePeriod") | |
39 | 39 | ||
40 | 40 | let startHeight = valueOrErrorMessage(getInteger(this, kStartHeight), "Empty kStartHeight") | |
41 | 41 | ||
42 | 42 | let periodLength = valueOrErrorMessage(getInteger(this, kPeriodLength), "Empty kPeriodLength") | |
43 | 43 | ||
44 | 44 | let durationFullVotePower = valueOrErrorMessage(getInteger(this, kDurationFullVotePower), "Empty kDurationFullVotePower") | |
45 | 45 | ||
46 | 46 | let minVotePower = valueOrErrorMessage(getInteger(this, kMinVotePower), "Empty kMinVotePower") | |
47 | 47 | ||
48 | 48 | let govAddr = Address(base58'3N8gfDJc5N53ePx2qBn3oQXbnhbz3Z7WFNj') | |
49 | 49 | ||
50 | 50 | let currPeriod = (basePeriod + ((height - startHeight) / periodLength)) | |
51 | 51 | ||
52 | 52 | func isCallerInGovernance (user) = if ((valueOrElse(getInteger(govAddr, (toString(user) + "_SWOP_amount")), 0) > 0)) | |
53 | 53 | then true | |
54 | 54 | else false | |
55 | 55 | ||
56 | 56 | ||
57 | 57 | func isPoolInGovernance (poolAddress) = isDefined(getInteger(govAddr, (poolAddress + "_current_pool_fraction_reward"))) | |
58 | 58 | ||
59 | 59 | ||
60 | 60 | func votingCoef () = { | |
61 | 61 | let votingDuration = (height - (startHeight + (currPeriod * periodLength))) | |
62 | 62 | if ((durationFullVotePower > votingDuration)) | |
63 | 63 | then scale8 | |
64 | 64 | else { | |
65 | 65 | let x1 = durationFullVotePower | |
66 | 66 | let y1 = scale8 | |
67 | 67 | let x2 = periodLength | |
68 | 68 | let y2 = minVotePower | |
69 | 69 | let k = (((y2 - y1) * scale8) / (x2 - x1)) | |
70 | 70 | let b = ((y1 * scale8) - (k * x1)) | |
71 | 71 | (((votingDuration * k) / scale8) + (b / scale8)) | |
72 | 72 | } | |
73 | 73 | } | |
74 | 74 | ||
75 | 75 | ||
76 | 76 | func calcDeleteEntry (caller,poolAddress,userPoolVoteSWOPnew) = { | |
77 | 77 | let deleteKeyUserPoolVoteSWOP = if (isDefined(getInteger(this, (((caller + "_") + poolAddress) + kUserPoolVoteSWOP)))) | |
78 | 78 | then DeleteEntry((((caller + "_") + poolAddress) + kUserPoolVoteSWOP)) | |
79 | 79 | else DeleteEntry(".") | |
80 | 80 | let deleteKeyUserTotalVoteSWOP = if (isDefined(getInteger(this, (caller + kUserTotalVoteSWOP)))) | |
81 | 81 | then DeleteEntry((caller + kUserTotalVoteSWOP)) | |
82 | 82 | else DeleteEntry(".") | |
83 | 83 | let deleteKeyPoolVoteSWOP = if (isDefined(getInteger(this, (poolAddress + kPoolVoteSWOP)))) | |
84 | 84 | then DeleteEntry((poolAddress + kPoolVoteSWOP)) | |
85 | 85 | else DeleteEntry(".") | |
86 | 86 | let deleteKeyTotalVoteSWOP = if (isDefined(getInteger(this, kTotalVoteSWOP))) | |
87 | 87 | then DeleteEntry(kTotalVoteSWOP) | |
88 | 88 | else DeleteEntry(".") | |
89 | 89 | [deleteKeyUserPoolVoteSWOP, deleteKeyUserTotalVoteSWOP, deleteKeyPoolVoteSWOP, deleteKeyTotalVoteSWOP] | |
90 | 90 | } | |
91 | 91 | ||
92 | 92 | ||
93 | 93 | @Callable(i) | |
94 | - | func votePoolWeight (poolAddress,userPoolVoteSWOPnew) = { | |
95 | - | let userSWOPinGovernance = valueOrErrorMessage(getInteger(govAddr, (toString(i.caller) + "_SWOP_amount")), "Empty _SWOP_amount at gov. address") | |
96 | - | let $t040924734 = if (isDefined(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)))) | |
97 | - | then { | |
98 | - | let data = split(valueOrErrorMessage(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)), "Empty kUserPoolStruc"), "_") | |
99 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
100 | - | } | |
101 | - | else { | |
102 | - | let uPoolVoteSWOP = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolVoteSWOP)), 0) | |
103 | - | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, currPeriod, 0) | |
104 | - | } | |
105 | - | let userPoolVoteSWOP = $t040924734._1 | |
106 | - | let userPoolActiveVoteSWOP = $t040924734._2 | |
107 | - | let userPoolVotePeriod = $t040924734._3 | |
108 | - | let userPoolFreezeSWOP = $t040924734._4 | |
109 | - | let $t047405257 = if (isDefined(getString(this, (toString(i.caller) + kUserTotalStruc)))) | |
110 | - | then { | |
111 | - | let data = split(valueOrErrorMessage(getString(this, (toString(i.caller) + kUserTotalStruc)), "Empty kUserTotalStruc"), "_") | |
112 | - | $Tuple3(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2])) | |
113 | - | } | |
114 | - | else { | |
115 | - | let uPoolTotalSWOP = valueOrElse(getInteger(this, (toString(i.caller) + kUserTotalVoteSWOP)), 0) | |
116 | - | $Tuple3(uPoolTotalSWOP, 0, currPeriod) | |
117 | - | } | |
118 | - | let userTotalVoteSWOP = $t047405257._1 | |
119 | - | let userUnvoted = $t047405257._2 | |
120 | - | let userUnvotedPeriod = $t047405257._3 | |
121 | - | let $t052625769 = if (isDefined(getString(this, (poolAddress + kPoolStruc)))) | |
122 | - | then { | |
123 | - | let data = split(valueOrErrorMessage(getString(this, (poolAddress + kPoolStruc)), "Empty kPoolStruc"), "_") | |
124 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
125 | - | } | |
126 | - | else { | |
127 | - | let uPoolVoteSWOP = valueOrElse(getInteger(this, (poolAddress + kPoolVoteSWOP)), 0) | |
128 | - | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, 0, 0) | |
129 | - | } | |
130 | - | let poolVoteSWOP = $t052625769._1 | |
131 | - | let poolActiveSWOP = $t052625769._2 | |
132 | - | let poolPeriod = $t052625769._3 | |
133 | - | let poolFreezeSWOP = $t052625769._4 | |
134 | - | let $t057756251 = if (isDefined(getString(this, kTotalStruc))) | |
135 | - | then { | |
136 | - | let data = split(valueOrErrorMessage(getString(this, kTotalStruc), "Empty kTotalStruc"), "_") | |
137 | - | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
138 | - | } | |
139 | - | else { | |
140 | - | let uTotalVoteSWOP = valueOrElse(getInteger(this, kTotalVoteSWOP), 0) | |
141 | - | $Tuple4(uTotalVoteSWOP, uTotalVoteSWOP, 0, 0) | |
142 | - | } | |
143 | - | let totalVoteSWOP = $t057756251._1 | |
144 | - | let totalActiveSWOP = $t057756251._2 | |
145 | - | let totalPeriod = $t057756251._3 | |
146 | - | let totalFreezeSWOP = $t057756251._4 | |
147 | - | let poolVoteDiffSWOP = (userPoolVoteSWOPnew - userPoolVoteSWOP) | |
148 | - | let userTotalVoteSWOPnew = (userTotalVoteSWOP + poolVoteDiffSWOP) | |
149 | - | if (!(isCallerInGovernance(i.caller))) | |
150 | - | then throw("This address has 0 SWOP in Governance dApp") | |
151 | - | else if ((userTotalVoteSWOPnew > userSWOPinGovernance)) | |
152 | - | then throw(((((toString(this) + " has ") + toString(userSWOPinGovernance)) + " SWOP in governance. New SWOP in voting ") + toString(userTotalVoteSWOPnew))) | |
153 | - | else if ((0 > userTotalVoteSWOPnew)) | |
154 | - | then throw("New userPoolVoteSWOPnew < 0") | |
155 | - | else if ((userPoolVoteSWOPnew >= userPoolVoteSWOP)) | |
156 | - | then { | |
157 | - | let coef = votingCoef() | |
158 | - | let userPoolActiveVoteSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
159 | - | then (userPoolActiveVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
160 | - | else (userPoolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
161 | - | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
162 | - | then userPoolFreezeSWOP | |
163 | - | else userPoolVoteSWOP | |
164 | - | let userUnvotedNew = if ((userUnvoted == currPeriod)) | |
165 | - | then userUnvoted | |
166 | - | else max([0, (userUnvoted - poolVoteDiffSWOP)]) | |
167 | - | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
168 | - | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
169 | - | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
170 | - | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
171 | - | let poolVoteSWOPnew = (poolVoteSWOP + poolVoteDiffSWOP) | |
172 | - | let poolActiveSWOPnew = if ((poolPeriod == currPeriod)) | |
173 | - | then (poolActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
174 | - | else (poolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
175 | - | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
176 | - | then poolFreezeSWOP | |
177 | - | else poolVoteSWOP | |
178 | - | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
179 | - | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
180 | - | let totalVoteSWOPnew = (totalVoteSWOP + poolVoteDiffSWOP) | |
181 | - | let totalActiveSWOPnew = if ((totalPeriod == currPeriod)) | |
182 | - | then (totalActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
183 | - | else (totalVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
184 | - | let totalFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
185 | - | then totalFreezeSWOP | |
186 | - | else totalVoteSWOP | |
187 | - | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
188 | - | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
189 | - | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
190 | - | } | |
191 | - | else { | |
192 | - | let removePoolVote = -(poolVoteDiffSWOP) | |
193 | - | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
194 | - | then min([userPoolFreezeSWOP, userPoolVoteSWOPnew]) | |
195 | - | else userPoolVoteSWOPnew | |
196 | - | let userPoolActiveVoteSWOPnew = if (((userPoolVoteSWOP - userPoolFreezeSWOP) == 0)) | |
197 | - | then 0 | |
198 | - | else (userPoolFreezeSWOPnew + (((userPoolActiveVoteSWOP - userPoolFreezeSWOP) * (userPoolVoteSWOPnew - userPoolFreezeSWOPnew)) / (userPoolVoteSWOP - userPoolFreezeSWOP))) | |
199 | - | let newUnvoted = max([0, (removePoolVote - (if ((userUnvotedPeriod == currPeriod)) | |
200 | - | then (userPoolVoteSWOP - userPoolFreezeSWOP) | |
201 | - | else 0))]) | |
202 | - | let userUnvotedNew = if ((userUnvotedPeriod == currPeriod)) | |
203 | - | then userUnvoted | |
204 | - | else (0 + newUnvoted) | |
205 | - | let userUnvotedPeriodNew = if ((newUnvoted > 0)) | |
206 | - | then currPeriod | |
207 | - | else userUnvotedPeriod | |
208 | - | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
209 | - | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
210 | - | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
211 | - | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
212 | - | let poolVoteSWOPnew = (poolVoteSWOP - removePoolVote) | |
213 | - | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
214 | - | then min([poolFreezeSWOP, poolVoteSWOPnew]) | |
215 | - | else poolVoteSWOPnew | |
216 | - | let poolActiveSWOPnew = if (((poolVoteSWOP - poolFreezeSWOP) == 0)) | |
217 | - | then 0 | |
218 | - | else (poolFreezeSWOPnew + (((poolActiveSWOP - poolFreezeSWOP) * (poolVoteSWOPnew - poolFreezeSWOPnew)) / (poolVoteSWOP - poolFreezeSWOP))) | |
219 | - | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
220 | - | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
221 | - | let totalVoteSWOPnew = (totalVoteSWOP - removePoolVote) | |
222 | - | let totalFreezeSWOPnew = if ((totalPeriod == currPeriod)) | |
223 | - | then min([totalFreezeSWOP, totalVoteSWOPnew]) | |
224 | - | else totalVoteSWOPnew | |
225 | - | let totalActiveSWOPnew = if (((totalVoteSWOP - totalFreezeSWOP) == 0)) | |
226 | - | then 0 | |
227 | - | else (totalFreezeSWOPnew + (((totalActiveSWOP - totalFreezeSWOP) * (totalVoteSWOPnew - totalFreezeSWOPnew)) / (totalVoteSWOP - totalFreezeSWOP))) | |
228 | - | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
229 | - | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
230 | - | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
231 | - | } | |
232 | - | } | |
94 | + | func votePoolWeight (poolAddress,userPoolVoteSWOPnew) = if (true) | |
95 | + | then throw(("we are here " + toString(minVotePower))) | |
96 | + | else { | |
97 | + | let userSWOPinGovernance = valueOrErrorMessage(getInteger(govAddr, (toString(i.caller) + "_SWOP_amount")), "Empty _SWOP_amount at gov. address") | |
98 | + | let $t041624804 = if (isDefined(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)))) | |
99 | + | then { | |
100 | + | let data = split(valueOrErrorMessage(getString(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc)), "Empty kUserPoolStruc"), "_") | |
101 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
102 | + | } | |
103 | + | else { | |
104 | + | let uPoolVoteSWOP = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + poolAddress) + kUserPoolVoteSWOP)), 0) | |
105 | + | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, currPeriod, 0) | |
106 | + | } | |
107 | + | let userPoolVoteSWOP = $t041624804._1 | |
108 | + | let userPoolActiveVoteSWOP = $t041624804._2 | |
109 | + | let userPoolVotePeriod = $t041624804._3 | |
110 | + | let userPoolFreezeSWOP = $t041624804._4 | |
111 | + | let $t048105327 = if (isDefined(getString(this, (toString(i.caller) + kUserTotalStruc)))) | |
112 | + | then { | |
113 | + | let data = split(valueOrErrorMessage(getString(this, (toString(i.caller) + kUserTotalStruc)), "Empty kUserTotalStruc"), "_") | |
114 | + | $Tuple3(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2])) | |
115 | + | } | |
116 | + | else { | |
117 | + | let uPoolTotalSWOP = valueOrElse(getInteger(this, (toString(i.caller) + kUserTotalVoteSWOP)), 0) | |
118 | + | $Tuple3(uPoolTotalSWOP, 0, currPeriod) | |
119 | + | } | |
120 | + | let userTotalVoteSWOP = $t048105327._1 | |
121 | + | let userUnvoted = $t048105327._2 | |
122 | + | let userUnvotedPeriod = $t048105327._3 | |
123 | + | let $t053325839 = if (isDefined(getString(this, (poolAddress + kPoolStruc)))) | |
124 | + | then { | |
125 | + | let data = split(valueOrErrorMessage(getString(this, (poolAddress + kPoolStruc)), "Empty kPoolStruc"), "_") | |
126 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
127 | + | } | |
128 | + | else { | |
129 | + | let uPoolVoteSWOP = valueOrElse(getInteger(this, (poolAddress + kPoolVoteSWOP)), 0) | |
130 | + | $Tuple4(uPoolVoteSWOP, uPoolVoteSWOP, 0, 0) | |
131 | + | } | |
132 | + | let poolVoteSWOP = $t053325839._1 | |
133 | + | let poolActiveSWOP = $t053325839._2 | |
134 | + | let poolPeriod = $t053325839._3 | |
135 | + | let poolFreezeSWOP = $t053325839._4 | |
136 | + | let $t058456321 = if (isDefined(getString(this, kTotalStruc))) | |
137 | + | then { | |
138 | + | let data = split(valueOrErrorMessage(getString(this, kTotalStruc), "Empty kTotalStruc"), "_") | |
139 | + | $Tuple4(parseIntValue(data[0]), parseIntValue(data[1]), parseIntValue(data[2]), parseIntValue(data[3])) | |
140 | + | } | |
141 | + | else { | |
142 | + | let uTotalVoteSWOP = valueOrElse(getInteger(this, kTotalVoteSWOP), 0) | |
143 | + | $Tuple4(uTotalVoteSWOP, uTotalVoteSWOP, 0, 0) | |
144 | + | } | |
145 | + | let totalVoteSWOP = $t058456321._1 | |
146 | + | let totalActiveSWOP = $t058456321._2 | |
147 | + | let totalPeriod = $t058456321._3 | |
148 | + | let totalFreezeSWOP = $t058456321._4 | |
149 | + | let poolVoteDiffSWOP = (userPoolVoteSWOPnew - userPoolVoteSWOP) | |
150 | + | let userTotalVoteSWOPnew = (userTotalVoteSWOP + poolVoteDiffSWOP) | |
151 | + | if (!(isCallerInGovernance(i.caller))) | |
152 | + | then throw("This address has 0 SWOP in Governance dApp") | |
153 | + | else if ((userTotalVoteSWOPnew > userSWOPinGovernance)) | |
154 | + | then throw(((((toString(this) + " has ") + toString(userSWOPinGovernance)) + " SWOP in governance. New SWOP in voting ") + toString(userTotalVoteSWOPnew))) | |
155 | + | else if ((0 > userTotalVoteSWOPnew)) | |
156 | + | then throw("New userPoolVoteSWOPnew < 0") | |
157 | + | else if ((userPoolVoteSWOPnew >= userPoolVoteSWOP)) | |
158 | + | then { | |
159 | + | let coef = votingCoef() | |
160 | + | let userPoolActiveVoteSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
161 | + | then (userPoolActiveVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
162 | + | else (userPoolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
163 | + | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
164 | + | then userPoolFreezeSWOP | |
165 | + | else userPoolVoteSWOP | |
166 | + | let userUnvotedNew = if ((userUnvoted == currPeriod)) | |
167 | + | then userUnvoted | |
168 | + | else max([0, (userUnvoted - poolVoteDiffSWOP)]) | |
169 | + | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
170 | + | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
171 | + | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
172 | + | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
173 | + | let poolVoteSWOPnew = (poolVoteSWOP + poolVoteDiffSWOP) | |
174 | + | let poolActiveSWOPnew = if ((poolPeriod == currPeriod)) | |
175 | + | then (poolActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
176 | + | else (poolVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
177 | + | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
178 | + | then poolFreezeSWOP | |
179 | + | else poolVoteSWOP | |
180 | + | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
181 | + | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
182 | + | let totalVoteSWOPnew = (totalVoteSWOP + poolVoteDiffSWOP) | |
183 | + | let totalActiveSWOPnew = if ((totalPeriod == currPeriod)) | |
184 | + | then (totalActiveSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
185 | + | else (totalVoteSWOP + ((poolVoteDiffSWOP * coef) / scale8)) | |
186 | + | let totalFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
187 | + | then totalFreezeSWOP | |
188 | + | else totalVoteSWOP | |
189 | + | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
190 | + | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
191 | + | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
192 | + | } | |
193 | + | else { | |
194 | + | let removePoolVote = -(poolVoteDiffSWOP) | |
195 | + | let userPoolFreezeSWOPnew = if ((userPoolVotePeriod == currPeriod)) | |
196 | + | then min([userPoolFreezeSWOP, userPoolVoteSWOPnew]) | |
197 | + | else userPoolVoteSWOPnew | |
198 | + | let userPoolActiveVoteSWOPnew = if (((userPoolVoteSWOP - userPoolFreezeSWOP) == 0)) | |
199 | + | then 0 | |
200 | + | else (userPoolFreezeSWOPnew + (((userPoolActiveVoteSWOP - userPoolFreezeSWOP) * (userPoolVoteSWOPnew - userPoolFreezeSWOPnew)) / (userPoolVoteSWOP - userPoolFreezeSWOP))) | |
201 | + | let newUnvoted = max([0, (removePoolVote - (if ((userUnvotedPeriod == currPeriod)) | |
202 | + | then (userPoolVoteSWOP - userPoolFreezeSWOP) | |
203 | + | else 0))]) | |
204 | + | let userUnvotedNew = if ((userUnvotedPeriod == currPeriod)) | |
205 | + | then userUnvoted | |
206 | + | else (0 + newUnvoted) | |
207 | + | let userUnvotedPeriodNew = if ((newUnvoted > 0)) | |
208 | + | then currPeriod | |
209 | + | else userUnvotedPeriod | |
210 | + | let userPoolStrucNew = ((((((toString(userPoolVoteSWOPnew) + "_") + toString(userPoolActiveVoteSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(userPoolFreezeSWOPnew)) | |
211 | + | let userPoolEntry = [StringEntry((((toString(i.caller) + "_") + poolAddress) + kUserPoolStruc), userPoolStrucNew)] | |
212 | + | let userTotalStrucNew = ((((toString(userTotalVoteSWOPnew) + "_") + toString(userUnvotedNew)) + "_") + toString(currPeriod)) | |
213 | + | let userTotalEntry = [StringEntry((toString(i.caller) + kUserTotalStruc), userTotalStrucNew)] | |
214 | + | let poolVoteSWOPnew = (poolVoteSWOP - removePoolVote) | |
215 | + | let poolFreezeSWOPnew = if ((poolPeriod == currPeriod)) | |
216 | + | then min([poolFreezeSWOP, poolVoteSWOPnew]) | |
217 | + | else poolVoteSWOPnew | |
218 | + | let poolActiveSWOPnew = if (((poolVoteSWOP - poolFreezeSWOP) == 0)) | |
219 | + | then 0 | |
220 | + | else (poolFreezeSWOPnew + (((poolActiveSWOP - poolFreezeSWOP) * (poolVoteSWOPnew - poolFreezeSWOPnew)) / (poolVoteSWOP - poolFreezeSWOP))) | |
221 | + | let poolStrucNew = ((((((toString(poolVoteSWOPnew) + "_") + toString(poolActiveSWOPnew)) + "_") + toString(currPeriod)) + "_") + toString(poolFreezeSWOPnew)) | |
222 | + | let poolEntry = [StringEntry((poolAddress + kPoolStruc), poolStrucNew)] | |
223 | + | let totalVoteSWOPnew = (totalVoteSWOP - removePoolVote) | |
224 | + | let totalFreezeSWOPnew = if ((totalPeriod == currPeriod)) | |
225 | + | then min([totalFreezeSWOP, totalVoteSWOPnew]) | |
226 | + | else totalVoteSWOPnew | |
227 | + | let totalActiveSWOPnew = if (((totalVoteSWOP - totalFreezeSWOP) == 0)) | |
228 | + | then 0 | |
229 | + | else (totalFreezeSWOPnew + (((totalActiveSWOP - totalFreezeSWOP) * (totalVoteSWOPnew - totalFreezeSWOPnew)) / (totalVoteSWOP - totalFreezeSWOP))) | |
230 | + | let totalStrucNew = ((((((toString(totalVoteSWOPnew) + "_") + toString(totalActiveSWOPnew)) + "_") + toString(totalPeriod)) + "_") + toString(totalFreezeSWOPnew)) | |
231 | + | let totalEntry = [StringEntry(kTotalStruc, totalStrucNew)] | |
232 | + | ((((userPoolEntry ++ userTotalEntry) ++ poolEntry) ++ totalEntry) ++ calcDeleteEntry(toString(i.caller), poolAddress, userPoolVoteSWOPnew)) | |
233 | + | } | |
234 | + | } | |
233 | 235 | ||
234 | 236 |
github/deemru/w8io/169f3d6 50.42 ms ◑