tx · FR9hkoL5DYtMkN9PmCmvHF2wymRKksghPECaUoje9zQS
3MxXA443AARoS3rQ9RNdPeBur74yBTCTyxJ: -0.03400000 Waves
2023.01.09 11:30 [2397166] smart account 3MxXA443AARoS3rQ9RNdPeBur74yBTCTyxJ > SELF 0.00000000 Waves
{
"type": 13,
"id": "FR9hkoL5DYtMkN9PmCmvHF2wymRKksghPECaUoje9zQS",
"fee": 3400000,
"feeAssetId": null,
"timestamp": 1673253069684,
"version": 2,
"chainId": 84,
"sender": "3MxXA443AARoS3rQ9RNdPeBur74yBTCTyxJ",
"senderPublicKey": "Dhf95pPhxwKtWsqgf6tyeDW2xpQA7TvM8nTwbwgqKjkd",
"proofs": [
"2gWp93xDhvLb8y6veTA5aypA4eTxEbZvN8jCnbJecPB15SKAJUKfE8chkGPoHf5s76MiNZHyP1d8tA3UCkGjpduW"
],
"script": "base64:BgJeCAISAwoBCBIDCgEIEgMKAQgSAwoBCBIDCgEIEgMKAQgSAwoBCBIDCgEIEgMKAQgSAwoBCBIECgIICBIDCgEIEgMKAQgSAwoBCBIDCgEIEgQKAggIEgMKAQgSAwoBCBsAE2tfaW5zdXJhbmNlX2FkZHJlc3MCE2tfaW5zdXJhbmNlX2FkZHJlc3MAD2tfdmF1bHRfYWRkcmVzcwIPa192YXVsdF9hZGRyZXNzAA9rX2FkbWluX2FkZHJlc3MCD2tfYWRtaW5fYWRkcmVzcwASa19hZG1pbl9wdWJsaWNfa2V5AhJrX2FkbWluX3B1YmxpY19rZXkADWtfcXVvdGVfYXNzZXQCDWtfcXVvdGVfYXNzZXQAD2tfcXVvdGVfc3Rha2luZwIPa19xdW90ZV9zdGFraW5nABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MAEWtfZmFybWluZ19hZGRyZXNzAhFrX2Zhcm1pbmdfYWRkcmVzcwAQa19wcml6ZXNfYWRkcmVzcwIQa19wcml6ZXNfYWRkcmVzcwAVa19ob3VzZWtlZXBlcl9hZGRyZXNzAhVrX2hvdXNla2VlcGVyX2FkZHJlc3MABWtfYW1tAgVrX2FtbQAKa19hbW1fZGF0YQIKa19hbW1fZGF0YQASa19nb3Zlcm5hbmNlX2Fzc2V0AgtrX2dvdl9hc3NldAAPa19taW5lcl9hZGRyZXNzAg9rX21pbmVyX2FkZHJlc3MAEGtfb3JkZXJzX2FkZHJlc3MCEGtfb3JkZXJzX2FkZHJlc3MAEmtfcmVmZXJyYWxfYWRkcmVzcwISa19yZWZlcnJhbF9hZGRyZXNzABFrX21hbmFnZXJfYWRkcmVzcwIRa19tYW5hZ2VyX2FkZHJlc3MAFWtfbmZ0X21hbmFnZXJfYWRkcmVzcwIVa19uZnRfbWFuYWdlcl9hZGRyZXNzABRrX2NvbGxhdGVyYWxfYWRkcmVzcwIUa19jb2xsYXRlcmFsX2FkZHJlc3MAEmtfZXhjaGFuZ2VfYWRkcmVzcwISa19leGNoYW5nZV9hZGRyZXNzAQ50b0NvbXBvc2l0ZUtleQIEX2tleQhfYWRkcmVzcwkArAICCQCsAgIFBF9rZXkCAV8FCF9hZGRyZXNzARFnZXRBZGRyZXNzSWZWYWxpZAEHYWRkcmVzcwkApQgBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUHYWRkcmVzcwkArAICCQCsAgICDUNhbid0IHBhcnNlICIFB2FkZHJlc3MCDCIgYXMgYWRkcmVzcwEOYWRtaW5QdWJsaWNLZXkACQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBRJrX2FkbWluX3B1YmxpY19rZXkBCWlzTm9BZG1pbgAJAAACCQCdCAIFBHRoaXMFD2tfYWRtaW5fYWRkcmVzcwUEdW5pdAEFYWRtaW4ACQERQGV4dHJOYXRpdmUoMTA2MikBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUPa19hZG1pbl9hZGRyZXNzAhFBZG1pbiBub3QgZGVmaW5lZAEQaXNOb0FkbWluT3JBZG1pbgEBaQMDCQEJaXNOb0FkbWluAAYJAAACCAUBaQZjYWxsZXIJAQVhZG1pbgAFBHVuaXQJAAIBAi5Pbmx5IHRoZSBBZG1pbiBpdHNlbGYgY2FuIGludm9rZSB0aGlzIGZ1bmN0aW9uAQdpc0FkbWluAQFpAwkAAAIIBQFpBmNhbGxlcgkBBWFkbWluAAUEdW5pdAkAAgECLk9ubHkgdGhlIEFkbWluIGl0c2VsZiBjYW4gaW52b2tlIHRoaXMgZnVuY3Rpb24SAWkBCHNldEFkbWluAQ9fYWRtaW5QdWJsaWNLZXkJAQt2YWx1ZU9yRWxzZQIJARBpc05vQWRtaW5PckFkbWluAQUBaQQFYnl0ZXMJANkEAQUPX2FkbWluUHVibGljS2V5BAdhZGRyZXNzCQCnCAEFBWJ5dGVzCQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tfYWRtaW5fYWRkcmVzcwkApQgBBQdhZGRyZXNzCQDMCAIJAQtTdHJpbmdFbnRyeQIFEmtfYWRtaW5fcHVibGljX2tleQUPX2FkbWluUHVibGljS2V5BQNuaWwBaQEQc2V0SW5zdXJhbmNlRnVuZAEOX2luc3VyYW5jZUZ1bmQJAQt2YWx1ZU9yRWxzZQIJAQdpc0FkbWluAQUBaQQHYWRkcmVzcwkBEWdldEFkZHJlc3NJZlZhbGlkAQUOX2luc3VyYW5jZUZ1bmQJAMwIAgkBC1N0cmluZ0VudHJ5AgUTa19pbnN1cmFuY2VfYWRkcmVzcwUHYWRkcmVzcwUDbmlsAWkBEXNldExpcXVpZGl0eU1pbmVyAQ9fbGlxdWlkaXR5TWluZXIJAQt2YWx1ZU9yRWxzZQIJAQdpc0FkbWluAQUBaQQHYWRkcmVzcwkBEWdldEFkZHJlc3NJZlZhbGlkAQUPX2xpcXVpZGl0eU1pbmVyCQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tfbWluZXJfYWRkcmVzcwUHYWRkcmVzcwUDbmlsAWkBCXNldE9yZGVycwEHX29yZGVycwkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBAdhZGRyZXNzCQERZ2V0QWRkcmVzc0lmVmFsaWQBBQdfb3JkZXJzCQDMCAIJAQtTdHJpbmdFbnRyeQIFEGtfb3JkZXJzX2FkZHJlc3MFB2FkZHJlc3MFA25pbAFpAQtzZXRSZWZlcnJhbAEJX3JlZmVycmFsCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkEB2FkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFCV9yZWZlcnJhbAkAzAgCCQELU3RyaW5nRW50cnkCBRJrX3JlZmVycmFsX2FkZHJlc3MFB2FkZHJlc3MFA25pbAFpAQpzZXRGYXJtaW5nAQhfZmFybWluZwkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBAdhZGRyZXNzCQERZ2V0QWRkcmVzc0lmVmFsaWQBBQhfZmFybWluZwkAzAgCCQELU3RyaW5nRW50cnkCBRFrX2Zhcm1pbmdfYWRkcmVzcwUHYWRkcmVzcwUDbmlsAWkBCnNldE1hbmFnZXIBCF9tYW5hZ2VyCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkEB2FkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFCF9tYW5hZ2VyCQDMCAIJAQtTdHJpbmdFbnRyeQIFEWtfbWFuYWdlcl9hZGRyZXNzBQdhZGRyZXNzBQNuaWwBaQEOc2V0SG91c2VrZWVwZXIBDF9ob3VzZWtlZXBlcgkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBAdhZGRyZXNzCQERZ2V0QWRkcmVzc0lmVmFsaWQBBQxfaG91c2VrZWVwZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgUVa19ob3VzZWtlZXBlcl9hZGRyZXNzBQdhZGRyZXNzBQNuaWwBaQEJc2V0UHJpemVzAQdfcHJpemVzCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkEB2FkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFB19wcml6ZXMJAMwIAgkBC1N0cmluZ0VudHJ5AgUQa19wcml6ZXNfYWRkcmVzcwUHYWRkcmVzcwUDbmlsAWkBDXNldE5mdE1hbmFnZXIBC19uZnRNYW5hZ2VyCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkEB2FkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFC19uZnRNYW5hZ2VyCQDMCAIJAQtTdHJpbmdFbnRyeQIFFWtfbmZ0X21hbmFnZXJfYWRkcmVzcwUHYWRkcmVzcwUDbmlsAWkBDXNldFF1b3RlQXNzZXQCCF9hc3NldElkD19zdGFraW5nQWRkcmVzcwkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBA5zdGFraW5nQWRkcmVzcwkBEWdldEFkZHJlc3NJZlZhbGlkAQUPX3N0YWtpbmdBZGRyZXNzCQDMCAIJAQtTdHJpbmdFbnRyeQIFDWtfcXVvdGVfYXNzZXQFCF9hc3NldElkCQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tfcXVvdGVfc3Rha2luZwUPX3N0YWtpbmdBZGRyZXNzBQNuaWwBaQERc2V0U3Rha2luZ0FkZHJlc3MBD19zdGFraW5nQWRkcmVzcwkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBA5zdGFraW5nQWRkcmVzcwkBEWdldEFkZHJlc3NJZlZhbGlkAQUPX3N0YWtpbmdBZGRyZXNzCQDMCAIJAQtTdHJpbmdFbnRyeQIFEWtfc3Rha2luZ19hZGRyZXNzBQ9fc3Rha2luZ0FkZHJlc3MFA25pbAFpARRzZXRDb2xsYXRlcmFsQWRkcmVzcwESX2NvbGxhdGVyYWxBZGRyZXNzCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkEEWNvbGxhdGVyYWxBZGRyZXNzCQERZ2V0QWRkcmVzc0lmVmFsaWQBBRJfY29sbGF0ZXJhbEFkZHJlc3MJAMwIAgkBC1N0cmluZ0VudHJ5AgUUa19jb2xsYXRlcmFsX2FkZHJlc3MFEl9jb2xsYXRlcmFsQWRkcmVzcwUDbmlsAWkBEnNldEV4Y2hhbmdlQWRkcmVzcwEQX2V4Y2hhbmdlQWRkcmVzcwkBC3ZhbHVlT3JFbHNlAgkBB2lzQWRtaW4BBQFpBA9leGNoYW5nZUFkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFEF9leGNoYW5nZUFkZHJlc3MJAMwIAgkBC1N0cmluZ0VudHJ5AgUSa19leGNoYW5nZV9hZGRyZXNzBRBfZXhjaGFuZ2VBZGRyZXNzBQNuaWwBaQEPc2V0VmF1bHRBZGRyZXNzAQ1fdmF1bHRBZGRyZXNzCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkED2V4Y2hhbmdlQWRkcmVzcwkBEWdldEFkZHJlc3NJZlZhbGlkAQUNX3ZhdWx0QWRkcmVzcwkAzAgCCQELU3RyaW5nRW50cnkCBQ9rX3ZhdWx0X2FkZHJlc3MFDV92YXVsdEFkZHJlc3MFA25pbAFpAQZhZGRBbW0CC19hbW1BZGRyZXNzBV9kYXRhCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkECmFtbUFkZHJlc3MJARFnZXRBZGRyZXNzSWZWYWxpZAEFC19hbW1BZGRyZXNzCQDMCAIJAQxCb29sZWFuRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQVrX2FtbQULX2FtbUFkZHJlc3MGCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFCmtfYW1tX2RhdGEFC19hbW1BZGRyZXNzBQVfZGF0YQUDbmlsAWkBCXJlbW92ZUFtbQELX2FtbUFkZHJlc3MJAQt2YWx1ZU9yRWxzZQIJAQdpc0FkbWluAQUBaQkAzAgCCQELRGVsZXRlRW50cnkBCQEOdG9Db21wb3NpdGVLZXkCBQVrX2FtbQULX2FtbUFkZHJlc3MFA25pbAFpARJzZXRHb3Zlcm5hbmNlQXNzZXQBCF9hc3NldElkCQELdmFsdWVPckVsc2UCCQEHaXNBZG1pbgEFAWkECmFzc2V0Qnl0ZXMJANkEAQUIX2Fzc2V0SWQEByRtYXRjaDAJAOwHAQUKYXNzZXRCeXRlcwMJAAECBQckbWF0Y2gwAgVBc3NldAQFYXNzZXQFByRtYXRjaDADCQECIT0CCAUFYXNzZXQIZGVjaW1hbHMACAkAAgECI0ludmFsaWQgYXNzZXQgZGVjaW1hbHMsIHNob3VsZCBiZSA4CQDMCAIJAQtTdHJpbmdFbnRyeQIFEmtfZ292ZXJuYW5jZV9hc3NldAUIX2Fzc2V0SWQFA25pbAkAAgECEENhbid0IGZpbmQgYXNzZXQBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACQDZBAEJAQ5hZG1pblB1YmxpY0tleQBp6u4k",
"height": 2397166,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: Atujbkv7E2XksrY1XPzZ2U3C5VrLfbh4EGrAjzoTCvbM
Next: GKcv2oYdn8wCF25xBedSsBRTsuUioj6NnBDzBdMNYQDy
Diff:
Old | New | | Differences |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let a = "k_insurance_address" |
---|
5 | 5 | | |
---|
6 | | - | let b = "k_admin_address" |
---|
| 6 | + | let b = "k_vault_address" |
---|
7 | 7 | | |
---|
8 | | - | let c = "k_admin_public_key" |
---|
| 8 | + | let c = "k_admin_address" |
---|
9 | 9 | | |
---|
10 | | - | let d = "k_quote_asset" |
---|
| 10 | + | let d = "k_admin_public_key" |
---|
11 | 11 | | |
---|
12 | | - | let e = "k_quote_staking" |
---|
| 12 | + | let e = "k_quote_asset" |
---|
13 | 13 | | |
---|
14 | | - | let f = "k_staking_address" |
---|
| 14 | + | let f = "k_quote_staking" |
---|
15 | 15 | | |
---|
16 | | - | let g = "k_farming_address" |
---|
| 16 | + | let g = "k_staking_address" |
---|
17 | 17 | | |
---|
18 | | - | let h = "k_prizes_address" |
---|
| 18 | + | let h = "k_farming_address" |
---|
19 | 19 | | |
---|
20 | | - | let i = "k_housekeeper_address" |
---|
| 20 | + | let i = "k_prizes_address" |
---|
21 | 21 | | |
---|
22 | | - | let j = "k_amm" |
---|
| 22 | + | let j = "k_housekeeper_address" |
---|
23 | 23 | | |
---|
24 | | - | let k = "k_amm_data" |
---|
| 24 | + | let k = "k_amm" |
---|
25 | 25 | | |
---|
26 | | - | let l = "k_gov_asset" |
---|
| 26 | + | let l = "k_amm_data" |
---|
27 | 27 | | |
---|
28 | | - | let m = "k_miner_address" |
---|
| 28 | + | let m = "k_gov_asset" |
---|
29 | 29 | | |
---|
30 | | - | let n = "k_orders_address" |
---|
| 30 | + | let n = "k_miner_address" |
---|
31 | 31 | | |
---|
32 | | - | let o = "k_referral_address" |
---|
| 32 | + | let o = "k_orders_address" |
---|
33 | 33 | | |
---|
34 | | - | let p = "k_manager_address" |
---|
| 34 | + | let p = "k_referral_address" |
---|
35 | 35 | | |
---|
36 | | - | let q = "k_nft_manager_address" |
---|
| 36 | + | let q = "k_manager_address" |
---|
37 | 37 | | |
---|
38 | | - | let r = "k_collateral_address" |
---|
| 38 | + | let r = "k_nft_manager_address" |
---|
39 | 39 | | |
---|
40 | | - | let s = "k_exchange_address" |
---|
| 40 | + | let s = "k_collateral_address" |
---|
41 | 41 | | |
---|
42 | | - | func t (u,v) = ((u + "_") + v) |
---|
| 42 | + | let t = "k_exchange_address" |
---|
| 43 | + | |
---|
| 44 | + | func u (v,w) = ((v + "_") + w) |
---|
43 | 45 | | |
---|
44 | 46 | | |
---|
45 | | - | func w (x) = toString(valueOrErrorMessage(addressFromString(x), (("Can't parse \"" + x) + "\" as address"))) |
---|
| 47 | + | func x (y) = toString(valueOrErrorMessage(addressFromString(y), (("Can't parse \"" + y) + "\" as address"))) |
---|
46 | 48 | | |
---|
47 | 49 | | |
---|
48 | | - | func y () = getStringValue(this, c) |
---|
| 50 | + | func z () = getStringValue(this, d) |
---|
49 | 51 | | |
---|
50 | 52 | | |
---|
51 | | - | func z () = (getString(this, b) == unit) |
---|
| 53 | + | func A () = (getString(this, c) == unit) |
---|
52 | 54 | | |
---|
53 | 55 | | |
---|
54 | | - | func A () = addressFromStringValue(valueOrErrorMessage(getString(this, b), "Admin not defined")) |
---|
| 56 | + | func B () = addressFromStringValue(valueOrErrorMessage(getString(this, c), "Admin not defined")) |
---|
55 | 57 | | |
---|
56 | 58 | | |
---|
57 | | - | func B (C) = if (if (z()) |
---|
| 59 | + | func C (D) = if (if (A()) |
---|
58 | 60 | | then true |
---|
59 | | - | else (C.caller == A())) |
---|
| 61 | + | else (D.caller == B())) |
---|
60 | 62 | | then unit |
---|
61 | 63 | | else throw("Only the Admin itself can invoke this function") |
---|
62 | 64 | | |
---|
63 | 65 | | |
---|
64 | | - | func D (C) = if ((C.caller == A())) |
---|
| 66 | + | func E (D) = if ((D.caller == B())) |
---|
65 | 67 | | then unit |
---|
66 | 68 | | else throw("Only the Admin itself can invoke this function") |
---|
67 | 69 | | |
---|
68 | 70 | | |
---|
69 | | - | @Callable(C) |
---|
70 | | - | func setAdmin (E) = valueOrElse(B(C), { |
---|
71 | | - | let F = fromBase58String(E) |
---|
72 | | - | let x = addressFromPublicKey(F) |
---|
73 | | - | [StringEntry(b, toString(x)), StringEntry(c, E)] |
---|
| 71 | + | @Callable(D) |
---|
| 72 | + | func setAdmin (F) = valueOrElse(C(D), { |
---|
| 73 | + | let G = fromBase58String(F) |
---|
| 74 | + | let y = addressFromPublicKey(G) |
---|
| 75 | + | [StringEntry(c, toString(y)), StringEntry(d, F)] |
---|
74 | 76 | | }) |
---|
75 | 77 | | |
---|
76 | 78 | | |
---|
77 | 79 | | |
---|
78 | | - | @Callable(C) |
---|
79 | | - | func setInsuranceFund (G) = valueOrElse(D(C), { |
---|
80 | | - | let x = w(G) |
---|
81 | | - | [StringEntry(a, x)] |
---|
| 80 | + | @Callable(D) |
---|
| 81 | + | func setInsuranceFund (H) = valueOrElse(E(D), { |
---|
| 82 | + | let y = x(H) |
---|
| 83 | + | [StringEntry(a, y)] |
---|
82 | 84 | | }) |
---|
83 | 85 | | |
---|
84 | 86 | | |
---|
85 | 87 | | |
---|
86 | | - | @Callable(C) |
---|
87 | | - | func setLiquidityMiner (H) = valueOrElse(D(C), { |
---|
88 | | - | let x = w(H) |
---|
89 | | - | [StringEntry(m, x)] |
---|
| 88 | + | @Callable(D) |
---|
| 89 | + | func setLiquidityMiner (I) = valueOrElse(E(D), { |
---|
| 90 | + | let y = x(I) |
---|
| 91 | + | [StringEntry(n, y)] |
---|
90 | 92 | | }) |
---|
91 | 93 | | |
---|
92 | 94 | | |
---|
93 | 95 | | |
---|
94 | | - | @Callable(C) |
---|
95 | | - | func setOrders (I) = valueOrElse(D(C), { |
---|
96 | | - | let x = w(I) |
---|
97 | | - | [StringEntry(n, x)] |
---|
| 96 | + | @Callable(D) |
---|
| 97 | + | func setOrders (J) = valueOrElse(E(D), { |
---|
| 98 | + | let y = x(J) |
---|
| 99 | + | [StringEntry(o, y)] |
---|
98 | 100 | | }) |
---|
99 | 101 | | |
---|
100 | 102 | | |
---|
101 | 103 | | |
---|
102 | | - | @Callable(C) |
---|
103 | | - | func setReferral (J) = valueOrElse(D(C), { |
---|
104 | | - | let x = w(J) |
---|
105 | | - | [StringEntry(o, x)] |
---|
| 104 | + | @Callable(D) |
---|
| 105 | + | func setReferral (K) = valueOrElse(E(D), { |
---|
| 106 | + | let y = x(K) |
---|
| 107 | + | [StringEntry(p, y)] |
---|
106 | 108 | | }) |
---|
107 | 109 | | |
---|
108 | 110 | | |
---|
109 | 111 | | |
---|
110 | | - | @Callable(C) |
---|
111 | | - | func setFarming (K) = valueOrElse(D(C), { |
---|
112 | | - | let x = w(K) |
---|
113 | | - | [StringEntry(g, x)] |
---|
| 112 | + | @Callable(D) |
---|
| 113 | + | func setFarming (L) = valueOrElse(E(D), { |
---|
| 114 | + | let y = x(L) |
---|
| 115 | + | [StringEntry(h, y)] |
---|
114 | 116 | | }) |
---|
115 | 117 | | |
---|
116 | 118 | | |
---|
117 | 119 | | |
---|
118 | | - | @Callable(C) |
---|
119 | | - | func setManager (L) = valueOrElse(D(C), { |
---|
120 | | - | let x = w(L) |
---|
121 | | - | [StringEntry(p, x)] |
---|
| 120 | + | @Callable(D) |
---|
| 121 | + | func setManager (M) = valueOrElse(E(D), { |
---|
| 122 | + | let y = x(M) |
---|
| 123 | + | [StringEntry(q, y)] |
---|
122 | 124 | | }) |
---|
123 | 125 | | |
---|
124 | 126 | | |
---|
125 | 127 | | |
---|
126 | | - | @Callable(C) |
---|
127 | | - | func setHousekeeper (M) = valueOrElse(D(C), { |
---|
128 | | - | let x = w(M) |
---|
129 | | - | [StringEntry(i, x)] |
---|
| 128 | + | @Callable(D) |
---|
| 129 | + | func setHousekeeper (N) = valueOrElse(E(D), { |
---|
| 130 | + | let y = x(N) |
---|
| 131 | + | [StringEntry(j, y)] |
---|
130 | 132 | | }) |
---|
131 | 133 | | |
---|
132 | 134 | | |
---|
133 | 135 | | |
---|
134 | | - | @Callable(C) |
---|
135 | | - | func setPrizes (N) = valueOrElse(D(C), { |
---|
136 | | - | let x = w(N) |
---|
137 | | - | [StringEntry(h, x)] |
---|
| 136 | + | @Callable(D) |
---|
| 137 | + | func setPrizes (O) = valueOrElse(E(D), { |
---|
| 138 | + | let y = x(O) |
---|
| 139 | + | [StringEntry(i, y)] |
---|
138 | 140 | | }) |
---|
139 | 141 | | |
---|
140 | 142 | | |
---|
141 | 143 | | |
---|
142 | | - | @Callable(C) |
---|
143 | | - | func setNftManager (O) = valueOrElse(D(C), { |
---|
144 | | - | let x = w(O) |
---|
145 | | - | [StringEntry(q, x)] |
---|
| 144 | + | @Callable(D) |
---|
| 145 | + | func setNftManager (P) = valueOrElse(E(D), { |
---|
| 146 | + | let y = x(P) |
---|
| 147 | + | [StringEntry(r, y)] |
---|
146 | 148 | | }) |
---|
147 | 149 | | |
---|
148 | 150 | | |
---|
149 | 151 | | |
---|
150 | | - | @Callable(C) |
---|
151 | | - | func setQuoteAsset (P,Q) = valueOrElse(D(C), { |
---|
152 | | - | let R = w(Q) |
---|
153 | | - | [StringEntry(d, P), StringEntry(e, Q)] |
---|
| 152 | + | @Callable(D) |
---|
| 153 | + | func setQuoteAsset (Q,R) = valueOrElse(E(D), { |
---|
| 154 | + | let S = x(R) |
---|
| 155 | + | [StringEntry(e, Q), StringEntry(f, R)] |
---|
154 | 156 | | }) |
---|
155 | 157 | | |
---|
156 | 158 | | |
---|
157 | 159 | | |
---|
158 | | - | @Callable(C) |
---|
159 | | - | func setStakingAddress (Q) = valueOrElse(D(C), { |
---|
160 | | - | let R = w(Q) |
---|
161 | | - | [StringEntry(f, Q)] |
---|
| 160 | + | @Callable(D) |
---|
| 161 | + | func setStakingAddress (R) = valueOrElse(E(D), { |
---|
| 162 | + | let S = x(R) |
---|
| 163 | + | [StringEntry(g, R)] |
---|
162 | 164 | | }) |
---|
163 | 165 | | |
---|
164 | 166 | | |
---|
165 | 167 | | |
---|
166 | | - | @Callable(C) |
---|
167 | | - | func setCollateralAddress (S) = valueOrElse(D(C), { |
---|
168 | | - | let T = w(S) |
---|
169 | | - | [StringEntry(r, S)] |
---|
| 168 | + | @Callable(D) |
---|
| 169 | + | func setCollateralAddress (T) = valueOrElse(E(D), { |
---|
| 170 | + | let U = x(T) |
---|
| 171 | + | [StringEntry(s, T)] |
---|
170 | 172 | | }) |
---|
171 | 173 | | |
---|
172 | 174 | | |
---|
173 | 175 | | |
---|
174 | | - | @Callable(C) |
---|
175 | | - | func setExchangeAddress (U) = valueOrElse(D(C), { |
---|
176 | | - | let V = w(U) |
---|
177 | | - | [StringEntry(s, U)] |
---|
| 176 | + | @Callable(D) |
---|
| 177 | + | func setExchangeAddress (V) = valueOrElse(E(D), { |
---|
| 178 | + | let W = x(V) |
---|
| 179 | + | [StringEntry(t, V)] |
---|
178 | 180 | | }) |
---|
179 | 181 | | |
---|
180 | 182 | | |
---|
181 | 183 | | |
---|
182 | | - | @Callable(C) |
---|
183 | | - | func addAmm (W,X) = valueOrElse(D(C), { |
---|
184 | | - | let Y = w(W) |
---|
185 | | - | [BooleanEntry(t(j, W), true), StringEntry(t(k, W), X)] |
---|
| 184 | + | @Callable(D) |
---|
| 185 | + | func setVaultAddress (X) = valueOrElse(E(D), { |
---|
| 186 | + | let W = x(X) |
---|
| 187 | + | [StringEntry(b, X)] |
---|
186 | 188 | | }) |
---|
187 | 189 | | |
---|
188 | 190 | | |
---|
189 | 191 | | |
---|
190 | | - | @Callable(C) |
---|
191 | | - | func removeAmm (W) = valueOrElse(D(C), [DeleteEntry(t(j, W))]) |
---|
| 192 | + | @Callable(D) |
---|
| 193 | + | func addAmm (Y,Z) = valueOrElse(E(D), { |
---|
| 194 | + | let aa = x(Y) |
---|
| 195 | + | [BooleanEntry(u(k, Y), true), StringEntry(u(l, Y), Z)] |
---|
| 196 | + | }) |
---|
192 | 197 | | |
---|
193 | 198 | | |
---|
194 | 199 | | |
---|
195 | | - | @Callable(C) |
---|
196 | | - | func setGovernanceAsset (P) = valueOrElse(D(C), { |
---|
197 | | - | let Z = fromBase58String(P) |
---|
198 | | - | let aa = assetInfo(Z) |
---|
199 | | - | if ($isInstanceOf(aa, "Asset")) |
---|
| 200 | + | @Callable(D) |
---|
| 201 | + | func removeAmm (Y) = valueOrElse(E(D), [DeleteEntry(u(k, Y))]) |
---|
| 202 | + | |
---|
| 203 | + | |
---|
| 204 | + | |
---|
| 205 | + | @Callable(D) |
---|
| 206 | + | func setGovernanceAsset (Q) = valueOrElse(E(D), { |
---|
| 207 | + | let ab = fromBase58String(Q) |
---|
| 208 | + | let ac = assetInfo(ab) |
---|
| 209 | + | if ($isInstanceOf(ac, "Asset")) |
---|
200 | 210 | | then { |
---|
201 | | - | let ab = aa |
---|
202 | | - | if ((ab.decimals != 8)) |
---|
| 211 | + | let ad = ac |
---|
| 212 | + | if ((ad.decimals != 8)) |
---|
203 | 213 | | then throw("Invalid asset decimals, should be 8") |
---|
204 | | - | else [StringEntry(l, P)] |
---|
| 214 | + | else [StringEntry(m, Q)] |
---|
205 | 215 | | } |
---|
206 | 216 | | else throw("Can't find asset") |
---|
207 | 217 | | }) |
---|
208 | 218 | | |
---|
209 | 219 | | |
---|
210 | | - | @Verifier(ac) |
---|
211 | | - | func ad () = sigVerify(ac.bodyBytes, ac.proofs[0], fromBase58String(y())) |
---|
| 220 | + | @Verifier(ae) |
---|
| 221 | + | func af () = sigVerify(ae.bodyBytes, ae.proofs[0], fromBase58String(z())) |
---|
212 | 222 | | |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 6 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let a = "k_insurance_address" |
---|
5 | 5 | | |
---|
6 | | - | let b = "k_admin_address" |
---|
| 6 | + | let b = "k_vault_address" |
---|
7 | 7 | | |
---|
8 | | - | let c = "k_admin_public_key" |
---|
| 8 | + | let c = "k_admin_address" |
---|
9 | 9 | | |
---|
10 | | - | let d = "k_quote_asset" |
---|
| 10 | + | let d = "k_admin_public_key" |
---|
11 | 11 | | |
---|
12 | | - | let e = "k_quote_staking" |
---|
| 12 | + | let e = "k_quote_asset" |
---|
13 | 13 | | |
---|
14 | | - | let f = "k_staking_address" |
---|
| 14 | + | let f = "k_quote_staking" |
---|
15 | 15 | | |
---|
16 | | - | let g = "k_farming_address" |
---|
| 16 | + | let g = "k_staking_address" |
---|
17 | 17 | | |
---|
18 | | - | let h = "k_prizes_address" |
---|
| 18 | + | let h = "k_farming_address" |
---|
19 | 19 | | |
---|
20 | | - | let i = "k_housekeeper_address" |
---|
| 20 | + | let i = "k_prizes_address" |
---|
21 | 21 | | |
---|
22 | | - | let j = "k_amm" |
---|
| 22 | + | let j = "k_housekeeper_address" |
---|
23 | 23 | | |
---|
24 | | - | let k = "k_amm_data" |
---|
| 24 | + | let k = "k_amm" |
---|
25 | 25 | | |
---|
26 | | - | let l = "k_gov_asset" |
---|
| 26 | + | let l = "k_amm_data" |
---|
27 | 27 | | |
---|
28 | | - | let m = "k_miner_address" |
---|
| 28 | + | let m = "k_gov_asset" |
---|
29 | 29 | | |
---|
30 | | - | let n = "k_orders_address" |
---|
| 30 | + | let n = "k_miner_address" |
---|
31 | 31 | | |
---|
32 | | - | let o = "k_referral_address" |
---|
| 32 | + | let o = "k_orders_address" |
---|
33 | 33 | | |
---|
34 | | - | let p = "k_manager_address" |
---|
| 34 | + | let p = "k_referral_address" |
---|
35 | 35 | | |
---|
36 | | - | let q = "k_nft_manager_address" |
---|
| 36 | + | let q = "k_manager_address" |
---|
37 | 37 | | |
---|
38 | | - | let r = "k_collateral_address" |
---|
| 38 | + | let r = "k_nft_manager_address" |
---|
39 | 39 | | |
---|
40 | | - | let s = "k_exchange_address" |
---|
| 40 | + | let s = "k_collateral_address" |
---|
41 | 41 | | |
---|
42 | | - | func t (u,v) = ((u + "_") + v) |
---|
| 42 | + | let t = "k_exchange_address" |
---|
| 43 | + | |
---|
| 44 | + | func u (v,w) = ((v + "_") + w) |
---|
43 | 45 | | |
---|
44 | 46 | | |
---|
45 | | - | func w (x) = toString(valueOrErrorMessage(addressFromString(x), (("Can't parse \"" + x) + "\" as address"))) |
---|
| 47 | + | func x (y) = toString(valueOrErrorMessage(addressFromString(y), (("Can't parse \"" + y) + "\" as address"))) |
---|
46 | 48 | | |
---|
47 | 49 | | |
---|
48 | | - | func y () = getStringValue(this, c) |
---|
| 50 | + | func z () = getStringValue(this, d) |
---|
49 | 51 | | |
---|
50 | 52 | | |
---|
51 | | - | func z () = (getString(this, b) == unit) |
---|
| 53 | + | func A () = (getString(this, c) == unit) |
---|
52 | 54 | | |
---|
53 | 55 | | |
---|
54 | | - | func A () = addressFromStringValue(valueOrErrorMessage(getString(this, b), "Admin not defined")) |
---|
| 56 | + | func B () = addressFromStringValue(valueOrErrorMessage(getString(this, c), "Admin not defined")) |
---|
55 | 57 | | |
---|
56 | 58 | | |
---|
57 | | - | func B (C) = if (if (z()) |
---|
| 59 | + | func C (D) = if (if (A()) |
---|
58 | 60 | | then true |
---|
59 | | - | else (C.caller == A())) |
---|
| 61 | + | else (D.caller == B())) |
---|
60 | 62 | | then unit |
---|
61 | 63 | | else throw("Only the Admin itself can invoke this function") |
---|
62 | 64 | | |
---|
63 | 65 | | |
---|
64 | | - | func D (C) = if ((C.caller == A())) |
---|
| 66 | + | func E (D) = if ((D.caller == B())) |
---|
65 | 67 | | then unit |
---|
66 | 68 | | else throw("Only the Admin itself can invoke this function") |
---|
67 | 69 | | |
---|
68 | 70 | | |
---|
69 | | - | @Callable(C) |
---|
70 | | - | func setAdmin (E) = valueOrElse(B(C), { |
---|
71 | | - | let F = fromBase58String(E) |
---|
72 | | - | let x = addressFromPublicKey(F) |
---|
73 | | - | [StringEntry(b, toString(x)), StringEntry(c, E)] |
---|
| 71 | + | @Callable(D) |
---|
| 72 | + | func setAdmin (F) = valueOrElse(C(D), { |
---|
| 73 | + | let G = fromBase58String(F) |
---|
| 74 | + | let y = addressFromPublicKey(G) |
---|
| 75 | + | [StringEntry(c, toString(y)), StringEntry(d, F)] |
---|
74 | 76 | | }) |
---|
75 | 77 | | |
---|
76 | 78 | | |
---|
77 | 79 | | |
---|
78 | | - | @Callable(C) |
---|
79 | | - | func setInsuranceFund (G) = valueOrElse(D(C), { |
---|
80 | | - | let x = w(G) |
---|
81 | | - | [StringEntry(a, x)] |
---|
| 80 | + | @Callable(D) |
---|
| 81 | + | func setInsuranceFund (H) = valueOrElse(E(D), { |
---|
| 82 | + | let y = x(H) |
---|
| 83 | + | [StringEntry(a, y)] |
---|
82 | 84 | | }) |
---|
83 | 85 | | |
---|
84 | 86 | | |
---|
85 | 87 | | |
---|
86 | | - | @Callable(C) |
---|
87 | | - | func setLiquidityMiner (H) = valueOrElse(D(C), { |
---|
88 | | - | let x = w(H) |
---|
89 | | - | [StringEntry(m, x)] |
---|
| 88 | + | @Callable(D) |
---|
| 89 | + | func setLiquidityMiner (I) = valueOrElse(E(D), { |
---|
| 90 | + | let y = x(I) |
---|
| 91 | + | [StringEntry(n, y)] |
---|
90 | 92 | | }) |
---|
91 | 93 | | |
---|
92 | 94 | | |
---|
93 | 95 | | |
---|
94 | | - | @Callable(C) |
---|
95 | | - | func setOrders (I) = valueOrElse(D(C), { |
---|
96 | | - | let x = w(I) |
---|
97 | | - | [StringEntry(n, x)] |
---|
| 96 | + | @Callable(D) |
---|
| 97 | + | func setOrders (J) = valueOrElse(E(D), { |
---|
| 98 | + | let y = x(J) |
---|
| 99 | + | [StringEntry(o, y)] |
---|
98 | 100 | | }) |
---|
99 | 101 | | |
---|
100 | 102 | | |
---|
101 | 103 | | |
---|
102 | | - | @Callable(C) |
---|
103 | | - | func setReferral (J) = valueOrElse(D(C), { |
---|
104 | | - | let x = w(J) |
---|
105 | | - | [StringEntry(o, x)] |
---|
| 104 | + | @Callable(D) |
---|
| 105 | + | func setReferral (K) = valueOrElse(E(D), { |
---|
| 106 | + | let y = x(K) |
---|
| 107 | + | [StringEntry(p, y)] |
---|
106 | 108 | | }) |
---|
107 | 109 | | |
---|
108 | 110 | | |
---|
109 | 111 | | |
---|
110 | | - | @Callable(C) |
---|
111 | | - | func setFarming (K) = valueOrElse(D(C), { |
---|
112 | | - | let x = w(K) |
---|
113 | | - | [StringEntry(g, x)] |
---|
| 112 | + | @Callable(D) |
---|
| 113 | + | func setFarming (L) = valueOrElse(E(D), { |
---|
| 114 | + | let y = x(L) |
---|
| 115 | + | [StringEntry(h, y)] |
---|
114 | 116 | | }) |
---|
115 | 117 | | |
---|
116 | 118 | | |
---|
117 | 119 | | |
---|
118 | | - | @Callable(C) |
---|
119 | | - | func setManager (L) = valueOrElse(D(C), { |
---|
120 | | - | let x = w(L) |
---|
121 | | - | [StringEntry(p, x)] |
---|
| 120 | + | @Callable(D) |
---|
| 121 | + | func setManager (M) = valueOrElse(E(D), { |
---|
| 122 | + | let y = x(M) |
---|
| 123 | + | [StringEntry(q, y)] |
---|
122 | 124 | | }) |
---|
123 | 125 | | |
---|
124 | 126 | | |
---|
125 | 127 | | |
---|
126 | | - | @Callable(C) |
---|
127 | | - | func setHousekeeper (M) = valueOrElse(D(C), { |
---|
128 | | - | let x = w(M) |
---|
129 | | - | [StringEntry(i, x)] |
---|
| 128 | + | @Callable(D) |
---|
| 129 | + | func setHousekeeper (N) = valueOrElse(E(D), { |
---|
| 130 | + | let y = x(N) |
---|
| 131 | + | [StringEntry(j, y)] |
---|
130 | 132 | | }) |
---|
131 | 133 | | |
---|
132 | 134 | | |
---|
133 | 135 | | |
---|
134 | | - | @Callable(C) |
---|
135 | | - | func setPrizes (N) = valueOrElse(D(C), { |
---|
136 | | - | let x = w(N) |
---|
137 | | - | [StringEntry(h, x)] |
---|
| 136 | + | @Callable(D) |
---|
| 137 | + | func setPrizes (O) = valueOrElse(E(D), { |
---|
| 138 | + | let y = x(O) |
---|
| 139 | + | [StringEntry(i, y)] |
---|
138 | 140 | | }) |
---|
139 | 141 | | |
---|
140 | 142 | | |
---|
141 | 143 | | |
---|
142 | | - | @Callable(C) |
---|
143 | | - | func setNftManager (O) = valueOrElse(D(C), { |
---|
144 | | - | let x = w(O) |
---|
145 | | - | [StringEntry(q, x)] |
---|
| 144 | + | @Callable(D) |
---|
| 145 | + | func setNftManager (P) = valueOrElse(E(D), { |
---|
| 146 | + | let y = x(P) |
---|
| 147 | + | [StringEntry(r, y)] |
---|
146 | 148 | | }) |
---|
147 | 149 | | |
---|
148 | 150 | | |
---|
149 | 151 | | |
---|
150 | | - | @Callable(C) |
---|
151 | | - | func setQuoteAsset (P,Q) = valueOrElse(D(C), { |
---|
152 | | - | let R = w(Q) |
---|
153 | | - | [StringEntry(d, P), StringEntry(e, Q)] |
---|
| 152 | + | @Callable(D) |
---|
| 153 | + | func setQuoteAsset (Q,R) = valueOrElse(E(D), { |
---|
| 154 | + | let S = x(R) |
---|
| 155 | + | [StringEntry(e, Q), StringEntry(f, R)] |
---|
154 | 156 | | }) |
---|
155 | 157 | | |
---|
156 | 158 | | |
---|
157 | 159 | | |
---|
158 | | - | @Callable(C) |
---|
159 | | - | func setStakingAddress (Q) = valueOrElse(D(C), { |
---|
160 | | - | let R = w(Q) |
---|
161 | | - | [StringEntry(f, Q)] |
---|
| 160 | + | @Callable(D) |
---|
| 161 | + | func setStakingAddress (R) = valueOrElse(E(D), { |
---|
| 162 | + | let S = x(R) |
---|
| 163 | + | [StringEntry(g, R)] |
---|
162 | 164 | | }) |
---|
163 | 165 | | |
---|
164 | 166 | | |
---|
165 | 167 | | |
---|
166 | | - | @Callable(C) |
---|
167 | | - | func setCollateralAddress (S) = valueOrElse(D(C), { |
---|
168 | | - | let T = w(S) |
---|
169 | | - | [StringEntry(r, S)] |
---|
| 168 | + | @Callable(D) |
---|
| 169 | + | func setCollateralAddress (T) = valueOrElse(E(D), { |
---|
| 170 | + | let U = x(T) |
---|
| 171 | + | [StringEntry(s, T)] |
---|
170 | 172 | | }) |
---|
171 | 173 | | |
---|
172 | 174 | | |
---|
173 | 175 | | |
---|
174 | | - | @Callable(C) |
---|
175 | | - | func setExchangeAddress (U) = valueOrElse(D(C), { |
---|
176 | | - | let V = w(U) |
---|
177 | | - | [StringEntry(s, U)] |
---|
| 176 | + | @Callable(D) |
---|
| 177 | + | func setExchangeAddress (V) = valueOrElse(E(D), { |
---|
| 178 | + | let W = x(V) |
---|
| 179 | + | [StringEntry(t, V)] |
---|
178 | 180 | | }) |
---|
179 | 181 | | |
---|
180 | 182 | | |
---|
181 | 183 | | |
---|
182 | | - | @Callable(C) |
---|
183 | | - | func addAmm (W,X) = valueOrElse(D(C), { |
---|
184 | | - | let Y = w(W) |
---|
185 | | - | [BooleanEntry(t(j, W), true), StringEntry(t(k, W), X)] |
---|
| 184 | + | @Callable(D) |
---|
| 185 | + | func setVaultAddress (X) = valueOrElse(E(D), { |
---|
| 186 | + | let W = x(X) |
---|
| 187 | + | [StringEntry(b, X)] |
---|
186 | 188 | | }) |
---|
187 | 189 | | |
---|
188 | 190 | | |
---|
189 | 191 | | |
---|
190 | | - | @Callable(C) |
---|
191 | | - | func removeAmm (W) = valueOrElse(D(C), [DeleteEntry(t(j, W))]) |
---|
| 192 | + | @Callable(D) |
---|
| 193 | + | func addAmm (Y,Z) = valueOrElse(E(D), { |
---|
| 194 | + | let aa = x(Y) |
---|
| 195 | + | [BooleanEntry(u(k, Y), true), StringEntry(u(l, Y), Z)] |
---|
| 196 | + | }) |
---|
192 | 197 | | |
---|
193 | 198 | | |
---|
194 | 199 | | |
---|
195 | | - | @Callable(C) |
---|
196 | | - | func setGovernanceAsset (P) = valueOrElse(D(C), { |
---|
197 | | - | let Z = fromBase58String(P) |
---|
198 | | - | let aa = assetInfo(Z) |
---|
199 | | - | if ($isInstanceOf(aa, "Asset")) |
---|
| 200 | + | @Callable(D) |
---|
| 201 | + | func removeAmm (Y) = valueOrElse(E(D), [DeleteEntry(u(k, Y))]) |
---|
| 202 | + | |
---|
| 203 | + | |
---|
| 204 | + | |
---|
| 205 | + | @Callable(D) |
---|
| 206 | + | func setGovernanceAsset (Q) = valueOrElse(E(D), { |
---|
| 207 | + | let ab = fromBase58String(Q) |
---|
| 208 | + | let ac = assetInfo(ab) |
---|
| 209 | + | if ($isInstanceOf(ac, "Asset")) |
---|
200 | 210 | | then { |
---|
201 | | - | let ab = aa |
---|
202 | | - | if ((ab.decimals != 8)) |
---|
| 211 | + | let ad = ac |
---|
| 212 | + | if ((ad.decimals != 8)) |
---|
203 | 213 | | then throw("Invalid asset decimals, should be 8") |
---|
204 | | - | else [StringEntry(l, P)] |
---|
| 214 | + | else [StringEntry(m, Q)] |
---|
205 | 215 | | } |
---|
206 | 216 | | else throw("Can't find asset") |
---|
207 | 217 | | }) |
---|
208 | 218 | | |
---|
209 | 219 | | |
---|
210 | | - | @Verifier(ac) |
---|
211 | | - | func ad () = sigVerify(ac.bodyBytes, ac.proofs[0], fromBase58String(y())) |
---|
| 220 | + | @Verifier(ae) |
---|
| 221 | + | func af () = sigVerify(ae.bodyBytes, ae.proofs[0], fromBase58String(z())) |
---|
212 | 222 | | |
---|