@hashgraphonline/standards-sdk 0.0.79 → 0.0.80

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/dist/es/hcs-10/browser.d.ts.map +1 -1
  2. package/dist/es/hcs-10/sdk.d.ts +10 -1
  3. package/dist/es/hcs-10/sdk.d.ts.map +1 -1
  4. package/dist/es/standards-sdk.es100.js +2 -29
  5. package/dist/es/standards-sdk.es100.js.map +1 -1
  6. package/dist/es/standards-sdk.es101.js +15 -28
  7. package/dist/es/standards-sdk.es101.js.map +1 -1
  8. package/dist/es/standards-sdk.es102.js +404 -16
  9. package/dist/es/standards-sdk.es102.js.map +1 -1
  10. package/dist/es/standards-sdk.es103.js +168 -38
  11. package/dist/es/standards-sdk.es103.js.map +1 -1
  12. package/dist/es/standards-sdk.es104.js +138 -13
  13. package/dist/es/standards-sdk.es104.js.map +1 -1
  14. package/dist/es/standards-sdk.es105.js +3 -61
  15. package/dist/es/standards-sdk.es105.js.map +1 -1
  16. package/dist/es/standards-sdk.es106.js +2 -1289
  17. package/dist/es/standards-sdk.es106.js.map +1 -1
  18. package/dist/es/standards-sdk.es107.js +2 -32
  19. package/dist/es/standards-sdk.es107.js.map +1 -1
  20. package/dist/es/standards-sdk.es108.js +33 -5
  21. package/dist/es/standards-sdk.es108.js.map +1 -1
  22. package/dist/es/standards-sdk.es109.js +29 -155
  23. package/dist/es/standards-sdk.es109.js.map +1 -1
  24. package/dist/es/standards-sdk.es110.js +9 -793
  25. package/dist/es/standards-sdk.es110.js.map +1 -1
  26. package/dist/es/standards-sdk.es111.js +30 -170
  27. package/dist/es/standards-sdk.es111.js.map +1 -1
  28. package/dist/es/standards-sdk.es112.js +2282 -143
  29. package/dist/es/standards-sdk.es112.js.map +1 -1
  30. package/dist/es/standards-sdk.es113.js +1 -1
  31. package/dist/es/standards-sdk.es12.js +2 -2
  32. package/dist/es/standards-sdk.es14.js +1 -1
  33. package/dist/es/standards-sdk.es17.js +2 -2
  34. package/dist/es/standards-sdk.es18.js +3 -3
  35. package/dist/es/standards-sdk.es21.js +966 -1692
  36. package/dist/es/standards-sdk.es21.js.map +1 -1
  37. package/dist/es/standards-sdk.es22.js +121 -5544
  38. package/dist/es/standards-sdk.es22.js.map +1 -1
  39. package/dist/es/standards-sdk.es23.js +36 -5
  40. package/dist/es/standards-sdk.es23.js.map +1 -1
  41. package/dist/es/standards-sdk.es24.js +48 -36
  42. package/dist/es/standards-sdk.es24.js.map +1 -1
  43. package/dist/es/standards-sdk.es25.js +7163 -21
  44. package/dist/es/standards-sdk.es25.js.map +1 -1
  45. package/dist/es/standards-sdk.es26.js +1 -1
  46. package/dist/es/standards-sdk.es28.js +4086 -960
  47. package/dist/es/standards-sdk.es28.js.map +1 -1
  48. package/dist/es/standards-sdk.es29.js +5 -4167
  49. package/dist/es/standards-sdk.es29.js.map +1 -1
  50. package/dist/es/standards-sdk.es33.js +337 -7109
  51. package/dist/es/standards-sdk.es33.js.map +1 -1
  52. package/dist/es/standards-sdk.es34.js +5 -3
  53. package/dist/es/standards-sdk.es34.js.map +1 -1
  54. package/dist/es/standards-sdk.es35.js +179 -3
  55. package/dist/es/standards-sdk.es35.js.map +1 -1
  56. package/dist/es/standards-sdk.es36.js +68 -351
  57. package/dist/es/standards-sdk.es36.js.map +1 -1
  58. package/dist/es/standards-sdk.es37.js +113 -5
  59. package/dist/es/standards-sdk.es37.js.map +1 -1
  60. package/dist/es/standards-sdk.es38.js +43 -170
  61. package/dist/es/standards-sdk.es38.js.map +1 -1
  62. package/dist/es/standards-sdk.es39.js +9 -80
  63. package/dist/es/standards-sdk.es39.js.map +1 -1
  64. package/dist/es/standards-sdk.es4.js +1 -1
  65. package/dist/es/standards-sdk.es40.js +87 -104
  66. package/dist/es/standards-sdk.es40.js.map +1 -1
  67. package/dist/es/standards-sdk.es41.js +3 -51
  68. package/dist/es/standards-sdk.es41.js.map +1 -1
  69. package/dist/es/standards-sdk.es42.js +2 -10
  70. package/dist/es/standards-sdk.es42.js.map +1 -1
  71. package/dist/es/standards-sdk.es43.js +102 -86
  72. package/dist/es/standards-sdk.es43.js.map +1 -1
  73. package/dist/es/standards-sdk.es44.js +73 -3
  74. package/dist/es/standards-sdk.es44.js.map +1 -1
  75. package/dist/es/standards-sdk.es45.js +6 -2
  76. package/dist/es/standards-sdk.es45.js.map +1 -1
  77. package/dist/es/standards-sdk.es46.js +4 -112
  78. package/dist/es/standards-sdk.es46.js.map +1 -1
  79. package/dist/es/standards-sdk.es47.js +216 -69
  80. package/dist/es/standards-sdk.es47.js.map +1 -1
  81. package/dist/es/standards-sdk.es48.js +58 -6
  82. package/dist/es/standards-sdk.es48.js.map +1 -1
  83. package/dist/es/standards-sdk.es49.js +69 -5
  84. package/dist/es/standards-sdk.es49.js.map +1 -1
  85. package/dist/es/standards-sdk.es5.js +3 -3
  86. package/dist/es/standards-sdk.es50.js +3 -220
  87. package/dist/es/standards-sdk.es50.js.map +1 -1
  88. package/dist/es/standards-sdk.es51.js +3 -58
  89. package/dist/es/standards-sdk.es51.js.map +1 -1
  90. package/dist/es/standards-sdk.es52.js +163 -68
  91. package/dist/es/standards-sdk.es52.js.map +1 -1
  92. package/dist/es/standards-sdk.es53.js +30 -99
  93. package/dist/es/standards-sdk.es53.js.map +1 -1
  94. package/dist/es/standards-sdk.es54.js +63 -2
  95. package/dist/es/standards-sdk.es54.js.map +1 -1
  96. package/dist/es/standards-sdk.es55.js +49 -15
  97. package/dist/es/standards-sdk.es55.js.map +1 -1
  98. package/dist/es/standards-sdk.es56.js +8 -407
  99. package/dist/es/standards-sdk.es56.js.map +1 -1
  100. package/dist/es/standards-sdk.es57.js +55 -154
  101. package/dist/es/standards-sdk.es57.js.map +1 -1
  102. package/dist/es/standards-sdk.es58.js +6 -32
  103. package/dist/es/standards-sdk.es58.js.map +1 -1
  104. package/dist/es/standards-sdk.es59.js +13 -61
  105. package/dist/es/standards-sdk.es59.js.map +1 -1
  106. package/dist/es/standards-sdk.es60.js +7 -50
  107. package/dist/es/standards-sdk.es60.js.map +1 -1
  108. package/dist/es/standards-sdk.es61.js +45 -10
  109. package/dist/es/standards-sdk.es61.js.map +1 -1
  110. package/dist/es/standards-sdk.es62.js +2 -65
  111. package/dist/es/standards-sdk.es62.js.map +1 -1
  112. package/dist/es/standards-sdk.es63.js +135 -5
  113. package/dist/es/standards-sdk.es63.js.map +1 -1
  114. package/dist/es/standards-sdk.es64.js +170 -13
  115. package/dist/es/standards-sdk.es64.js.map +1 -1
  116. package/dist/es/standards-sdk.es65.js +2 -7
  117. package/dist/es/standards-sdk.es65.js.map +1 -1
  118. package/dist/es/standards-sdk.es66.js +12 -44
  119. package/dist/es/standards-sdk.es66.js.map +1 -1
  120. package/dist/es/standards-sdk.es67.js +13 -2
  121. package/dist/es/standards-sdk.es67.js.map +1 -1
  122. package/dist/es/standards-sdk.es68.js +7111 -111
  123. package/dist/es/standards-sdk.es68.js.map +1 -1
  124. package/dist/es/standards-sdk.es69.js +29 -169
  125. package/dist/es/standards-sdk.es69.js.map +1 -1
  126. package/dist/es/standards-sdk.es7.js +70 -2
  127. package/dist/es/standards-sdk.es7.js.map +1 -1
  128. package/dist/es/standards-sdk.es70.js +15 -2282
  129. package/dist/es/standards-sdk.es70.js.map +1 -1
  130. package/dist/es/standards-sdk.es71.js +4 -13
  131. package/dist/es/standards-sdk.es71.js.map +1 -1
  132. package/dist/es/standards-sdk.es72.js +4 -13
  133. package/dist/es/standards-sdk.es72.js.map +1 -1
  134. package/dist/es/standards-sdk.es73.js +15 -31
  135. package/dist/es/standards-sdk.es73.js.map +1 -1
  136. package/dist/es/standards-sdk.es74.js +4 -14
  137. package/dist/es/standards-sdk.es74.js.map +1 -1
  138. package/dist/es/standards-sdk.es75.js +39 -4
  139. package/dist/es/standards-sdk.es75.js.map +1 -1
  140. package/dist/es/standards-sdk.es76.js +40 -4
  141. package/dist/es/standards-sdk.es76.js.map +1 -1
  142. package/dist/es/standards-sdk.es77.js +36 -15
  143. package/dist/es/standards-sdk.es77.js.map +1 -1
  144. package/dist/es/standards-sdk.es78.js +78 -5
  145. package/dist/es/standards-sdk.es78.js.map +1 -1
  146. package/dist/es/standards-sdk.es79.js +193 -37
  147. package/dist/es/standards-sdk.es79.js.map +1 -1
  148. package/dist/es/standards-sdk.es8.js +6 -6
  149. package/dist/es/standards-sdk.es8.js.map +1 -1
  150. package/dist/es/standards-sdk.es80.js +437 -39
  151. package/dist/es/standards-sdk.es80.js.map +1 -1
  152. package/dist/es/standards-sdk.es81.js +24 -36
  153. package/dist/es/standards-sdk.es81.js.map +1 -1
  154. package/dist/es/standards-sdk.es82.js +131 -70
  155. package/dist/es/standards-sdk.es82.js.map +1 -1
  156. package/dist/es/standards-sdk.es83.js +18 -3
  157. package/dist/es/standards-sdk.es83.js.map +1 -1
  158. package/dist/es/standards-sdk.es84.js +29 -2
  159. package/dist/es/standards-sdk.es84.js.map +1 -1
  160. package/dist/es/standards-sdk.es85.js +29 -2
  161. package/dist/es/standards-sdk.es85.js.map +1 -1
  162. package/dist/es/standards-sdk.es86.js +19 -32
  163. package/dist/es/standards-sdk.es86.js.map +1 -1
  164. package/dist/es/standards-sdk.es87.js +41 -30
  165. package/dist/es/standards-sdk.es87.js.map +1 -1
  166. package/dist/es/standards-sdk.es88.js +18 -9
  167. package/dist/es/standards-sdk.es88.js.map +1 -1
  168. package/dist/es/standards-sdk.es89.js +59 -32
  169. package/dist/es/standards-sdk.es89.js.map +1 -1
  170. package/dist/es/standards-sdk.es90.js +1289 -2
  171. package/dist/es/standards-sdk.es90.js.map +1 -1
  172. package/dist/es/standards-sdk.es91.js +131 -67
  173. package/dist/es/standards-sdk.es91.js.map +1 -1
  174. package/dist/es/standards-sdk.es92.js +90 -22
  175. package/dist/es/standards-sdk.es92.js.map +1 -1
  176. package/dist/es/standards-sdk.es93.js +67 -131
  177. package/dist/es/standards-sdk.es93.js.map +1 -1
  178. package/dist/es/standards-sdk.es94.js +27 -86
  179. package/dist/es/standards-sdk.es94.js.map +1 -1
  180. package/dist/es/standards-sdk.es95.js +5 -194
  181. package/dist/es/standards-sdk.es95.js.map +1 -1
  182. package/dist/es/standards-sdk.es96.js +140 -419
  183. package/dist/es/standards-sdk.es96.js.map +1 -1
  184. package/dist/es/standards-sdk.es97.js +22 -24
  185. package/dist/es/standards-sdk.es97.js.map +1 -1
  186. package/dist/es/standards-sdk.es98.js +777 -123
  187. package/dist/es/standards-sdk.es98.js.map +1 -1
  188. package/dist/es/standards-sdk.es99.js +100 -17
  189. package/dist/es/standards-sdk.es99.js.map +1 -1
  190. package/dist/umd/hcs-10/browser.d.ts.map +1 -1
  191. package/dist/umd/hcs-10/sdk.d.ts +10 -1
  192. package/dist/umd/hcs-10/sdk.d.ts.map +1 -1
  193. package/dist/umd/standards-sdk.umd.js +1 -1
  194. package/dist/umd/standards-sdk.umd.js.map +1 -1
  195. package/package.json +1 -1
@@ -1,42 +1,198 @@
1
- import speedometer from "./standards-sdk.es86.js";
2
- import throttle from "./standards-sdk.es87.js";
3
- import utils from "./standards-sdk.es36.js";
4
- const progressEventReducer = (listener, isDownloadStream, freq = 3) => {
5
- let bytesNotified = 0;
6
- const _speedometer = speedometer(50, 250);
7
- return throttle((e) => {
8
- const loaded = e.loaded;
9
- const total = e.lengthComputable ? e.total : void 0;
10
- const progressBytes = loaded - bytesNotified;
11
- const rate = _speedometer(progressBytes);
12
- const inRange = loaded <= total;
13
- bytesNotified = loaded;
14
- const data = {
15
- loaded,
16
- total,
17
- progress: total ? loaded / total : void 0,
18
- bytes: progressBytes,
19
- rate: rate ? rate : void 0,
20
- estimated: rate && total && inRange ? (total - loaded) / rate : void 0,
21
- event: e,
22
- lengthComputable: total != null,
23
- [isDownloadStream ? "download" : "upload"]: true
24
- };
25
- listener(data);
26
- }, freq);
1
+ var __typeError = (msg) => {
2
+ throw TypeError(msg);
27
3
  };
28
- const progressEventDecorator = (total, throttled) => {
29
- const lengthComputable = total != null;
30
- return [(loaded) => throttled[0]({
31
- lengthComputable,
32
- total,
33
- loaded
34
- }), throttled[1]];
4
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
5
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
6
+ var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
7
+ var _AbiCoder_instances, getCoder_fn;
8
+ import { Writer, Reader } from "./standards-sdk.es80.js";
9
+ import { AddressCoder } from "./standards-sdk.es81.js";
10
+ import { ArrayCoder } from "./standards-sdk.es82.js";
11
+ import { BooleanCoder } from "./standards-sdk.es83.js";
12
+ import { BytesCoder } from "./standards-sdk.es84.js";
13
+ import { FixedBytesCoder } from "./standards-sdk.es85.js";
14
+ import { NullCoder } from "./standards-sdk.es86.js";
15
+ import { NumberCoder } from "./standards-sdk.es87.js";
16
+ import { StringCoder } from "./standards-sdk.es88.js";
17
+ import { TupleCoder } from "./standards-sdk.es89.js";
18
+ import { ParamType } from "./standards-sdk.es90.js";
19
+ import { assertArgument, assertArgumentCount, makeError } from "./standards-sdk.es91.js";
20
+ import { getBytes, hexlify } from "./standards-sdk.es92.js";
21
+ import { getAddress } from "./standards-sdk.es93.js";
22
+ const PanicReasons = /* @__PURE__ */ new Map();
23
+ PanicReasons.set(0, "GENERIC_PANIC");
24
+ PanicReasons.set(1, "ASSERT_FALSE");
25
+ PanicReasons.set(17, "OVERFLOW");
26
+ PanicReasons.set(18, "DIVIDE_BY_ZERO");
27
+ PanicReasons.set(33, "ENUM_RANGE_ERROR");
28
+ PanicReasons.set(34, "BAD_STORAGE_DATA");
29
+ PanicReasons.set(49, "STACK_UNDERFLOW");
30
+ PanicReasons.set(50, "ARRAY_RANGE_ERROR");
31
+ PanicReasons.set(65, "OUT_OF_MEMORY");
32
+ PanicReasons.set(81, "UNINITIALIZED_FUNCTION_CALL");
33
+ const paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);
34
+ const paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);
35
+ let defaultCoder = null;
36
+ let defaultMaxInflation = 1024;
37
+ function getBuiltinCallException(action, tx, data, abiCoder) {
38
+ let message = "missing revert data";
39
+ let reason = null;
40
+ const invocation = null;
41
+ let revert = null;
42
+ if (data) {
43
+ message = "execution reverted";
44
+ const bytes = getBytes(data);
45
+ data = hexlify(data);
46
+ if (bytes.length === 0) {
47
+ message += " (no data present; likely require(false) occurred";
48
+ reason = "require(false)";
49
+ } else if (bytes.length % 32 !== 4) {
50
+ message += " (could not decode reason; invalid data length)";
51
+ } else if (hexlify(bytes.slice(0, 4)) === "0x08c379a0") {
52
+ try {
53
+ reason = abiCoder.decode(["string"], bytes.slice(4))[0];
54
+ revert = {
55
+ signature: "Error(string)",
56
+ name: "Error",
57
+ args: [reason]
58
+ };
59
+ message += `: ${JSON.stringify(reason)}`;
60
+ } catch (error) {
61
+ message += " (could not decode reason; invalid string data)";
62
+ }
63
+ } else if (hexlify(bytes.slice(0, 4)) === "0x4e487b71") {
64
+ try {
65
+ const code = Number(abiCoder.decode(["uint256"], bytes.slice(4))[0]);
66
+ revert = {
67
+ signature: "Panic(uint256)",
68
+ name: "Panic",
69
+ args: [code]
70
+ };
71
+ reason = `Panic due to ${PanicReasons.get(code) || "UNKNOWN"}(${code})`;
72
+ message += `: ${reason}`;
73
+ } catch (error) {
74
+ message += " (could not decode panic code)";
75
+ }
76
+ } else {
77
+ message += " (unknown custom error)";
78
+ }
79
+ }
80
+ const transaction = {
81
+ to: tx.to ? getAddress(tx.to) : null,
82
+ data: tx.data || "0x"
83
+ };
84
+ if (tx.from) {
85
+ transaction.from = getAddress(tx.from);
86
+ }
87
+ return makeError(message, "CALL_EXCEPTION", {
88
+ action,
89
+ data,
90
+ reason,
91
+ transaction,
92
+ invocation,
93
+ revert
94
+ });
95
+ }
96
+ const _AbiCoder = class _AbiCoder {
97
+ constructor() {
98
+ __privateAdd(this, _AbiCoder_instances);
99
+ }
100
+ /**
101
+ * Get the default values for the given %%types%%.
102
+ *
103
+ * For example, a ``uint`` is by default ``0`` and ``bool``
104
+ * is by default ``false``.
105
+ */
106
+ getDefaultValue(types) {
107
+ const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
108
+ const coder = new TupleCoder(coders, "_");
109
+ return coder.defaultValue();
110
+ }
111
+ /**
112
+ * Encode the %%values%% as the %%types%% into ABI data.
113
+ *
114
+ * @returns DataHexstring
115
+ */
116
+ encode(types, values) {
117
+ assertArgumentCount(values.length, types.length, "types/values length mismatch");
118
+ const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
119
+ const coder = new TupleCoder(coders, "_");
120
+ const writer = new Writer();
121
+ coder.encode(writer, values);
122
+ return writer.data;
123
+ }
124
+ /**
125
+ * Decode the ABI %%data%% as the %%types%% into values.
126
+ *
127
+ * If %%loose%% decoding is enabled, then strict padding is
128
+ * not enforced. Some older versions of Solidity incorrectly
129
+ * padded event data emitted from ``external`` functions.
130
+ */
131
+ decode(types, data, loose) {
132
+ const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
133
+ const coder = new TupleCoder(coders, "_");
134
+ return coder.decode(new Reader(data, loose, defaultMaxInflation));
135
+ }
136
+ static _setDefaultMaxInflation(value) {
137
+ assertArgument(typeof value === "number" && Number.isInteger(value), "invalid defaultMaxInflation factor", "value", value);
138
+ defaultMaxInflation = value;
139
+ }
140
+ /**
141
+ * Returns the shared singleton instance of a default [[AbiCoder]].
142
+ *
143
+ * On the first call, the instance is created internally.
144
+ */
145
+ static defaultAbiCoder() {
146
+ if (defaultCoder == null) {
147
+ defaultCoder = new _AbiCoder();
148
+ }
149
+ return defaultCoder;
150
+ }
151
+ /**
152
+ * Returns an ethers-compatible [[CallExceptionError]] Error for the given
153
+ * result %%data%% for the [[CallExceptionAction]] %%action%% against
154
+ * the Transaction %%tx%%.
155
+ */
156
+ static getBuiltinCallException(action, tx, data) {
157
+ return getBuiltinCallException(action, tx, data, _AbiCoder.defaultAbiCoder());
158
+ }
35
159
  };
36
- const asyncDecorator = (fn) => (...args) => utils.asap(() => fn(...args));
160
+ _AbiCoder_instances = new WeakSet();
161
+ getCoder_fn = function(param) {
162
+ if (param.isArray()) {
163
+ return new ArrayCoder(__privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, param.arrayChildren), param.arrayLength, param.name);
164
+ }
165
+ if (param.isTuple()) {
166
+ return new TupleCoder(param.components.map((c) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, c)), param.name);
167
+ }
168
+ switch (param.baseType) {
169
+ case "address":
170
+ return new AddressCoder(param.name);
171
+ case "bool":
172
+ return new BooleanCoder(param.name);
173
+ case "string":
174
+ return new StringCoder(param.name);
175
+ case "bytes":
176
+ return new BytesCoder(param.name);
177
+ case "":
178
+ return new NullCoder(param.name);
179
+ }
180
+ let match = param.type.match(paramTypeNumber);
181
+ if (match) {
182
+ let size = parseInt(match[2] || "256");
183
+ assertArgument(size !== 0 && size <= 256 && size % 8 === 0, "invalid " + match[1] + " bit length", "param", param);
184
+ return new NumberCoder(size / 8, match[1] === "int", param.name);
185
+ }
186
+ match = param.type.match(paramTypeBytes);
187
+ if (match) {
188
+ let size = parseInt(match[1]);
189
+ assertArgument(size !== 0 && size <= 32, "invalid bytes length", "param", param);
190
+ return new FixedBytesCoder(size, param.name);
191
+ }
192
+ assertArgument(false, "invalid type", "type", param.type);
193
+ };
194
+ let AbiCoder = _AbiCoder;
37
195
  export {
38
- asyncDecorator,
39
- progressEventDecorator,
40
- progressEventReducer
196
+ AbiCoder
41
197
  };
42
198
  //# sourceMappingURL=standards-sdk.es79.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es79.js","sources":["../../node_modules/axios/lib/helpers/progressEventReducer.js"],"sourcesContent":["import speedometer from \"./speedometer.js\";\nimport throttle from \"./throttle.js\";\nimport utils from \"../utils.js\";\n\nexport const progressEventReducer = (listener, isDownloadStream, freq = 3) => {\n let bytesNotified = 0;\n const _speedometer = speedometer(50, 250);\n\n return throttle(e => {\n const loaded = e.loaded;\n const total = e.lengthComputable ? e.total : undefined;\n const progressBytes = loaded - bytesNotified;\n const rate = _speedometer(progressBytes);\n const inRange = loaded <= total;\n\n bytesNotified = loaded;\n\n const data = {\n loaded,\n total,\n progress: total ? (loaded / total) : undefined,\n bytes: progressBytes,\n rate: rate ? rate : undefined,\n estimated: rate && total && inRange ? (total - loaded) / rate : undefined,\n event: e,\n lengthComputable: total != null,\n [isDownloadStream ? 'download' : 'upload']: true\n };\n\n listener(data);\n }, freq);\n}\n\nexport const progressEventDecorator = (total, throttled) => {\n const lengthComputable = total != null;\n\n return [(loaded) => throttled[0]({\n lengthComputable,\n total,\n loaded\n }), throttled[1]];\n}\n\nexport const asyncDecorator = (fn) => (...args) => utils.asap(() => fn(...args));\n"],"names":[],"mappings":";;;AAIY,MAAC,uBAAuB,CAAC,UAAU,kBAAkB,OAAO,MAAM;AAC5E,MAAI,gBAAgB;AACpB,QAAM,eAAe,YAAY,IAAI,GAAG;AAExC,SAAO,SAAS,OAAK;AACnB,UAAM,SAAS,EAAE;AACjB,UAAM,QAAQ,EAAE,mBAAmB,EAAE,QAAQ;AAC7C,UAAM,gBAAgB,SAAS;AAC/B,UAAM,OAAO,aAAa,aAAa;AACvC,UAAM,UAAU,UAAU;AAE1B,oBAAgB;AAEhB,UAAM,OAAO;AAAA,MACX;AAAA,MACA;AAAA,MACA,UAAU,QAAS,SAAS,QAAS;AAAA,MACrC,OAAO;AAAA,MACP,MAAM,OAAO,OAAO;AAAA,MACpB,WAAW,QAAQ,SAAS,WAAW,QAAQ,UAAU,OAAO;AAAA,MAChE,OAAO;AAAA,MACP,kBAAkB,SAAS;AAAA,MAC3B,CAAC,mBAAmB,aAAa,QAAQ,GAAG;AAAA,IAC7C;AAED,aAAS,IAAI;AAAA,EACd,GAAE,IAAI;AACT;AAEY,MAAC,yBAAyB,CAAC,OAAO,cAAc;AAC1D,QAAM,mBAAmB,SAAS;AAElC,SAAO,CAAC,CAAC,WAAW,UAAU,CAAC,EAAE;AAAA,IAC/B;AAAA,IACA;AAAA,IACA;AAAA,EACJ,CAAG,GAAG,UAAU,CAAC,CAAC;AAClB;AAEY,MAAC,iBAAiB,CAAC,OAAO,IAAI,SAAS,MAAM,KAAK,MAAM,GAAG,GAAG,IAAI,CAAC;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es79.js","sources":["../../node_modules/ethers/lib.esm/abi/abi-coder.js"],"sourcesContent":["/**\n * When sending values to or receiving values from a [[Contract]], the\n * data is generally encoded using the [ABI standard](link-solc-abi).\n *\n * The AbiCoder provides a utility to encode values to ABI data and\n * decode values from ABI data.\n *\n * Most of the time, developers should favour the [[Contract]] class,\n * which further abstracts a lot of the finer details of ABI data.\n *\n * @_section api/abi/abi-coder:ABI Encoding\n */\n// See: https://github.com/ethereum/wiki/wiki/Ethereum-Contract-ABI\nimport { assertArgumentCount, assertArgument } from \"../utils/index.js\";\nimport { Reader, Writer } from \"./coders/abstract-coder.js\";\nimport { AddressCoder } from \"./coders/address.js\";\nimport { ArrayCoder } from \"./coders/array.js\";\nimport { BooleanCoder } from \"./coders/boolean.js\";\nimport { BytesCoder } from \"./coders/bytes.js\";\nimport { FixedBytesCoder } from \"./coders/fixed-bytes.js\";\nimport { NullCoder } from \"./coders/null.js\";\nimport { NumberCoder } from \"./coders/number.js\";\nimport { StringCoder } from \"./coders/string.js\";\nimport { TupleCoder } from \"./coders/tuple.js\";\nimport { ParamType } from \"./fragments.js\";\nimport { getAddress } from \"../address/index.js\";\nimport { getBytes, hexlify, makeError } from \"../utils/index.js\";\n// https://docs.soliditylang.org/en/v0.8.17/control-structures.html\nconst PanicReasons = new Map();\nPanicReasons.set(0x00, \"GENERIC_PANIC\");\nPanicReasons.set(0x01, \"ASSERT_FALSE\");\nPanicReasons.set(0x11, \"OVERFLOW\");\nPanicReasons.set(0x12, \"DIVIDE_BY_ZERO\");\nPanicReasons.set(0x21, \"ENUM_RANGE_ERROR\");\nPanicReasons.set(0x22, \"BAD_STORAGE_DATA\");\nPanicReasons.set(0x31, \"STACK_UNDERFLOW\");\nPanicReasons.set(0x32, \"ARRAY_RANGE_ERROR\");\nPanicReasons.set(0x41, \"OUT_OF_MEMORY\");\nPanicReasons.set(0x51, \"UNINITIALIZED_FUNCTION_CALL\");\nconst paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);\nconst paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);\nlet defaultCoder = null;\nlet defaultMaxInflation = 1024;\nfunction getBuiltinCallException(action, tx, data, abiCoder) {\n let message = \"missing revert data\";\n let reason = null;\n const invocation = null;\n let revert = null;\n if (data) {\n message = \"execution reverted\";\n const bytes = getBytes(data);\n data = hexlify(data);\n if (bytes.length === 0) {\n message += \" (no data present; likely require(false) occurred\";\n reason = \"require(false)\";\n }\n else if (bytes.length % 32 !== 4) {\n message += \" (could not decode reason; invalid data length)\";\n }\n else if (hexlify(bytes.slice(0, 4)) === \"0x08c379a0\") {\n // Error(string)\n try {\n reason = abiCoder.decode([\"string\"], bytes.slice(4))[0];\n revert = {\n signature: \"Error(string)\",\n name: \"Error\",\n args: [reason]\n };\n message += `: ${JSON.stringify(reason)}`;\n }\n catch (error) {\n message += \" (could not decode reason; invalid string data)\";\n }\n }\n else if (hexlify(bytes.slice(0, 4)) === \"0x4e487b71\") {\n // Panic(uint256)\n try {\n const code = Number(abiCoder.decode([\"uint256\"], bytes.slice(4))[0]);\n revert = {\n signature: \"Panic(uint256)\",\n name: \"Panic\",\n args: [code]\n };\n reason = `Panic due to ${PanicReasons.get(code) || \"UNKNOWN\"}(${code})`;\n message += `: ${reason}`;\n }\n catch (error) {\n message += \" (could not decode panic code)\";\n }\n }\n else {\n message += \" (unknown custom error)\";\n }\n }\n const transaction = {\n to: (tx.to ? getAddress(tx.to) : null),\n data: (tx.data || \"0x\")\n };\n if (tx.from) {\n transaction.from = getAddress(tx.from);\n }\n return makeError(message, \"CALL_EXCEPTION\", {\n action, data, reason, transaction, invocation, revert\n });\n}\n/**\n * The **AbiCoder** is a low-level class responsible for encoding JavaScript\n * values into binary data and decoding binary data into JavaScript values.\n */\nexport class AbiCoder {\n #getCoder(param) {\n if (param.isArray()) {\n return new ArrayCoder(this.#getCoder(param.arrayChildren), param.arrayLength, param.name);\n }\n if (param.isTuple()) {\n return new TupleCoder(param.components.map((c) => this.#getCoder(c)), param.name);\n }\n switch (param.baseType) {\n case \"address\":\n return new AddressCoder(param.name);\n case \"bool\":\n return new BooleanCoder(param.name);\n case \"string\":\n return new StringCoder(param.name);\n case \"bytes\":\n return new BytesCoder(param.name);\n case \"\":\n return new NullCoder(param.name);\n }\n // u?int[0-9]*\n let match = param.type.match(paramTypeNumber);\n if (match) {\n let size = parseInt(match[2] || \"256\");\n assertArgument(size !== 0 && size <= 256 && (size % 8) === 0, \"invalid \" + match[1] + \" bit length\", \"param\", param);\n return new NumberCoder(size / 8, (match[1] === \"int\"), param.name);\n }\n // bytes[0-9]+\n match = param.type.match(paramTypeBytes);\n if (match) {\n let size = parseInt(match[1]);\n assertArgument(size !== 0 && size <= 32, \"invalid bytes length\", \"param\", param);\n return new FixedBytesCoder(size, param.name);\n }\n assertArgument(false, \"invalid type\", \"type\", param.type);\n }\n /**\n * Get the default values for the given %%types%%.\n *\n * For example, a ``uint`` is by default ``0`` and ``bool``\n * is by default ``false``.\n */\n getDefaultValue(types) {\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.defaultValue();\n }\n /**\n * Encode the %%values%% as the %%types%% into ABI data.\n *\n * @returns DataHexstring\n */\n encode(types, values) {\n assertArgumentCount(values.length, types.length, \"types/values length mismatch\");\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = (new TupleCoder(coders, \"_\"));\n const writer = new Writer();\n coder.encode(writer, values);\n return writer.data;\n }\n /**\n * Decode the ABI %%data%% as the %%types%% into values.\n *\n * If %%loose%% decoding is enabled, then strict padding is\n * not enforced. Some older versions of Solidity incorrectly\n * padded event data emitted from ``external`` functions.\n */\n decode(types, data, loose) {\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.decode(new Reader(data, loose, defaultMaxInflation));\n }\n static _setDefaultMaxInflation(value) {\n assertArgument(typeof (value) === \"number\" && Number.isInteger(value), \"invalid defaultMaxInflation factor\", \"value\", value);\n defaultMaxInflation = value;\n }\n /**\n * Returns the shared singleton instance of a default [[AbiCoder]].\n *\n * On the first call, the instance is created internally.\n */\n static defaultAbiCoder() {\n if (defaultCoder == null) {\n defaultCoder = new AbiCoder();\n }\n return defaultCoder;\n }\n /**\n * Returns an ethers-compatible [[CallExceptionError]] Error for the given\n * result %%data%% for the [[CallExceptionAction]] %%action%% against\n * the Transaction %%tx%%.\n */\n static getBuiltinCallException(action, tx, data) {\n return getBuiltinCallException(action, tx, data, AbiCoder.defaultAbiCoder());\n }\n}\n//# sourceMappingURL=abi-coder.js.map"],"names":[],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,7 +1,7 @@
1
- import Buffer from "./standards-sdk.es21.js";
2
- import { KeyList, TopicCreateTransaction, Transaction, TopicMessageSubmitTransaction, Hbar } from "@hashgraph/sdk";
1
+ import Buffer from "./standards-sdk.es22.js";
2
+ import { KeyList, TopicCreateTransaction, AccountId, Transaction, TopicMessageSubmitTransaction, Hbar } from "@hashgraph/sdk";
3
3
  import { Logger } from "./standards-sdk.es14.js";
4
- import { I as InscriptionSDK } from "./standards-sdk.es22.js";
4
+ import { I as InscriptionSDK } from "./standards-sdk.es25.js";
5
5
  import { HCS10BaseClient, Hcs10MemoType } from "./standards-sdk.es5.js";
6
6
  import { m as mimeTypesExports } from "./standards-sdk.es26.js";
7
7
  import { AgentBuilder } from "./standards-sdk.es10.js";
@@ -131,17 +131,17 @@ class BrowserHCSClient extends HCS10BaseClient {
131
131
  inboundTopicId,
132
132
  connectionId
133
133
  });
134
- const transaction = new TopicCreateTransaction().setTopicMemo(memo).setAdminKey(thresholdKey).setSubmitKey(thresholdKey);
134
+ const transaction = new TopicCreateTransaction().setTopicMemo(memo).setAutoRenewAccountId(AccountId.fromString(userAccountId)).setAdminKey(thresholdKey).setSubmitKey(thresholdKey);
135
135
  this.logger.debug("Executing topic creation transaction");
136
136
  const txResponse = await this.hwc.executeTransactionWithErrorHandling(
137
137
  transaction,
138
138
  false
139
139
  );
140
- if (txResponse.error) {
140
+ if (txResponse?.error) {
141
141
  this.logger.error(txResponse.error);
142
142
  throw new Error(txResponse.error);
143
143
  }
144
- const resultReceipt = txResponse.result;
144
+ const resultReceipt = txResponse?.result;
145
145
  if (!resultReceipt?.topicId) {
146
146
  this.logger.error("Failed to create topic: topicId is null");
147
147
  throw new Error("Failed to create topic: topicId is null");
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es8.js","sources":["../../src/hcs-10/browser.ts"],"sourcesContent":["import {\n KeyList,\n PublicKey,\n TopicCreateTransaction,\n TopicMessageSubmitTransaction,\n TransactionReceipt,\n PrivateKey,\n Hbar,\n} from '@hashgraph/sdk';\nimport { HashinalsWalletConnectSDK } from '@hashgraphonline/hashinal-wc';\nimport { Logger, LogLevel } from '../utils/logger';\nimport {\n InscriptionSDK,\n RetrievedInscriptionResult,\n} from '@kiloscribe/inscription-sdk';\nimport { HCS10BaseClient } from './base-client';\nimport * as mime from 'mime-types';\nimport {\n AgentConfig,\n InscribePfpResponse,\n StoreHCS11ProfileResponse,\n AgentRegistrationResult,\n HandleConnectionRequestResponse,\n RegistrationProgressCallback,\n AgentCreationState,\n GetAccountAndSignerResponse,\n} from './types';\nimport {\n HCS11Client,\n AgentMetadata as AIAgentMetadata,\n InscribeProfileResponse,\n HCS11Profile,\n AIAgentProfile,\n PersonalProfile,\n SocialLink,\n SocialPlatform,\n} from '../hcs-11';\nimport { ProgressReporter, ProgressData } from '../utils/progress-reporter';\nimport { Transaction } from '@hashgraph/sdk';\nimport { AgentBuilder } from '../hcs-11/agent-builder';\nimport { PersonBuilder } from '../hcs-11/person-builder';\nimport { Hcs10MemoType } from './base-client';\nimport { inscribe, inscribeWithSigner } from '../inscribe/inscriber';\n\nconst isBrowser = typeof window !== 'undefined';\n\nexport type BrowserHCSClientConfig = {\n network: 'mainnet' | 'testnet';\n hwc: HashinalsWalletConnectSDK;\n logLevel?: LogLevel;\n prettyPrint?: boolean;\n guardedRegistryTopicId?: string;\n guardedRegistryBaseUrl?: string;\n feeAmount?: number;\n};\n\ninterface SocialLinks {\n x?: string;\n discord?: string;\n github?: string;\n website?: string;\n}\n\nexport type BrowserAgentConfig = Omit<\n AgentConfig<BrowserHCSClient>,\n 'privateKey'\n> & {\n client: BrowserHCSClient;\n};\n\nexport type RegisteredAgent = {\n outboundTopicId: string;\n inboundTopicId: string;\n pfpTopicId: string;\n profileTopicId: string;\n error?: string;\n success: boolean;\n state: AgentCreationState;\n};\n\nexport class BrowserHCSClient extends HCS10BaseClient {\n private hwc: HashinalsWalletConnectSDK;\n protected declare logger: Logger;\n private guardedRegistryBaseUrl: string;\n private hcs11Client: HCS11Client | null = null;\n\n constructor(config: BrowserHCSClientConfig) {\n super({\n network: config.network,\n logLevel: config.logLevel,\n prettyPrint: config.prettyPrint,\n feeAmount: config.feeAmount,\n });\n\n this.hwc = config.hwc;\n if (!config.guardedRegistryBaseUrl) {\n this.guardedRegistryBaseUrl = 'https://moonscape.tech';\n } else {\n this.guardedRegistryBaseUrl = config.guardedRegistryBaseUrl;\n }\n\n let logLevel: LogLevel;\n if (config.logLevel) {\n logLevel = config.logLevel;\n } else {\n logLevel = 'info';\n }\n\n this.logger = Logger.getInstance({\n level: logLevel,\n module: 'HCS-Browser',\n prettyPrint: config.prettyPrint,\n });\n\n if (isBrowser) {\n try {\n const { accountId, signer } = this.getAccountAndSigner();\n\n this.hcs11Client = new HCS11Client({\n network: config.network,\n auth: {\n operatorId: accountId,\n signer: signer as any,\n },\n logLevel: config.logLevel,\n });\n } catch (err) {\n this.logger.warn(`Failed to initialize HCS11Client: ${err}`);\n }\n } else {\n this.logger.error(\n 'BrowserHCSClient initialized in server environment - browser-specific features will not be available. Use HCS10Client instead.'\n );\n }\n }\n\n async sendMessage(\n connectionTopicId: string,\n data: string,\n memo?: string,\n submitKey?: PrivateKey,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n waitMaxAttempts?: number;\n waitIntervalMs?: number;\n }\n ): Promise<TransactionReceipt> {\n this.logger.info('Sending message');\n const operatorId = await this.getOperatorId();\n\n const payload = {\n p: 'hcs-10',\n op: 'message',\n operator_id: operatorId,\n data,\n m: memo,\n };\n\n const submissionCheck = await this.canSubmitToTopic(\n connectionTopicId,\n this.hwc.getAccountInfo().accountId\n );\n\n const payloadString = JSON.stringify(payload);\n const isLargePayload = Buffer.from(payloadString).length > 1000;\n\n if (isLargePayload) {\n this.logger.info(\n 'Message payload exceeds 1000 bytes, storing via inscription'\n );\n try {\n const contentBuffer = Buffer.from(data);\n const fileName = `message-${Date.now()}.json`;\n const inscriptionResult = await this.inscribeFile(\n contentBuffer,\n fileName,\n {\n progressCallback: options?.progressCallback,\n waitMaxAttempts: options?.waitMaxAttempts,\n waitIntervalMs: options?.waitIntervalMs,\n }\n );\n\n if (inscriptionResult?.topic_id) {\n payload.data = `hcs://1/${inscriptionResult.topic_id}`;\n this.logger.info(\n `Large message inscribed with topic ID: ${inscriptionResult.topic_id}`\n );\n } else {\n throw new Error('Failed to inscribe large message content');\n }\n } catch (error) {\n this.logger.error('Error inscribing large message:', error);\n throw new Error(\n `Failed to handle large message: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`\n );\n }\n }\n\n return await this.submitPayload(\n connectionTopicId,\n payload,\n submitKey,\n submissionCheck.requiresFee\n );\n }\n\n async getPublicKey(accountId: string): Promise<PublicKey> {\n return await this.mirrorNode.getPublicKey(accountId);\n }\n\n async handleConnectionRequest(\n inboundTopicId: string,\n requestingAccountId: string,\n connectionId: number,\n connectionMemo: string = 'Connection accepted. Looking forward to collaborating!',\n ttl: number = 60\n ): Promise<HandleConnectionRequestResponse> {\n this.logger.info('Handling connection request');\n const userAccountId = this.hwc.getAccountInfo().accountId;\n if (!userAccountId) {\n throw new Error('Failed to retrieve user account ID');\n }\n\n const requesterKey = await this.mirrorNode.getPublicKey(\n requestingAccountId\n );\n const accountKey = await this.mirrorNode.getPublicKey(userAccountId);\n\n if (!accountKey) {\n throw new Error('Failed to retrieve public key');\n }\n\n const thresholdKey = new KeyList([accountKey, requesterKey], 1);\n const memo = this._generateHcs10Memo(Hcs10MemoType.CONNECTION, {\n ttl,\n inboundTopicId,\n connectionId,\n });\n\n const transaction = new TopicCreateTransaction()\n .setTopicMemo(memo)\n .setAdminKey(thresholdKey)\n .setSubmitKey(thresholdKey);\n\n this.logger.debug('Executing topic creation transaction');\n const txResponse = await this.hwc.executeTransactionWithErrorHandling(\n transaction,\n false\n );\n if (txResponse.error) {\n this.logger.error(txResponse.error);\n throw new Error(txResponse.error);\n }\n\n const resultReceipt = txResponse.result;\n if (!resultReceipt?.topicId) {\n this.logger.error('Failed to create topic: topicId is null');\n throw new Error('Failed to create topic: topicId is null');\n }\n\n const connectionTopicId = resultReceipt.topicId.toString();\n const operatorId = `${inboundTopicId}@${userAccountId}`;\n const confirmedConnectionSequenceNumber = await this.confirmConnection(\n inboundTopicId,\n connectionTopicId,\n requestingAccountId,\n connectionId,\n operatorId,\n connectionMemo\n );\n\n const accountTopics = await this.retrieveCommunicationTopics(userAccountId);\n\n const requestingAccountTopics = await this.retrieveCommunicationTopics(\n requestingAccountId\n );\n\n const requestingAccountOperatorId = `${requestingAccountTopics.inboundTopic}@${requestingAccountId}`;\n\n await this.recordOutboundConnectionConfirmation({\n outboundTopicId: accountTopics.outboundTopic,\n requestorOutboundTopicId: requestingAccountTopics.outboundTopic,\n connectionRequestId: connectionId,\n confirmedRequestId: confirmedConnectionSequenceNumber,\n connectionTopicId,\n operatorId: requestingAccountOperatorId,\n memo: `Connection established with ${requestingAccountId}`,\n });\n\n return {\n connectionTopicId,\n confirmedConnectionSequenceNumber,\n operatorId,\n };\n }\n\n async confirmConnection(\n inboundTopicId: string,\n connectionTopicId: string,\n connectedAccountId: string,\n connectionId: number,\n operatorId: string,\n memo: string\n ): Promise<number> {\n this.logger.info('Confirming connection');\n const payload = {\n p: 'hcs-10',\n op: 'connection_created',\n connection_topic_id: connectionTopicId,\n connected_account_id: connectedAccountId,\n operator_id: operatorId,\n connection_id: connectionId,\n m: memo,\n };\n\n const transactionResponse = await this.submitPayload(\n inboundTopicId,\n payload\n );\n if (!transactionResponse?.topicSequenceNumber) {\n this.logger.error(\n 'Failed to confirm connection: sequence number is null'\n );\n throw new Error('Failed to confirm connection: sequence number is null');\n }\n return transactionResponse.topicSequenceNumber.toNumber();\n }\n\n async create(\n builder: AgentBuilder | PersonBuilder,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n existingState?: AgentCreationState;\n ttl?: number;\n updateAccountMemo?: boolean;\n }\n ): Promise<RegisteredAgent | InscribeProfileResponse> {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'ProfileCreate',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n try {\n const isAgentBuilder = builder instanceof AgentBuilder;\n\n let state;\n if (options?.existingState) {\n state = options.existingState;\n } else {\n state = {\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState;\n }\n\n if (isAgentBuilder) {\n this.logger.info('Creating Agent Profile and HCS-10 Topics');\n const agentConfig = (builder as AgentBuilder).build();\n state.agentMetadata = agentConfig.metadata;\n } else {\n this.logger.info('Creating Person HCS-11 Profile');\n }\n\n progressReporter.preparing(\n `Starting ${isAgentBuilder ? 'agent' : 'person'} resource creation`,\n 0,\n {\n state,\n }\n );\n\n const {\n inboundTopicId,\n outboundTopicId,\n state: updatedState,\n } = await this.createCommunicationTopics(options, progressReporter);\n\n state = updatedState;\n\n if (!isAgentBuilder) {\n (builder as PersonBuilder).setInboundTopicId(inboundTopicId);\n (builder as PersonBuilder).setOutboundTopicId(outboundTopicId);\n }\n\n let pfpTopicId: string | undefined;\n let hasPfpBuffer: Buffer | undefined;\n let pfpFileName: string | undefined;\n\n if (isAgentBuilder) {\n const agentProfile = (builder as AgentBuilder).build();\n pfpTopicId = agentProfile.existingPfpTopicId || state.pfpTopicId;\n hasPfpBuffer = agentProfile.pfpBuffer;\n pfpFileName = agentProfile.pfpFileName || 'pfp.png';\n } else {\n const personProfile = (builder as PersonBuilder).build();\n pfpTopicId = state.pfpTopicId;\n hasPfpBuffer = personProfile.pfpBuffer;\n pfpFileName = personProfile.pfpFileName;\n }\n\n if (!pfpTopicId && hasPfpBuffer && pfpFileName) {\n pfpTopicId = await this.handleProfilePictureCreation(\n hasPfpBuffer,\n pfpFileName,\n state,\n progressReporter\n );\n } else if (pfpTopicId) {\n progressReporter.preparing(\n `Using existing profile picture: ${pfpTopicId}`,\n 50,\n { state }\n );\n state.pfpTopicId = pfpTopicId;\n }\n\n await this.createAndInscribeProfile(\n isAgentBuilder,\n builder as any,\n pfpTopicId,\n state,\n inboundTopicId,\n outboundTopicId,\n options,\n progressReporter\n );\n\n state.currentStage = 'complete';\n state.completedPercentage = 100;\n progressReporter.completed(\n `${isAgentBuilder ? 'Agent' : 'Person'} profile created successfully`,\n {\n profileTopicId: state.profileTopicId,\n inboundTopicId,\n outboundTopicId,\n pfpTopicId,\n state,\n }\n );\n\n let outTopicId = '';\n if (state.outboundTopicId) {\n outTopicId = state.outboundTopicId;\n }\n\n let inTopicId = '';\n if (state.inboundTopicId) {\n inTopicId = state.inboundTopicId;\n }\n\n let profilePicTopicId = '';\n if (state.pfpTopicId) {\n profilePicTopicId = state.pfpTopicId;\n }\n\n let profTopicId = '';\n if (state.profileTopicId) {\n profTopicId = state.profileTopicId;\n }\n\n return {\n outboundTopicId: outTopicId,\n inboundTopicId: inTopicId,\n pfpTopicId: profilePicTopicId,\n profileTopicId: profTopicId,\n success: true,\n state,\n } as RegisteredAgent | InscribeProfileResponse;\n } catch (error: any) {\n progressReporter.failed('Error during profile creation', {\n error: error.message,\n });\n return {\n outboundTopicId: '',\n inboundTopicId: '',\n pfpTopicId: '',\n profileTopicId: '',\n success: false,\n error: error.message,\n state: {\n currentStage: 'init',\n completedPercentage: 0,\n error: error.message,\n } as AgentCreationState,\n } as RegisteredAgent;\n }\n }\n\n private async handleProfilePictureCreation(\n pfpBuffer: Buffer,\n pfpFileName: string,\n state: AgentCreationState,\n progressReporter: ProgressReporter\n ): Promise<string> {\n state.currentStage = 'pfp';\n progressReporter.preparing('Creating profile picture', 30, {\n state,\n });\n\n const pfpProgress = progressReporter.createSubProgress({\n minPercent: 30,\n maxPercent: 50,\n logPrefix: 'PFP',\n });\n\n const pfpResult = await this.inscribePfp(pfpBuffer, pfpFileName, {\n progressCallback: (data) =>\n pfpProgress.report({\n ...data,\n progressPercent: data.progressPercent ?? 0,\n details: { ...data.details, state },\n }),\n });\n\n if (!pfpResult.success) {\n let errorMessage = 'Failed to inscribe profile picture';\n if (pfpResult.error) {\n errorMessage = pfpResult.error;\n }\n throw new Error(errorMessage);\n }\n\n const pfpTopicId = pfpResult.pfpTopicId;\n state.pfpTopicId = pfpTopicId;\n\n if (state.createdResources) {\n state.createdResources.push(`pfp:${state.pfpTopicId}`);\n }\n\n progressReporter.preparing('Profile picture created', 50, { state });\n\n return pfpTopicId;\n }\n\n private async createAndInscribeProfile(\n isAgentBuilder: boolean,\n builder: AgentBuilder | PersonBuilder,\n pfpTopicId: string | undefined,\n state: AgentCreationState,\n inboundTopicId: string,\n outboundTopicId: string,\n options?: {\n updateAccountMemo?: boolean;\n },\n progressReporter?: ProgressReporter\n ): Promise<void> {\n if (!this.hcs11Client) {\n if (progressReporter) {\n progressReporter.failed('HCS11Client is not available');\n }\n throw new Error('HCS11Client is not available');\n }\n\n this.logger.info('Creating and inscribing profile');\n if (!state.profileTopicId) {\n if (progressReporter) {\n progressReporter.preparing(\n `Storing HCS-11 ${isAgentBuilder ? 'agent' : 'person'} profile`,\n 80\n );\n }\n\n const profileProgress = progressReporter?.createSubProgress({\n minPercent: 80,\n maxPercent: 95,\n logPrefix: 'StoreProfile',\n });\n\n let hcs11Profile;\n\n if (isAgentBuilder) {\n const agentProfile = (builder as AgentBuilder).build();\n\n const socialLinks = agentProfile.metadata?.socials\n ? Object.entries(agentProfile.metadata.socials).map(\n ([platform, handle]) => ({\n platform: platform as SocialPlatform,\n handle: handle as string,\n })\n )\n : [];\n\n hcs11Profile = this.hcs11Client.createAIAgentProfile(\n agentProfile.name,\n agentProfile.metadata?.type === 'manual' ? 0 : 1,\n agentProfile.capabilities || [],\n agentProfile.metadata?.model || 'unknown',\n {\n alias: agentProfile.name.toLowerCase().replace(/\\s+/g, '_'),\n bio: agentProfile.bio,\n profileImage: pfpTopicId ? `hcs://1/${pfpTopicId}` : undefined,\n socials: socialLinks,\n properties: agentProfile.metadata?.properties || {},\n inboundTopicId,\n outboundTopicId,\n creator: agentProfile.metadata?.creator,\n }\n );\n } else {\n const personProfile = (builder as PersonBuilder).build();\n\n const { pfpBuffer, pfpFileName, ...cleanProfile } = personProfile;\n\n hcs11Profile = this.hcs11Client.createPersonalProfile(\n personProfile.display_name,\n {\n alias: personProfile.alias,\n bio: personProfile.bio,\n socials: personProfile.socials,\n profileImage: pfpTopicId\n ? `hcs://1/${pfpTopicId}`\n : personProfile.profileImage,\n properties: personProfile.properties,\n inboundTopicId,\n outboundTopicId,\n }\n );\n }\n\n const profileResult = await this.hcs11Client.createAndInscribeProfile(\n hcs11Profile,\n options?.updateAccountMemo ?? true,\n {\n progressCallback: (data) =>\n profileProgress?.report({\n ...data,\n progressPercent: data.progressPercent ?? 0,\n }),\n }\n );\n\n if (!profileResult.success) {\n if (progressReporter) {\n progressReporter.failed(\n `Failed to inscribe ${isAgentBuilder ? 'agent' : 'person'} profile`,\n {\n error: profileResult.error,\n }\n );\n }\n\n let errorMessage = `Failed to inscribe ${\n isAgentBuilder ? 'agent' : 'person'\n } profile`;\n if (profileResult.error) {\n errorMessage = profileResult.error;\n }\n throw new Error(errorMessage);\n }\n\n state.profileTopicId = profileResult.profileTopicId;\n\n if (state.createdResources) {\n state.createdResources.push(`profile:${profileResult.profileTopicId}`);\n }\n\n if (progressReporter) {\n progressReporter.preparing('HCS-11 Profile stored', 95, { state });\n }\n } else if (progressReporter) {\n progressReporter.preparing(\n `Using existing ${isAgentBuilder ? 'agent' : 'person'} profile`,\n 95,\n {\n state,\n }\n );\n }\n }\n\n private initializeRegistrationState(\n inboundTopicId: string,\n existingState?: AgentCreationState\n ): AgentCreationState {\n const state = existingState || {\n inboundTopicId,\n currentStage: 'registration',\n completedPercentage: 0,\n createdResources: [],\n };\n\n if (\n state.currentStage !== 'registration' &&\n state.currentStage !== 'complete'\n ) {\n state.currentStage = 'registration';\n }\n\n return state;\n }\n\n private updateStateForCompletedRegistration(\n state: AgentCreationState,\n inboundTopicId: string\n ): void {\n state.currentStage = 'complete';\n state.completedPercentage = 100;\n if (state.createdResources) {\n state.createdResources.push(`registration:${inboundTopicId}`);\n }\n }\n\n async registerAgentWithGuardedRegistry(\n accountId: string,\n network: string = this.network,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n maxAttempts?: number;\n delayMs?: number;\n existingState?: AgentCreationState;\n }\n ): Promise<AgentRegistrationResult> {\n try {\n this.logger.info('Registering agent with guarded registry');\n\n const agentProfile = await this.retrieveProfile(accountId);\n const inboundTopicId = agentProfile.topicInfo.inboundTopic;\n const state = this.initializeRegistrationState(\n inboundTopicId,\n options?.existingState\n );\n const progressReporter = new ProgressReporter({\n module: 'AgentRegistration',\n logger: this.logger,\n callback: options?.progressCallback,\n });\n\n progressReporter.preparing('Preparing agent registration', 10, {\n inboundTopicId,\n accountId,\n });\n\n const registrationResult = await this.executeRegistration(\n accountId,\n network as string,\n this.guardedRegistryBaseUrl,\n this.logger\n );\n\n if (!registrationResult.success) {\n return {\n ...registrationResult,\n state,\n };\n }\n\n progressReporter.submitting('Submitting registration to registry', 30, {\n transactionId: registrationResult.transactionId,\n });\n\n if (registrationResult.transaction) {\n const transaction = Transaction.fromBytes(\n Buffer.from(registrationResult.transaction, 'base64')\n );\n\n this.logger.info(`Processing registration transaction`);\n const txResult = await this.hwc.executeTransactionWithErrorHandling(\n transaction as any,\n true\n );\n\n if (txResult.error) {\n return {\n ...registrationResult,\n error: txResult.error,\n success: false,\n state,\n };\n }\n\n this.logger.info(`Successfully processed registration transaction`);\n }\n\n progressReporter.confirming('Confirming registration transaction', 60, {\n accountId,\n inboundTopicId,\n transactionId: registrationResult.transactionId,\n });\n\n const maxAttempts = options?.maxAttempts ?? 60;\n const delayMs = options?.delayMs ?? 2000;\n\n const confirmed = await this.waitForRegistrationConfirmation(\n registrationResult.transactionId!,\n network,\n this.guardedRegistryBaseUrl,\n maxAttempts,\n delayMs,\n this.logger\n );\n\n this.updateStateForCompletedRegistration(state, inboundTopicId);\n\n progressReporter.completed('Agent registration complete', {\n transactionId: registrationResult.transactionId,\n inboundTopicId,\n state,\n confirmed,\n });\n\n return {\n ...registrationResult,\n confirmed,\n state,\n };\n } catch (error: any) {\n this.logger.error(`Registration error: ${error.message}`);\n return {\n error: `Error during registration: ${error.message}`,\n success: false,\n state: {\n currentStage: 'registration',\n completedPercentage: 0,\n error: error.message,\n },\n };\n }\n }\n\n async createAndRegisterAgent(\n builder: AgentBuilder,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n maxAttempts?: number;\n delayMs?: number;\n existingState?: AgentCreationState;\n baseUrl?: string;\n }\n ): Promise<AgentRegistrationResult> {\n try {\n const agentConfig = builder.build();\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'AgentCreateRegister',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n let state =\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState);\n\n state.agentMetadata = agentConfig.metadata;\n\n progressReporter.preparing('Starting agent creation process', 0, {\n state,\n });\n\n if (\n state.currentStage !== 'complete' ||\n !state.inboundTopicId ||\n !state.outboundTopicId ||\n !state.profileTopicId\n ) {\n const createResult = await this.create(builder, {\n progressCallback: (progress: any) => {\n const adjustedPercent = (progress.progressPercent || 0) * 0.3;\n progressReporter.report({\n ...progress,\n progressPercent: adjustedPercent,\n details: {\n ...progress.details,\n state: progress.details?.state || state,\n },\n });\n },\n existingState: state,\n updateAccountMemo: false,\n });\n\n if (!('state' in createResult)) {\n throw new Error('Create method did not return expected agent state.');\n }\n\n if (!createResult.success) {\n throw new Error(\n createResult.error || 'Failed to create agent resources'\n );\n }\n\n state = createResult.state;\n state.agentMetadata = agentConfig.metadata;\n }\n\n progressReporter.preparing(\n `Agent creation status: ${state.currentStage}, ${state.completedPercentage}%`,\n 30,\n { state }\n );\n\n const { accountId } = this.getAccountAndSigner();\n\n if (\n state.currentStage !== 'complete' ||\n !state.createdResources?.includes(\n `registration:${state.inboundTopicId}`\n )\n ) {\n if (options?.baseUrl) {\n this.guardedRegistryBaseUrl = options.baseUrl;\n }\n\n const registrationResult = await this.registerAgentWithGuardedRegistry(\n accountId,\n agentConfig.network,\n {\n progressCallback: (progress) => {\n const adjustedPercent =\n 30 + (progress.progressPercent || 0) * 0.7;\n progressReporter.report({\n ...progress,\n progressPercent: adjustedPercent,\n details: {\n ...progress.details,\n state: progress.details?.state || state,\n },\n });\n },\n maxAttempts: options?.maxAttempts,\n delayMs: options?.delayMs,\n existingState: state,\n }\n );\n\n if (!registrationResult.success) {\n throw new Error(\n registrationResult.error || 'Failed to register agent with registry'\n );\n }\n\n state = registrationResult.state;\n\n if (state.profileTopicId) {\n await this.hcs11Client?.updateAccountMemoWithProfile(\n accountId,\n state.profileTopicId\n );\n }\n }\n\n progressReporter.completed('Agent creation and registration complete', {\n state,\n });\n\n return {\n success: true,\n state,\n metadata: {\n accountId,\n operatorId: `${state.inboundTopicId}@${accountId}`,\n inboundTopicId: state.inboundTopicId!,\n outboundTopicId: state.outboundTopicId!,\n profileTopicId: state.profileTopicId!,\n pfpTopicId: state.pfpTopicId!,\n privateKey: null,\n ...state.agentMetadata,\n },\n };\n } catch (error: any) {\n this.logger.error(\n `Failed to create and register agent: ${error.message}`\n );\n return {\n success: false,\n error: `Failed to create and register agent: ${error.message}`,\n state:\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n error: error.message,\n } as AgentCreationState),\n };\n }\n }\n\n async storeHCS11Profile(\n agentName: string,\n agentBio: string,\n inboundTopicId: string,\n outboundTopicId: string,\n capabilities: number[] = [],\n metadata: Record<string, any> = {},\n pfpBuffer?: Buffer,\n pfpFileName?: string,\n existingPfpTopicId?: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n }\n ): Promise<StoreHCS11ProfileResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'StoreHCS11Profile',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n progressReporter.preparing('Preparing agent profile data', 0);\n\n let pfpTopicId = existingPfpTopicId;\n\n if (!pfpTopicId && pfpBuffer && pfpFileName) {\n const pfpProgress = progressReporter.createSubProgress({\n minPercent: 0,\n maxPercent: 60,\n logPrefix: 'PFP',\n });\n\n const pfpResult = await this.inscribePfp(pfpBuffer, pfpFileName, {\n progressCallback: (data) => {\n pfpProgress.report({\n stage: data.stage,\n message: data.message,\n progressPercent: data.progressPercent || 0,\n details: data.details,\n });\n },\n });\n\n if (!pfpResult.success) {\n progressReporter.failed(\n 'Failed to inscribe profile picture, continuing without PFP'\n );\n } else {\n pfpTopicId = pfpResult.pfpTopicId;\n }\n } else if (existingPfpTopicId) {\n progressReporter.preparing(\n `Using existing profile picture: ${existingPfpTopicId}`,\n 30\n );\n } else {\n progressReporter.preparing('No profile picture provided', 30);\n }\n\n if (!this.hcs11Client) {\n progressReporter.failed(\n 'HCS11Client is not available in this environment'\n );\n return {\n profileTopicId: '',\n success: false,\n error: 'HCS11Client is not available in this environment',\n transactionId: '',\n };\n }\n\n const agentType = this.hcs11Client.getAgentTypeFromMetadata({\n type: metadata.type || 'autonomous',\n } as AIAgentMetadata);\n\n progressReporter.preparing('Building agent profile', 65);\n\n const formattedSocials: SocialLink[] | undefined = metadata.socials\n ? Object.entries(metadata.socials)\n .filter(([_, handle]) => handle)\n .map(([platform, handle]) => ({\n platform: platform as SocialPlatform,\n handle: handle as string,\n }))\n : undefined;\n\n const profile = this.hcs11Client.createAIAgentProfile(\n agentName,\n agentType,\n capabilities,\n metadata.model || 'unknown',\n {\n alias: agentName.toLowerCase().replace(/\\s+/g, '_'),\n bio: agentBio,\n profileImage: pfpTopicId ? `hcs://1/${pfpTopicId}` : undefined,\n socials: formattedSocials,\n properties: {\n version: metadata.version || '1.0.0',\n creator: metadata.creator || 'Unknown',\n supported_languages: metadata.supported_languages || ['en'],\n permissions: metadata.permissions || [],\n model_details: metadata.model_details,\n training: metadata.training,\n capabilities_description: metadata.capabilities_description,\n ...metadata,\n },\n inboundTopicId,\n outboundTopicId,\n creator: metadata.creator,\n }\n );\n\n const profileProgress = progressReporter.createSubProgress({\n minPercent: 65,\n maxPercent: 100,\n logPrefix: 'Profile',\n });\n\n const profileResult = await this.hcs11Client.createAndInscribeProfile(\n profile,\n true,\n {\n progressCallback: (profileData) => {\n profileProgress.report({\n stage: profileData.stage,\n message: profileData.message,\n progressPercent: profileData.progressPercent || 0,\n details: profileData.details,\n });\n },\n }\n );\n\n if (!profileResult.success) {\n progressReporter.failed('Failed to inscribe profile');\n return {\n profileTopicId: '',\n success: false,\n error: profileResult.error || 'Failed to inscribe profile',\n transactionId: profileResult.transactionId || '',\n };\n }\n\n progressReporter.completed('Profile stored successfully', {\n profileTopicId: profileResult.profileTopicId,\n });\n\n return {\n profileTopicId: profileResult.profileTopicId,\n pfpTopicId,\n success: true,\n transactionId: profileResult.transactionId || '',\n };\n } catch (error: any) {\n this.logger.error(`Error storing HCS11 profile: ${error.message}`);\n return {\n profileTopicId: '',\n success: false,\n error: error.message,\n transactionId: '',\n };\n }\n }\n\n async createTopic(\n memo: string,\n adminKey?: boolean,\n submitKey?: boolean\n ): Promise<{\n success: boolean;\n topicId?: string;\n error?: string;\n }> {\n this.logger.info('Creating topic');\n const { accountId, signer } = this.getAccountAndSigner();\n\n const transaction = new TopicCreateTransaction().setTopicMemo(memo);\n\n const publicKey = await this.mirrorNode.getPublicKey(accountId);\n\n if (adminKey && publicKey) {\n transaction.setAdminKey(publicKey);\n transaction.setAutoRenewAccountId(accountId);\n }\n\n if (submitKey && publicKey) {\n transaction.setSubmitKey(publicKey);\n }\n\n const transactionResponse =\n await this.hwc.executeTransactionWithErrorHandling(\n transaction as any,\n false\n );\n\n const error = transactionResponse.error;\n\n if (error) {\n this.logger.error(error);\n return {\n success: false,\n error,\n };\n }\n\n const resultReceipt = transactionResponse.result;\n\n if (!resultReceipt?.topicId) {\n this.logger.error('Failed to create topic: topicId is null');\n return {\n success: false,\n error: 'Failed to create topic: topicId is null',\n };\n }\n\n return {\n success: true,\n topicId: resultReceipt.topicId.toString(),\n };\n }\n\n public async submitPayload(\n topicId: string,\n payload: object | string,\n submitKey?: PrivateKey,\n requiresFee?: boolean\n ): Promise<TransactionReceipt> {\n this.logger.debug(`Submitting payload to topic ${topicId}`);\n\n let message: string;\n if (typeof payload === 'string') {\n message = payload;\n } else {\n message = JSON.stringify(payload);\n }\n\n const transaction = new TopicMessageSubmitTransaction()\n .setTopicId(topicId)\n .setMessage(message);\n\n let transactionResponse: {\n result?: TransactionReceipt;\n error?: string;\n };\n\n if (requiresFee) {\n this.logger.info(\n 'Topic requires fee payment, setting max transaction fee'\n );\n transaction.setMaxTransactionFee(new Hbar(this.feeAmount));\n }\n\n if (submitKey) {\n const { accountId, signer } = this.getAccountAndSigner();\n transaction.freezeWithSigner(signer as any);\n const signedTransaction = await transaction.sign(submitKey);\n transactionResponse = await this.hwc.executeTransactionWithErrorHandling(\n signedTransaction,\n true\n );\n } else {\n transactionResponse = await this.hwc.executeTransactionWithErrorHandling(\n transaction,\n false\n );\n }\n\n if (transactionResponse?.error) {\n this.logger.error(\n `Failed to submit payload: ${transactionResponse.error}`\n );\n throw new Error(`Failed to submit payload: ${transactionResponse.error}`);\n }\n\n if (!transactionResponse?.result) {\n this.logger.error(\n 'Failed to submit message: receipt is null or undefined'\n );\n throw new Error('Failed to submit message: receipt is null or undefined');\n }\n\n this.logger.debug('Payload submitted successfully via HWC');\n return transactionResponse.result;\n }\n\n async inscribeFile(\n buffer: Buffer,\n fileName: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n waitMaxAttempts?: number;\n waitIntervalMs?: number;\n }\n ): Promise<RetrievedInscriptionResult> {\n const { accountId, signer } = this.getAccountAndSigner();\n\n const mimeType = mime.lookup(fileName) || 'application/octet-stream';\n\n const sdk = await InscriptionSDK.createWithAuth({\n type: 'client',\n accountId: accountId,\n signer: signer as any,\n network: this.network as 'testnet' | 'mainnet',\n });\n\n const inscriptionOptions = {\n mode: 'file' as const,\n waitForConfirmation: true,\n waitMaxAttempts: options?.waitMaxAttempts || 30,\n waitIntervalMs: options?.waitIntervalMs || 4000,\n progressCallback: options?.progressCallback,\n logging: {\n level: this.logger.getLevel ? this.logger.getLevel() : 'info',\n },\n };\n\n const response = await inscribeWithSigner(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n signer as any,\n {\n ...inscriptionOptions,\n network: this.network as 'testnet' | 'mainnet',\n },\n sdk\n );\n\n if (!response.confirmed || !response.inscription) {\n throw new Error('Inscription was not confirmed');\n }\n\n return response.inscription;\n }\n\n getAccountAndSigner(): GetAccountAndSignerResponse {\n const accountInfo = this.hwc.getAccountInfo();\n const accountId = accountInfo.accountId.toString();\n const signer = this.hwc.dAppConnector.signers.find((s) => {\n return s.getAccountId().toString() === accountId;\n });\n\n if (!signer) {\n this.logger.error('Failed to find signer');\n throw new Error('Failed to find signer');\n }\n\n return { accountId, signer: signer as any };\n }\n\n /**\n * Inscribes a profile picture (PFP) on HCS-11.\n *\n * @param buffer - The buffer containing the PFP image.\n * @param fileName - The name of the file containing the PFP image.\n * @param options - Optional configuration options.\n * @returns A promise that resolves to the topic ID of the inscribed PFP.\n */\n async inscribePfp(\n buffer: Buffer,\n fileName: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n }\n ): Promise<InscribePfpResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'PFP-Inscription',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n if (!this.hcs11Client) {\n progressReporter.failed(\n 'HCS11Client is not available in this environment'\n );\n return {\n pfpTopicId: '',\n success: false,\n error: 'HCS11Client is not available in this environment',\n transactionId: '',\n };\n }\n\n progressReporter.preparing('Preparing to inscribe profile picture', 10);\n this.logger.info('Inscribing profile picture using HCS-11 client');\n\n const wrappedProgressCallback = (data: any) => {\n progressReporter.report({\n stage: data.stage || 'confirming',\n message: data.message || 'Processing PFP inscription',\n progressPercent: data.progressPercent || 50,\n details: data.details,\n });\n };\n\n const imageResult = await this.hcs11Client.inscribeImage(\n buffer,\n fileName,\n { progressCallback: wrappedProgressCallback }\n );\n\n if (!imageResult.success) {\n let errorMessage = 'Failed to inscribe profile picture';\n if (imageResult.error) {\n errorMessage = imageResult.error;\n }\n\n let txId = '';\n if (imageResult.transactionId) {\n txId = imageResult.transactionId;\n }\n\n return {\n pfpTopicId: '',\n success: false,\n error: errorMessage,\n transactionId: txId,\n };\n }\n\n progressReporter.completed('Successfully inscribed profile picture', {\n pfpTopicId: imageResult.imageTopicId,\n });\n\n this.logger.info(\n `Successfully inscribed profile picture with topic ID: ${imageResult.imageTopicId}`\n );\n return {\n pfpTopicId: imageResult.imageTopicId,\n success: true,\n transactionId: imageResult.transactionId || '',\n };\n } catch (error: any) {\n this.logger.error(`Error inscribing profile picture: ${error.message}`);\n return {\n pfpTopicId: '',\n success: false,\n error: error.message,\n transactionId: '',\n };\n }\n }\n\n private async createCommunicationTopics(\n options?: {\n existingState?: AgentCreationState;\n ttl?: number;\n },\n progressReporter?: ProgressReporter\n ): Promise<{\n inboundTopicId: string;\n outboundTopicId: string;\n state: AgentCreationState;\n }> {\n let state =\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState);\n\n if (progressReporter) {\n progressReporter.preparing('Starting communication topic creation', 0, {\n state,\n });\n }\n\n const { accountId } = this.getAccountAndSigner();\n if (!state.outboundTopicId) {\n state.currentStage = 'topics';\n if (progressReporter) {\n progressReporter.preparing('Creating outbound topic', 5, {\n state,\n });\n }\n const outboundMemo = this._generateHcs10Memo(Hcs10MemoType.OUTBOUND, {\n ttl: options?.ttl,\n accountId,\n });\n const outboundResult = await this.createTopic(outboundMemo, true, true);\n if (!outboundResult.success || !outboundResult.topicId) {\n throw new Error(\n outboundResult.error || 'Failed to create outbound topic'\n );\n }\n state.outboundTopicId = outboundResult.topicId;\n if (state.createdResources)\n state.createdResources.push(`outbound:${state.outboundTopicId}`);\n }\n\n if (!state.inboundTopicId) {\n state.currentStage = 'topics';\n if (progressReporter) {\n progressReporter.preparing('Creating inbound topic', 10, {\n state,\n });\n }\n const inboundMemo = this._generateHcs10Memo(Hcs10MemoType.INBOUND, {\n ttl: options?.ttl,\n accountId,\n });\n // TODO: mimic SDK's createInboundTopic\n const inboundResult = await this.createTopic(inboundMemo, true, false);\n if (!inboundResult.success || !inboundResult.topicId) {\n throw new Error(\n inboundResult.error || 'Failed to create inbound topic'\n );\n }\n state.inboundTopicId = inboundResult.topicId;\n if (state.createdResources)\n state.createdResources.push(`inbound:${state.inboundTopicId}`);\n }\n\n return {\n inboundTopicId: state.inboundTopicId,\n outboundTopicId: state.outboundTopicId,\n state,\n };\n }\n}\n"],"names":["mime.lookup"],"mappings":"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"}
1
+ {"version":3,"file":"standards-sdk.es8.js","sources":["../../src/hcs-10/browser.ts"],"sourcesContent":["import {\n KeyList,\n PublicKey,\n TopicCreateTransaction,\n TopicMessageSubmitTransaction,\n TransactionReceipt,\n PrivateKey,\n Hbar,\n AccountId,\n} from '@hashgraph/sdk';\nimport { HashinalsWalletConnectSDK } from '@hashgraphonline/hashinal-wc';\nimport { Logger, LogLevel } from '../utils/logger';\nimport {\n InscriptionSDK,\n RetrievedInscriptionResult,\n} from '@kiloscribe/inscription-sdk';\nimport { HCS10BaseClient } from './base-client';\nimport * as mime from 'mime-types';\nimport {\n AgentConfig,\n InscribePfpResponse,\n StoreHCS11ProfileResponse,\n AgentRegistrationResult,\n HandleConnectionRequestResponse,\n RegistrationProgressCallback,\n AgentCreationState,\n GetAccountAndSignerResponse,\n} from './types';\nimport {\n HCS11Client,\n AgentMetadata as AIAgentMetadata,\n InscribeProfileResponse,\n HCS11Profile,\n AIAgentProfile,\n PersonalProfile,\n SocialLink,\n SocialPlatform,\n} from '../hcs-11';\nimport { ProgressReporter, ProgressData } from '../utils/progress-reporter';\nimport { Transaction } from '@hashgraph/sdk';\nimport { AgentBuilder } from '../hcs-11/agent-builder';\nimport { PersonBuilder } from '../hcs-11/person-builder';\nimport { Hcs10MemoType } from './base-client';\nimport { inscribe, inscribeWithSigner } from '../inscribe/inscriber';\n\nconst isBrowser = typeof window !== 'undefined';\n\nexport type BrowserHCSClientConfig = {\n network: 'mainnet' | 'testnet';\n hwc: HashinalsWalletConnectSDK;\n logLevel?: LogLevel;\n prettyPrint?: boolean;\n guardedRegistryTopicId?: string;\n guardedRegistryBaseUrl?: string;\n feeAmount?: number;\n};\n\ninterface SocialLinks {\n x?: string;\n discord?: string;\n github?: string;\n website?: string;\n}\n\nexport type BrowserAgentConfig = Omit<\n AgentConfig<BrowserHCSClient>,\n 'privateKey'\n> & {\n client: BrowserHCSClient;\n};\n\nexport type RegisteredAgent = {\n outboundTopicId: string;\n inboundTopicId: string;\n pfpTopicId: string;\n profileTopicId: string;\n error?: string;\n success: boolean;\n state: AgentCreationState;\n};\n\nexport class BrowserHCSClient extends HCS10BaseClient {\n private hwc: HashinalsWalletConnectSDK;\n protected declare logger: Logger;\n private guardedRegistryBaseUrl: string;\n private hcs11Client: HCS11Client | null = null;\n\n constructor(config: BrowserHCSClientConfig) {\n super({\n network: config.network,\n logLevel: config.logLevel,\n prettyPrint: config.prettyPrint,\n feeAmount: config.feeAmount,\n });\n\n this.hwc = config.hwc;\n if (!config.guardedRegistryBaseUrl) {\n this.guardedRegistryBaseUrl = 'https://moonscape.tech';\n } else {\n this.guardedRegistryBaseUrl = config.guardedRegistryBaseUrl;\n }\n\n let logLevel: LogLevel;\n if (config.logLevel) {\n logLevel = config.logLevel;\n } else {\n logLevel = 'info';\n }\n\n this.logger = Logger.getInstance({\n level: logLevel,\n module: 'HCS-Browser',\n prettyPrint: config.prettyPrint,\n });\n\n if (isBrowser) {\n try {\n const { accountId, signer } = this.getAccountAndSigner();\n\n this.hcs11Client = new HCS11Client({\n network: config.network,\n auth: {\n operatorId: accountId,\n signer: signer as any,\n },\n logLevel: config.logLevel,\n });\n } catch (err) {\n this.logger.warn(`Failed to initialize HCS11Client: ${err}`);\n }\n } else {\n this.logger.error(\n 'BrowserHCSClient initialized in server environment - browser-specific features will not be available. Use HCS10Client instead.'\n );\n }\n }\n\n async sendMessage(\n connectionTopicId: string,\n data: string,\n memo?: string,\n submitKey?: PrivateKey,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n waitMaxAttempts?: number;\n waitIntervalMs?: number;\n }\n ): Promise<TransactionReceipt> {\n this.logger.info('Sending message');\n const operatorId = await this.getOperatorId();\n\n const payload = {\n p: 'hcs-10',\n op: 'message',\n operator_id: operatorId,\n data,\n m: memo,\n };\n\n const submissionCheck = await this.canSubmitToTopic(\n connectionTopicId,\n this.hwc.getAccountInfo().accountId\n );\n\n const payloadString = JSON.stringify(payload);\n const isLargePayload = Buffer.from(payloadString).length > 1000;\n\n if (isLargePayload) {\n this.logger.info(\n 'Message payload exceeds 1000 bytes, storing via inscription'\n );\n try {\n const contentBuffer = Buffer.from(data);\n const fileName = `message-${Date.now()}.json`;\n const inscriptionResult = await this.inscribeFile(\n contentBuffer,\n fileName,\n {\n progressCallback: options?.progressCallback,\n waitMaxAttempts: options?.waitMaxAttempts,\n waitIntervalMs: options?.waitIntervalMs,\n }\n );\n\n if (inscriptionResult?.topic_id) {\n payload.data = `hcs://1/${inscriptionResult.topic_id}`;\n this.logger.info(\n `Large message inscribed with topic ID: ${inscriptionResult.topic_id}`\n );\n } else {\n throw new Error('Failed to inscribe large message content');\n }\n } catch (error) {\n this.logger.error('Error inscribing large message:', error);\n throw new Error(\n `Failed to handle large message: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`\n );\n }\n }\n\n return await this.submitPayload(\n connectionTopicId,\n payload,\n submitKey,\n submissionCheck.requiresFee\n );\n }\n\n async getPublicKey(accountId: string): Promise<PublicKey> {\n return await this.mirrorNode.getPublicKey(accountId);\n }\n\n async handleConnectionRequest(\n inboundTopicId: string,\n requestingAccountId: string,\n connectionId: number,\n connectionMemo: string = 'Connection accepted. Looking forward to collaborating!',\n ttl: number = 60\n ): Promise<HandleConnectionRequestResponse> {\n this.logger.info('Handling connection request');\n const userAccountId = this.hwc.getAccountInfo().accountId;\n if (!userAccountId) {\n throw new Error('Failed to retrieve user account ID');\n }\n\n const requesterKey = await this.mirrorNode.getPublicKey(\n requestingAccountId\n );\n const accountKey = await this.mirrorNode.getPublicKey(userAccountId);\n\n if (!accountKey) {\n throw new Error('Failed to retrieve public key');\n }\n\n const thresholdKey = new KeyList([accountKey, requesterKey], 1);\n const memo = this._generateHcs10Memo(Hcs10MemoType.CONNECTION, {\n ttl,\n inboundTopicId,\n connectionId,\n });\n\n const transaction = new TopicCreateTransaction()\n .setTopicMemo(memo)\n .setAutoRenewAccountId(AccountId.fromString(userAccountId))\n .setAdminKey(thresholdKey)\n .setSubmitKey(thresholdKey);\n\n this.logger.debug('Executing topic creation transaction');\n const txResponse = await this.hwc.executeTransactionWithErrorHandling(\n transaction,\n false\n );\n if (txResponse?.error) {\n this.logger.error(txResponse.error);\n throw new Error(txResponse.error);\n }\n\n const resultReceipt = txResponse?.result;\n if (!resultReceipt?.topicId) {\n this.logger.error('Failed to create topic: topicId is null');\n throw new Error('Failed to create topic: topicId is null');\n }\n\n const connectionTopicId = resultReceipt.topicId.toString();\n const operatorId = `${inboundTopicId}@${userAccountId}`;\n const confirmedConnectionSequenceNumber = await this.confirmConnection(\n inboundTopicId,\n connectionTopicId,\n requestingAccountId,\n connectionId,\n operatorId,\n connectionMemo\n );\n\n const accountTopics = await this.retrieveCommunicationTopics(userAccountId);\n\n const requestingAccountTopics = await this.retrieveCommunicationTopics(\n requestingAccountId\n );\n\n const requestingAccountOperatorId = `${requestingAccountTopics.inboundTopic}@${requestingAccountId}`;\n\n await this.recordOutboundConnectionConfirmation({\n outboundTopicId: accountTopics.outboundTopic,\n requestorOutboundTopicId: requestingAccountTopics.outboundTopic,\n connectionRequestId: connectionId,\n confirmedRequestId: confirmedConnectionSequenceNumber,\n connectionTopicId,\n operatorId: requestingAccountOperatorId,\n memo: `Connection established with ${requestingAccountId}`,\n });\n\n return {\n connectionTopicId,\n confirmedConnectionSequenceNumber,\n operatorId,\n };\n }\n\n async confirmConnection(\n inboundTopicId: string,\n connectionTopicId: string,\n connectedAccountId: string,\n connectionId: number,\n operatorId: string,\n memo: string\n ): Promise<number> {\n this.logger.info('Confirming connection');\n const payload = {\n p: 'hcs-10',\n op: 'connection_created',\n connection_topic_id: connectionTopicId,\n connected_account_id: connectedAccountId,\n operator_id: operatorId,\n connection_id: connectionId,\n m: memo,\n };\n\n const transactionResponse = await this.submitPayload(\n inboundTopicId,\n payload\n );\n if (!transactionResponse?.topicSequenceNumber) {\n this.logger.error(\n 'Failed to confirm connection: sequence number is null'\n );\n throw new Error('Failed to confirm connection: sequence number is null');\n }\n return transactionResponse.topicSequenceNumber.toNumber();\n }\n\n async create(\n builder: AgentBuilder | PersonBuilder,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n existingState?: AgentCreationState;\n ttl?: number;\n updateAccountMemo?: boolean;\n }\n ): Promise<RegisteredAgent | InscribeProfileResponse> {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'ProfileCreate',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n try {\n const isAgentBuilder = builder instanceof AgentBuilder;\n\n let state;\n if (options?.existingState) {\n state = options.existingState;\n } else {\n state = {\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState;\n }\n\n if (isAgentBuilder) {\n this.logger.info('Creating Agent Profile and HCS-10 Topics');\n const agentConfig = (builder as AgentBuilder).build();\n state.agentMetadata = agentConfig.metadata;\n } else {\n this.logger.info('Creating Person HCS-11 Profile');\n }\n\n progressReporter.preparing(\n `Starting ${isAgentBuilder ? 'agent' : 'person'} resource creation`,\n 0,\n {\n state,\n }\n );\n\n const {\n inboundTopicId,\n outboundTopicId,\n state: updatedState,\n } = await this.createCommunicationTopics(options, progressReporter);\n\n state = updatedState;\n\n if (!isAgentBuilder) {\n (builder as PersonBuilder).setInboundTopicId(inboundTopicId);\n (builder as PersonBuilder).setOutboundTopicId(outboundTopicId);\n }\n\n let pfpTopicId: string | undefined;\n let hasPfpBuffer: Buffer | undefined;\n let pfpFileName: string | undefined;\n\n if (isAgentBuilder) {\n const agentProfile = (builder as AgentBuilder).build();\n pfpTopicId = agentProfile.existingPfpTopicId || state.pfpTopicId;\n hasPfpBuffer = agentProfile.pfpBuffer;\n pfpFileName = agentProfile.pfpFileName || 'pfp.png';\n } else {\n const personProfile = (builder as PersonBuilder).build();\n pfpTopicId = state.pfpTopicId;\n hasPfpBuffer = personProfile.pfpBuffer;\n pfpFileName = personProfile.pfpFileName;\n }\n\n if (!pfpTopicId && hasPfpBuffer && pfpFileName) {\n pfpTopicId = await this.handleProfilePictureCreation(\n hasPfpBuffer,\n pfpFileName,\n state,\n progressReporter\n );\n } else if (pfpTopicId) {\n progressReporter.preparing(\n `Using existing profile picture: ${pfpTopicId}`,\n 50,\n { state }\n );\n state.pfpTopicId = pfpTopicId;\n }\n\n await this.createAndInscribeProfile(\n isAgentBuilder,\n builder as any,\n pfpTopicId,\n state,\n inboundTopicId,\n outboundTopicId,\n options,\n progressReporter\n );\n\n state.currentStage = 'complete';\n state.completedPercentage = 100;\n progressReporter.completed(\n `${isAgentBuilder ? 'Agent' : 'Person'} profile created successfully`,\n {\n profileTopicId: state.profileTopicId,\n inboundTopicId,\n outboundTopicId,\n pfpTopicId,\n state,\n }\n );\n\n let outTopicId = '';\n if (state.outboundTopicId) {\n outTopicId = state.outboundTopicId;\n }\n\n let inTopicId = '';\n if (state.inboundTopicId) {\n inTopicId = state.inboundTopicId;\n }\n\n let profilePicTopicId = '';\n if (state.pfpTopicId) {\n profilePicTopicId = state.pfpTopicId;\n }\n\n let profTopicId = '';\n if (state.profileTopicId) {\n profTopicId = state.profileTopicId;\n }\n\n return {\n outboundTopicId: outTopicId,\n inboundTopicId: inTopicId,\n pfpTopicId: profilePicTopicId,\n profileTopicId: profTopicId,\n success: true,\n state,\n } as RegisteredAgent | InscribeProfileResponse;\n } catch (error: any) {\n progressReporter.failed('Error during profile creation', {\n error: error.message,\n });\n return {\n outboundTopicId: '',\n inboundTopicId: '',\n pfpTopicId: '',\n profileTopicId: '',\n success: false,\n error: error.message,\n state: {\n currentStage: 'init',\n completedPercentage: 0,\n error: error.message,\n } as AgentCreationState,\n } as RegisteredAgent;\n }\n }\n\n private async handleProfilePictureCreation(\n pfpBuffer: Buffer,\n pfpFileName: string,\n state: AgentCreationState,\n progressReporter: ProgressReporter\n ): Promise<string> {\n state.currentStage = 'pfp';\n progressReporter.preparing('Creating profile picture', 30, {\n state,\n });\n\n const pfpProgress = progressReporter.createSubProgress({\n minPercent: 30,\n maxPercent: 50,\n logPrefix: 'PFP',\n });\n\n const pfpResult = await this.inscribePfp(pfpBuffer, pfpFileName, {\n progressCallback: (data) =>\n pfpProgress.report({\n ...data,\n progressPercent: data.progressPercent ?? 0,\n details: { ...data.details, state },\n }),\n });\n\n if (!pfpResult.success) {\n let errorMessage = 'Failed to inscribe profile picture';\n if (pfpResult.error) {\n errorMessage = pfpResult.error;\n }\n throw new Error(errorMessage);\n }\n\n const pfpTopicId = pfpResult.pfpTopicId;\n state.pfpTopicId = pfpTopicId;\n\n if (state.createdResources) {\n state.createdResources.push(`pfp:${state.pfpTopicId}`);\n }\n\n progressReporter.preparing('Profile picture created', 50, { state });\n\n return pfpTopicId;\n }\n\n private async createAndInscribeProfile(\n isAgentBuilder: boolean,\n builder: AgentBuilder | PersonBuilder,\n pfpTopicId: string | undefined,\n state: AgentCreationState,\n inboundTopicId: string,\n outboundTopicId: string,\n options?: {\n updateAccountMemo?: boolean;\n },\n progressReporter?: ProgressReporter\n ): Promise<void> {\n if (!this.hcs11Client) {\n if (progressReporter) {\n progressReporter.failed('HCS11Client is not available');\n }\n throw new Error('HCS11Client is not available');\n }\n\n this.logger.info('Creating and inscribing profile');\n if (!state.profileTopicId) {\n if (progressReporter) {\n progressReporter.preparing(\n `Storing HCS-11 ${isAgentBuilder ? 'agent' : 'person'} profile`,\n 80\n );\n }\n\n const profileProgress = progressReporter?.createSubProgress({\n minPercent: 80,\n maxPercent: 95,\n logPrefix: 'StoreProfile',\n });\n\n let hcs11Profile;\n\n if (isAgentBuilder) {\n const agentProfile = (builder as AgentBuilder).build();\n\n const socialLinks = agentProfile.metadata?.socials\n ? Object.entries(agentProfile.metadata.socials).map(\n ([platform, handle]) => ({\n platform: platform as SocialPlatform,\n handle: handle as string,\n })\n )\n : [];\n\n hcs11Profile = this.hcs11Client.createAIAgentProfile(\n agentProfile.name,\n agentProfile.metadata?.type === 'manual' ? 0 : 1,\n agentProfile.capabilities || [],\n agentProfile.metadata?.model || 'unknown',\n {\n alias: agentProfile.name.toLowerCase().replace(/\\s+/g, '_'),\n bio: agentProfile.bio,\n profileImage: pfpTopicId ? `hcs://1/${pfpTopicId}` : undefined,\n socials: socialLinks,\n properties: agentProfile.metadata?.properties || {},\n inboundTopicId,\n outboundTopicId,\n creator: agentProfile.metadata?.creator,\n }\n );\n } else {\n const personProfile = (builder as PersonBuilder).build();\n\n const { pfpBuffer, pfpFileName, ...cleanProfile } = personProfile;\n\n hcs11Profile = this.hcs11Client.createPersonalProfile(\n personProfile.display_name,\n {\n alias: personProfile.alias,\n bio: personProfile.bio,\n socials: personProfile.socials,\n profileImage: pfpTopicId\n ? `hcs://1/${pfpTopicId}`\n : personProfile.profileImage,\n properties: personProfile.properties,\n inboundTopicId,\n outboundTopicId,\n }\n );\n }\n\n const profileResult = await this.hcs11Client.createAndInscribeProfile(\n hcs11Profile,\n options?.updateAccountMemo ?? true,\n {\n progressCallback: (data) =>\n profileProgress?.report({\n ...data,\n progressPercent: data.progressPercent ?? 0,\n }),\n }\n );\n\n if (!profileResult.success) {\n if (progressReporter) {\n progressReporter.failed(\n `Failed to inscribe ${isAgentBuilder ? 'agent' : 'person'} profile`,\n {\n error: profileResult.error,\n }\n );\n }\n\n let errorMessage = `Failed to inscribe ${\n isAgentBuilder ? 'agent' : 'person'\n } profile`;\n if (profileResult.error) {\n errorMessage = profileResult.error;\n }\n throw new Error(errorMessage);\n }\n\n state.profileTopicId = profileResult.profileTopicId;\n\n if (state.createdResources) {\n state.createdResources.push(`profile:${profileResult.profileTopicId}`);\n }\n\n if (progressReporter) {\n progressReporter.preparing('HCS-11 Profile stored', 95, { state });\n }\n } else if (progressReporter) {\n progressReporter.preparing(\n `Using existing ${isAgentBuilder ? 'agent' : 'person'} profile`,\n 95,\n {\n state,\n }\n );\n }\n }\n\n private initializeRegistrationState(\n inboundTopicId: string,\n existingState?: AgentCreationState\n ): AgentCreationState {\n const state = existingState || {\n inboundTopicId,\n currentStage: 'registration',\n completedPercentage: 0,\n createdResources: [],\n };\n\n if (\n state.currentStage !== 'registration' &&\n state.currentStage !== 'complete'\n ) {\n state.currentStage = 'registration';\n }\n\n return state;\n }\n\n private updateStateForCompletedRegistration(\n state: AgentCreationState,\n inboundTopicId: string\n ): void {\n state.currentStage = 'complete';\n state.completedPercentage = 100;\n if (state.createdResources) {\n state.createdResources.push(`registration:${inboundTopicId}`);\n }\n }\n\n async registerAgentWithGuardedRegistry(\n accountId: string,\n network: string = this.network,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n maxAttempts?: number;\n delayMs?: number;\n existingState?: AgentCreationState;\n }\n ): Promise<AgentRegistrationResult> {\n try {\n this.logger.info('Registering agent with guarded registry');\n\n const agentProfile = await this.retrieveProfile(accountId);\n const inboundTopicId = agentProfile.topicInfo.inboundTopic;\n const state = this.initializeRegistrationState(\n inboundTopicId,\n options?.existingState\n );\n const progressReporter = new ProgressReporter({\n module: 'AgentRegistration',\n logger: this.logger,\n callback: options?.progressCallback,\n });\n\n progressReporter.preparing('Preparing agent registration', 10, {\n inboundTopicId,\n accountId,\n });\n\n const registrationResult = await this.executeRegistration(\n accountId,\n network as string,\n this.guardedRegistryBaseUrl,\n this.logger\n );\n\n if (!registrationResult.success) {\n return {\n ...registrationResult,\n state,\n };\n }\n\n progressReporter.submitting('Submitting registration to registry', 30, {\n transactionId: registrationResult.transactionId,\n });\n\n if (registrationResult.transaction) {\n const transaction = Transaction.fromBytes(\n Buffer.from(registrationResult.transaction, 'base64')\n );\n\n this.logger.info(`Processing registration transaction`);\n const txResult = await this.hwc.executeTransactionWithErrorHandling(\n transaction as any,\n true\n );\n\n if (txResult.error) {\n return {\n ...registrationResult,\n error: txResult.error,\n success: false,\n state,\n };\n }\n\n this.logger.info(`Successfully processed registration transaction`);\n }\n\n progressReporter.confirming('Confirming registration transaction', 60, {\n accountId,\n inboundTopicId,\n transactionId: registrationResult.transactionId,\n });\n\n const maxAttempts = options?.maxAttempts ?? 60;\n const delayMs = options?.delayMs ?? 2000;\n\n const confirmed = await this.waitForRegistrationConfirmation(\n registrationResult.transactionId!,\n network,\n this.guardedRegistryBaseUrl,\n maxAttempts,\n delayMs,\n this.logger\n );\n\n this.updateStateForCompletedRegistration(state, inboundTopicId);\n\n progressReporter.completed('Agent registration complete', {\n transactionId: registrationResult.transactionId,\n inboundTopicId,\n state,\n confirmed,\n });\n\n return {\n ...registrationResult,\n confirmed,\n state,\n };\n } catch (error: any) {\n this.logger.error(`Registration error: ${error.message}`);\n return {\n error: `Error during registration: ${error.message}`,\n success: false,\n state: {\n currentStage: 'registration',\n completedPercentage: 0,\n error: error.message,\n },\n };\n }\n }\n\n async createAndRegisterAgent(\n builder: AgentBuilder,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n maxAttempts?: number;\n delayMs?: number;\n existingState?: AgentCreationState;\n baseUrl?: string;\n }\n ): Promise<AgentRegistrationResult> {\n try {\n const agentConfig = builder.build();\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'AgentCreateRegister',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n let state =\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState);\n\n state.agentMetadata = agentConfig.metadata;\n\n progressReporter.preparing('Starting agent creation process', 0, {\n state,\n });\n\n if (\n state.currentStage !== 'complete' ||\n !state.inboundTopicId ||\n !state.outboundTopicId ||\n !state.profileTopicId\n ) {\n const createResult = await this.create(builder, {\n progressCallback: (progress: any) => {\n const adjustedPercent = (progress.progressPercent || 0) * 0.3;\n progressReporter.report({\n ...progress,\n progressPercent: adjustedPercent,\n details: {\n ...progress.details,\n state: progress.details?.state || state,\n },\n });\n },\n existingState: state,\n updateAccountMemo: false,\n });\n\n if (!('state' in createResult)) {\n throw new Error('Create method did not return expected agent state.');\n }\n\n if (!createResult.success) {\n throw new Error(\n createResult.error || 'Failed to create agent resources'\n );\n }\n\n state = createResult.state;\n state.agentMetadata = agentConfig.metadata;\n }\n\n progressReporter.preparing(\n `Agent creation status: ${state.currentStage}, ${state.completedPercentage}%`,\n 30,\n { state }\n );\n\n const { accountId } = this.getAccountAndSigner();\n\n if (\n state.currentStage !== 'complete' ||\n !state.createdResources?.includes(\n `registration:${state.inboundTopicId}`\n )\n ) {\n if (options?.baseUrl) {\n this.guardedRegistryBaseUrl = options.baseUrl;\n }\n\n const registrationResult = await this.registerAgentWithGuardedRegistry(\n accountId,\n agentConfig.network,\n {\n progressCallback: (progress) => {\n const adjustedPercent =\n 30 + (progress.progressPercent || 0) * 0.7;\n progressReporter.report({\n ...progress,\n progressPercent: adjustedPercent,\n details: {\n ...progress.details,\n state: progress.details?.state || state,\n },\n });\n },\n maxAttempts: options?.maxAttempts,\n delayMs: options?.delayMs,\n existingState: state,\n }\n );\n\n if (!registrationResult.success) {\n throw new Error(\n registrationResult.error || 'Failed to register agent with registry'\n );\n }\n\n state = registrationResult.state;\n\n if (state.profileTopicId) {\n await this.hcs11Client?.updateAccountMemoWithProfile(\n accountId,\n state.profileTopicId\n );\n }\n }\n\n progressReporter.completed('Agent creation and registration complete', {\n state,\n });\n\n return {\n success: true,\n state,\n metadata: {\n accountId,\n operatorId: `${state.inboundTopicId}@${accountId}`,\n inboundTopicId: state.inboundTopicId!,\n outboundTopicId: state.outboundTopicId!,\n profileTopicId: state.profileTopicId!,\n pfpTopicId: state.pfpTopicId!,\n privateKey: null,\n ...state.agentMetadata,\n },\n };\n } catch (error: any) {\n this.logger.error(\n `Failed to create and register agent: ${error.message}`\n );\n return {\n success: false,\n error: `Failed to create and register agent: ${error.message}`,\n state:\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n error: error.message,\n } as AgentCreationState),\n };\n }\n }\n\n async storeHCS11Profile(\n agentName: string,\n agentBio: string,\n inboundTopicId: string,\n outboundTopicId: string,\n capabilities: number[] = [],\n metadata: Record<string, any> = {},\n pfpBuffer?: Buffer,\n pfpFileName?: string,\n existingPfpTopicId?: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n }\n ): Promise<StoreHCS11ProfileResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'StoreHCS11Profile',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n progressReporter.preparing('Preparing agent profile data', 0);\n\n let pfpTopicId = existingPfpTopicId;\n\n if (!pfpTopicId && pfpBuffer && pfpFileName) {\n const pfpProgress = progressReporter.createSubProgress({\n minPercent: 0,\n maxPercent: 60,\n logPrefix: 'PFP',\n });\n\n const pfpResult = await this.inscribePfp(pfpBuffer, pfpFileName, {\n progressCallback: (data) => {\n pfpProgress.report({\n stage: data.stage,\n message: data.message,\n progressPercent: data.progressPercent || 0,\n details: data.details,\n });\n },\n });\n\n if (!pfpResult.success) {\n progressReporter.failed(\n 'Failed to inscribe profile picture, continuing without PFP'\n );\n } else {\n pfpTopicId = pfpResult.pfpTopicId;\n }\n } else if (existingPfpTopicId) {\n progressReporter.preparing(\n `Using existing profile picture: ${existingPfpTopicId}`,\n 30\n );\n } else {\n progressReporter.preparing('No profile picture provided', 30);\n }\n\n if (!this.hcs11Client) {\n progressReporter.failed(\n 'HCS11Client is not available in this environment'\n );\n return {\n profileTopicId: '',\n success: false,\n error: 'HCS11Client is not available in this environment',\n transactionId: '',\n };\n }\n\n const agentType = this.hcs11Client.getAgentTypeFromMetadata({\n type: metadata.type || 'autonomous',\n } as AIAgentMetadata);\n\n progressReporter.preparing('Building agent profile', 65);\n\n const formattedSocials: SocialLink[] | undefined = metadata.socials\n ? Object.entries(metadata.socials)\n .filter(([_, handle]) => handle)\n .map(([platform, handle]) => ({\n platform: platform as SocialPlatform,\n handle: handle as string,\n }))\n : undefined;\n\n const profile = this.hcs11Client.createAIAgentProfile(\n agentName,\n agentType,\n capabilities,\n metadata.model || 'unknown',\n {\n alias: agentName.toLowerCase().replace(/\\s+/g, '_'),\n bio: agentBio,\n profileImage: pfpTopicId ? `hcs://1/${pfpTopicId}` : undefined,\n socials: formattedSocials,\n properties: {\n version: metadata.version || '1.0.0',\n creator: metadata.creator || 'Unknown',\n supported_languages: metadata.supported_languages || ['en'],\n permissions: metadata.permissions || [],\n model_details: metadata.model_details,\n training: metadata.training,\n capabilities_description: metadata.capabilities_description,\n ...metadata,\n },\n inboundTopicId,\n outboundTopicId,\n creator: metadata.creator,\n }\n );\n\n const profileProgress = progressReporter.createSubProgress({\n minPercent: 65,\n maxPercent: 100,\n logPrefix: 'Profile',\n });\n\n const profileResult = await this.hcs11Client.createAndInscribeProfile(\n profile,\n true,\n {\n progressCallback: (profileData) => {\n profileProgress.report({\n stage: profileData.stage,\n message: profileData.message,\n progressPercent: profileData.progressPercent || 0,\n details: profileData.details,\n });\n },\n }\n );\n\n if (!profileResult.success) {\n progressReporter.failed('Failed to inscribe profile');\n return {\n profileTopicId: '',\n success: false,\n error: profileResult.error || 'Failed to inscribe profile',\n transactionId: profileResult.transactionId || '',\n };\n }\n\n progressReporter.completed('Profile stored successfully', {\n profileTopicId: profileResult.profileTopicId,\n });\n\n return {\n profileTopicId: profileResult.profileTopicId,\n pfpTopicId,\n success: true,\n transactionId: profileResult.transactionId || '',\n };\n } catch (error: any) {\n this.logger.error(`Error storing HCS11 profile: ${error.message}`);\n return {\n profileTopicId: '',\n success: false,\n error: error.message,\n transactionId: '',\n };\n }\n }\n\n async createTopic(\n memo: string,\n adminKey?: boolean,\n submitKey?: boolean\n ): Promise<{\n success: boolean;\n topicId?: string;\n error?: string;\n }> {\n this.logger.info('Creating topic');\n const { accountId, signer } = this.getAccountAndSigner();\n\n const transaction = new TopicCreateTransaction().setTopicMemo(memo);\n\n const publicKey = await this.mirrorNode.getPublicKey(accountId);\n\n if (adminKey && publicKey) {\n transaction.setAdminKey(publicKey);\n transaction.setAutoRenewAccountId(accountId);\n }\n\n if (submitKey && publicKey) {\n transaction.setSubmitKey(publicKey);\n }\n\n const transactionResponse =\n await this.hwc.executeTransactionWithErrorHandling(\n transaction as any,\n false\n );\n\n const error = transactionResponse.error;\n\n if (error) {\n this.logger.error(error);\n return {\n success: false,\n error,\n };\n }\n\n const resultReceipt = transactionResponse.result;\n\n if (!resultReceipt?.topicId) {\n this.logger.error('Failed to create topic: topicId is null');\n return {\n success: false,\n error: 'Failed to create topic: topicId is null',\n };\n }\n\n return {\n success: true,\n topicId: resultReceipt.topicId.toString(),\n };\n }\n\n public async submitPayload(\n topicId: string,\n payload: object | string,\n submitKey?: PrivateKey,\n requiresFee?: boolean\n ): Promise<TransactionReceipt> {\n this.logger.debug(`Submitting payload to topic ${topicId}`);\n\n let message: string;\n if (typeof payload === 'string') {\n message = payload;\n } else {\n message = JSON.stringify(payload);\n }\n\n const transaction = new TopicMessageSubmitTransaction()\n .setTopicId(topicId)\n .setMessage(message);\n\n let transactionResponse: {\n result?: TransactionReceipt;\n error?: string;\n };\n\n if (requiresFee) {\n this.logger.info(\n 'Topic requires fee payment, setting max transaction fee'\n );\n transaction.setMaxTransactionFee(new Hbar(this.feeAmount));\n }\n\n if (submitKey) {\n const { accountId, signer } = this.getAccountAndSigner();\n transaction.freezeWithSigner(signer as any);\n const signedTransaction = await transaction.sign(submitKey);\n transactionResponse = await this.hwc.executeTransactionWithErrorHandling(\n signedTransaction,\n true\n );\n } else {\n transactionResponse = await this.hwc.executeTransactionWithErrorHandling(\n transaction,\n false\n );\n }\n\n if (transactionResponse?.error) {\n this.logger.error(\n `Failed to submit payload: ${transactionResponse.error}`\n );\n throw new Error(`Failed to submit payload: ${transactionResponse.error}`);\n }\n\n if (!transactionResponse?.result) {\n this.logger.error(\n 'Failed to submit message: receipt is null or undefined'\n );\n throw new Error('Failed to submit message: receipt is null or undefined');\n }\n\n this.logger.debug('Payload submitted successfully via HWC');\n return transactionResponse.result;\n }\n\n async inscribeFile(\n buffer: Buffer,\n fileName: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n waitMaxAttempts?: number;\n waitIntervalMs?: number;\n }\n ): Promise<RetrievedInscriptionResult> {\n const { accountId, signer } = this.getAccountAndSigner();\n\n const mimeType = mime.lookup(fileName) || 'application/octet-stream';\n\n const sdk = await InscriptionSDK.createWithAuth({\n type: 'client',\n accountId: accountId,\n signer: signer as any,\n network: this.network as 'testnet' | 'mainnet',\n });\n\n const inscriptionOptions = {\n mode: 'file' as const,\n waitForConfirmation: true,\n waitMaxAttempts: options?.waitMaxAttempts || 30,\n waitIntervalMs: options?.waitIntervalMs || 4000,\n progressCallback: options?.progressCallback,\n logging: {\n level: this.logger.getLevel ? this.logger.getLevel() : 'info',\n },\n };\n\n const response = await inscribeWithSigner(\n {\n type: 'buffer',\n buffer,\n fileName,\n mimeType,\n },\n signer as any,\n {\n ...inscriptionOptions,\n network: this.network as 'testnet' | 'mainnet',\n },\n sdk\n );\n\n if (!response.confirmed || !response.inscription) {\n throw new Error('Inscription was not confirmed');\n }\n\n return response.inscription;\n }\n\n getAccountAndSigner(): GetAccountAndSignerResponse {\n const accountInfo = this.hwc.getAccountInfo();\n const accountId = accountInfo.accountId.toString();\n const signer = this.hwc.dAppConnector.signers.find((s) => {\n return s.getAccountId().toString() === accountId;\n });\n\n if (!signer) {\n this.logger.error('Failed to find signer');\n throw new Error('Failed to find signer');\n }\n\n return { accountId, signer: signer as any };\n }\n\n /**\n * Inscribes a profile picture (PFP) on HCS-11.\n *\n * @param buffer - The buffer containing the PFP image.\n * @param fileName - The name of the file containing the PFP image.\n * @param options - Optional configuration options.\n * @returns A promise that resolves to the topic ID of the inscribed PFP.\n */\n async inscribePfp(\n buffer: Buffer,\n fileName: string,\n options?: {\n progressCallback?: RegistrationProgressCallback;\n }\n ): Promise<InscribePfpResponse> {\n try {\n const progressCallback = options?.progressCallback;\n const progressReporter = new ProgressReporter({\n module: 'PFP-Inscription',\n logger: this.logger,\n callback: progressCallback as any,\n });\n\n if (!this.hcs11Client) {\n progressReporter.failed(\n 'HCS11Client is not available in this environment'\n );\n return {\n pfpTopicId: '',\n success: false,\n error: 'HCS11Client is not available in this environment',\n transactionId: '',\n };\n }\n\n progressReporter.preparing('Preparing to inscribe profile picture', 10);\n this.logger.info('Inscribing profile picture using HCS-11 client');\n\n const wrappedProgressCallback = (data: any) => {\n progressReporter.report({\n stage: data.stage || 'confirming',\n message: data.message || 'Processing PFP inscription',\n progressPercent: data.progressPercent || 50,\n details: data.details,\n });\n };\n\n const imageResult = await this.hcs11Client.inscribeImage(\n buffer,\n fileName,\n { progressCallback: wrappedProgressCallback }\n );\n\n if (!imageResult.success) {\n let errorMessage = 'Failed to inscribe profile picture';\n if (imageResult.error) {\n errorMessage = imageResult.error;\n }\n\n let txId = '';\n if (imageResult.transactionId) {\n txId = imageResult.transactionId;\n }\n\n return {\n pfpTopicId: '',\n success: false,\n error: errorMessage,\n transactionId: txId,\n };\n }\n\n progressReporter.completed('Successfully inscribed profile picture', {\n pfpTopicId: imageResult.imageTopicId,\n });\n\n this.logger.info(\n `Successfully inscribed profile picture with topic ID: ${imageResult.imageTopicId}`\n );\n return {\n pfpTopicId: imageResult.imageTopicId,\n success: true,\n transactionId: imageResult.transactionId || '',\n };\n } catch (error: any) {\n this.logger.error(`Error inscribing profile picture: ${error.message}`);\n return {\n pfpTopicId: '',\n success: false,\n error: error.message,\n transactionId: '',\n };\n }\n }\n\n private async createCommunicationTopics(\n options?: {\n existingState?: AgentCreationState;\n ttl?: number;\n },\n progressReporter?: ProgressReporter\n ): Promise<{\n inboundTopicId: string;\n outboundTopicId: string;\n state: AgentCreationState;\n }> {\n let state =\n options?.existingState ||\n ({\n currentStage: 'init',\n completedPercentage: 0,\n createdResources: [],\n } as AgentCreationState);\n\n if (progressReporter) {\n progressReporter.preparing('Starting communication topic creation', 0, {\n state,\n });\n }\n\n const { accountId } = this.getAccountAndSigner();\n if (!state.outboundTopicId) {\n state.currentStage = 'topics';\n if (progressReporter) {\n progressReporter.preparing('Creating outbound topic', 5, {\n state,\n });\n }\n const outboundMemo = this._generateHcs10Memo(Hcs10MemoType.OUTBOUND, {\n ttl: options?.ttl,\n accountId,\n });\n const outboundResult = await this.createTopic(outboundMemo, true, true);\n if (!outboundResult.success || !outboundResult.topicId) {\n throw new Error(\n outboundResult.error || 'Failed to create outbound topic'\n );\n }\n state.outboundTopicId = outboundResult.topicId;\n if (state.createdResources)\n state.createdResources.push(`outbound:${state.outboundTopicId}`);\n }\n\n if (!state.inboundTopicId) {\n state.currentStage = 'topics';\n if (progressReporter) {\n progressReporter.preparing('Creating inbound topic', 10, {\n state,\n });\n }\n const inboundMemo = this._generateHcs10Memo(Hcs10MemoType.INBOUND, {\n ttl: options?.ttl,\n accountId,\n });\n // TODO: mimic SDK's createInboundTopic\n const inboundResult = await this.createTopic(inboundMemo, true, false);\n if (!inboundResult.success || !inboundResult.topicId) {\n throw new Error(\n inboundResult.error || 'Failed to create inbound topic'\n );\n }\n state.inboundTopicId = inboundResult.topicId;\n if (state.createdResources)\n state.createdResources.push(`inbound:${state.inboundTopicId}`);\n }\n\n return {\n inboundTopicId: state.inboundTopicId,\n outboundTopicId: state.outboundTopicId,\n state,\n };\n }\n}\n"],"names":["mime.lookup"],"mappings":";;;;;;;;;;AA6CA,MAAM,YAAY,OAAO,WAAW;AAoC7B,MAAM,yBAAyB,gBAAgB;AAAA,EAMpD,YAAY,QAAgC;AACpC,UAAA;AAAA,MACJ,SAAS,OAAO;AAAA,MAChB,UAAU,OAAO;AAAA,MACjB,aAAa,OAAO;AAAA,MACpB,WAAW,OAAO;AAAA,IAAA,CACnB;AARH,SAAQ,cAAkC;AAUxC,SAAK,MAAM,OAAO;AACd,QAAA,CAAC,OAAO,wBAAwB;AAClC,WAAK,yBAAyB;AAAA,IAAA,OACzB;AACL,WAAK,yBAAyB,OAAO;AAAA,IAAA;AAGnC,QAAA;AACJ,QAAI,OAAO,UAAU;AACnB,iBAAW,OAAO;AAAA,IAAA,OACb;AACM,iBAAA;AAAA,IAAA;AAGR,SAAA,SAAS,OAAO,YAAY;AAAA,MAC/B,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,aAAa,OAAO;AAAA,IAAA,CACrB;AAED,QAAI,WAAW;AACT,UAAA;AACF,cAAM,EAAE,WAAW,WAAW,KAAK,oBAAoB;AAElD,aAAA,cAAc,IAAI,YAAY;AAAA,UACjC,SAAS,OAAO;AAAA,UAChB,MAAM;AAAA,YACJ,YAAY;AAAA,YACZ;AAAA,UACF;AAAA,UACA,UAAU,OAAO;AAAA,QAAA,CAClB;AAAA,eACM,KAAK;AACZ,aAAK,OAAO,KAAK,qCAAqC,GAAG,EAAE;AAAA,MAAA;AAAA,IAC7D,OACK;AACL,WAAK,OAAO;AAAA,QACV;AAAA,MACF;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAM,YACJ,mBACA,MACA,MACA,WACA,SAK6B;AACxB,SAAA,OAAO,KAAK,iBAAiB;AAC5B,UAAA,aAAa,MAAM,KAAK,cAAc;AAE5C,UAAM,UAAU;AAAA,MACd,GAAG;AAAA,MACH,IAAI;AAAA,MACJ,aAAa;AAAA,MACb;AAAA,MACA,GAAG;AAAA,IACL;AAEM,UAAA,kBAAkB,MAAM,KAAK;AAAA,MACjC;AAAA,MACA,KAAK,IAAI,iBAAiB;AAAA,IAC5B;AAEM,UAAA,gBAAgB,KAAK,UAAU,OAAO;AAC5C,UAAM,iBAAiB,OAAO,KAAK,aAAa,EAAE,SAAS;AAE3D,QAAI,gBAAgB;AAClB,WAAK,OAAO;AAAA,QACV;AAAA,MACF;AACI,UAAA;AACI,cAAA,gBAAgB,OAAO,KAAK,IAAI;AACtC,cAAM,WAAW,WAAW,KAAK,IAAA,CAAK;AAChC,cAAA,oBAAoB,MAAM,KAAK;AAAA,UACnC;AAAA,UACA;AAAA,UACA;AAAA,YACE,kBAAkB,SAAS;AAAA,YAC3B,iBAAiB,SAAS;AAAA,YAC1B,gBAAgB,SAAS;AAAA,UAAA;AAAA,QAE7B;AAEA,YAAI,mBAAmB,UAAU;AACvB,kBAAA,OAAO,WAAW,kBAAkB,QAAQ;AACpD,eAAK,OAAO;AAAA,YACV,0CAA0C,kBAAkB,QAAQ;AAAA,UACtE;AAAA,QAAA,OACK;AACC,gBAAA,IAAI,MAAM,0CAA0C;AAAA,QAAA;AAAA,eAErD,OAAO;AACT,aAAA,OAAO,MAAM,mCAAmC,KAAK;AAC1D,cAAM,IAAI;AAAA,UACR,mCACE,iBAAiB,QAAQ,MAAM,UAAU,eAC3C;AAAA,QACF;AAAA,MAAA;AAAA,IACF;AAGF,WAAO,MAAM,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,MACA;AAAA,MACA,gBAAgB;AAAA,IAClB;AAAA,EAAA;AAAA,EAGF,MAAM,aAAa,WAAuC;AACxD,WAAO,MAAM,KAAK,WAAW,aAAa,SAAS;AAAA,EAAA;AAAA,EAGrD,MAAM,wBACJ,gBACA,qBACA,cACA,iBAAyB,0DACzB,MAAc,IAC4B;AACrC,SAAA,OAAO,KAAK,6BAA6B;AAC9C,UAAM,gBAAgB,KAAK,IAAI,eAAiB,EAAA;AAChD,QAAI,CAAC,eAAe;AACZ,YAAA,IAAI,MAAM,oCAAoC;AAAA,IAAA;AAGhD,UAAA,eAAe,MAAM,KAAK,WAAW;AAAA,MACzC;AAAA,IACF;AACA,UAAM,aAAa,MAAM,KAAK,WAAW,aAAa,aAAa;AAEnE,QAAI,CAAC,YAAY;AACT,YAAA,IAAI,MAAM,+BAA+B;AAAA,IAAA;AAGjD,UAAM,eAAe,IAAI,QAAQ,CAAC,YAAY,YAAY,GAAG,CAAC;AAC9D,UAAM,OAAO,KAAK,mBAAmB,cAAc,YAAY;AAAA,MAC7D;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAED,UAAM,cAAc,IAAI,uBAAA,EACrB,aAAa,IAAI,EACjB,sBAAsB,UAAU,WAAW,aAAa,CAAC,EACzD,YAAY,YAAY,EACxB,aAAa,YAAY;AAEvB,SAAA,OAAO,MAAM,sCAAsC;AAClD,UAAA,aAAa,MAAM,KAAK,IAAI;AAAA,MAChC;AAAA,MACA;AAAA,IACF;AACA,QAAI,YAAY,OAAO;AAChB,WAAA,OAAO,MAAM,WAAW,KAAK;AAC5B,YAAA,IAAI,MAAM,WAAW,KAAK;AAAA,IAAA;AAGlC,UAAM,gBAAgB,YAAY;AAC9B,QAAA,CAAC,eAAe,SAAS;AACtB,WAAA,OAAO,MAAM,yCAAyC;AACrD,YAAA,IAAI,MAAM,yCAAyC;AAAA,IAAA;AAGrD,UAAA,oBAAoB,cAAc,QAAQ,SAAS;AACzD,UAAM,aAAa,GAAG,cAAc,IAAI,aAAa;AAC/C,UAAA,oCAAoC,MAAM,KAAK;AAAA,MACnD;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,UAAM,gBAAgB,MAAM,KAAK,4BAA4B,aAAa;AAEpE,UAAA,0BAA0B,MAAM,KAAK;AAAA,MACzC;AAAA,IACF;AAEA,UAAM,8BAA8B,GAAG,wBAAwB,YAAY,IAAI,mBAAmB;AAElG,UAAM,KAAK,qCAAqC;AAAA,MAC9C,iBAAiB,cAAc;AAAA,MAC/B,0BAA0B,wBAAwB;AAAA,MAClD,qBAAqB;AAAA,MACrB,oBAAoB;AAAA,MACpB;AAAA,MACA,YAAY;AAAA,MACZ,MAAM,+BAA+B,mBAAmB;AAAA,IAAA,CACzD;AAEM,WAAA;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EAAA;AAAA,EAGF,MAAM,kBACJ,gBACA,mBACA,oBACA,cACA,YACA,MACiB;AACZ,SAAA,OAAO,KAAK,uBAAuB;AACxC,UAAM,UAAU;AAAA,MACd,GAAG;AAAA,MACH,IAAI;AAAA,MACJ,qBAAqB;AAAA,MACrB,sBAAsB;AAAA,MACtB,aAAa;AAAA,MACb,eAAe;AAAA,MACf,GAAG;AAAA,IACL;AAEM,UAAA,sBAAsB,MAAM,KAAK;AAAA,MACrC;AAAA,MACA;AAAA,IACF;AACI,QAAA,CAAC,qBAAqB,qBAAqB;AAC7C,WAAK,OAAO;AAAA,QACV;AAAA,MACF;AACM,YAAA,IAAI,MAAM,uDAAuD;AAAA,IAAA;AAElE,WAAA,oBAAoB,oBAAoB,SAAS;AAAA,EAAA;AAAA,EAG1D,MAAM,OACJ,SACA,SAMoD;AACpD,UAAM,mBAAmB,SAAS;AAC5B,UAAA,mBAAmB,IAAI,iBAAiB;AAAA,MAC5C,QAAQ;AAAA,MACR,QAAQ,KAAK;AAAA,MACb,UAAU;AAAA,IAAA,CACX;AAEG,QAAA;AACF,YAAM,iBAAiB,mBAAmB;AAEtC,UAAA;AACJ,UAAI,SAAS,eAAe;AAC1B,gBAAQ,QAAQ;AAAA,MAAA,OACX;AACG,gBAAA;AAAA,UACN,cAAc;AAAA,UACd,qBAAqB;AAAA,UACrB,kBAAkB,CAAA;AAAA,QACpB;AAAA,MAAA;AAGF,UAAI,gBAAgB;AACb,aAAA,OAAO,KAAK,0CAA0C;AACrD,cAAA,cAAe,QAAyB,MAAM;AACpD,cAAM,gBAAgB,YAAY;AAAA,MAAA,OAC7B;AACA,aAAA,OAAO,KAAK,gCAAgC;AAAA,MAAA;AAGlC,uBAAA;AAAA,QACf,YAAY,iBAAiB,UAAU,QAAQ;AAAA,QAC/C;AAAA,QACA;AAAA,UACE;AAAA,QAAA;AAAA,MAEJ;AAEM,YAAA;AAAA,QACJ;AAAA,QACA;AAAA,QACA,OAAO;AAAA,MACL,IAAA,MAAM,KAAK,0BAA0B,SAAS,gBAAgB;AAE1D,cAAA;AAER,UAAI,CAAC,gBAAgB;AAClB,gBAA0B,kBAAkB,cAAc;AAC1D,gBAA0B,mBAAmB,eAAe;AAAA,MAAA;AAG3D,UAAA;AACA,UAAA;AACA,UAAA;AAEJ,UAAI,gBAAgB;AACZ,cAAA,eAAgB,QAAyB,MAAM;AACxC,qBAAA,aAAa,sBAAsB,MAAM;AACtD,uBAAe,aAAa;AAC5B,sBAAc,aAAa,eAAe;AAAA,MAAA,OACrC;AACC,cAAA,gBAAiB,QAA0B,MAAM;AACvD,qBAAa,MAAM;AACnB,uBAAe,cAAc;AAC7B,sBAAc,cAAc;AAAA,MAAA;AAG1B,UAAA,CAAC,cAAc,gBAAgB,aAAa;AAC9C,qBAAa,MAAM,KAAK;AAAA,UACtB;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAAA,iBACS,YAAY;AACJ,yBAAA;AAAA,UACf,mCAAmC,UAAU;AAAA,UAC7C;AAAA,UACA,EAAE,MAAM;AAAA,QACV;AACA,cAAM,aAAa;AAAA,MAAA;AAGrB,YAAM,KAAK;AAAA,QACT;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAEA,YAAM,eAAe;AACrB,YAAM,sBAAsB;AACX,uBAAA;AAAA,QACf,GAAG,iBAAiB,UAAU,QAAQ;AAAA,QACtC;AAAA,UACE,gBAAgB,MAAM;AAAA,UACtB;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,MAEJ;AAEA,UAAI,aAAa;AACjB,UAAI,MAAM,iBAAiB;AACzB,qBAAa,MAAM;AAAA,MAAA;AAGrB,UAAI,YAAY;AAChB,UAAI,MAAM,gBAAgB;AACxB,oBAAY,MAAM;AAAA,MAAA;AAGpB,UAAI,oBAAoB;AACxB,UAAI,MAAM,YAAY;AACpB,4BAAoB,MAAM;AAAA,MAAA;AAG5B,UAAI,cAAc;AAClB,UAAI,MAAM,gBAAgB;AACxB,sBAAc,MAAM;AAAA,MAAA;AAGf,aAAA;AAAA,QACL,iBAAiB;AAAA,QACjB,gBAAgB;AAAA,QAChB,YAAY;AAAA,QACZ,gBAAgB;AAAA,QAChB,SAAS;AAAA,QACT;AAAA,MACF;AAAA,aACO,OAAY;AACnB,uBAAiB,OAAO,iCAAiC;AAAA,QACvD,OAAO,MAAM;AAAA,MAAA,CACd;AACM,aAAA;AAAA,QACL,iBAAiB;AAAA,QACjB,gBAAgB;AAAA,QAChB,YAAY;AAAA,QACZ,gBAAgB;AAAA,QAChB,SAAS;AAAA,QACT,OAAO,MAAM;AAAA,QACb,OAAO;AAAA,UACL,cAAc;AAAA,UACd,qBAAqB;AAAA,UACrB,OAAO,MAAM;AAAA,QAAA;AAAA,MAEjB;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAc,6BACZ,WACA,aACA,OACA,kBACiB;AACjB,UAAM,eAAe;AACJ,qBAAA,UAAU,4BAA4B,IAAI;AAAA,MACzD;AAAA,IAAA,CACD;AAEK,UAAA,cAAc,iBAAiB,kBAAkB;AAAA,MACrD,YAAY;AAAA,MACZ,YAAY;AAAA,MACZ,WAAW;AAAA,IAAA,CACZ;AAED,UAAM,YAAY,MAAM,KAAK,YAAY,WAAW,aAAa;AAAA,MAC/D,kBAAkB,CAAC,SACjB,YAAY,OAAO;AAAA,QACjB,GAAG;AAAA,QACH,iBAAiB,KAAK,mBAAmB;AAAA,QACzC,SAAS,EAAE,GAAG,KAAK,SAAS,MAAM;AAAA,MACnC,CAAA;AAAA,IAAA,CACJ;AAEG,QAAA,CAAC,UAAU,SAAS;AACtB,UAAI,eAAe;AACnB,UAAI,UAAU,OAAO;AACnB,uBAAe,UAAU;AAAA,MAAA;AAErB,YAAA,IAAI,MAAM,YAAY;AAAA,IAAA;AAG9B,UAAM,aAAa,UAAU;AAC7B,UAAM,aAAa;AAEnB,QAAI,MAAM,kBAAkB;AAC1B,YAAM,iBAAiB,KAAK,OAAO,MAAM,UAAU,EAAE;AAAA,IAAA;AAGvD,qBAAiB,UAAU,2BAA2B,IAAI,EAAE,OAAO;AAE5D,WAAA;AAAA,EAAA;AAAA,EAGT,MAAc,yBACZ,gBACA,SACA,YACA,OACA,gBACA,iBACA,SAGA,kBACe;AACX,QAAA,CAAC,KAAK,aAAa;AACrB,UAAI,kBAAkB;AACpB,yBAAiB,OAAO,8BAA8B;AAAA,MAAA;AAElD,YAAA,IAAI,MAAM,8BAA8B;AAAA,IAAA;AAG3C,SAAA,OAAO,KAAK,iCAAiC;AAC9C,QAAA,CAAC,MAAM,gBAAgB;AACzB,UAAI,kBAAkB;AACH,yBAAA;AAAA,UACf,kBAAkB,iBAAiB,UAAU,QAAQ;AAAA,UACrD;AAAA,QACF;AAAA,MAAA;AAGI,YAAA,kBAAkB,kBAAkB,kBAAkB;AAAA,QAC1D,YAAY;AAAA,QACZ,YAAY;AAAA,QACZ,WAAW;AAAA,MAAA,CACZ;AAEG,UAAA;AAEJ,UAAI,gBAAgB;AACZ,cAAA,eAAgB,QAAyB,MAAM;AAE/C,cAAA,cAAc,aAAa,UAAU,UACvC,OAAO,QAAQ,aAAa,SAAS,OAAO,EAAE;AAAA,UAC5C,CAAC,CAAC,UAAU,MAAM,OAAO;AAAA,YACvB;AAAA,YACA;AAAA,UACF;AAAA,QAAA,IAEF,CAAC;AAEL,uBAAe,KAAK,YAAY;AAAA,UAC9B,aAAa;AAAA,UACb,aAAa,UAAU,SAAS,WAAW,IAAI;AAAA,UAC/C,aAAa,gBAAgB,CAAC;AAAA,UAC9B,aAAa,UAAU,SAAS;AAAA,UAChC;AAAA,YACE,OAAO,aAAa,KAAK,YAAc,EAAA,QAAQ,QAAQ,GAAG;AAAA,YAC1D,KAAK,aAAa;AAAA,YAClB,cAAc,aAAa,WAAW,UAAU,KAAK;AAAA,YACrD,SAAS;AAAA,YACT,YAAY,aAAa,UAAU,cAAc,CAAC;AAAA,YAClD;AAAA,YACA;AAAA,YACA,SAAS,aAAa,UAAU;AAAA,UAAA;AAAA,QAEpC;AAAA,MAAA,OACK;AACC,cAAA,gBAAiB,QAA0B,MAAM;AAEvD,cAAM,EAAE,WAAW,aAAa,GAAG,aAAiB,IAAA;AAEpD,uBAAe,KAAK,YAAY;AAAA,UAC9B,cAAc;AAAA,UACd;AAAA,YACE,OAAO,cAAc;AAAA,YACrB,KAAK,cAAc;AAAA,YACnB,SAAS,cAAc;AAAA,YACvB,cAAc,aACV,WAAW,UAAU,KACrB,cAAc;AAAA,YAClB,YAAY,cAAc;AAAA,YAC1B;AAAA,YACA;AAAA,UAAA;AAAA,QAEJ;AAAA,MAAA;AAGI,YAAA,gBAAgB,MAAM,KAAK,YAAY;AAAA,QAC3C;AAAA,QACA,SAAS,qBAAqB;AAAA,QAC9B;AAAA,UACE,kBAAkB,CAAC,SACjB,iBAAiB,OAAO;AAAA,YACtB,GAAG;AAAA,YACH,iBAAiB,KAAK,mBAAmB;AAAA,UAC1C,CAAA;AAAA,QAAA;AAAA,MAEP;AAEI,UAAA,CAAC,cAAc,SAAS;AAC1B,YAAI,kBAAkB;AACH,2BAAA;AAAA,YACf,sBAAsB,iBAAiB,UAAU,QAAQ;AAAA,YACzD;AAAA,cACE,OAAO,cAAc;AAAA,YAAA;AAAA,UAEzB;AAAA,QAAA;AAGF,YAAI,eAAe,sBACjB,iBAAiB,UAAU,QAC7B;AACA,YAAI,cAAc,OAAO;AACvB,yBAAe,cAAc;AAAA,QAAA;AAEzB,cAAA,IAAI,MAAM,YAAY;AAAA,MAAA;AAG9B,YAAM,iBAAiB,cAAc;AAErC,UAAI,MAAM,kBAAkB;AAC1B,cAAM,iBAAiB,KAAK,WAAW,cAAc,cAAc,EAAE;AAAA,MAAA;AAGvE,UAAI,kBAAkB;AACpB,yBAAiB,UAAU,yBAAyB,IAAI,EAAE,OAAO;AAAA,MAAA;AAAA,eAE1D,kBAAkB;AACV,uBAAA;AAAA,QACf,kBAAkB,iBAAiB,UAAU,QAAQ;AAAA,QACrD;AAAA,QACA;AAAA,UACE;AAAA,QAAA;AAAA,MAEJ;AAAA,IAAA;AAAA,EACF;AAAA,EAGM,4BACN,gBACA,eACoB;AACpB,UAAM,QAAQ,iBAAiB;AAAA,MAC7B;AAAA,MACA,cAAc;AAAA,MACd,qBAAqB;AAAA,MACrB,kBAAkB,CAAA;AAAA,IACpB;AAEA,QACE,MAAM,iBAAiB,kBACvB,MAAM,iBAAiB,YACvB;AACA,YAAM,eAAe;AAAA,IAAA;AAGhB,WAAA;AAAA,EAAA;AAAA,EAGD,oCACN,OACA,gBACM;AACN,UAAM,eAAe;AACrB,UAAM,sBAAsB;AAC5B,QAAI,MAAM,kBAAkB;AAC1B,YAAM,iBAAiB,KAAK,gBAAgB,cAAc,EAAE;AAAA,IAAA;AAAA,EAC9D;AAAA,EAGF,MAAM,iCACJ,WACA,UAAkB,KAAK,SACvB,SAMkC;AAC9B,QAAA;AACG,WAAA,OAAO,KAAK,yCAAyC;AAE1D,YAAM,eAAe,MAAM,KAAK,gBAAgB,SAAS;AACnD,YAAA,iBAAiB,aAAa,UAAU;AAC9C,YAAM,QAAQ,KAAK;AAAA,QACjB;AAAA,QACA,SAAS;AAAA,MACX;AACM,YAAA,mBAAmB,IAAI,iBAAiB;AAAA,QAC5C,QAAQ;AAAA,QACR,QAAQ,KAAK;AAAA,QACb,UAAU,SAAS;AAAA,MAAA,CACpB;AAEgB,uBAAA,UAAU,gCAAgC,IAAI;AAAA,QAC7D;AAAA,QACA;AAAA,MAAA,CACD;AAEK,YAAA,qBAAqB,MAAM,KAAK;AAAA,QACpC;AAAA,QACA;AAAA,QACA,KAAK;AAAA,QACL,KAAK;AAAA,MACP;AAEI,UAAA,CAAC,mBAAmB,SAAS;AACxB,eAAA;AAAA,UACL,GAAG;AAAA,UACH;AAAA,QACF;AAAA,MAAA;AAGe,uBAAA,WAAW,uCAAuC,IAAI;AAAA,QACrE,eAAe,mBAAmB;AAAA,MAAA,CACnC;AAED,UAAI,mBAAmB,aAAa;AAClC,cAAM,cAAc,YAAY;AAAA,UAC9B,OAAO,KAAK,mBAAmB,aAAa,QAAQ;AAAA,QACtD;AAEK,aAAA,OAAO,KAAK,qCAAqC;AAChD,cAAA,WAAW,MAAM,KAAK,IAAI;AAAA,UAC9B;AAAA,UACA;AAAA,QACF;AAEA,YAAI,SAAS,OAAO;AACX,iBAAA;AAAA,YACL,GAAG;AAAA,YACH,OAAO,SAAS;AAAA,YAChB,SAAS;AAAA,YACT;AAAA,UACF;AAAA,QAAA;AAGG,aAAA,OAAO,KAAK,iDAAiD;AAAA,MAAA;AAGnD,uBAAA,WAAW,uCAAuC,IAAI;AAAA,QACrE;AAAA,QACA;AAAA,QACA,eAAe,mBAAmB;AAAA,MAAA,CACnC;AAEK,YAAA,cAAc,SAAS,eAAe;AACtC,YAAA,UAAU,SAAS,WAAW;AAE9B,YAAA,YAAY,MAAM,KAAK;AAAA,QAC3B,mBAAmB;AAAA,QACnB;AAAA,QACA,KAAK;AAAA,QACL;AAAA,QACA;AAAA,QACA,KAAK;AAAA,MACP;AAEK,WAAA,oCAAoC,OAAO,cAAc;AAE9D,uBAAiB,UAAU,+BAA+B;AAAA,QACxD,eAAe,mBAAmB;AAAA,QAClC;AAAA,QACA;AAAA,QACA;AAAA,MAAA,CACD;AAEM,aAAA;AAAA,QACL,GAAG;AAAA,QACH;AAAA,QACA;AAAA,MACF;AAAA,aACO,OAAY;AACnB,WAAK,OAAO,MAAM,uBAAuB,MAAM,OAAO,EAAE;AACjD,aAAA;AAAA,QACL,OAAO,8BAA8B,MAAM,OAAO;AAAA,QAClD,SAAS;AAAA,QACT,OAAO;AAAA,UACL,cAAc;AAAA,UACd,qBAAqB;AAAA,UACrB,OAAO,MAAM;AAAA,QAAA;AAAA,MAEjB;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAM,uBACJ,SACA,SAOkC;AAC9B,QAAA;AACI,YAAA,cAAc,QAAQ,MAAM;AAClC,YAAM,mBAAmB,SAAS;AAC5B,YAAA,mBAAmB,IAAI,iBAAiB;AAAA,QAC5C,QAAQ;AAAA,QACR,QAAQ,KAAK;AAAA,QACb,UAAU;AAAA,MAAA,CACX;AAEG,UAAA,QACF,SAAS,iBACR;AAAA,QACC,cAAc;AAAA,QACd,qBAAqB;AAAA,QACrB,kBAAkB,CAAA;AAAA,MACpB;AAEF,YAAM,gBAAgB,YAAY;AAEjB,uBAAA,UAAU,mCAAmC,GAAG;AAAA,QAC/D;AAAA,MAAA,CACD;AAGC,UAAA,MAAM,iBAAiB,cACvB,CAAC,MAAM,kBACP,CAAC,MAAM,mBACP,CAAC,MAAM,gBACP;AACA,cAAM,eAAe,MAAM,KAAK,OAAO,SAAS;AAAA,UAC9C,kBAAkB,CAAC,aAAkB;AAC7B,kBAAA,mBAAmB,SAAS,mBAAmB,KAAK;AAC1D,6BAAiB,OAAO;AAAA,cACtB,GAAG;AAAA,cACH,iBAAiB;AAAA,cACjB,SAAS;AAAA,gBACP,GAAG,SAAS;AAAA,gBACZ,OAAO,SAAS,SAAS,SAAS;AAAA,cAAA;AAAA,YACpC,CACD;AAAA,UACH;AAAA,UACA,eAAe;AAAA,UACf,mBAAmB;AAAA,QAAA,CACpB;AAEG,YAAA,EAAE,WAAW,eAAe;AACxB,gBAAA,IAAI,MAAM,oDAAoD;AAAA,QAAA;AAGlE,YAAA,CAAC,aAAa,SAAS;AACzB,gBAAM,IAAI;AAAA,YACR,aAAa,SAAS;AAAA,UACxB;AAAA,QAAA;AAGF,gBAAQ,aAAa;AACrB,cAAM,gBAAgB,YAAY;AAAA,MAAA;AAGnB,uBAAA;AAAA,QACf,0BAA0B,MAAM,YAAY,KAAK,MAAM,mBAAmB;AAAA,QAC1E;AAAA,QACA,EAAE,MAAM;AAAA,MACV;AAEA,YAAM,EAAE,UAAA,IAAc,KAAK,oBAAoB;AAE/C,UACE,MAAM,iBAAiB,cACvB,CAAC,MAAM,kBAAkB;AAAA,QACvB,gBAAgB,MAAM,cAAc;AAAA,MAAA,GAEtC;AACA,YAAI,SAAS,SAAS;AACpB,eAAK,yBAAyB,QAAQ;AAAA,QAAA;AAGlC,cAAA,qBAAqB,MAAM,KAAK;AAAA,UACpC;AAAA,UACA,YAAY;AAAA,UACZ;AAAA,YACE,kBAAkB,CAAC,aAAa;AAC9B,oBAAM,kBACJ,MAAM,SAAS,mBAAmB,KAAK;AACzC,+BAAiB,OAAO;AAAA,gBACtB,GAAG;AAAA,gBACH,iBAAiB;AAAA,gBACjB,SAAS;AAAA,kBACP,GAAG,SAAS;AAAA,kBACZ,OAAO,SAAS,SAAS,SAAS;AAAA,gBAAA;AAAA,cACpC,CACD;AAAA,YACH;AAAA,YACA,aAAa,SAAS;AAAA,YACtB,SAAS,SAAS;AAAA,YAClB,eAAe;AAAA,UAAA;AAAA,QAEnB;AAEI,YAAA,CAAC,mBAAmB,SAAS;AAC/B,gBAAM,IAAI;AAAA,YACR,mBAAmB,SAAS;AAAA,UAC9B;AAAA,QAAA;AAGF,gBAAQ,mBAAmB;AAE3B,YAAI,MAAM,gBAAgB;AACxB,gBAAM,KAAK,aAAa;AAAA,YACtB;AAAA,YACA,MAAM;AAAA,UACR;AAAA,QAAA;AAAA,MACF;AAGF,uBAAiB,UAAU,4CAA4C;AAAA,QACrE;AAAA,MAAA,CACD;AAEM,aAAA;AAAA,QACL,SAAS;AAAA,QACT;AAAA,QACA,UAAU;AAAA,UACR;AAAA,UACA,YAAY,GAAG,MAAM,cAAc,IAAI,SAAS;AAAA,UAChD,gBAAgB,MAAM;AAAA,UACtB,iBAAiB,MAAM;AAAA,UACvB,gBAAgB,MAAM;AAAA,UACtB,YAAY,MAAM;AAAA,UAClB,YAAY;AAAA,UACZ,GAAG,MAAM;AAAA,QAAA;AAAA,MAEb;AAAA,aACO,OAAY;AACnB,WAAK,OAAO;AAAA,QACV,wCAAwC,MAAM,OAAO;AAAA,MACvD;AACO,aAAA;AAAA,QACL,SAAS;AAAA,QACT,OAAO,wCAAwC,MAAM,OAAO;AAAA,QAC5D,OACE,SAAS,iBACR;AAAA,UACC,cAAc;AAAA,UACd,qBAAqB;AAAA,UACrB,OAAO,MAAM;AAAA,QAAA;AAAA,MAEnB;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAM,kBACJ,WACA,UACA,gBACA,iBACA,eAAyB,IACzB,WAAgC,CAAA,GAChC,WACA,aACA,oBACA,SAGoC;AAChC,QAAA;AACF,YAAM,mBAAmB,SAAS;AAC5B,YAAA,mBAAmB,IAAI,iBAAiB;AAAA,QAC5C,QAAQ;AAAA,QACR,QAAQ,KAAK;AAAA,QACb,UAAU;AAAA,MAAA,CACX;AAEgB,uBAAA,UAAU,gCAAgC,CAAC;AAE5D,UAAI,aAAa;AAEb,UAAA,CAAC,cAAc,aAAa,aAAa;AACrC,cAAA,cAAc,iBAAiB,kBAAkB;AAAA,UACrD,YAAY;AAAA,UACZ,YAAY;AAAA,UACZ,WAAW;AAAA,QAAA,CACZ;AAED,cAAM,YAAY,MAAM,KAAK,YAAY,WAAW,aAAa;AAAA,UAC/D,kBAAkB,CAAC,SAAS;AAC1B,wBAAY,OAAO;AAAA,cACjB,OAAO,KAAK;AAAA,cACZ,SAAS,KAAK;AAAA,cACd,iBAAiB,KAAK,mBAAmB;AAAA,cACzC,SAAS,KAAK;AAAA,YAAA,CACf;AAAA,UAAA;AAAA,QACH,CACD;AAEG,YAAA,CAAC,UAAU,SAAS;AACL,2BAAA;AAAA,YACf;AAAA,UACF;AAAA,QAAA,OACK;AACL,uBAAa,UAAU;AAAA,QAAA;AAAA,iBAEhB,oBAAoB;AACZ,yBAAA;AAAA,UACf,mCAAmC,kBAAkB;AAAA,UACrD;AAAA,QACF;AAAA,MAAA,OACK;AACY,yBAAA,UAAU,+BAA+B,EAAE;AAAA,MAAA;AAG1D,UAAA,CAAC,KAAK,aAAa;AACJ,yBAAA;AAAA,UACf;AAAA,QACF;AACO,eAAA;AAAA,UACL,gBAAgB;AAAA,UAChB,SAAS;AAAA,UACT,OAAO;AAAA,UACP,eAAe;AAAA,QACjB;AAAA,MAAA;AAGI,YAAA,YAAY,KAAK,YAAY,yBAAyB;AAAA,QAC1D,MAAM,SAAS,QAAQ;AAAA,MAAA,CACL;AAEH,uBAAA,UAAU,0BAA0B,EAAE;AAEjD,YAAA,mBAA6C,SAAS,UACxD,OAAO,QAAQ,SAAS,OAAO,EAC5B,OAAO,CAAC,CAAC,GAAG,MAAM,MAAM,MAAM,EAC9B,IAAI,CAAC,CAAC,UAAU,MAAM,OAAO;AAAA,QAC5B;AAAA,QACA;AAAA,MAAA,EACA,IACJ;AAEE,YAAA,UAAU,KAAK,YAAY;AAAA,QAC/B;AAAA,QACA;AAAA,QACA;AAAA,QACA,SAAS,SAAS;AAAA,QAClB;AAAA,UACE,OAAO,UAAU,YAAA,EAAc,QAAQ,QAAQ,GAAG;AAAA,UAClD,KAAK;AAAA,UACL,cAAc,aAAa,WAAW,UAAU,KAAK;AAAA,UACrD,SAAS;AAAA,UACT,YAAY;AAAA,YACV,SAAS,SAAS,WAAW;AAAA,YAC7B,SAAS,SAAS,WAAW;AAAA,YAC7B,qBAAqB,SAAS,uBAAuB,CAAC,IAAI;AAAA,YAC1D,aAAa,SAAS,eAAe,CAAC;AAAA,YACtC,eAAe,SAAS;AAAA,YACxB,UAAU,SAAS;AAAA,YACnB,0BAA0B,SAAS;AAAA,YACnC,GAAG;AAAA,UACL;AAAA,UACA;AAAA,UACA;AAAA,UACA,SAAS,SAAS;AAAA,QAAA;AAAA,MAEtB;AAEM,YAAA,kBAAkB,iBAAiB,kBAAkB;AAAA,QACzD,YAAY;AAAA,QACZ,YAAY;AAAA,QACZ,WAAW;AAAA,MAAA,CACZ;AAEK,YAAA,gBAAgB,MAAM,KAAK,YAAY;AAAA,QAC3C;AAAA,QACA;AAAA,QACA;AAAA,UACE,kBAAkB,CAAC,gBAAgB;AACjC,4BAAgB,OAAO;AAAA,cACrB,OAAO,YAAY;AAAA,cACnB,SAAS,YAAY;AAAA,cACrB,iBAAiB,YAAY,mBAAmB;AAAA,cAChD,SAAS,YAAY;AAAA,YAAA,CACtB;AAAA,UAAA;AAAA,QACH;AAAA,MAEJ;AAEI,UAAA,CAAC,cAAc,SAAS;AAC1B,yBAAiB,OAAO,4BAA4B;AAC7C,eAAA;AAAA,UACL,gBAAgB;AAAA,UAChB,SAAS;AAAA,UACT,OAAO,cAAc,SAAS;AAAA,UAC9B,eAAe,cAAc,iBAAiB;AAAA,QAChD;AAAA,MAAA;AAGF,uBAAiB,UAAU,+BAA+B;AAAA,QACxD,gBAAgB,cAAc;AAAA,MAAA,CAC/B;AAEM,aAAA;AAAA,QACL,gBAAgB,cAAc;AAAA,QAC9B;AAAA,QACA,SAAS;AAAA,QACT,eAAe,cAAc,iBAAiB;AAAA,MAChD;AAAA,aACO,OAAY;AACnB,WAAK,OAAO,MAAM,gCAAgC,MAAM,OAAO,EAAE;AAC1D,aAAA;AAAA,QACL,gBAAgB;AAAA,QAChB,SAAS;AAAA,QACT,OAAO,MAAM;AAAA,QACb,eAAe;AAAA,MACjB;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAM,YACJ,MACA,UACA,WAKC;AACI,SAAA,OAAO,KAAK,gBAAgB;AACjC,UAAM,EAAE,WAAW,WAAW,KAAK,oBAAoB;AAEvD,UAAM,cAAc,IAAI,yBAAyB,aAAa,IAAI;AAElE,UAAM,YAAY,MAAM,KAAK,WAAW,aAAa,SAAS;AAE9D,QAAI,YAAY,WAAW;AACzB,kBAAY,YAAY,SAAS;AACjC,kBAAY,sBAAsB,SAAS;AAAA,IAAA;AAG7C,QAAI,aAAa,WAAW;AAC1B,kBAAY,aAAa,SAAS;AAAA,IAAA;AAG9B,UAAA,sBACJ,MAAM,KAAK,IAAI;AAAA,MACb;AAAA,MACA;AAAA,IACF;AAEF,UAAM,QAAQ,oBAAoB;AAElC,QAAI,OAAO;AACJ,WAAA,OAAO,MAAM,KAAK;AAChB,aAAA;AAAA,QACL,SAAS;AAAA,QACT;AAAA,MACF;AAAA,IAAA;AAGF,UAAM,gBAAgB,oBAAoB;AAEtC,QAAA,CAAC,eAAe,SAAS;AACtB,WAAA,OAAO,MAAM,yCAAyC;AACpD,aAAA;AAAA,QACL,SAAS;AAAA,QACT,OAAO;AAAA,MACT;AAAA,IAAA;AAGK,WAAA;AAAA,MACL,SAAS;AAAA,MACT,SAAS,cAAc,QAAQ,SAAS;AAAA,IAC1C;AAAA,EAAA;AAAA,EAGF,MAAa,cACX,SACA,SACA,WACA,aAC6B;AAC7B,SAAK,OAAO,MAAM,+BAA+B,OAAO,EAAE;AAEtD,QAAA;AACA,QAAA,OAAO,YAAY,UAAU;AACrB,gBAAA;AAAA,IAAA,OACL;AACK,gBAAA,KAAK,UAAU,OAAO;AAAA,IAAA;AAG5B,UAAA,cAAc,IAAI,8BAA8B,EACnD,WAAW,OAAO,EAClB,WAAW,OAAO;AAEjB,QAAA;AAKJ,QAAI,aAAa;AACf,WAAK,OAAO;AAAA,QACV;AAAA,MACF;AACA,kBAAY,qBAAqB,IAAI,KAAK,KAAK,SAAS,CAAC;AAAA,IAAA;AAG3D,QAAI,WAAW;AACb,YAAM,EAAE,WAAW,WAAW,KAAK,oBAAoB;AACvD,kBAAY,iBAAiB,MAAa;AAC1C,YAAM,oBAAoB,MAAM,YAAY,KAAK,SAAS;AACpC,4BAAA,MAAM,KAAK,IAAI;AAAA,QACnC;AAAA,QACA;AAAA,MACF;AAAA,IAAA,OACK;AACiB,4BAAA,MAAM,KAAK,IAAI;AAAA,QACnC;AAAA,QACA;AAAA,MACF;AAAA,IAAA;AAGF,QAAI,qBAAqB,OAAO;AAC9B,WAAK,OAAO;AAAA,QACV,6BAA6B,oBAAoB,KAAK;AAAA,MACxD;AACA,YAAM,IAAI,MAAM,6BAA6B,oBAAoB,KAAK,EAAE;AAAA,IAAA;AAGtE,QAAA,CAAC,qBAAqB,QAAQ;AAChC,WAAK,OAAO;AAAA,QACV;AAAA,MACF;AACM,YAAA,IAAI,MAAM,wDAAwD;AAAA,IAAA;AAGrE,SAAA,OAAO,MAAM,wCAAwC;AAC1D,WAAO,oBAAoB;AAAA,EAAA;AAAA,EAG7B,MAAM,aACJ,QACA,UACA,SAKqC;AACrC,UAAM,EAAE,WAAW,WAAW,KAAK,oBAAoB;AAEvD,UAAM,WAAWA,iBAAAA,OAAY,QAAQ,KAAK;AAEpC,UAAA,MAAM,MAAM,eAAe,eAAe;AAAA,MAC9C,MAAM;AAAA,MACN;AAAA,MACA;AAAA,MACA,SAAS,KAAK;AAAA,IAAA,CACf;AAED,UAAM,qBAAqB;AAAA,MACzB,MAAM;AAAA,MACN,qBAAqB;AAAA,MACrB,iBAAiB,SAAS,mBAAmB;AAAA,MAC7C,gBAAgB,SAAS,kBAAkB;AAAA,MAC3C,kBAAkB,SAAS;AAAA,MAC3B,SAAS;AAAA,QACP,OAAO,KAAK,OAAO,WAAW,KAAK,OAAO,aAAa;AAAA,MAAA;AAAA,IAE3D;AAEA,UAAM,WAAW,MAAM;AAAA,MACrB;AAAA,QACE,MAAM;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MACA;AAAA,MACA;AAAA,QACE,GAAG;AAAA,QACH,SAAS,KAAK;AAAA,MAChB;AAAA,MACA;AAAA,IACF;AAEA,QAAI,CAAC,SAAS,aAAa,CAAC,SAAS,aAAa;AAC1C,YAAA,IAAI,MAAM,+BAA+B;AAAA,IAAA;AAGjD,WAAO,SAAS;AAAA,EAAA;AAAA,EAGlB,sBAAmD;AAC3C,UAAA,cAAc,KAAK,IAAI,eAAe;AACtC,UAAA,YAAY,YAAY,UAAU,SAAS;AACjD,UAAM,SAAS,KAAK,IAAI,cAAc,QAAQ,KAAK,CAAC,MAAM;AACxD,aAAO,EAAE,eAAe,SAAe,MAAA;AAAA,IAAA,CACxC;AAED,QAAI,CAAC,QAAQ;AACN,WAAA,OAAO,MAAM,uBAAuB;AACnC,YAAA,IAAI,MAAM,uBAAuB;AAAA,IAAA;AAGlC,WAAA,EAAE,WAAW,OAAsB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAW5C,MAAM,YACJ,QACA,UACA,SAG8B;AAC1B,QAAA;AACF,YAAM,mBAAmB,SAAS;AAC5B,YAAA,mBAAmB,IAAI,iBAAiB;AAAA,QAC5C,QAAQ;AAAA,QACR,QAAQ,KAAK;AAAA,QACb,UAAU;AAAA,MAAA,CACX;AAEG,UAAA,CAAC,KAAK,aAAa;AACJ,yBAAA;AAAA,UACf;AAAA,QACF;AACO,eAAA;AAAA,UACL,YAAY;AAAA,UACZ,SAAS;AAAA,UACT,OAAO;AAAA,UACP,eAAe;AAAA,QACjB;AAAA,MAAA;AAGe,uBAAA,UAAU,yCAAyC,EAAE;AACjE,WAAA,OAAO,KAAK,gDAAgD;AAE3D,YAAA,0BAA0B,CAAC,SAAc;AAC7C,yBAAiB,OAAO;AAAA,UACtB,OAAO,KAAK,SAAS;AAAA,UACrB,SAAS,KAAK,WAAW;AAAA,UACzB,iBAAiB,KAAK,mBAAmB;AAAA,UACzC,SAAS,KAAK;AAAA,QAAA,CACf;AAAA,MACH;AAEM,YAAA,cAAc,MAAM,KAAK,YAAY;AAAA,QACzC;AAAA,QACA;AAAA,QACA,EAAE,kBAAkB,wBAAwB;AAAA,MAC9C;AAEI,UAAA,CAAC,YAAY,SAAS;AACxB,YAAI,eAAe;AACnB,YAAI,YAAY,OAAO;AACrB,yBAAe,YAAY;AAAA,QAAA;AAG7B,YAAI,OAAO;AACX,YAAI,YAAY,eAAe;AAC7B,iBAAO,YAAY;AAAA,QAAA;AAGd,eAAA;AAAA,UACL,YAAY;AAAA,UACZ,SAAS;AAAA,UACT,OAAO;AAAA,UACP,eAAe;AAAA,QACjB;AAAA,MAAA;AAGF,uBAAiB,UAAU,0CAA0C;AAAA,QACnE,YAAY,YAAY;AAAA,MAAA,CACzB;AAED,WAAK,OAAO;AAAA,QACV,yDAAyD,YAAY,YAAY;AAAA,MACnF;AACO,aAAA;AAAA,QACL,YAAY,YAAY;AAAA,QACxB,SAAS;AAAA,QACT,eAAe,YAAY,iBAAiB;AAAA,MAC9C;AAAA,aACO,OAAY;AACnB,WAAK,OAAO,MAAM,qCAAqC,MAAM,OAAO,EAAE;AAC/D,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,SAAS;AAAA,QACT,OAAO,MAAM;AAAA,QACb,eAAe;AAAA,MACjB;AAAA,IAAA;AAAA,EACF;AAAA,EAGF,MAAc,0BACZ,SAIA,kBAKC;AACG,QAAA,QACF,SAAS,iBACR;AAAA,MACC,cAAc;AAAA,MACd,qBAAqB;AAAA,MACrB,kBAAkB,CAAA;AAAA,IACpB;AAEF,QAAI,kBAAkB;AACH,uBAAA,UAAU,yCAAyC,GAAG;AAAA,QACrE;AAAA,MAAA,CACD;AAAA,IAAA;AAGH,UAAM,EAAE,UAAA,IAAc,KAAK,oBAAoB;AAC3C,QAAA,CAAC,MAAM,iBAAiB;AAC1B,YAAM,eAAe;AACrB,UAAI,kBAAkB;AACH,yBAAA,UAAU,2BAA2B,GAAG;AAAA,UACvD;AAAA,QAAA,CACD;AAAA,MAAA;AAEH,YAAM,eAAe,KAAK,mBAAmB,cAAc,UAAU;AAAA,QACnE,KAAK,SAAS;AAAA,QACd;AAAA,MAAA,CACD;AACD,YAAM,iBAAiB,MAAM,KAAK,YAAY,cAAc,MAAM,IAAI;AACtE,UAAI,CAAC,eAAe,WAAW,CAAC,eAAe,SAAS;AACtD,cAAM,IAAI;AAAA,UACR,eAAe,SAAS;AAAA,QAC1B;AAAA,MAAA;AAEF,YAAM,kBAAkB,eAAe;AACvC,UAAI,MAAM;AACR,cAAM,iBAAiB,KAAK,YAAY,MAAM,eAAe,EAAE;AAAA,IAAA;AAG/D,QAAA,CAAC,MAAM,gBAAgB;AACzB,YAAM,eAAe;AACrB,UAAI,kBAAkB;AACH,yBAAA,UAAU,0BAA0B,IAAI;AAAA,UACvD;AAAA,QAAA,CACD;AAAA,MAAA;AAEH,YAAM,cAAc,KAAK,mBAAmB,cAAc,SAAS;AAAA,QACjE,KAAK,SAAS;AAAA,QACd;AAAA,MAAA,CACD;AAED,YAAM,gBAAgB,MAAM,KAAK,YAAY,aAAa,MAAM,KAAK;AACrE,UAAI,CAAC,cAAc,WAAW,CAAC,cAAc,SAAS;AACpD,cAAM,IAAI;AAAA,UACR,cAAc,SAAS;AAAA,QACzB;AAAA,MAAA;AAEF,YAAM,iBAAiB,cAAc;AACrC,UAAI,MAAM;AACR,cAAM,iBAAiB,KAAK,WAAW,MAAM,cAAc,EAAE;AAAA,IAAA;AAG1D,WAAA;AAAA,MACL,gBAAgB,MAAM;AAAA,MACtB,iBAAiB,MAAM;AAAA,MACvB;AAAA,IACF;AAAA,EAAA;AAEJ;"}