tx · ChGeWu4zwoRH9YgcF3C8QqCqokWcUAHYELf7j2GEmzQv

3N9tKixzqTYWnEXQxrDQ5pBTGvQd6sFsvmV:  -0.01000000 Waves

2023.09.07 13:11 [2744832] smart account 3N9tKixzqTYWnEXQxrDQ5pBTGvQd6sFsvmV > SELF 0.00000000 Waves

{ "type": 13, "id": "ChGeWu4zwoRH9YgcF3C8QqCqokWcUAHYELf7j2GEmzQv", "fee": 1000000, "feeAssetId": null, "timestamp": 1694081480345, "version": 2, "chainId": 84, "sender": "3N9tKixzqTYWnEXQxrDQ5pBTGvQd6sFsvmV", "senderPublicKey": "DS6HkopS9zypvxX6VhkdNvv6v4wcPZuChRvTwKJeacxE", "proofs": [ "5isETbTRQW8BMhEwKjDZYiMWAip8yUAfaUqGYTK13ZbxHcbBFHZAVhGBPN7eENUukw92JhEuzSAsTKvkbzEVH7RU" ], "script": "base64:BgIdCAISBAoCCAgSBQoDCAgIEgQKAggIEgQKAggIEgANABFBSV9UT0tFTl9BU1NFVF9JRAEgk+FyOHEEm2rommMfBCS3ZFOXLD68ZguDdK9ouySN4kIAC1NUQVRVU19PUEVOAgRvcGVuABJTVEFUVVNfQ0hFQ0tFRF9PVVQCC2NoZWNrZWRfb3V0AAtTVEFUVVNfRE9ORQIEZG9uZQAOQ0hFQ0tFRF9PVVRfQlkCEF9jaGVja2VkX291dF9ieV8AE1NJTVBMRV9DSEFUR1BUX1RBU0sCE3NpbXBsZV9DaGF0R1BUX3Rhc2sAEENIRUNLX09VVF9IRUlHSFQCEl9jaGVja19vdXRfaGVpZ2h0XwAPUkVHSVNURVJfSEVJR0hUAhFfcmVnaXN0ZXJfaGVpZ2h0XwANQ09NTUlUX0hFSUdIVAIPX2NvbW1pdF9oZWlnaHRfAQ9jYW5CZUNoZWNrZWRPdXQCBnRhc2tJZAR0eXBlBAZzdGF0dXMJAJ0IAgUEdGhpcwkArAICCQCsAgIFBnRhc2tJZAIIX3N0YXR1c18FBHR5cGUJAAACBQZzdGF0dXMFC1NUQVRVU19PUEVOAQ5pc0NvcnJlY3RBZ2VudAMGdGFza0lkB2FnZW50SWQEdHlwZQQPY2hlY2tvdXRBZ2VudElkCQCdCAIFBHRoaXMJAKwCAgkArAICBQZ0YXNrSWQFDkNIRUNLRURfT1VUX0JZBQR0eXBlCQAAAgUPY2hlY2tvdXRBZ2VudElkBQdhZ2VudElkAQlnZXRUYXNrSWQCBHR4SWQEdHlwZQQPY2FsbGVyUHVibGljS2V5BAckbWF0Y2gwCQCdCAIFBHRoaXMJAKwCAgkArAICBQR0eElkAg1faW5pdGlhbGl6ZXJfBQR0eXBlAwkAAQIFByRtYXRjaDACBlN0cmluZwQDc3RyBQckbWF0Y2gwBQNzdHICAAQHJG1hdGNoMAkAnQgCBQR0aGlzCQCsAgIJAKwCAgUEdHhJZAIBXwUPY2FsbGVyUHVibGljS2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQDc3RyBQckbWF0Y2gwBQNzdHICAAEPZ2V0UHJpY2VGb3JUeXBlAQR0eXBlBAckbWF0Y2gwCQCaCAIFBHRoaXMJAKwCAgIGcHJpY2VfBQR0eXBlAwkAAQIFByRtYXRjaDACA0ludAQBaQUHJG1hdGNoMAUBaQD///////////8BBQFpAQxyZWdpc3RlclRhc2sCC2Rlc2NyaXB0aW9uBHR5cGUEEG51bWJlck9mUGF5bWVudHMJAJADAQgFAWkIcGF5bWVudHMDCQECIT0CBRBudW1iZXJPZlBheW1lbnRzAAEJAAIBAhJQYXltZW50IG5lY2Vzc2FyeSEED2NhbGxlclB1YmxpY0tleQkA2AQBCAUBaQ9jYWxsZXJQdWJsaWNLZXkEBHR4SWQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAQHcGF5bWVudAkAkQMCCAUBaQhwYXltZW50cwAABANmZWUIBQdwYXltZW50BmFtb3VudAQKZmVlQXNzZXRJZAgFB3BheW1lbnQHYXNzZXRJZAQGdGFza0lkCQCsAgIJAKwCAgUEdHhJZAIBXwUPY2FsbGVyUHVibGljS2V5BAl0aW1lc3RhbXAIBQlsYXN0QmxvY2sJdGltZXN0YW1wBAZtaW5GZWUJAQ9nZXRQcmljZUZvclR5cGUBBQR0eXBlAwkBAiE9AgUKZmVlQXNzZXRJZAURQUlfVE9LRU5fQVNTRVRfSUQJAAIBAiZQYXltZW50IG9ubHkgcG9zc2libGUgaW4gdGhlIEFJIFRva2VuIQMJAAACBQZtaW5GZWUA////////////AQkAAgECGFRhc2sgdHlwZSBub3Qgc3VwcG9ydGVkIQMJAGYCBQZtaW5GZWUFA2ZlZQkAAgEJAKwCAgkArAICAh1QYXltZW50IG5lZWRzIHRvIGJlIGF0IGxlYXN0IAkApAMBBQZtaW5GZWUCCiBBSSBUb2tlbiEJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIFBnRhc2tJZAINX2Rlc2NyaXB0aW9uXwUEdHlwZQULZGVzY3JpcHRpb24JAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIFBHR4SWQCDV9pbml0aWFsaXplcl8FBHR5cGUFD2NhbGxlclB1YmxpY0tleQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAghfc3RhdHVzXwUEdHlwZQULU1RBVFVTX09QRU4JAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICBQZ0YXNrSWQCBV90eXBlBQR0eXBlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkBQ9SRUdJU1RFUl9IRUlHSFQFBHR5cGUFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFBnRhc2tJZAIUX3JlZ2lzdGVyX3RpbWVzdGFtcF8FBHR5cGUFCXRpbWVzdGFtcAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkArAICCQCsAgIJAKwCAgIFb3Blbl8FBHR5cGUCAV8FBnRhc2tJZAYFA25pbAFpARRyZWdpc3RlclRhc2tDYWxsYmFjawMLZGVzY3JpcHRpb24EdHlwZQhjYWxsYmFjawQQbnVtYmVyT2ZQYXltZW50cwkAkAMBCAUBaQhwYXltZW50cwMJAQIhPQIFEG51bWJlck9mUGF5bWVudHMAAQkAAgECElBheW1lbnQgbmVjZXNzYXJ5IQQPY2FsbGVyUHVibGljS2V5CQDYBAEIBQFpD2NhbGxlclB1YmxpY0tleQQGY2FsbGVyCQClCAEIBQFpBmNhbGxlcgQEdHhJZAkA2AQBCAUBaQ10cmFuc2FjdGlvbklkBAdwYXltZW50CQCRAwIIBQFpCHBheW1lbnRzAAAEA2ZlZQgFB3BheW1lbnQGYW1vdW50BApmZWVBc3NldElkCAUHcGF5bWVudAdhc3NldElkBAZ0YXNrSWQJAKwCAgkArAICBQR0eElkAgFfBQ9jYWxsZXJQdWJsaWNLZXkECXRpbWVzdGFtcAgFCWxhc3RCbG9jawl0aW1lc3RhbXAEBm1pbkZlZQkBD2dldFByaWNlRm9yVHlwZQEFBHR5cGUDCQECIT0CBQpmZWVBc3NldElkBRFBSV9UT0tFTl9BU1NFVF9JRAkAAgECJlBheW1lbnQgb25seSBwb3NzaWJsZSBpbiB0aGUgQUkgVG9rZW4hAwkAAAIFBm1pbkZlZQD///////////8BCQACAQIYVGFzayB0eXBlIG5vdCBzdXBwb3J0ZWQhAwkAZgIFBm1pbkZlZQUDZmVlCQACAQkArAICCQCsAgICHVBheW1lbnQgbmVlZHMgdG8gYmUgYXQgbGVhc3QgCQCkAwEFBm1pbkZlZQIKIEFJIFRva2VuIQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAg1fZGVzY3JpcHRpb25fBQR0eXBlBQtkZXNjcmlwdGlvbgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUEdHhJZAINX2luaXRpYWxpemVyXwUEdHlwZQUPY2FsbGVyUHVibGljS2V5CQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICBQR0eElkAgpfY2FsbGJhY2tfBQR0eXBlBQhjYWxsYmFjawkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUEdHhJZAIIX2NhbGxlcl8FBHR5cGUFBmNhbGxlcgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAghfc3RhdHVzXwUEdHlwZQULU1RBVFVTX09QRU4JAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICBQZ0YXNrSWQCBV90eXBlBQR0eXBlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkBQ9SRUdJU1RFUl9IRUlHSFQFBHR5cGUFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFBnRhc2tJZAIUX3JlZ2lzdGVyX3RpbWVzdGFtcF8FBHR5cGUFCXRpbWVzdGFtcAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkArAICCQCsAgIJAKwCAgIFb3Blbl8FBHR5cGUCAV8FBnRhc2tJZAYFA25pbAFpAQxjaGVja291dFRhc2sCBnRhc2tJZAR0eXBlBA9jYWxsZXJQdWJsaWNLZXkJANgEAQgFAWkPY2FsbGVyUHVibGljS2V5BA10YXNrU3RpbGxPcGVuCQEPY2FuQmVDaGVja2VkT3V0AgUGdGFza0lkBQR0eXBlBAl0aW1lc3RhbXAIBQlsYXN0QmxvY2sJdGltZXN0YW1wAwkBASEBBQ10YXNrU3RpbGxPcGVuCQACAQIbVGFzayBub3Qgb3BlbiBmb3IgY2hlY2tvdXQhCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICBQZ0YXNrSWQFDkNIRUNLRURfT1VUX0JZBQR0eXBlBQ9jYWxsZXJQdWJsaWNLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIFBnRhc2tJZAIIX3N0YXR1c18FBHR5cGUFElNUQVRVU19DSEVDS0VEX09VVAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFBnRhc2tJZAUQQ0hFQ0tfT1VUX0hFSUdIVAUEdHlwZQUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAhVfY2hlY2tfb3V0X3RpbWVzdGFtcF8FBHR5cGUFCXRpbWVzdGFtcAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICD2NoZWNrZWRfb3V0X2J5XwUPY2FsbGVyUHVibGljS2V5AgFfBQR0eXBlAgFfBQZ0YXNrSWQGCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgICBW9wZW5fBQR0eXBlAgFfBQZ0YXNrSWQFA25pbAFpAQpjb21taXRUYXNrAgZ0YXNrSWQIcmVzcG9uc2UED2NhbGxlclB1YmxpY0tleQkA2AQBCAUBaQ9jYWxsZXJQdWJsaWNLZXkEBHR5cGUEByRtYXRjaDAJAKIIAQkArAICBQZ0YXNrSWQCBV90eXBlAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAUBcwIHbm90IHNldAQMY29ycmVjdEFnZW50CQEOaXNDb3JyZWN0QWdlbnQDBQZ0YXNrSWQFD2NhbGxlclB1YmxpY0tleQUEdHlwZQQJdGltZXN0YW1wCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAQIY2FsbGJhY2sEByRtYXRjaDAJAKIIAQkArAICBQZ0YXNrSWQCCV9jYWxsYmFjawMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAFAXMCC25vIGNhbGxiYWNrBAZjYWxsZXIEByRtYXRjaDAJAKIIAQkArAICBQZ0YXNrSWQCB19jYWxsZXIDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwBQFzAgtubyBjYWxsYmFjawMJAQEhAQUMY29ycmVjdEFnZW50CQACAQJBVGFzayBtYXkgb25seSBiZSBzdWJtaXR0ZWQgYnkgdGhlIGFnZW50IHdobyBjaGVja2VkIHRoZSB0YXNrIG91dCEDCQAAAgUEdHlwZQIHbm90IHNldAkAAgECIENhbiBub3QgaWRlbnRpZnkgdHlwZSBvZiB0YXNrIGlkAwkBAiE9AgUIY2FsbGJhY2sCC25vIGNhbGxiYWNrBAZyZXN1bHQJAPwHBAkBB0FkZHJlc3MBCQDZBAEFBmNhbGxlcgUIY2FsbGJhY2sJAMwIAgUIcmVzcG9uc2UFA25pbAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICBQZ0YXNrSWQCCF9zdGF0dXNfBQR0eXBlBQtTVEFUVVNfRE9ORQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAghfcmVzdWx0XwUEdHlwZQUIcmVzcG9uc2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICBQZ0YXNrSWQFDUNPTU1JVF9IRUlHSFQFBHR5cGUFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFBnRhc2tJZAISX2NvbW1pdF90aW1lc3RhbXBfBQR0eXBlBQl0aW1lc3RhbXAJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgkArAICCQCsAgICD2NoZWNrZWRfb3V0X2J5XwUPY2FsbGVyUHVibGljS2V5AgFfBQR0eXBlAgFfBQZ0YXNrSWQFA25pbAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkAghfc3RhdHVzXwUEdHlwZQULU1RBVFVTX0RPTkUJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIFBnRhc2tJZAIIX3Jlc3VsdF8FBHR5cGUFCHJlc3BvbnNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUGdGFza0lkBQ1DT01NSVRfSEVJR0hUBQR0eXBlBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICBQZ0YXNrSWQCEl9jb21taXRfdGltZXN0YW1wXwUEdHlwZQUJdGltZXN0YW1wCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAg9jaGVja2VkX291dF9ieV8FD2NhbGxlclB1YmxpY0tleQIBXwUEdHlwZQIBXwUGdGFza0lkBQNuaWwBaQEDYnV5AAQRV0FWRVNfVVNEVF9PUkFDTEUJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNOMVdqaG1GM0V5dXR2cnZ0c2ZzU0xiaG1pTFU4QmMxVG95BBVXQVZFU19VU0RUX09SQUNMRV9LRVkCFyVzJXNfX3ByaWNlX19XQVZFUy1VU0RUBA1VU0RUX0FTU0VUX0lEAiw5OEQzcGtLdmZyWEVuWG1RcUtHV2d0b0d2VmgxYVRmNENQRHR0cUc5Y3N1bQQNVVNEQ19BU1NFVF9JRAIsOThEM3BrS3ZmclhFblhtUXFLR1dndG9HdlZoMWFUZjRDUER0dHFHOWNzdW0EDEJBSV9BU1NFVF9JRAIsQXhHS1FSeEtvNEYyRWJoclJxNk4ydGRMc3h0TW5welFzUzRRZW1WNlYxVzEEEG51bWJlck9mUGF5bWVudHMJAJADAQgFAWkIcGF5bWVudHMDCQECIT0CBRBudW1iZXJPZlBheW1lbnRzAAEJAAIBAhJQYXltZW50IG5lY2Vzc2FyeSEEB3BheW1lbnQJAJEDAggFAWkIcGF5bWVudHMAAAQKZmVlQXNzZXRJZAgFB3BheW1lbnQHYXNzZXRJZAQQZmVlQXNzZXRJZFN0cmluZwQHJG1hdGNoMAUKZmVlQXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFiBQckbWF0Y2gwCQDYBAEFAWICAAQNcGF5bWVudEFtb3VudAgFB3BheW1lbnQGYW1vdW50BAZhbW91bnQDCQEBIQEJAQlpc0RlZmluZWQBBQpmZWVBc3NldElkBA53YXZlc1VzZHRQcmljZQQHJG1hdGNoMAkAmggCBRFXQVZFU19VU0RUX09SQUNMRQUVV0FWRVNfVVNEVF9PUkFDTEVfS0VZAwkAAQIFByRtYXRjaDACA0ludAQBbgUHJG1hdGNoMAUBbgAACQBoAgkAawMFDXBheW1lbnRBbW91bnQFDndhdmVzVXNkdFByaWNlAIDC1y8AZAMJAAACBRBmZWVBc3NldElkU3RyaW5nBQ1VU0RUX0FTU0VUX0lECQBoAgUNcGF5bWVudEFtb3VudABkAwkAAAIFEGZlZUFzc2V0SWRTdHJpbmcFDVVTRENfQVNTRVRfSUQJAGgCBQ1wYXltZW50QW1vdW50AGQJAAIBAilwYXltZW50IG5lY2Vzc2FyeSBpbiBXYXZlcywgVVNEQyBvciBVU0RUIQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFBmFtb3VudAkA2QQBBQxCQUlfQVNTRVRfSUQFA25pbAECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkaZWhu", "height": 2744832, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 5EJBhiRcVDXxuJecUFqwuhcEDqS45XYyq3XGCddhE3Kt Next: 6RZiqs7RERs6TSjcGiamz6UN24nST3SuSnMvVVT6YW4q Diff:
OldNewDifferences
1919
2020 let COMMIT_HEIGHT = "_commit_height_"
2121
22-func canBeCheckedOut (taskId) = {
23- let status = getString(this, (taskId + "_status"))
22+func canBeCheckedOut (taskId,type) = {
23+ let status = getString(this, ((taskId + "_status_") + type))
2424 (status == STATUS_OPEN)
2525 }
2626
2727
28-func isCorrectAgent (taskId,agentId) = {
29- let checkoutAgentId = getString(this, (taskId + CHECKED_OUT_BY))
28+func isCorrectAgent (taskId,agentId,type) = {
29+ let checkoutAgentId = getString(this, ((taskId + CHECKED_OUT_BY) + type))
3030 (checkoutAgentId == agentId)
3131 }
3232
3333
34-func getTaskId (txId) = {
35- let callerPublicKey = match getString(this, (txId + "_initializer")) {
34+func getTaskId (txId,type) = {
35+ let callerPublicKey = match getString(this, ((txId + "_initializer_") + type)) {
3636 case str: String =>
3737 str
3838 case _ =>
111111 @Callable(i)
112112 func checkoutTask (taskId,type) = {
113113 let callerPublicKey = toBase58String(i.callerPublicKey)
114- let taskStillOpen = canBeCheckedOut(taskId)
114+ let taskStillOpen = canBeCheckedOut(taskId, type)
115115 let timestamp = lastBlock.timestamp
116116 if (!(taskStillOpen))
117117 then throw("Task not open for checkout!")
123123 @Callable(i)
124124 func commitTask (taskId,response) = {
125125 let callerPublicKey = toBase58String(i.callerPublicKey)
126- let correctAgent = isCorrectAgent(taskId, callerPublicKey)
127- let timestamp = lastBlock.timestamp
128126 let type = match getString((taskId + "_type")) {
129127 case s: String =>
130128 s
131129 case _ =>
132130 "not set"
133131 }
132+ let correctAgent = isCorrectAgent(taskId, callerPublicKey, type)
133+ let timestamp = lastBlock.timestamp
134134 let callback = match getString((taskId + "_callback")) {
135135 case s: String =>
136136 s
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let AI_TOKEN_ASSET_ID = base58'AxGKQRxKo4F2EbhrRq6N2tdLsxtMnpzQsS4QemV6V1W1'
55
66 let STATUS_OPEN = "open"
77
88 let STATUS_CHECKED_OUT = "checked_out"
99
1010 let STATUS_DONE = "done"
1111
1212 let CHECKED_OUT_BY = "_checked_out_by_"
1313
1414 let SIMPLE_CHATGPT_TASK = "simple_ChatGPT_task"
1515
1616 let CHECK_OUT_HEIGHT = "_check_out_height_"
1717
1818 let REGISTER_HEIGHT = "_register_height_"
1919
2020 let COMMIT_HEIGHT = "_commit_height_"
2121
22-func canBeCheckedOut (taskId) = {
23- let status = getString(this, (taskId + "_status"))
22+func canBeCheckedOut (taskId,type) = {
23+ let status = getString(this, ((taskId + "_status_") + type))
2424 (status == STATUS_OPEN)
2525 }
2626
2727
28-func isCorrectAgent (taskId,agentId) = {
29- let checkoutAgentId = getString(this, (taskId + CHECKED_OUT_BY))
28+func isCorrectAgent (taskId,agentId,type) = {
29+ let checkoutAgentId = getString(this, ((taskId + CHECKED_OUT_BY) + type))
3030 (checkoutAgentId == agentId)
3131 }
3232
3333
34-func getTaskId (txId) = {
35- let callerPublicKey = match getString(this, (txId + "_initializer")) {
34+func getTaskId (txId,type) = {
35+ let callerPublicKey = match getString(this, ((txId + "_initializer_") + type)) {
3636 case str: String =>
3737 str
3838 case _ =>
3939 ""
4040 }
4141 match getString(this, ((txId + "_") + callerPublicKey)) {
4242 case str: String =>
4343 str
4444 case _ =>
4545 ""
4646 }
4747 }
4848
4949
5050 func getPriceForType (type) = match getInteger(this, ("price_" + type)) {
5151 case i: Int =>
5252 i
5353 case _ =>
5454 -1
5555 }
5656
5757
5858 @Callable(i)
5959 func registerTask (description,type) = {
6060 let numberOfPayments = size(i.payments)
6161 if ((numberOfPayments != 1))
6262 then throw("Payment necessary!")
6363 else {
6464 let callerPublicKey = toBase58String(i.callerPublicKey)
6565 let txId = toBase58String(i.transactionId)
6666 let payment = i.payments[0]
6767 let fee = payment.amount
6868 let feeAssetId = payment.assetId
6969 let taskId = ((txId + "_") + callerPublicKey)
7070 let timestamp = lastBlock.timestamp
7171 let minFee = getPriceForType(type)
7272 if ((feeAssetId != AI_TOKEN_ASSET_ID))
7373 then throw("Payment only possible in the AI Token!")
7474 else if ((minFee == -1))
7575 then throw("Task type not supported!")
7676 else if ((minFee > fee))
7777 then throw((("Payment needs to be at least " + toString(minFee)) + " AI Token!"))
7878 else [StringEntry(((taskId + "_description_") + type), description), StringEntry(((txId + "_initializer_") + type), callerPublicKey), StringEntry(((taskId + "_status_") + type), STATUS_OPEN), StringEntry((taskId + "_type"), type), IntegerEntry(((taskId + REGISTER_HEIGHT) + type), height), IntegerEntry(((taskId + "_register_timestamp_") + type), timestamp), BooleanEntry(((("open_" + type) + "_") + taskId), true)]
7979 }
8080 }
8181
8282
8383
8484 @Callable(i)
8585 func registerTaskCallback (description,type,callback) = {
8686 let numberOfPayments = size(i.payments)
8787 if ((numberOfPayments != 1))
8888 then throw("Payment necessary!")
8989 else {
9090 let callerPublicKey = toBase58String(i.callerPublicKey)
9191 let caller = toString(i.caller)
9292 let txId = toBase58String(i.transactionId)
9393 let payment = i.payments[0]
9494 let fee = payment.amount
9595 let feeAssetId = payment.assetId
9696 let taskId = ((txId + "_") + callerPublicKey)
9797 let timestamp = lastBlock.timestamp
9898 let minFee = getPriceForType(type)
9999 if ((feeAssetId != AI_TOKEN_ASSET_ID))
100100 then throw("Payment only possible in the AI Token!")
101101 else if ((minFee == -1))
102102 then throw("Task type not supported!")
103103 else if ((minFee > fee))
104104 then throw((("Payment needs to be at least " + toString(minFee)) + " AI Token!"))
105105 else [StringEntry(((taskId + "_description_") + type), description), StringEntry(((txId + "_initializer_") + type), callerPublicKey), StringEntry(((txId + "_callback_") + type), callback), StringEntry(((txId + "_caller_") + type), caller), StringEntry(((taskId + "_status_") + type), STATUS_OPEN), StringEntry((taskId + "_type"), type), IntegerEntry(((taskId + REGISTER_HEIGHT) + type), height), IntegerEntry(((taskId + "_register_timestamp_") + type), timestamp), BooleanEntry(((("open_" + type) + "_") + taskId), true)]
106106 }
107107 }
108108
109109
110110
111111 @Callable(i)
112112 func checkoutTask (taskId,type) = {
113113 let callerPublicKey = toBase58String(i.callerPublicKey)
114- let taskStillOpen = canBeCheckedOut(taskId)
114+ let taskStillOpen = canBeCheckedOut(taskId, type)
115115 let timestamp = lastBlock.timestamp
116116 if (!(taskStillOpen))
117117 then throw("Task not open for checkout!")
118118 else [StringEntry(((taskId + CHECKED_OUT_BY) + type), callerPublicKey), StringEntry(((taskId + "_status_") + type), STATUS_CHECKED_OUT), IntegerEntry(((taskId + CHECK_OUT_HEIGHT) + type), height), IntegerEntry(((taskId + "_check_out_timestamp_") + type), timestamp), BooleanEntry(((((("checked_out_by_" + callerPublicKey) + "_") + type) + "_") + taskId), true), DeleteEntry(((("open_" + type) + "_") + taskId))]
119119 }
120120
121121
122122
123123 @Callable(i)
124124 func commitTask (taskId,response) = {
125125 let callerPublicKey = toBase58String(i.callerPublicKey)
126- let correctAgent = isCorrectAgent(taskId, callerPublicKey)
127- let timestamp = lastBlock.timestamp
128126 let type = match getString((taskId + "_type")) {
129127 case s: String =>
130128 s
131129 case _ =>
132130 "not set"
133131 }
132+ let correctAgent = isCorrectAgent(taskId, callerPublicKey, type)
133+ let timestamp = lastBlock.timestamp
134134 let callback = match getString((taskId + "_callback")) {
135135 case s: String =>
136136 s
137137 case _ =>
138138 "no callback"
139139 }
140140 let caller = match getString((taskId + "_caller")) {
141141 case s: String =>
142142 s
143143 case _ =>
144144 "no callback"
145145 }
146146 if (!(correctAgent))
147147 then throw("Task may only be submitted by the agent who checked the task out!")
148148 else if ((type == "not set"))
149149 then throw("Can not identify type of task id")
150150 else if ((callback != "no callback"))
151151 then {
152152 let result = invoke(Address(fromBase58String(caller)), callback, [response], nil)
153153 [StringEntry(((taskId + "_status_") + type), STATUS_DONE), StringEntry(((taskId + "_result_") + type), response), IntegerEntry(((taskId + COMMIT_HEIGHT) + type), height), IntegerEntry(((taskId + "_commit_timestamp_") + type), timestamp), DeleteEntry(((((("checked_out_by_" + callerPublicKey) + "_") + type) + "_") + taskId))]
154154 }
155155 else [StringEntry(((taskId + "_status_") + type), STATUS_DONE), StringEntry(((taskId + "_result_") + type), response), IntegerEntry(((taskId + COMMIT_HEIGHT) + type), height), IntegerEntry(((taskId + "_commit_timestamp_") + type), timestamp), DeleteEntry(((((("checked_out_by_" + callerPublicKey) + "_") + type) + "_") + taskId))]
156156 }
157157
158158
159159
160160 @Callable(i)
161161 func buy () = {
162162 let WAVES_USDT_ORACLE = addressFromStringValue("3N1WjhmF3EyutvrvtsfsSLbhmiLU8Bc1Toy")
163163 let WAVES_USDT_ORACLE_KEY = "%s%s__price__WAVES-USDT"
164164 let USDT_ASSET_ID = "98D3pkKvfrXEnXmQqKGWgtoGvVh1aTf4CPDttqG9csum"
165165 let USDC_ASSET_ID = "98D3pkKvfrXEnXmQqKGWgtoGvVh1aTf4CPDttqG9csum"
166166 let BAI_ASSET_ID = "AxGKQRxKo4F2EbhrRq6N2tdLsxtMnpzQsS4QemV6V1W1"
167167 let numberOfPayments = size(i.payments)
168168 if ((numberOfPayments != 1))
169169 then throw("Payment necessary!")
170170 else {
171171 let payment = i.payments[0]
172172 let feeAssetId = payment.assetId
173173 let feeAssetIdString = match feeAssetId {
174174 case b: ByteVector =>
175175 toBase58String(b)
176176 case _ =>
177177 ""
178178 }
179179 let paymentAmount = payment.amount
180180 let amount = if (!(isDefined(feeAssetId)))
181181 then {
182182 let wavesUsdtPrice = match getInteger(WAVES_USDT_ORACLE, WAVES_USDT_ORACLE_KEY) {
183183 case n: Int =>
184184 n
185185 case _ =>
186186 0
187187 }
188188 (fraction(paymentAmount, wavesUsdtPrice, 100000000) * 100)
189189 }
190190 else if ((feeAssetIdString == USDT_ASSET_ID))
191191 then (paymentAmount * 100)
192192 else if ((feeAssetIdString == USDC_ASSET_ID))
193193 then (paymentAmount * 100)
194194 else throw("payment necessary in Waves, USDC or USDT!")
195195 [ScriptTransfer(i.caller, amount, fromBase58String(BAI_ASSET_ID))]
196196 }
197197 }
198198
199199
200200 @Verifier(tx)
201201 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
202202

github/deemru/w8io/3ef1775 
51.89 ms