tx · EQo1RE32saFNforZA4FDPBjNY1VsVtUGMZxPV1Lgt9LD
3Mz29fiz3zgY9JDbiHKANvHsFgQutdfu4Ua: -0.01400000 Waves
2021.03.17 13:12 [1441584] smart account 3Mz29fiz3zgY9JDbiHKANvHsFgQutdfu4Ua > SELF 0.00000000 Waves
{
"type": 13,
"id": "EQo1RE32saFNforZA4FDPBjNY1VsVtUGMZxPV1Lgt9LD",
"fee": 1400000,
"feeAssetId": null,
"timestamp": 1615975977813,
"version": 2,
"chainId": 84,
"sender": "3Mz29fiz3zgY9JDbiHKANvHsFgQutdfu4Ua",
"senderPublicKey": "CTyHhnVTxf16Z4CmGGneAK8WB5g2QyT4MB8kUn8vPPcu",
"proofs": [
"kV2cbMuwh4KpujTRe273K4XsfMXibfroDVHksB5aFtLc84ttjfq5nFX5mLPQXSFm5u2cjoGg7Mi3iwMsVBvZTdb"
],
"script": "base64:AAIEAAAAAAAAAAkIAhIAEgMKAQgAAAAEAAAAAAlzZXBhcmF0b3ICAAAAA19fXwAAAAARa2V5TG9ja2FibGVBc3NldHMCAAAAE2RBcHBfTG9ja2FibGVBc3NldHMBAAAADWdldEFzc2V0SW5mb3MAAAABAAAAB2Fzc2V0SWQEAAAAByRtYXRjaDAJAAPsAAAAAQUAAAAHYXNzZXRJZAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAFQXNzZXQEAAAAB2lzQXNzZXQFAAAAByRtYXRjaDAFAAAAB2lzQXNzZXQJAAACAAAAAQIAAAAVTm90IGFuIGV4aXN0aW5nIGFzc2V0AQAAABFnZXRMb2NrYWJsZUFzc2V0cwAAAAAJAAS1AAAAAgkBAAAAEUBleHRyTmF0aXZlKDEwNTMpAAAAAgUAAAAEdGhpcwUAAAARa2V5TG9ja2FibGVBc3NldHMFAAAACXNlcGFyYXRvcgAAAAIAAAABaQEAAAAEaW5pdAAAAAAJAARMAAAAAgkBAAAAC1N0cmluZ0VudHJ5AAAAAgUAAAARa2V5TG9ja2FibGVBc3NldHMCAAAAAAUAAAADbmlsAAAAAWkBAAAAEm9wQWRkTG9ja2FibGVBc3NldAAAAAEAAAAKYXNzZXRJZFN0cgMJAQAAAAIhPQAAAAIFAAAABHRoaXMIBQAAAAFpAAAABmNhbGxlcgkAAAIAAAABAgAAAA1BY2Nlc3MgZGVuaWVkBAAAAAdhc3NldElkCQACWQAAAAEFAAAACmFzc2V0SWRTdHIEAAAACmFzc2V0SW5mb3MJAQAAAA1nZXRBc3NldEluZm9zAAAAAQUAAAAHYXNzZXRJZAQAAAAObG9ja2FibGVBc3NldHMJAQAAABFnZXRMb2NrYWJsZUFzc2V0cwAAAAADCQAAAAAAAAIJAQAAAA9jb250YWluc0VsZW1lbnQAAAACBQAAAA5sb2NrYWJsZUFzc2V0cwUAAAAKYXNzZXRJZFN0cgYJAAACAAAAAQIAAAAWQXNzZXQgYWxyZWFkeSBsb2NrYWJsZQkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACBQAAABFrZXlMb2NrYWJsZUFzc2V0cwkABLkAAAACCQAETAAAAAIFAAAACmFzc2V0SWRTdHIFAAAADmxvY2thYmxlQXNzZXRzBQAAAAlzZXBhcmF0b3IFAAAAA25pbAAAAAEAAAACdHgBAAAABnZlcmlmeQAAAAAJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAAACAUAAAACdHgAAAAPc2VuZGVyUHVibGljS2V561GpPw==",
"height": 1441584,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: 5cGy6dLsfzKVT3fwzPY7JS5nwhc3DPMJBnh8x4dT8ErC
Next: Bd55XmExNtfgy4yuRLkCxmayqy42evz4cPjPwo8hPyAK
Diff:
Old | New | | Differences |
---|
13 | 13 | | } |
---|
14 | 14 | | |
---|
15 | 15 | | |
---|
16 | | - | func getLockableAssets () = match getString(this, keyLockableAssets) { |
---|
17 | | - | case str: String => |
---|
18 | | - | split(str, separator) |
---|
19 | | - | case _ => |
---|
20 | | - | throw("Missing 'keyLockableAssets'") |
---|
21 | | - | } |
---|
| 16 | + | func getLockableAssets () = split(getStringValue(this, keyLockableAssets), separator) |
---|
22 | 17 | | |
---|
23 | 18 | | |
---|
24 | 19 | | @Callable(i) |
---|
25 | | - | func init () = [StringEntry("keyLockableAssets", "")] |
---|
| 20 | + | func init () = [StringEntry(keyLockableAssets, "")] |
---|
26 | 21 | | |
---|
27 | 22 | | |
---|
28 | 23 | | |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 4 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let separator = "___" |
---|
5 | 5 | | |
---|
6 | 6 | | let keyLockableAssets = "dApp_LockableAssets" |
---|
7 | 7 | | |
---|
8 | 8 | | func getAssetInfos (assetId) = match assetInfo(assetId) { |
---|
9 | 9 | | case isAsset: Asset => |
---|
10 | 10 | | isAsset |
---|
11 | 11 | | case _ => |
---|
12 | 12 | | throw("Not an existing asset") |
---|
13 | 13 | | } |
---|
14 | 14 | | |
---|
15 | 15 | | |
---|
16 | | - | func getLockableAssets () = match getString(this, keyLockableAssets) { |
---|
17 | | - | case str: String => |
---|
18 | | - | split(str, separator) |
---|
19 | | - | case _ => |
---|
20 | | - | throw("Missing 'keyLockableAssets'") |
---|
21 | | - | } |
---|
| 16 | + | func getLockableAssets () = split(getStringValue(this, keyLockableAssets), separator) |
---|
22 | 17 | | |
---|
23 | 18 | | |
---|
24 | 19 | | @Callable(i) |
---|
25 | | - | func init () = [StringEntry("keyLockableAssets", "")] |
---|
| 20 | + | func init () = [StringEntry(keyLockableAssets, "")] |
---|
26 | 21 | | |
---|
27 | 22 | | |
---|
28 | 23 | | |
---|
29 | 24 | | @Callable(i) |
---|
30 | 25 | | func opAddLockableAsset (assetIdStr) = if ((this != i.caller)) |
---|
31 | 26 | | then throw("Access denied") |
---|
32 | 27 | | else { |
---|
33 | 28 | | let assetId = fromBase58String(assetIdStr) |
---|
34 | 29 | | let assetInfos = getAssetInfos(assetId) |
---|
35 | 30 | | let lockableAssets = getLockableAssets() |
---|
36 | 31 | | if ((containsElement(lockableAssets, assetIdStr) == true)) |
---|
37 | 32 | | then throw("Asset already lockable") |
---|
38 | 33 | | else [StringEntry(keyLockableAssets, makeString(assetIdStr :: lockableAssets, separator))] |
---|
39 | 34 | | } |
---|
40 | 35 | | |
---|
41 | 36 | | |
---|
42 | 37 | | @Verifier(tx) |
---|
43 | 38 | | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) |
---|
44 | 39 | | |
---|