tx · G297U5QHoyWVvTmgffEPtiQPomkCPKNys4bzc5XbQVxR 3NAg879tKUJh949h21umkwiaRQhwZftz1BE: -0.05000000 Waves 2019.09.04 12:41 [661084] smart account 3NAg879tKUJh949h21umkwiaRQhwZftz1BE > SELF 0.00000000 Waves
{ "type": 13, "id": "G297U5QHoyWVvTmgffEPtiQPomkCPKNys4bzc5XbQVxR", "fee": 5000000, "feeAssetId": null, "timestamp": 1567590102067, "version": 1, "sender": "3NAg879tKUJh949h21umkwiaRQhwZftz1BE", "senderPublicKey": "BqY2jhkQCcbidtQdQZu6f9RV3AkFAS8VPToHxwYu1KdJ", "proofs": [ "2nxYbp7S2yGGc1Y8yft7VQH6iQ13xnk9xWEfyee5HSPQjW4BnTXuhuxLUvUAQ3jKypzyM8W5hWtQzXyeaiSXtoZH" ], "script": "base64:AAIDAAAAAAAAAAAAAAAVAAAAAAN3dnMAAAAAAAX14QAAAAAAFmRlc2NyaXB0aW9uVXBkYXRlUHJpY2UJAABoAAAAAgAAAAAAAAAAAQUAAAADd3ZzAAAAAA9saW5rVXBkYXRlUHJpY2UJAABoAAAAAgAAAAAAAAAAAQUAAAADd3ZzAAAAABF0aWNrZXJVcGRhdGVQcmljZQkAAGgAAAACAAAAAAAAAAACBQAAAAN3dnMAAAAAD3RpY2tlck1pbkxlbmd0aAAAAAAAAAAAAQAAAAAPdGlja2VyTWF4TGVuZ3RoAAAAAAAAAAAGAAAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwIAAAAaQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVoAAAAAHHRpY2tlckNhdGFsb2d1ZU9yYWNsZUFkZHJlc3MJAQAAABxAZXh0clVzZXIoYWRkcmVzc0Zyb21TdHJpbmcpAAAAAQIAAAAjM014SHhXNVZXcTRLcldjYmhGZnhLcmFmWG00bUw2clpIZmoAAAAAGHRva2VuUmF0aW5nT3JhY2xlQWRkcmVzcwkBAAAAHEBleHRyVXNlcihhZGRyZXNzRnJvbVN0cmluZykAAAABAgAAACMzTkFEcUhvTE1iTVRmWGRQMlRlQkJTeDVtUVhlUFZqM0tabQEAAAAVZ2V0SW50ZWdlckZyb21BY2NvdW50AAAAAgAAAA5hY2NvdW50QWRkcmVzcwAAAANrZXkEAAAAByRtYXRjaDAJAAQaAAAAAgUAAAAOYWNjb3VudEFkZHJlc3MFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFpBQAAAAckbWF0Y2gwBQAAAAFpAAAAAAAAAAAAAQAAAA1pc1N1YnN0ckV4aXN0AAAAAgAAAANzdHIAAAAGc3Vic3RyBAAAAAckbWF0Y2gwCQAEswAAAAIFAAAAA3N0cgUAAAAGc3Vic3RyAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAABWluZGV4BQAAAAckbWF0Y2gwBgMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAEVW5pdAQAAAAFaW5kZXgFAAAAByRtYXRjaDAHCQEAAAAFdGhyb3cAAAAAAQAAAA1pc1ZhbGlkVGlja2VyAAAAAQAAAAZ0aWNrZXIEAAAADXRpY2tlckxldHRlcnMJAAS1AAAAAgUAAAAGdGlja2VyAgAAAAAEAAAADHRpY2tlckxlbmd0aAkAAZAAAAABBQAAAA10aWNrZXJMZXR0ZXJzBAAAAA5pc0xldHRlcjFWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAAABAAAAA5pc0xldHRlcjJWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAABBAAAAA5pc0xldHRlcjNWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAACBAAAAA5pc0xldHRlcjRWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAADBAAAAA5pc0xldHRlcjVWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAAEBAAAAA5pc0xldHRlcjZWYWxpZAkBAAAADWlzU3Vic3RyRXhpc3QAAAACBQAAABR0aWNrZXJBbGxvd2VkTGV0dGVycwkAAZEAAAACBQAAAA10aWNrZXJMZXR0ZXJzAAAAAAAAAAAFAwkBAAAAAiE9AAAAAgUAAAAGdGlja2VyAgAAAAADAwkAAGcAAAACBQAAAAx0aWNrZXJMZW5ndGgFAAAAD3RpY2tlck1pbkxlbmd0aAkAAGcAAAACBQAAAA90aWNrZXJNYXhMZW5ndGgFAAAADHRpY2tlckxlbmd0aAcDCQAAAAAAAAIAAAAAAAAAAAEFAAAADHRpY2tlckxlbmd0aAUAAAAOaXNMZXR0ZXIxVmFsaWQDCQAAAAAAAAIAAAAAAAAAAAIFAAAADHRpY2tlckxlbmd0aAMFAAAADmlzTGV0dGVyMVZhbGlkBQAAAA5pc0xldHRlcjJWYWxpZAcDCQAAAAAAAAIAAAAAAAAAAAMFAAAADHRpY2tlckxlbmd0aAMDBQAAAA5pc0xldHRlcjFWYWxpZAUAAAAOaXNMZXR0ZXIyVmFsaWQHBQAAAA5pc0xldHRlcjNWYWxpZAcDCQAAAAAAAAIAAAAAAAAAAAQFAAAADHRpY2tlckxlbmd0aAMDAwUAAAAOaXNMZXR0ZXIxVmFsaWQFAAAADmlzTGV0dGVyMlZhbGlkBwUAAAAOaXNMZXR0ZXIzVmFsaWQHBQAAAA5pc0xldHRlcjRWYWxpZAcDCQAAAAAAAAIAAAAAAAAAAAUFAAAADHRpY2tlckxlbmd0aAMDAwMFAAAADmlzTGV0dGVyMVZhbGlkBQAAAA5pc0xldHRlcjJWYWxpZAcFAAAADmlzTGV0dGVyM1ZhbGlkBwUAAAAOaXNMZXR0ZXI0VmFsaWQHBQAAAA5pc0xldHRlcjVWYWxpZAcDCQAAAAAAAAIAAAAAAAAAAAYFAAAADHRpY2tlckxlbmd0aAMDAwMDBQAAAA5pc0xldHRlcjFWYWxpZAUAAAAOaXNMZXR0ZXIyVmFsaWQHBQAAAA5pc0xldHRlcjNWYWxpZAcFAAAADmlzTGV0dGVyNFZhbGlkBwUAAAAOaXNMZXR0ZXI1VmFsaWQHBQAAAA5pc0xldHRlcjZWYWxpZAcHBwcBAAAAHGlzQXNzZXRVcGRhdGVBbGxvd2VkQnlSYXRpbmcAAAABAAAAB2Fzc2V0SWQEAAAADmFzc2V0UmF0aW5nS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAMYXNzZXRSYXRpbmdfBQAAAAdhc3NldElkAgAAAAJfMQQAAAAQYXNzZXRSYXRpbmdWYWx1ZQkBAAAAFWdldEludGVnZXJGcm9tQWNjb3VudAAAAAIFAAAAGHRva2VuUmF0aW5nT3JhY2xlQWRkcmVzcwUAAAAOYXNzZXRSYXRpbmdLZXkEAAAAE2Fzc2V0UmF0aW5nVHJlc2hvbGQJAQAAABVnZXRJbnRlZ2VyRnJvbUFjY291bnQAAAACBQAAABh0b2tlblJhdGluZ09yYWNsZUFkZHJlc3MCAAAADnRpY2tlclJhdGluZ18xCQAAZwAAAAIFAAAAEGFzc2V0UmF0aW5nVmFsdWUFAAAAE2Fzc2V0UmF0aW5nVHJlc2hvbGQBAAAAHGlzQXNzZXRVcGRhdGVBbGxvd2VkQnlXZWlnaHQAAAABAAAAB2Fzc2V0SWQEAAAADmFzc2V0V2VpZ2h0S2V5AgAAAAthc3NldFdlaWdodAQAAAAQYXNzZXRXZWlnaHRWYWx1ZQkBAAAAFWdldEludGVnZXJGcm9tQWNjb3VudAAAAAIFAAAAGHRva2VuUmF0aW5nT3JhY2xlQWRkcmVzcwUAAAAOYXNzZXRXZWlnaHRLZXkEAAAAE2Fzc2V0V2VpZ2h0VHJlc2hvbGQJAQAAABVnZXRJbnRlZ2VyRnJvbUFjY291bnQAAAACBQAAABh0b2tlblJhdGluZ09yYWNsZUFkZHJlc3MCAAAADHRpY2tlcldlaWdodAkAAGcAAAACBQAAABBhc3NldFdlaWdodFZhbHVlBQAAABNhc3NldFdlaWdodFRyZXNob2xkAQAAABtpc0Fzc2V0VXBkYXRlQWxsb3dlZEJ5Vm90ZXMAAAABAAAAB2Fzc2V0SWQEAAAADWFzc2V0Vm90ZXNLZXkCAAAACmFzc2V0Vm90ZXMEAAAAD2Fzc2V0Vm90ZXNWYWx1ZQkBAAAAFWdldEludGVnZXJGcm9tQWNjb3VudAAAAAIFAAAAGHRva2VuUmF0aW5nT3JhY2xlQWRkcmVzcwUAAAANYXNzZXRWb3Rlc0tleQQAAAASYXNzZXRWb3Rlc1RyZXNob2xkCQEAAAAVZ2V0SW50ZWdlckZyb21BY2NvdW50AAAAAgUAAAAYdG9rZW5SYXRpbmdPcmFjbGVBZGRyZXNzAgAAAAt0aWNrZXJWb3RlcwkAAGcAAAACBQAAAA9hc3NldFZvdGVzVmFsdWUFAAAAEmFzc2V0Vm90ZXNUcmVzaG9sZAEAAAAXaXNVcGRhdGVBbGxvd2VkQnlSYXRpbmcAAAABAAAAB2Fzc2V0SWQDAwkBAAAAHGlzQXNzZXRVcGRhdGVBbGxvd2VkQnlSYXRpbmcAAAABBQAAAAdhc3NldElkCQEAAAAcaXNBc3NldFVwZGF0ZUFsbG93ZWRCeVdlaWdodAAAAAEFAAAAB2Fzc2V0SWQHCQEAAAAbaXNBc3NldFVwZGF0ZUFsbG93ZWRCeVZvdGVzAAAAAQUAAAAHYXNzZXRJZAcBAAAAIGdldEFzc2V0SXNzdWVyQWRkcmVzc0Zyb21Bc3NldElkAAAAAQAAAAdhc3NldElkCQAEJQAAAAEICQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAPsAAAAAQkAAlkAAAABBQAAAAdhc3NldElkAgAAACdlcnJvciM2LiB0aGVyZSBpcyBubyBhc3NldCB3aXRoIHN1Y2ggaWQAAAAGaXNzdWVyAQAAAApnZXRQYXltZW50AAAAAQAAAAFpCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIIBQAAAAFpAAAAB3BheW1lbnQCAAAAKmVycm9yIzguIHRoZXJlIGlzIG5vIHBheW1lbnQgaW4gaW52b2NhdGlvbgEAAAAQaXNQYXltZW50SW5XYXZlcwAAAAEAAAABaQQAAAAHcGF5bWVudAkBAAAACmdldFBheW1lbnQAAAABBQAAAAFpAwkBAAAAASEAAAABCQEAAAAJaXNEZWZpbmVkAAAAAQgFAAAAB3BheW1lbnQAAAAHYXNzZXRJZAYHAQAAAA9pc0Vub3VnaFBheW1lbnQAAAACAAAAAWkAAAAPcmVxdWlyZWRQYXltZW50BAAAAAdwYXltZW50CQEAAAAKZ2V0UGF5bWVudAAAAAEFAAAAAWkDCQAAZwAAAAIIBQAAAAdwYXltZW50AAAABmFtb3VudAUAAAAPcmVxdWlyZWRQYXltZW50BgcBAAAAE2lzQ2FsbGVyQXNzZXRJc3N1ZXIAAAACAAAAAWkAAAAHYXNzZXRJZAQAAAANY2FsbGVyQWRkcmVzcwkAAlgAAAABCAgFAAAAAWkAAAAGY2FsbGVyAAAABWJ5dGVzBAAAABFhc3NldElzc3VlckFkcmVzcwkBAAAAIGdldEFzc2V0SXNzdWVyQWRkcmVzc0Zyb21Bc3NldElkAAAAAQUAAAAHYXNzZXRJZAMJAAAAAAAAAgUAAAANY2FsbGVyQWRkcmVzcwUAAAARYXNzZXRJc3N1ZXJBZHJlc3MGBwAAAAMAAAABaQEAAAAMdXBkYXRlVGlja2VyAAAAAgAAAAdhc3NldElkAAAABnRpY2tlcgQAAAAPaXNzdWVyVGlja2VyS2V5CQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAAA1pc3N1ZXJUaWNrZXJfAgAAAAE8BQAAAAdhc3NldElkAgAAAAE+BAAAAAxpc1RpY2tlckZyZWUEAAAAByRtYXRjaDAJAAQdAAAAAgUAAAAcdGlja2VyQ2F0YWxvZ3VlT3JhY2xlQWRkcmVzcwUAAAAGdGlja2VyAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAZTdHJpbmcEAAAAAXQFAAAAByRtYXRjaDAHAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAARVbml0BAAAAAF0BQAAAAckbWF0Y2gwBgkBAAAABXRocm93AAAAAAMJAQAAABBpc1BheW1lbnRJbldhdmVzAAAAAQUAAAABaQMJAQAAAA9pc0Vub3VnaFBheW1lbnQAAAACBQAAAAFpBQAAABF0aWNrZXJVcGRhdGVQcmljZQMJAQAAABNpc0NhbGxlckFzc2V0SXNzdWVyAAAAAgUAAAABaQUAAAAHYXNzZXRJZAMJAQAAABdpc1VwZGF0ZUFsbG93ZWRCeVJhdGluZwAAAAEFAAAAB2Fzc2V0SWQDBQAAAAxpc1RpY2tlckZyZWUDCQEAAAANaXNWYWxpZFRpY2tlcgAAAAEFAAAABnRpY2tlcgkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAPaXNzdWVyVGlja2VyS2V5BQAAAAZ0aWNrZXIFAAAAA25pbAkAAAIAAAABAgAAAD9lcnJvciM1LiBUaWNrZXIgc2hvdWxkIGNvbnNpc3Qgb2YgMS02IGNhcGl0YWwgTGF0aW4gY2hhcmFjdGVycy4JAAACAAAAAQIAAAAwZXJyb3IjNC4gQXNzZXQgd2l0aCBzdWNoIHRpY2tlciBpcyBhbHJlYWR5IGV4aXN0CQAAAgAAAAECAAAAGmVycm9yIzMuIFRvbyBsaXR0bGUgcmF0aW5nCQAAAgAAAAECAAAAMmVycm9yIzIuIE9ubHkgYXNzZXQgaXNzdWVyIGNhbiB1cGRhdGUgYXNzZXQgdGlja2VyCQAAAgAAAAECAAAAPmVycm9yIzIuIEluc3VmZmljaWVudCBwYXltZW50IGZvciBhc3NldCB0aWNrZXIgdXBkYXRlIHNlcnZpY2UuCQAAAgAAAAECAAAALmVycm9yIzEuIFRoZSBzZXJ2aWNlIGNhbiBvbmx5IGJlIHBhaWQgaW4gd2F2ZXMAAAABaQEAAAARdXBkYXRlRGVzY3JpcHRpb24AAAACAAAAB2Fzc2V0SWQAAAALZGVzY3JpcHRpb24EAAAAFGlzc3VlckRlc2NyaXB0aW9uS2V5CQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAABJpc3N1ZXJEZXNjcmlwdGlvbl8CAAAAATwFAAAAB2Fzc2V0SWQCAAAAAT4DCQEAAAAQaXNQYXltZW50SW5XYXZlcwAAAAEFAAAAAWkDCQEAAAAPaXNFbm91Z2hQYXltZW50AAAAAgUAAAABaQUAAAAWZGVzY3JpcHRpb25VcGRhdGVQcmljZQMJAQAAABNpc0NhbGxlckFzc2V0SXNzdWVyAAAAAgUAAAABaQUAAAAHYXNzZXRJZAkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAUaXNzdWVyRGVzY3JpcHRpb25LZXkFAAAAC2Rlc2NyaXB0aW9uBQAAAANuaWwJAAACAAAAAQIAAAA3ZXJyb3IjNi4gT25seSBhc3NldCBpc3N1ZXIgY2FuIHVwZGF0ZSBhc3NldCBkZXNjcmlwdGlvbgkAAAIAAAABAgAAAENlcnJvciM3LiBJbnN1ZmZpY2llbnQgcGF5bWVudCBmb3IgYXNzZXQgZGVzY3JpcHRpb24gdXBkYXRlIHNlcnZpY2UuCQAAAgAAAAECAAAALmVycm9yIzEuIFRoZSBzZXJ2aWNlIGNhbiBvbmx5IGJlIHBhaWQgaW4gd2F2ZXMAAAABaQEAAAAKdXBkYXRlTGluawAAAAIAAAAHYXNzZXRJZAAAAARsaW5rBAAAAA1pc3N1ZXJMaW5rS2V5CQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAAAtpc3N1ZXJMaW5rXwIAAAABPAUAAAAHYXNzZXRJZAIAAAABPgMJAQAAABBpc1BheW1lbnRJbldhdmVzAAAAAQUAAAABaQMJAQAAAA9pc0Vub3VnaFBheW1lbnQAAAACBQAAAAFpBQAAAA9saW5rVXBkYXRlUHJpY2UDCQEAAAATaXNDYWxsZXJBc3NldElzc3VlcgAAAAIFAAAAAWkFAAAAB2Fzc2V0SWQJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAADWlzc3VlckxpbmtLZXkFAAAABGxpbmsFAAAAA25pbAkAAAIAAAABAgAAADBlcnJvciM2LiBPbmx5IGFzc2V0IGlzc3VlciBjYW4gdXBkYXRlIGFzc2V0IGxpbmsJAAACAAAAAQIAAAA8ZXJyb3IjNy4gSW5zdWZmaWNpZW50IHBheW1lbnQgZm9yIGFzc2V0IGxpbmsgdXBkYXRlIHNlcnZpY2UuCQAAAgAAAAECAAAALmVycm9yIzEuIFRoZSBzZXJ2aWNlIGNhbiBvbmx5IGJlIHBhaWQgaW4gd2F2ZXMAAAAAOzaumA==", "chainId": 84, "height": 661084, "spentComplexity": 0 } View: original | compacted Prev: BHzd39TzY4LvvpUyNPwTJzsnnkMrTYGJzz23YXTMqia4 Next: CUkEBXTs4Rx2rLqrAAMXufrCNygXrcmwzYyE7Fk2YFbS Diff:
Old | New | Differences | |
---|---|---|---|
132 | 132 | func getAssetIssuerAddressFromAssetId (assetId) = toString(valueOrErrorMessage(assetInfo(fromBase58String(assetId)), "error#6. there is no asset with such id").issuer) | |
133 | 133 | ||
134 | 134 | ||
135 | + | func getPayment (i) = valueOrErrorMessage(i.payment, "error#8. there is no payment in invocation") | |
136 | + | ||
137 | + | ||
138 | + | func isPaymentInWaves (i) = { | |
139 | + | let payment = getPayment(i) | |
140 | + | if (!(isDefined(payment.assetId))) | |
141 | + | then true | |
142 | + | else false | |
143 | + | } | |
144 | + | ||
145 | + | ||
146 | + | func isEnoughPayment (i,requiredPayment) = { | |
147 | + | let payment = getPayment(i) | |
148 | + | if ((payment.amount >= requiredPayment)) | |
149 | + | then true | |
150 | + | else false | |
151 | + | } | |
152 | + | ||
153 | + | ||
135 | 154 | func isCallerAssetIssuer (i,assetId) = { | |
136 | 155 | let callerAddress = toBase58String(i.caller.bytes) | |
137 | 156 | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
143 | 162 | ||
144 | 163 | @Callable(i) | |
145 | 164 | func updateTicker (assetId,ticker) = { | |
146 | - | let payment = valueOrErrorMessage(i.payment, "error#8. there is no payment in invocation") | |
147 | 165 | let issuerTickerKey = ((("issuerTicker_" + "<") + assetId) + ">") | |
148 | - | let isPaymentInWaves = !(isDefined(payment.assetId)) | |
149 | - | let isEnoughPayment = (payment.amount >= tickerUpdatePrice) | |
150 | 166 | let isTickerFree = match getString(tickerCatalogueOracleAddress, ticker) { | |
151 | 167 | case t: String => | |
152 | 168 | false | |
155 | 171 | case _ => | |
156 | 172 | throw() | |
157 | 173 | } | |
158 | - | if (isPaymentInWaves) | |
159 | - | then if (isEnoughPayment) | |
174 | + | if (isPaymentInWaves(i)) | |
175 | + | then if (isEnoughPayment(i, tickerUpdatePrice)) | |
160 | 176 | then if (isCallerAssetIssuer(i, assetId)) | |
161 | 177 | then if (isUpdateAllowedByRating(assetId)) | |
162 | 178 | then if (isTickerFree) | |
174 | 190 | ||
175 | 191 | @Callable(i) | |
176 | 192 | func updateDescription (assetId,description) = { | |
177 | - | let payment = extract(i.payment) | |
178 | - | let callerAddress = toBase58String(i.caller.bytes) | |
179 | 193 | let issuerDescriptionKey = ((("issuerDescription_" + "<") + assetId) + ">") | |
180 | - | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
181 | - | if (!(isDefined(payment.assetId))) | |
182 | - | then if ((payment.amount >= descriptionUpdatePrice)) | |
183 | - | then if ((callerAddress == assetIssuerAdress)) | |
194 | + | if (isPaymentInWaves(i)) | |
195 | + | then if (isEnoughPayment(i, descriptionUpdatePrice)) | |
196 | + | then if (isCallerAssetIssuer(i, assetId)) | |
184 | 197 | then WriteSet([DataEntry(issuerDescriptionKey, description)]) | |
185 | 198 | else throw("error#6. Only asset issuer can update asset description") | |
186 | 199 | else throw("error#7. Insufficient payment for asset description update service.") | |
191 | 204 | ||
192 | 205 | @Callable(i) | |
193 | 206 | func updateLink (assetId,link) = { | |
194 | - | let payment = extract(i.payment) | |
195 | - | let callerAddress = toBase58String(i.caller.bytes) | |
196 | 207 | let issuerLinkKey = ((("issuerLink_" + "<") + assetId) + ">") | |
197 | - | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
198 | - | if (!(isDefined(payment.assetId))) | |
199 | - | then if ((payment.amount >= linkUpdatePrice)) | |
200 | - | then if ((callerAddress == assetIssuerAdress)) | |
208 | + | if (isPaymentInWaves(i)) | |
209 | + | then if (isEnoughPayment(i, linkUpdatePrice)) | |
210 | + | then if (isCallerAssetIssuer(i, assetId)) | |
201 | 211 | then WriteSet([DataEntry(issuerLinkKey, link)]) | |
202 | 212 | else throw("error#6. Only asset issuer can update asset link") | |
203 | 213 | else throw("error#7. Insufficient payment for asset link update service.") |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let wvs = 100000000 | |
5 | 5 | ||
6 | 6 | let descriptionUpdatePrice = (1 * wvs) | |
7 | 7 | ||
8 | 8 | let linkUpdatePrice = (1 * wvs) | |
9 | 9 | ||
10 | 10 | let tickerUpdatePrice = (2 * wvs) | |
11 | 11 | ||
12 | 12 | let tickerMinLength = 1 | |
13 | 13 | ||
14 | 14 | let tickerMaxLength = 6 | |
15 | 15 | ||
16 | 16 | let tickerAllowedLetters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" | |
17 | 17 | ||
18 | 18 | let tickerCatalogueOracleAddress = addressFromStringValue("3MxHxW5VWq4KrWcbhFfxKrafXm4mL6rZHfj") | |
19 | 19 | ||
20 | 20 | let tokenRatingOracleAddress = addressFromStringValue("3NADqHoLMbMTfXdP2TeBBSx5mQXePVj3KZm") | |
21 | 21 | ||
22 | 22 | func getIntegerFromAccount (accountAddress,key) = match getInteger(accountAddress, key) { | |
23 | 23 | case i: Int => | |
24 | 24 | i | |
25 | 25 | case _ => | |
26 | 26 | 0 | |
27 | 27 | } | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func isSubstrExist (str,substr) = match indexOf(str, substr) { | |
31 | 31 | case index: Int => | |
32 | 32 | true | |
33 | 33 | case index: Unit => | |
34 | 34 | false | |
35 | 35 | case _ => | |
36 | 36 | throw() | |
37 | 37 | } | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func isValidTicker (ticker) = { | |
41 | 41 | let tickerLetters = split(ticker, "") | |
42 | 42 | let tickerLength = size(tickerLetters) | |
43 | 43 | let isLetter1Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[0]) | |
44 | 44 | let isLetter2Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[1]) | |
45 | 45 | let isLetter3Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[2]) | |
46 | 46 | let isLetter4Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[3]) | |
47 | 47 | let isLetter5Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[4]) | |
48 | 48 | let isLetter6Valid = isSubstrExist(tickerAllowedLetters, tickerLetters[5]) | |
49 | 49 | if ((ticker != "")) | |
50 | 50 | then if (if ((tickerLength >= tickerMinLength)) | |
51 | 51 | then (tickerMaxLength >= tickerLength) | |
52 | 52 | else false) | |
53 | 53 | then if ((1 == tickerLength)) | |
54 | 54 | then isLetter1Valid | |
55 | 55 | else if ((2 == tickerLength)) | |
56 | 56 | then if (isLetter1Valid) | |
57 | 57 | then isLetter2Valid | |
58 | 58 | else false | |
59 | 59 | else if ((3 == tickerLength)) | |
60 | 60 | then if (if (isLetter1Valid) | |
61 | 61 | then isLetter2Valid | |
62 | 62 | else false) | |
63 | 63 | then isLetter3Valid | |
64 | 64 | else false | |
65 | 65 | else if ((4 == tickerLength)) | |
66 | 66 | then if (if (if (isLetter1Valid) | |
67 | 67 | then isLetter2Valid | |
68 | 68 | else false) | |
69 | 69 | then isLetter3Valid | |
70 | 70 | else false) | |
71 | 71 | then isLetter4Valid | |
72 | 72 | else false | |
73 | 73 | else if ((5 == tickerLength)) | |
74 | 74 | then if (if (if (if (isLetter1Valid) | |
75 | 75 | then isLetter2Valid | |
76 | 76 | else false) | |
77 | 77 | then isLetter3Valid | |
78 | 78 | else false) | |
79 | 79 | then isLetter4Valid | |
80 | 80 | else false) | |
81 | 81 | then isLetter5Valid | |
82 | 82 | else false | |
83 | 83 | else if ((6 == tickerLength)) | |
84 | 84 | then if (if (if (if (if (isLetter1Valid) | |
85 | 85 | then isLetter2Valid | |
86 | 86 | else false) | |
87 | 87 | then isLetter3Valid | |
88 | 88 | else false) | |
89 | 89 | then isLetter4Valid | |
90 | 90 | else false) | |
91 | 91 | then isLetter5Valid | |
92 | 92 | else false) | |
93 | 93 | then isLetter6Valid | |
94 | 94 | else false | |
95 | 95 | else false | |
96 | 96 | else false | |
97 | 97 | else false | |
98 | 98 | } | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | func isAssetUpdateAllowedByRating (assetId) = { | |
102 | 102 | let assetRatingKey = (("assetRating_" + assetId) + "_1") | |
103 | 103 | let assetRatingValue = getIntegerFromAccount(tokenRatingOracleAddress, assetRatingKey) | |
104 | 104 | let assetRatingTreshold = getIntegerFromAccount(tokenRatingOracleAddress, "tickerRating_1") | |
105 | 105 | (assetRatingValue >= assetRatingTreshold) | |
106 | 106 | } | |
107 | 107 | ||
108 | 108 | ||
109 | 109 | func isAssetUpdateAllowedByWeight (assetId) = { | |
110 | 110 | let assetWeightKey = "assetWeight" | |
111 | 111 | let assetWeightValue = getIntegerFromAccount(tokenRatingOracleAddress, assetWeightKey) | |
112 | 112 | let assetWeightTreshold = getIntegerFromAccount(tokenRatingOracleAddress, "tickerWeight") | |
113 | 113 | (assetWeightValue >= assetWeightTreshold) | |
114 | 114 | } | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | func isAssetUpdateAllowedByVotes (assetId) = { | |
118 | 118 | let assetVotesKey = "assetVotes" | |
119 | 119 | let assetVotesValue = getIntegerFromAccount(tokenRatingOracleAddress, assetVotesKey) | |
120 | 120 | let assetVotesTreshold = getIntegerFromAccount(tokenRatingOracleAddress, "tickerVotes") | |
121 | 121 | (assetVotesValue >= assetVotesTreshold) | |
122 | 122 | } | |
123 | 123 | ||
124 | 124 | ||
125 | 125 | func isUpdateAllowedByRating (assetId) = if (if (isAssetUpdateAllowedByRating(assetId)) | |
126 | 126 | then isAssetUpdateAllowedByWeight(assetId) | |
127 | 127 | else false) | |
128 | 128 | then isAssetUpdateAllowedByVotes(assetId) | |
129 | 129 | else false | |
130 | 130 | ||
131 | 131 | ||
132 | 132 | func getAssetIssuerAddressFromAssetId (assetId) = toString(valueOrErrorMessage(assetInfo(fromBase58String(assetId)), "error#6. there is no asset with such id").issuer) | |
133 | 133 | ||
134 | 134 | ||
135 | + | func getPayment (i) = valueOrErrorMessage(i.payment, "error#8. there is no payment in invocation") | |
136 | + | ||
137 | + | ||
138 | + | func isPaymentInWaves (i) = { | |
139 | + | let payment = getPayment(i) | |
140 | + | if (!(isDefined(payment.assetId))) | |
141 | + | then true | |
142 | + | else false | |
143 | + | } | |
144 | + | ||
145 | + | ||
146 | + | func isEnoughPayment (i,requiredPayment) = { | |
147 | + | let payment = getPayment(i) | |
148 | + | if ((payment.amount >= requiredPayment)) | |
149 | + | then true | |
150 | + | else false | |
151 | + | } | |
152 | + | ||
153 | + | ||
135 | 154 | func isCallerAssetIssuer (i,assetId) = { | |
136 | 155 | let callerAddress = toBase58String(i.caller.bytes) | |
137 | 156 | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
138 | 157 | if ((callerAddress == assetIssuerAdress)) | |
139 | 158 | then true | |
140 | 159 | else false | |
141 | 160 | } | |
142 | 161 | ||
143 | 162 | ||
144 | 163 | @Callable(i) | |
145 | 164 | func updateTicker (assetId,ticker) = { | |
146 | - | let payment = valueOrErrorMessage(i.payment, "error#8. there is no payment in invocation") | |
147 | 165 | let issuerTickerKey = ((("issuerTicker_" + "<") + assetId) + ">") | |
148 | - | let isPaymentInWaves = !(isDefined(payment.assetId)) | |
149 | - | let isEnoughPayment = (payment.amount >= tickerUpdatePrice) | |
150 | 166 | let isTickerFree = match getString(tickerCatalogueOracleAddress, ticker) { | |
151 | 167 | case t: String => | |
152 | 168 | false | |
153 | 169 | case t: Unit => | |
154 | 170 | true | |
155 | 171 | case _ => | |
156 | 172 | throw() | |
157 | 173 | } | |
158 | - | if (isPaymentInWaves) | |
159 | - | then if (isEnoughPayment) | |
174 | + | if (isPaymentInWaves(i)) | |
175 | + | then if (isEnoughPayment(i, tickerUpdatePrice)) | |
160 | 176 | then if (isCallerAssetIssuer(i, assetId)) | |
161 | 177 | then if (isUpdateAllowedByRating(assetId)) | |
162 | 178 | then if (isTickerFree) | |
163 | 179 | then if (isValidTicker(ticker)) | |
164 | 180 | then WriteSet([DataEntry(issuerTickerKey, ticker)]) | |
165 | 181 | else throw("error#5. Ticker should consist of 1-6 capital Latin characters.") | |
166 | 182 | else throw("error#4. Asset with such ticker is already exist") | |
167 | 183 | else throw("error#3. Too little rating") | |
168 | 184 | else throw("error#2. Only asset issuer can update asset ticker") | |
169 | 185 | else throw("error#2. Insufficient payment for asset ticker update service.") | |
170 | 186 | else throw("error#1. The service can only be paid in waves") | |
171 | 187 | } | |
172 | 188 | ||
173 | 189 | ||
174 | 190 | ||
175 | 191 | @Callable(i) | |
176 | 192 | func updateDescription (assetId,description) = { | |
177 | - | let payment = extract(i.payment) | |
178 | - | let callerAddress = toBase58String(i.caller.bytes) | |
179 | 193 | let issuerDescriptionKey = ((("issuerDescription_" + "<") + assetId) + ">") | |
180 | - | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
181 | - | if (!(isDefined(payment.assetId))) | |
182 | - | then if ((payment.amount >= descriptionUpdatePrice)) | |
183 | - | then if ((callerAddress == assetIssuerAdress)) | |
194 | + | if (isPaymentInWaves(i)) | |
195 | + | then if (isEnoughPayment(i, descriptionUpdatePrice)) | |
196 | + | then if (isCallerAssetIssuer(i, assetId)) | |
184 | 197 | then WriteSet([DataEntry(issuerDescriptionKey, description)]) | |
185 | 198 | else throw("error#6. Only asset issuer can update asset description") | |
186 | 199 | else throw("error#7. Insufficient payment for asset description update service.") | |
187 | 200 | else throw("error#1. The service can only be paid in waves") | |
188 | 201 | } | |
189 | 202 | ||
190 | 203 | ||
191 | 204 | ||
192 | 205 | @Callable(i) | |
193 | 206 | func updateLink (assetId,link) = { | |
194 | - | let payment = extract(i.payment) | |
195 | - | let callerAddress = toBase58String(i.caller.bytes) | |
196 | 207 | let issuerLinkKey = ((("issuerLink_" + "<") + assetId) + ">") | |
197 | - | let assetIssuerAdress = getAssetIssuerAddressFromAssetId(assetId) | |
198 | - | if (!(isDefined(payment.assetId))) | |
199 | - | then if ((payment.amount >= linkUpdatePrice)) | |
200 | - | then if ((callerAddress == assetIssuerAdress)) | |
208 | + | if (isPaymentInWaves(i)) | |
209 | + | then if (isEnoughPayment(i, linkUpdatePrice)) | |
210 | + | then if (isCallerAssetIssuer(i, assetId)) | |
201 | 211 | then WriteSet([DataEntry(issuerLinkKey, link)]) | |
202 | 212 | else throw("error#6. Only asset issuer can update asset link") | |
203 | 213 | else throw("error#7. Insufficient payment for asset link update service.") | |
204 | 214 | else throw("error#1. The service can only be paid in waves") | |
205 | 215 | } | |
206 | 216 | ||
207 | 217 |
github/deemru/w8io/873ac7e 47.12 ms ◑![]()