tx · 3DW1tQC1Q5jNQwiyGxnst8gAcEYicg7TDGH6J2Q8D49N

3N91zFrRoofbPpkoDbWKrQsQSdLu2EgLL8c:  -0.01000000 Waves

2023.12.06 17:24 [2874905] smart account 3N91zFrRoofbPpkoDbWKrQsQSdLu2EgLL8c > SELF 0.00000000 Waves

{ "type": 13, "id": "3DW1tQC1Q5jNQwiyGxnst8gAcEYicg7TDGH6J2Q8D49N", "fee": 1000000, "feeAssetId": null, "timestamp": 1701872711983, "version": 2, "chainId": 84, "sender": "3N91zFrRoofbPpkoDbWKrQsQSdLu2EgLL8c", "senderPublicKey": "5FyjUYCR5Q8jvG6ri6Ysz574HerUK6r1LJzzQ7DvSkLk", "proofs": [ "4Ac3V19EsuoHxT4h425xtwMKtjSzLYvC2i4dmW5odnRderrRj1GrXwrKseLSWYLrc7gmLtC8jz8ctWJifZGs4vWF" ], "script": "base64:BgIVCAISBgoEAgICARIECgIICBIDCgECIQAJc2VwYXJhdG9yAgJfXwAHY2hhaW5JZAkAyQECCQDKAQIIBQR0aGlzBWJ5dGVzAAEAAQAIY2hhaW5JZFQBAVQACGNoYWluSWRXAQFXAQttdXN0QWRkcmVzcwIBaQdhZGRyZXNzAwkAAAIIBQFpBmNhbGxlcgUHYWRkcmVzcwYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAEIbXVzdFRoaXMBAWkJAQttdXN0QWRkcmVzcwIFAWkFBHRoaXMAC3dhdmVzU3RyaW5nAgVXQVZFUwANcXVldWVJdGVtU2l6ZQAgAQxwYXJzZUFzc2V0SWQBBWlucHV0AwkAAAIFBWlucHV0BQt3YXZlc1N0cmluZwUEdW5pdAkA2QQBBQVpbnB1dAEPYXNzZXRJZFRvU3RyaW5nAQVpbnB1dAMJAAACBQVpbnB1dAUEdW5pdAULd2F2ZXNTdHJpbmcJANgEAQkBBXZhbHVlAQUFaW5wdXQAEWtTZXJ2aWNlUHVibGljS2V5AhQlc19fc2VydmljZVB1YmxpY0tleQANa0JvdFB1YmxpY0tleQIQJXNfX2JvdFB1YmxpY0tleQAOa0FjY291bnRTY3JpcHQCESVzX19hY2NvdW50U2NyaXB0AQ1hY2NvdW50U2NyaXB0AAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCcCAIFBHRoaXMFDmtBY2NvdW50U2NyaXB0AhlhY2NvdW50IHNjcmlwdCBpcyBub3Qgc2V0AA1rUmV3YXJkQW1vdW50AhAlc19fcmV3YXJkQW1vdW50AQxyZXdhcmRBbW91bnQACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUEdGhpcwUNa1Jld2FyZEFtb3VudAIYcmV3YXJkIGFtb3VudCBpcyBub3Qgc2V0ABRSRVFVRVNUX1NUQVRVU19FTVBUWQAAABRSRVFVRVNUX1NUQVRVU19SRUFEWQABAQ5rUmVxdWVzdFN0YXR1cwEJcmVxdWVzdElkCQC5CQIJAMwIAgIEJXMlcwkAzAgCCQDYBAEFCXJlcXVlc3RJZAkAzAgCAgZzdGF0dXMFA25pbAUJc2VwYXJhdG9yARhrQWNjb3VudENyZWF0b3JQdWJsaWNLZXkBDmFjY291bnRBZGRyZXNzCQC5CQIJAMwIAgIEJXMlcwkAzAgCCQClCAEFDmFjY291bnRBZGRyZXNzCQDMCAICEGNyZWF0b3JQdWJsaWNLZXkFA25pbAUJc2VwYXJhdG9yARZrUmVxdWVzdE93bmVyUHVibGljS2V5AQlyZXF1ZXN0SWQJALkJAgkAzAgCAgQlcyVzCQDMCAIJANgEAQUJcmVxdWVzdElkCQDMCAICDm93bmVyUHVibGljS2V5BQNuaWwFCXNlcGFyYXRvcgEVa1JlcXVlc3RBbW91bnRBc3NldElkAQlyZXF1ZXN0SWQJALkJAgkAzAgCAgQlcyVzCQDMCAIJANgEAQUJcmVxdWVzdElkCQDMCAICDWFtb3VudEFzc2V0SWQFA25pbAUJc2VwYXJhdG9yARRrUmVxdWVzdFByaWNlQXNzZXRJZAEJcmVxdWVzdElkCQC5CQIJAMwIAgIEJXMlcwkAzAgCCQDYBAEFCXJlcXVlc3RJZAkAzAgCAgxwcmljZUFzc2V0SWQFA25pbAUJc2VwYXJhdG9yARxrUmVxdWVzdElkVG9BY2NvdW50UHVibGljS2V5AQlyZXF1ZXN0SWQJALkJAgkAzAgCAgQlcyVzCQDMCAIJANgEAQUJcmVxdWVzdElkCQDMCAICG3JlcXVlc3RJZFRvQWNjb3VudFB1YmxpY0tleQUDbmlsBQlzZXBhcmF0b3IBGmtBY2NvdW50QWRkcmVzc1RvUmVxdWVzdElkAQ5hY2NvdW50QWRkcmVzcwkAuQkCCQDMCAICBCVzJXMJAMwIAgkApQgBBQ5hY2NvdW50QWRkcmVzcwkAzAgCAhlhY2NvdW50QWRkcmVzc1RvUmVxdWVzdElkBQNuaWwFCXNlcGFyYXRvcgEOa1JlcXVlc3RzUXVldWUACQC5CQIJAMwIAgICJXMJAMwIAgINcmVxdWVzdHNRdWV1ZQUDbmlsBQlzZXBhcmF0b3IBDXJlcXVlc3RzUXVldWUACQELdmFsdWVPckVsc2UCCQCcCAIFBHRoaXMJAQ5rUmVxdWVzdHNRdWV1ZQABAAEOa0FjY291bnRzUXVldWUACQC5CQIJAMwIAgICJXMJAMwIAgINYWNjb3VudHNRdWV1ZQUDbmlsBQlzZXBhcmF0b3IBDWFjY291bnRzUXVldWUACQELdmFsdWVPckVsc2UCCQCcCAIFBHRoaXMJAQ5rQWNjb3VudHNRdWV1ZQABAAEMa1BhaXJBbGxvd2VkAg1hbW91bnRBc3NldElkDHByaWNlQXNzZXRJZAkAuQkCCQDMCAICBiVzJXMlcwkAzAgCCQEPYXNzZXRJZFRvU3RyaW5nAQUNYW1vdW50QXNzZXRJZAkAzAgCCQEPYXNzZXRJZFRvU3RyaW5nAQUMcHJpY2VBc3NldElkCQDMCAICC3BhaXJBbGxvd2VkBQNuaWwFCXNlcGFyYXRvcgELcGFpckFsbG93ZWQCDWFtb3VudEFzc2V0SWQMcHJpY2VBc3NldElkCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJAQxrUGFpckFsbG93ZWQCBQ1hbW91bnRBc3NldElkBQxwcmljZUFzc2V0SWQHAA5zZXJ2aWNlQWRkcmVzcwkApwgBCQERQGV4dHJOYXRpdmUoMTA1MikCBQR0aGlzBRFrU2VydmljZVB1YmxpY0tleQAMYm90UHVibGljS2V5CQERQGV4dHJOYXRpdmUoMTA1MikCBQR0aGlzBQ1rQm90UHVibGljS2V5AwFpAQRpbml0BBBzZXJ2aWNlUHVibGljS2V5DGJvdFB1YmxpY0tleQ1hY2NvdW50U2NyaXB0DHJld2FyZEFtb3VudAQLY2hlY2tDYWxsZXIJAQhtdXN0VGhpcwEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyCQCUCgIJAMwIAgkBC0JpbmFyeUVudHJ5AgURa1NlcnZpY2VQdWJsaWNLZXkFEHNlcnZpY2VQdWJsaWNLZXkJAMwIAgkBC0JpbmFyeUVudHJ5AgUNa0JvdFB1YmxpY0tleQUMYm90UHVibGljS2V5CQDMCAIJAQtCaW5hcnlFbnRyeQIFDmtBY2NvdW50U2NyaXB0BQ1hY2NvdW50U2NyaXB0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ1rUmV3YXJkQW1vdW50BQxyZXdhcmRBbW91bnQFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ5yZXF1ZXN0QWNjb3VudAIQYW1vdW50QXNzZXRJZFN0cg9wcmljZUFzc2V0SWRTdHIECXJlcXVlc3RJZAkA9wMBCQDLAQIJAMsBAggIBQFpBmNhbGxlcgVieXRlcwkA2QQBBRBhbW91bnRBc3NldElkU3RyCQDZBAEFD3ByaWNlQXNzZXRJZFN0cgQNYW1vdW50QXNzZXRJZAkBDHBhcnNlQXNzZXRJZAEFEGFtb3VudEFzc2V0SWRTdHIEDHByaWNlQXNzZXRJZAkBDHBhcnNlQXNzZXRJZAEFD3ByaWNlQXNzZXRJZFN0cgQGY2hlY2tzCQDMCAIDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABBgkAAgECFTEgcGF5bWVudCBpcyByZXF1aXJlZAkAzAgCAwkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUEdW5pdAYJAAIBAg1pbnZhbGlkIGFzc2V0CQDMCAIDCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAQxyZXdhcmRBbW91bnQABgkAAgECDmludmFsaWQgYW1vdW50CQDMCAIDCQELcGFpckFsbG93ZWQCBQ1hbW91bnRBc3NldElkBQxwcmljZUFzc2V0SWQGCQACAQITcGFpciBpcyBub3QgYWxsb3dlZAkAzAgCAwkAAAIJAJoIAgUEdGhpcwkBDmtSZXF1ZXN0U3RhdHVzAQUJcmVxdWVzdElkBQR1bml0BgkAAgECGWFjY291bnQgaXMgYWxyZWFkeSBleGlzdHMFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQHYWN0aW9ucwMJAAACCQDIAQEJAQ1hY2NvdW50c1F1ZXVlAAAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOa1JlcXVlc3RTdGF0dXMBBQlyZXF1ZXN0SWQFFFJFUVVFU1RfU1RBVFVTX0VNUFRZCQDMCAIJAQtCaW5hcnlFbnRyeQIJAQ5rUmVxdWVzdHNRdWV1ZQAJAMsBAgkBDXJlcXVlc3RzUXVldWUABQlyZXF1ZXN0SWQFA25pbAQQYWNjb3VudFB1YmxpY0tleQkAyQECCQENYWNjb3VudHNRdWV1ZQAFDXF1ZXVlSXRlbVNpemUEDmFjY291bnRBZGRyZXNzCQCnCAEFEGFjY291bnRQdWJsaWNLZXkEDmNyZWF0b3JBZGRyZXNzCQCnCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnAgCBQR0aGlzCQEYa0FjY291bnRDcmVhdG9yUHVibGljS2V5AQUOYWNjb3VudEFkZHJlc3MCGmludmFsaWQgY3JlYXRvciBwdWJsaWMga2V5CQDMCAIJAQtCaW5hcnlFbnRyeQIJAQ5rQWNjb3VudHNRdWV1ZQAJAMoBAgkBDWFjY291bnRzUXVldWUABQ1xdWV1ZUl0ZW1TaXplCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOa1JlcXVlc3RTdGF0dXMBBQlyZXF1ZXN0SWQFFFJFUVVFU1RfU1RBVFVTX1JFQURZCQDMCAIJAQtCaW5hcnlFbnRyeQIJARxrUmVxdWVzdElkVG9BY2NvdW50UHVibGljS2V5AQUJcmVxdWVzdElkBRBhY2NvdW50UHVibGljS2V5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARprQWNjb3VudEFkZHJlc3NUb1JlcXVlc3RJZAEFDmFjY291bnRBZGRyZXNzCQDYBAEFCXJlcXVlc3RJZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQ5jcmVhdG9yQWRkcmVzcwkBDHJld2FyZEFtb3VudAAFBHVuaXQFA25pbAkAlAoCCQDOCAIFB2FjdGlvbnMJAMwIAgkBC0JpbmFyeUVudHJ5AgkBFmtSZXF1ZXN0T3duZXJQdWJsaWNLZXkBBQlyZXF1ZXN0SWQIBQFpD2NhbGxlclB1YmxpY0tleQkAzAgCCQELU3RyaW5nRW50cnkCCQEVa1JlcXVlc3RBbW91bnRBc3NldElkAQUJcmVxdWVzdElkBRBhbW91bnRBc3NldElkU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJARRrUmVxdWVzdFByaWNlQXNzZXRJZAEFCXJlcXVlc3RJZAUPcHJpY2VBc3NldElkU3RyBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKYWRkQWNjb3VudAEQY3JlYXRvclB1YmxpY0tleQQQYWNjb3VudFB1YmxpY0tleQgFAWkPY2FsbGVyUHVibGljS2V5BA5hY2NvdW50QWRkcmVzcwgFAWkGY2FsbGVyBA5jcmVhdG9yQWRkcmVzcwkApwgBBRBjcmVhdG9yUHVibGljS2V5BAZjaGVja3MJAMwIAgkAAgECBHRlc3QJAMwIAgMJAAACCQCcCAIFBHRoaXMJARhrQWNjb3VudENyZWF0b3JQdWJsaWNLZXkBBQ5hY2NvdW50QWRkcmVzcwUEdW5pdAYJAAIBAhlhY2NvdW50IGlzIGFscmVhZHkgZXhpc3RzCQDMCAIDBAckbWF0Y2gwCQDxBwEFDmFjY291bnRBZGRyZXNzAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAWIFByRtYXRjaDAJAAACBQFiCQDxFQEJAQ1hY2NvdW50U2NyaXB0AAcGCQACAQIOaW52YWxpZCBzY3JpcHQFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQHYWN0aW9ucwMJAAACCQDIAQEJAQ1yZXF1ZXN0c1F1ZXVlAAAACQDMCAIJAQtCaW5hcnlFbnRyeQIJAQ5rQWNjb3VudHNRdWV1ZQAJAMsBAgkBDWFjY291bnRzUXVldWUABRBhY2NvdW50UHVibGljS2V5BQNuaWwECXJlcXVlc3RJZAkAyQECCQENcmVxdWVzdHNRdWV1ZQAFDXF1ZXVlSXRlbVNpemUJAMwIAgkBC0JpbmFyeUVudHJ5AgkBDmtSZXF1ZXN0c1F1ZXVlAAkAygECCQENcmVxdWVzdHNRdWV1ZQAFDXF1ZXVlSXRlbVNpemUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ5rUmVxdWVzdFN0YXR1cwEFCXJlcXVlc3RJZAUUUkVRVUVTVF9TVEFUVVNfUkVBRFkJAMwIAgkBC0JpbmFyeUVudHJ5AgkBHGtSZXF1ZXN0SWRUb0FjY291bnRQdWJsaWNLZXkBBQlyZXF1ZXN0SWQFEGFjY291bnRQdWJsaWNLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBGmtBY2NvdW50QWRkcmVzc1RvUmVxdWVzdElkAQUOYWNjb3VudEFkZHJlc3MJANgEAQUJcmVxdWVzdElkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFDmNyZWF0b3JBZGRyZXNzCQEMcmV3YXJkQW1vdW50AAUEdW5pdAUDbmlsCQCUCgIJAM4IAgUHYWN0aW9ucwkAzAgCCQELQmluYXJ5RW50cnkCCQEYa0FjY291bnRDcmVhdG9yUHVibGljS2V5AQUOYWNjb3VudEFkZHJlc3MFEGNyZWF0b3JQdWJsaWNLZXkFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgCG6lJT", "height": 2874905, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 22nZWUvTNviqAg9qHtfgwQo3CwvQDsgtsarFSAU5kac7 Next: FKMuH5AFy6mVBDmLLsziqzMh8pk2WLoT2P5VR6aSZeFp Diff:
OldNewDifferences
140140 let accountPublicKey = i.callerPublicKey
141141 let accountAddress = i.caller
142142 let creatorAddress = addressFromPublicKey(creatorPublicKey)
143- let checks = [if ((getBinary(this, kAccountCreatorPublicKey(accountAddress)) == unit))
143+ let checks = [throw("test"), if ((getBinary(this, kAccountCreatorPublicKey(accountAddress)) == unit))
144144 then true
145145 else throw("account is already exists"), if ( match scriptHash(accountAddress) {
146146 case b: ByteVector =>
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let separator = "__"
55
66 let chainId = take(drop(this.bytes, 1), 1)
77
88 let chainIdT = base58'2T'
99
1010 let chainIdW = base58'2W'
1111
1212 func mustAddress (i,address) = if ((i.caller == address))
1313 then true
1414 else throw("permission denied")
1515
1616
1717 func mustThis (i) = mustAddress(i, this)
1818
1919
2020 let wavesString = "WAVES"
2121
2222 let queueItemSize = 32
2323
2424 func parseAssetId (input) = if ((input == wavesString))
2525 then unit
2626 else fromBase58String(input)
2727
2828
2929 func assetIdToString (input) = if ((input == unit))
3030 then wavesString
3131 else toBase58String(value(input))
3232
3333
3434 let kServicePublicKey = "%s__servicePublicKey"
3535
3636 let kBotPublicKey = "%s__botPublicKey"
3737
3838 let kAccountScript = "%s__accountScript"
3939
4040 func accountScript () = valueOrErrorMessage(getBinary(this, kAccountScript), "account script is not set")
4141
4242
4343 let kRewardAmount = "%s__rewardAmount"
4444
4545 func rewardAmount () = valueOrErrorMessage(getInteger(this, kRewardAmount), "reward amount is not set")
4646
4747
4848 let REQUEST_STATUS_EMPTY = 0
4949
5050 let REQUEST_STATUS_READY = 1
5151
5252 func kRequestStatus (requestId) = makeString(["%s%s", toBase58String(requestId), "status"], separator)
5353
5454
5555 func kAccountCreatorPublicKey (accountAddress) = makeString(["%s%s", toString(accountAddress), "creatorPublicKey"], separator)
5656
5757
5858 func kRequestOwnerPublicKey (requestId) = makeString(["%s%s", toBase58String(requestId), "ownerPublicKey"], separator)
5959
6060
6161 func kRequestAmountAssetId (requestId) = makeString(["%s%s", toBase58String(requestId), "amountAssetId"], separator)
6262
6363
6464 func kRequestPriceAssetId (requestId) = makeString(["%s%s", toBase58String(requestId), "priceAssetId"], separator)
6565
6666
6767 func kRequestIdToAccountPublicKey (requestId) = makeString(["%s%s", toBase58String(requestId), "requestIdToAccountPublicKey"], separator)
6868
6969
7070 func kAccountAddressToRequestId (accountAddress) = makeString(["%s%s", toString(accountAddress), "accountAddressToRequestId"], separator)
7171
7272
7373 func kRequestsQueue () = makeString(["%s", "requestsQueue"], separator)
7474
7575
7676 func requestsQueue () = valueOrElse(getBinary(this, kRequestsQueue()), base58'')
7777
7878
7979 func kAccountsQueue () = makeString(["%s", "accountsQueue"], separator)
8080
8181
8282 func accountsQueue () = valueOrElse(getBinary(this, kAccountsQueue()), base58'')
8383
8484
8585 func kPairAllowed (amountAssetId,priceAssetId) = makeString(["%s%s%s", assetIdToString(amountAssetId), assetIdToString(priceAssetId), "pairAllowed"], separator)
8686
8787
8888 func pairAllowed (amountAssetId,priceAssetId) = valueOrElse(getBoolean(this, kPairAllowed(amountAssetId, priceAssetId)), false)
8989
9090
9191 let serviceAddress = addressFromPublicKey(getBinaryValue(this, kServicePublicKey))
9292
9393 let botPublicKey = getBinaryValue(this, kBotPublicKey)
9494
9595 @Callable(i)
9696 func init (servicePublicKey,botPublicKey,accountScript,rewardAmount) = {
9797 let checkCaller = mustThis(i)
9898 if ((checkCaller == checkCaller))
9999 then $Tuple2([BinaryEntry(kServicePublicKey, servicePublicKey), BinaryEntry(kBotPublicKey, botPublicKey), BinaryEntry(kAccountScript, accountScript), IntegerEntry(kRewardAmount, rewardAmount)], unit)
100100 else throw("Strict value is not equal to itself.")
101101 }
102102
103103
104104
105105 @Callable(i)
106106 func requestAccount (amountAssetIdStr,priceAssetIdStr) = {
107107 let requestId = sha256(((i.caller.bytes + fromBase58String(amountAssetIdStr)) + fromBase58String(priceAssetIdStr)))
108108 let amountAssetId = parseAssetId(amountAssetIdStr)
109109 let priceAssetId = parseAssetId(priceAssetIdStr)
110110 let checks = [if ((size(i.payments) == 1))
111111 then true
112112 else throw("1 payment is required"), if ((i.payments[0].assetId == unit))
113113 then true
114114 else throw("invalid asset"), if ((i.payments[0].amount == rewardAmount()))
115115 then true
116116 else throw("invalid amount"), if (pairAllowed(amountAssetId, priceAssetId))
117117 then true
118118 else throw("pair is not allowed"), if ((getInteger(this, kRequestStatus(requestId)) == unit))
119119 then true
120120 else throw("account is already exists")]
121121 if ((checks == checks))
122122 then {
123123 let actions = if ((size(accountsQueue()) == 0))
124124 then [IntegerEntry(kRequestStatus(requestId), REQUEST_STATUS_EMPTY), BinaryEntry(kRequestsQueue(), (requestsQueue() + requestId))]
125125 else {
126126 let accountPublicKey = take(accountsQueue(), queueItemSize)
127127 let accountAddress = addressFromPublicKey(accountPublicKey)
128128 let creatorAddress = addressFromPublicKey(valueOrErrorMessage(getBinary(this, kAccountCreatorPublicKey(accountAddress)), "invalid creator public key"))
129129 [BinaryEntry(kAccountsQueue(), drop(accountsQueue(), queueItemSize)), IntegerEntry(kRequestStatus(requestId), REQUEST_STATUS_READY), BinaryEntry(kRequestIdToAccountPublicKey(requestId), accountPublicKey), StringEntry(kAccountAddressToRequestId(accountAddress), toBase58String(requestId)), ScriptTransfer(creatorAddress, rewardAmount(), unit)]
130130 }
131131 $Tuple2((actions ++ [BinaryEntry(kRequestOwnerPublicKey(requestId), i.callerPublicKey), StringEntry(kRequestAmountAssetId(requestId), amountAssetIdStr), StringEntry(kRequestPriceAssetId(requestId), priceAssetIdStr)]), unit)
132132 }
133133 else throw("Strict value is not equal to itself.")
134134 }
135135
136136
137137
138138 @Callable(i)
139139 func addAccount (creatorPublicKey) = {
140140 let accountPublicKey = i.callerPublicKey
141141 let accountAddress = i.caller
142142 let creatorAddress = addressFromPublicKey(creatorPublicKey)
143- let checks = [if ((getBinary(this, kAccountCreatorPublicKey(accountAddress)) == unit))
143+ let checks = [throw("test"), if ((getBinary(this, kAccountCreatorPublicKey(accountAddress)) == unit))
144144 then true
145145 else throw("account is already exists"), if ( match scriptHash(accountAddress) {
146146 case b: ByteVector =>
147147 (b == blake2b256_32Kb(accountScript()))
148148 case _ =>
149149 false
150150 })
151151 then true
152152 else throw("invalid script")]
153153 if ((checks == checks))
154154 then {
155155 let actions = if ((size(requestsQueue()) == 0))
156156 then [BinaryEntry(kAccountsQueue(), (accountsQueue() + accountPublicKey))]
157157 else {
158158 let requestId = take(requestsQueue(), queueItemSize)
159159 [BinaryEntry(kRequestsQueue(), drop(requestsQueue(), queueItemSize)), IntegerEntry(kRequestStatus(requestId), REQUEST_STATUS_READY), BinaryEntry(kRequestIdToAccountPublicKey(requestId), accountPublicKey), StringEntry(kAccountAddressToRequestId(accountAddress), toBase58String(requestId)), ScriptTransfer(creatorAddress, rewardAmount(), unit)]
160160 }
161161 $Tuple2((actions ++ [BinaryEntry(kAccountCreatorPublicKey(accountAddress), creatorPublicKey)]), unit)
162162 }
163163 else throw("Strict value is not equal to itself.")
164164 }
165165
166166

github/deemru/w8io/026f985 
31.37 ms