@hashgraphonline/standards-sdk 0.1.146-chore-jsr-improvements.canary.46c0c0f.91 → 0.1.146-chore-jsr-improvements.canary.62a5b19.93

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 (175) hide show
  1. package/dist/cjs/services/registry-broker/client/adapters.d.ts +4 -19
  2. package/dist/cjs/services/registry-broker/client/adapters.d.ts.map +1 -1
  3. package/dist/cjs/services/registry-broker/client/agents.d.ts +4 -15
  4. package/dist/cjs/services/registry-broker/client/agents.d.ts.map +1 -1
  5. package/dist/cjs/services/registry-broker/client/base-client.d.ts +64 -1
  6. package/dist/cjs/services/registry-broker/client/base-client.d.ts.map +1 -1
  7. package/dist/cjs/services/registry-broker/client/chat-history.d.ts +4 -22
  8. package/dist/cjs/services/registry-broker/client/chat-history.d.ts.map +1 -1
  9. package/dist/cjs/services/registry-broker/client/chat.d.ts +4 -32
  10. package/dist/cjs/services/registry-broker/client/chat.d.ts.map +1 -1
  11. package/dist/cjs/services/registry-broker/client/credits.d.ts +4 -39
  12. package/dist/cjs/services/registry-broker/client/credits.d.ts.map +1 -1
  13. package/dist/cjs/services/registry-broker/client/encrypted-chat-manager.d.ts +4 -34
  14. package/dist/cjs/services/registry-broker/client/encrypted-chat-manager.d.ts.map +1 -1
  15. package/dist/cjs/services/registry-broker/client/encryption.d.ts +4 -32
  16. package/dist/cjs/services/registry-broker/client/encryption.d.ts.map +1 -1
  17. package/dist/cjs/services/registry-broker/client/ledger-auth.d.ts +4 -9
  18. package/dist/cjs/services/registry-broker/client/ledger-auth.d.ts.map +1 -1
  19. package/dist/cjs/services/registry-broker/client/search-helpers.d.ts +16 -0
  20. package/dist/cjs/services/registry-broker/client/search-helpers.d.ts.map +1 -0
  21. package/dist/cjs/services/registry-broker/client/search.d.ts +5 -18
  22. package/dist/cjs/services/registry-broker/client/search.d.ts.map +1 -1
  23. package/dist/cjs/services/registry-broker/client.d.ts +4 -0
  24. package/dist/cjs/services/registry-broker/client.d.ts.map +1 -1
  25. package/dist/cjs/standards-sdk.cjs +3 -3
  26. package/dist/cjs/standards-sdk.cjs.map +1 -1
  27. package/dist/es/services/registry-broker/client/adapters.d.ts +4 -19
  28. package/dist/es/services/registry-broker/client/adapters.d.ts.map +1 -1
  29. package/dist/es/services/registry-broker/client/agents.d.ts +4 -15
  30. package/dist/es/services/registry-broker/client/agents.d.ts.map +1 -1
  31. package/dist/es/services/registry-broker/client/base-client.d.ts +64 -1
  32. package/dist/es/services/registry-broker/client/base-client.d.ts.map +1 -1
  33. package/dist/es/services/registry-broker/client/chat-history.d.ts +4 -22
  34. package/dist/es/services/registry-broker/client/chat-history.d.ts.map +1 -1
  35. package/dist/es/services/registry-broker/client/chat.d.ts +4 -32
  36. package/dist/es/services/registry-broker/client/chat.d.ts.map +1 -1
  37. package/dist/es/services/registry-broker/client/credits.d.ts +4 -39
  38. package/dist/es/services/registry-broker/client/credits.d.ts.map +1 -1
  39. package/dist/es/services/registry-broker/client/encrypted-chat-manager.d.ts +4 -34
  40. package/dist/es/services/registry-broker/client/encrypted-chat-manager.d.ts.map +1 -1
  41. package/dist/es/services/registry-broker/client/encryption.d.ts +4 -32
  42. package/dist/es/services/registry-broker/client/encryption.d.ts.map +1 -1
  43. package/dist/es/services/registry-broker/client/ledger-auth.d.ts +4 -9
  44. package/dist/es/services/registry-broker/client/ledger-auth.d.ts.map +1 -1
  45. package/dist/es/services/registry-broker/client/search-helpers.d.ts +16 -0
  46. package/dist/es/services/registry-broker/client/search-helpers.d.ts.map +1 -0
  47. package/dist/es/services/registry-broker/client/search.d.ts +5 -18
  48. package/dist/es/services/registry-broker/client/search.d.ts.map +1 -1
  49. package/dist/es/services/registry-broker/client.d.ts +4 -0
  50. package/dist/es/services/registry-broker/client.d.ts.map +1 -1
  51. package/dist/es/standards-sdk.es.js +9 -17
  52. package/dist/es/standards-sdk.es.js.map +1 -1
  53. package/dist/es/standards-sdk.es101.js +1 -1
  54. package/dist/es/standards-sdk.es103.js +1 -1
  55. package/dist/es/standards-sdk.es109.js +2 -10
  56. package/dist/es/standards-sdk.es109.js.map +1 -1
  57. package/dist/es/standards-sdk.es11.js +1 -1
  58. package/dist/es/standards-sdk.es110.js +5 -5
  59. package/dist/es/standards-sdk.es12.js +1 -1
  60. package/dist/es/standards-sdk.es120.js +1 -1
  61. package/dist/es/standards-sdk.es121.js +1 -1
  62. package/dist/es/standards-sdk.es122.js +5 -5
  63. package/dist/es/standards-sdk.es124.js +1 -1
  64. package/dist/es/standards-sdk.es125.js +1 -1
  65. package/dist/es/standards-sdk.es127.js +624 -155
  66. package/dist/es/standards-sdk.es127.js.map +1 -1
  67. package/dist/es/standards-sdk.es128.js +15 -205
  68. package/dist/es/standards-sdk.es128.js.map +1 -1
  69. package/dist/es/standards-sdk.es129.js +74 -97
  70. package/dist/es/standards-sdk.es129.js.map +1 -1
  71. package/dist/es/standards-sdk.es130.js +78 -112
  72. package/dist/es/standards-sdk.es130.js.map +1 -1
  73. package/dist/es/standards-sdk.es131.js +51 -238
  74. package/dist/es/standards-sdk.es131.js.map +1 -1
  75. package/dist/es/standards-sdk.es132.js +146 -167
  76. package/dist/es/standards-sdk.es132.js.map +1 -1
  77. package/dist/es/standards-sdk.es133.js +8 -123
  78. package/dist/es/standards-sdk.es133.js.map +1 -1
  79. package/dist/es/standards-sdk.es134.js +77 -317
  80. package/dist/es/standards-sdk.es134.js.map +1 -1
  81. package/dist/es/standards-sdk.es135.js +61 -460
  82. package/dist/es/standards-sdk.es135.js.map +1 -1
  83. package/dist/es/standards-sdk.es136.js +30 -17
  84. package/dist/es/standards-sdk.es136.js.map +1 -1
  85. package/dist/es/standards-sdk.es137.js +34 -81
  86. package/dist/es/standards-sdk.es137.js.map +1 -1
  87. package/dist/es/standards-sdk.es138.js +28 -87
  88. package/dist/es/standards-sdk.es138.js.map +1 -1
  89. package/dist/es/standards-sdk.es139.js +932 -59
  90. package/dist/es/standards-sdk.es139.js.map +1 -1
  91. package/dist/es/standards-sdk.es140.js +12263 -133
  92. package/dist/es/standards-sdk.es140.js.map +1 -1
  93. package/dist/es/standards-sdk.es141.js +138 -7
  94. package/dist/es/standards-sdk.es141.js.map +1 -1
  95. package/dist/es/standards-sdk.es142.js +36 -80
  96. package/dist/es/standards-sdk.es142.js.map +1 -1
  97. package/dist/es/standards-sdk.es143.js +49 -58
  98. package/dist/es/standards-sdk.es143.js.map +1 -1
  99. package/dist/es/standards-sdk.es144.js +84 -30
  100. package/dist/es/standards-sdk.es144.js.map +1 -1
  101. package/dist/es/standards-sdk.es145.js +17 -34
  102. package/dist/es/standards-sdk.es145.js.map +1 -1
  103. package/dist/es/standards-sdk.es146.js +172 -28
  104. package/dist/es/standards-sdk.es146.js.map +1 -1
  105. package/dist/es/standards-sdk.es147.js +299 -115
  106. package/dist/es/standards-sdk.es147.js.map +1 -1
  107. package/dist/es/standards-sdk.es148.js +340 -36
  108. package/dist/es/standards-sdk.es148.js.map +1 -1
  109. package/dist/es/standards-sdk.es149.js +453 -959
  110. package/dist/es/standards-sdk.es149.js.map +1 -1
  111. package/dist/es/standards-sdk.es150.js +267 -12225
  112. package/dist/es/standards-sdk.es150.js.map +1 -1
  113. package/dist/es/standards-sdk.es151.js +74 -15
  114. package/dist/es/standards-sdk.es151.js.map +1 -1
  115. package/dist/es/standards-sdk.es152.js +132 -49
  116. package/dist/es/standards-sdk.es152.js.map +1 -1
  117. package/dist/es/standards-sdk.es16.js +2 -10
  118. package/dist/es/standards-sdk.es16.js.map +1 -1
  119. package/dist/es/standards-sdk.es18.js +5 -13
  120. package/dist/es/standards-sdk.es18.js.map +1 -1
  121. package/dist/es/standards-sdk.es19.js +3 -11
  122. package/dist/es/standards-sdk.es19.js.map +1 -1
  123. package/dist/es/standards-sdk.es22.js +1 -1
  124. package/dist/es/standards-sdk.es27.js +5 -13
  125. package/dist/es/standards-sdk.es27.js.map +1 -1
  126. package/dist/es/standards-sdk.es30.js +1 -1
  127. package/dist/es/standards-sdk.es31.js +1 -1
  128. package/dist/es/standards-sdk.es35.js +3 -11
  129. package/dist/es/standards-sdk.es35.js.map +1 -1
  130. package/dist/es/standards-sdk.es36.js +3 -3
  131. package/dist/es/standards-sdk.es37.js +1 -1
  132. package/dist/es/standards-sdk.es4.js +1 -1
  133. package/dist/es/standards-sdk.es53.js +1 -1
  134. package/dist/es/standards-sdk.es56.js +1 -1
  135. package/dist/es/standards-sdk.es58.js +1 -1
  136. package/dist/es/standards-sdk.es59.js +1 -1
  137. package/dist/es/standards-sdk.es60.js +3 -11
  138. package/dist/es/standards-sdk.es60.js.map +1 -1
  139. package/dist/es/standards-sdk.es62.js +1 -1
  140. package/dist/es/standards-sdk.es64.js +1 -1
  141. package/dist/es/standards-sdk.es65.js +2 -2
  142. package/dist/es/standards-sdk.es68.js +2 -2
  143. package/dist/es/standards-sdk.es69.js +1 -1
  144. package/dist/es/standards-sdk.es7.js +1 -1
  145. package/dist/es/standards-sdk.es71.js +1 -1
  146. package/dist/es/standards-sdk.es76.js +1 -1
  147. package/dist/es/standards-sdk.es77.js +2 -10
  148. package/dist/es/standards-sdk.es77.js.map +1 -1
  149. package/dist/es/standards-sdk.es78.js +1 -1
  150. package/dist/es/standards-sdk.es81.js +1 -1
  151. package/dist/es/standards-sdk.es83.js +1 -1
  152. package/dist/es/standards-sdk.es87.js +3 -3
  153. package/dist/es/standards-sdk.es91.js +1 -1
  154. package/dist/es/standards-sdk.es92.js +1 -1
  155. package/dist/es/standards-sdk.es97.js +1 -1
  156. package/dist/es/standards-sdk.es99.js +1 -1
  157. package/package.json +1 -1
  158. package/dist/es/standards-sdk.es153.js +0 -87
  159. package/dist/es/standards-sdk.es153.js.map +0 -1
  160. package/dist/es/standards-sdk.es154.js +0 -175
  161. package/dist/es/standards-sdk.es154.js.map +0 -1
  162. package/dist/es/standards-sdk.es155.js +0 -325
  163. package/dist/es/standards-sdk.es155.js.map +0 -1
  164. package/dist/es/standards-sdk.es156.js +0 -349
  165. package/dist/es/standards-sdk.es156.js.map +0 -1
  166. package/dist/es/standards-sdk.es157.js +0 -456
  167. package/dist/es/standards-sdk.es157.js.map +0 -1
  168. package/dist/es/standards-sdk.es158.js +0 -334
  169. package/dist/es/standards-sdk.es158.js.map +0 -1
  170. package/dist/es/standards-sdk.es159.js +0 -79
  171. package/dist/es/standards-sdk.es159.js.map +0 -1
  172. package/dist/es/standards-sdk.es160.js +0 -242
  173. package/dist/es/standards-sdk.es160.js.map +0 -1
  174. package/dist/es/standards-sdk.es161.js +0 -247
  175. package/dist/es/standards-sdk.es161.js.map +0 -1
@@ -1,467 +1,68 @@
1
- import { Buffer } from "buffer";
2
- import { randomBytes, createHash, createCipheriv, createDecipheriv } from "crypto";
3
- import { secp256k1 } from "@noble/curves/secp256k1.js";
4
- import { ZodError } from "zod";
5
- import { agentFeedbackResponseSchema, agentFeedbackIndexResponseSchema, agentFeedbackEntriesIndexResponseSchema, agentFeedbackEligibilityResponseSchema, agentFeedbackSubmissionResponseSchema } from "./standards-sdk.es149.js";
6
- import { DEFAULT_BASE_URL, normaliseBaseUrl, normaliseHeaderName, isBrowserRuntime, DEFAULT_USER_AGENT, JSON_CONTENT_TYPE, createAbortError, isJsonObject, DEFAULT_HISTORY_TOP_UP_HBAR } from "./standards-sdk.es160.js";
7
- import { RegistryBrokerError, RegistryBrokerParseError } from "./standards-sdk.es136.js";
8
- class RegistryBrokerClient {
9
- constructor(options = {}) {
10
- this.encryptionBootstrapPromise = null;
11
- const {
12
- baseUrl = DEFAULT_BASE_URL,
13
- fetchImplementation,
14
- defaultHeaders,
15
- apiKey,
16
- ledgerApiKey,
17
- registrationAutoTopUp,
18
- historyAutoTopUp,
19
- encryption
20
- } = options;
21
- this.baseUrl = normaliseBaseUrl(baseUrl);
22
- this.fetchImpl = fetchImplementation ?? fetch;
23
- this.defaultHeaders = {
24
- ...defaultHeaders ?? {}
25
- };
26
- Object.entries(this.defaultHeaders).forEach(([key, value]) => {
27
- const headerName = normaliseHeaderName(key);
28
- if (headerName !== key) {
29
- delete this.defaultHeaders[key];
30
- this.defaultHeaders[headerName] = value;
31
- }
32
- });
33
- if (apiKey) {
34
- this.defaultHeaders["x-api-key"] = apiKey;
35
- }
36
- if (ledgerApiKey) {
37
- this.defaultHeaders["x-ledger-api-key"] = ledgerApiKey;
38
- }
39
- this.registrationAutoTopUp = registrationAutoTopUp;
40
- this.historyAutoTopUp = historyAutoTopUp;
41
- this.encryptionOptions = encryption;
42
- if (this.encryptionOptions) {
43
- this.encryptionBootstrapPromise = this.initializeEncryptionBootstrap(
44
- this.encryptionOptions
45
- );
46
- }
47
- }
48
- static async initializeAgent(options) {
49
- const { uaid, ensureEncryptionKey = true, ...clientOptions } = options;
50
- const client = new RegistryBrokerClient(clientOptions);
51
- let encryption = null;
52
- if (ensureEncryptionKey) {
53
- const ensureOptions = typeof ensureEncryptionKey === "object" ? ensureEncryptionKey : { generateIfMissing: true };
54
- encryption = await client.encryption.ensureAgentKey({
55
- uaid,
56
- ...ensureOptions
57
- });
58
- }
59
- return { client, encryption };
60
- }
61
- setApiKey(apiKey) {
62
- this.setDefaultHeader("x-api-key", apiKey);
63
- }
64
- setLedgerApiKey(apiKey) {
65
- this.setDefaultHeader("x-ledger-api-key", apiKey);
66
- }
67
- setDefaultHeader(name, value) {
68
- if (!name || name.trim().length === 0) {
69
- return;
70
- }
71
- const headerName = normaliseHeaderName(name);
72
- if (!value || value.trim().length === 0) {
73
- delete this.defaultHeaders[headerName];
74
- return;
75
- }
76
- this.defaultHeaders[headerName] = value.trim();
77
- }
78
- getDefaultHeaders() {
79
- return { ...this.defaultHeaders };
80
- }
81
- async encryptionReady() {
82
- if (!this.encryptionBootstrapPromise) {
83
- return;
84
- }
85
- await this.encryptionBootstrapPromise;
86
- }
87
- buildUrl(path) {
88
- const normalisedPath = path.startsWith("/") ? path : `/${path}`;
89
- return `${this.baseUrl}${normalisedPath}`;
90
- }
91
- async request(path, config) {
92
- const headers = new Headers();
93
- Object.entries(this.defaultHeaders).forEach(([key, value]) => {
94
- headers.set(key, value);
95
- });
96
- if (config.headers) {
97
- Object.entries(config.headers).forEach(([key, value]) => {
98
- headers.set(key, value);
99
- });
100
- }
101
- if (!headers.has("accept")) {
102
- headers.set("accept", "application/json");
103
- }
104
- if (!headers.has("user-agent") && !isBrowserRuntime()) {
105
- headers.set("user-agent", DEFAULT_USER_AGENT);
106
- }
107
- const init = {
108
- method: config.method ?? "GET",
109
- headers
110
- };
111
- if (config.body !== void 0) {
112
- init.body = JSON.stringify(config.body);
113
- if (!headers.has("content-type")) {
114
- headers.set("content-type", "application/json");
115
- }
116
- }
117
- const response = await this.fetchImpl(this.buildUrl(path), init);
118
- if (response.ok) {
119
- return response;
120
- }
121
- const errorBody = await this.extractErrorBody(response);
122
- throw new RegistryBrokerError("Registry broker request failed", {
123
- status: response.status,
124
- statusText: response.statusText,
125
- body: errorBody
126
- });
127
- }
128
- async requestJson(path, config) {
129
- const response = await this.request(path, config);
130
- const contentType = response.headers?.get("content-type") ?? "";
131
- if (!JSON_CONTENT_TYPE.test(contentType)) {
132
- const body = await response.text();
133
- throw new RegistryBrokerParseError(
134
- "Expected JSON response from registry broker",
135
- body
136
- );
137
- }
138
- return await response.json();
139
- }
140
- async getAgentFeedback(uaid, options = {}) {
141
- const normalized = uaid.trim();
142
- if (!normalized) {
143
- throw new Error("uaid is required");
144
- }
145
- const query = options.includeRevoked === true ? "?includeRevoked=true" : "";
146
- const raw = await this.requestJson(
147
- `/agents/${encodeURIComponent(normalized)}/feedback${query}`,
148
- { method: "GET" }
149
- );
150
- return this.parseWithSchema(
151
- raw,
152
- agentFeedbackResponseSchema,
153
- "agent feedback response"
154
- );
155
- }
156
- async listAgentFeedbackIndex(options = {}) {
157
- const params = new URLSearchParams();
158
- if (typeof options.page === "number" && Number.isFinite(options.page)) {
159
- params.set("page", String(Math.trunc(options.page)));
160
- }
161
- if (typeof options.limit === "number" && Number.isFinite(options.limit)) {
162
- params.set("limit", String(Math.trunc(options.limit)));
163
- }
164
- if (options.registries?.length) {
165
- params.set("registry", options.registries.join(","));
166
- }
167
- const suffix = params.size > 0 ? `?${params.toString()}` : "";
168
- const raw = await this.requestJson(`/agents/feedback${suffix}`, {
169
- method: "GET"
170
- });
171
- return this.parseWithSchema(
172
- raw,
173
- agentFeedbackIndexResponseSchema,
174
- "agent feedback index response"
175
- );
176
- }
177
- async listAgentFeedbackEntriesIndex(options = {}) {
178
- const params = new URLSearchParams();
179
- if (typeof options.page === "number" && Number.isFinite(options.page)) {
180
- params.set("page", String(Math.trunc(options.page)));
181
- }
182
- if (typeof options.limit === "number" && Number.isFinite(options.limit)) {
183
- params.set("limit", String(Math.trunc(options.limit)));
184
- }
185
- if (options.registries?.length) {
186
- params.set("registry", options.registries.join(","));
187
- }
188
- const suffix = params.size > 0 ? `?${params.toString()}` : "";
189
- const raw = await this.requestJson(
190
- `/agents/feedback/entries${suffix}`,
191
- { method: "GET" }
192
- );
193
- return this.parseWithSchema(
194
- raw,
195
- agentFeedbackEntriesIndexResponseSchema,
196
- "agent feedback entries index response"
197
- );
198
- }
199
- async checkAgentFeedbackEligibility(uaid, payload) {
200
- const normalized = uaid.trim();
201
- if (!normalized) {
202
- throw new Error("uaid is required");
203
- }
204
- const raw = await this.requestJson(
205
- `/agents/${encodeURIComponent(normalized)}/feedback/eligibility`,
206
- {
207
- method: "POST",
208
- body: payload,
209
- headers: { "content-type": "application/json" }
210
- }
211
- );
212
- return this.parseWithSchema(
213
- raw,
214
- agentFeedbackEligibilityResponseSchema,
215
- "agent feedback eligibility response"
216
- );
217
- }
218
- async submitAgentFeedback(uaid, payload) {
219
- const normalized = uaid.trim();
220
- if (!normalized) {
221
- throw new Error("uaid is required");
222
- }
223
- const raw = await this.requestJson(
224
- `/agents/${encodeURIComponent(normalized)}/feedback`,
225
- {
226
- method: "POST",
227
- body: payload,
228
- headers: { "content-type": "application/json" }
229
- }
230
- );
231
- return this.parseWithSchema(
232
- raw,
233
- agentFeedbackSubmissionResponseSchema,
234
- "agent feedback submission response"
235
- );
236
- }
237
- async extractErrorBody(response) {
238
- const contentType = response.headers?.get("content-type") ?? "";
239
- if (JSON_CONTENT_TYPE.test(contentType)) {
240
- try {
241
- return await response.json();
242
- } catch (error) {
243
- return { parseError: String(error) };
244
- }
245
- }
246
- try {
247
- return await response.text();
248
- } catch (error) {
249
- return { parseError: String(error) };
250
- }
1
+ import { Logger } from "./standards-sdk.es105.js";
2
+ const REFERENCE_THRESHOLD = 50 * 1024;
3
+ class ContentStoreServiceImpl {
4
+ constructor() {
5
+ this.contentStore = null;
6
+ this.logger = Logger.getInstance({ module: "ContentStoreService" });
7
+ }
8
+ static getInstance() {
9
+ if (!ContentStoreServiceImpl._instance) {
10
+ ContentStoreServiceImpl._instance = new ContentStoreServiceImpl();
11
+ }
12
+ return ContentStoreServiceImpl._instance;
13
+ }
14
+ /**
15
+ * Set the content store instance
16
+ */
17
+ async setInstance(store) {
18
+ if (this.contentStore) {
19
+ this.logger.warn("Content store already set, replacing");
20
+ }
21
+ this.contentStore = store;
22
+ this.logger.info("Content store instance set");
23
+ }
24
+ /**
25
+ * Get the content store instance
26
+ */
27
+ getInstance() {
28
+ return this.contentStore;
29
+ }
30
+ /**
31
+ * Clear the content store instance
32
+ */
33
+ dispose() {
34
+ this.contentStore = null;
35
+ this.logger.info("Content store disposed");
36
+ }
37
+ /**
38
+ * Check if content store is available
39
+ */
40
+ isAvailable() {
41
+ return this.contentStore !== null;
251
42
  }
252
- parseWithSchema(value, schema, context) {
253
- try {
254
- return schema.parse(value);
255
- } catch (error) {
256
- throw new RegistryBrokerParseError(
257
- `Failed to parse ${context}`,
258
- error instanceof ZodError || error instanceof Error ? error : String(error),
259
- value
260
- );
261
- }
262
- }
263
- async delay(ms, signal) {
264
- if (ms <= 0) {
265
- if (signal?.aborted) {
266
- throw createAbortError();
267
- }
268
- return;
269
- }
270
- await new Promise((resolve, reject) => {
271
- const timer = setTimeout(() => {
272
- if (signal) {
273
- signal.removeEventListener("abort", onAbort);
274
- }
275
- resolve();
276
- }, ms);
277
- const onAbort = () => {
278
- clearTimeout(timer);
279
- signal?.removeEventListener("abort", onAbort);
280
- reject(createAbortError());
281
- };
282
- if (signal) {
283
- if (signal.aborted) {
284
- clearTimeout(timer);
285
- reject(createAbortError());
286
- return;
287
- }
288
- signal.addEventListener("abort", onAbort, { once: true });
289
- }
290
- });
291
- }
292
- assertNodeRuntime(feature) {
293
- if (typeof process === "undefined" || !process.versions?.node) {
294
- throw new Error(`${feature} is only available in Node.js environments`);
295
- }
296
- }
297
- createEphemeralKeyPair() {
298
- this.assertNodeRuntime("generateEphemeralKeyPair");
299
- const privateKeyBytes = randomBytes(32);
300
- const publicKey = secp256k1.getPublicKey(privateKeyBytes, true);
301
- return {
302
- privateKey: Buffer.from(privateKeyBytes).toString("hex"),
303
- publicKey: Buffer.from(publicKey).toString("hex")
304
- };
305
- }
306
- deriveSharedSecret(options) {
307
- this.assertNodeRuntime("deriveSharedSecret");
308
- const privateKey = this.hexToBuffer(options.privateKey);
309
- const peerPublicKey = this.hexToBuffer(options.peerPublicKey);
310
- const shared = secp256k1.getSharedSecret(privateKey, peerPublicKey, true);
311
- return createHash("sha256").update(Buffer.from(shared)).digest();
312
- }
313
- buildCipherEnvelope(options) {
314
- this.assertNodeRuntime("encryptCipherEnvelope");
315
- const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);
316
- const iv = randomBytes(12);
317
- const cipher = createCipheriv("aes-256-gcm", sharedSecret, iv);
318
- const aadSource = options.associatedData ?? options.sessionId;
319
- const associatedDataEncoded = aadSource ? Buffer.from(aadSource, "utf8").toString("base64") : void 0;
320
- if (aadSource) {
321
- cipher.setAAD(Buffer.from(aadSource, "utf8"));
322
- }
323
- const ciphertext = Buffer.concat([
324
- cipher.update(Buffer.from(options.plaintext, "utf8")),
325
- cipher.final()
326
- ]);
327
- const tag = cipher.getAuthTag();
328
- const payload = Buffer.concat([ciphertext, tag]);
329
- return {
330
- algorithm: "aes-256-gcm",
331
- ciphertext: payload.toString("base64"),
332
- nonce: iv.toString("base64"),
333
- associatedData: associatedDataEncoded,
334
- keyLocator: {
335
- sessionId: options.sessionId,
336
- revision: options.revision ?? 1
337
- },
338
- recipients: options.recipients.map((recipient) => ({
339
- ...recipient,
340
- encryptedShare: ""
341
- }))
342
- };
343
- }
344
- openCipherEnvelope(options) {
345
- this.assertNodeRuntime("decryptCipherEnvelope");
346
- const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);
347
- const payload = Buffer.from(options.envelope.ciphertext, "base64");
348
- const nonce = Buffer.from(options.envelope.nonce, "base64");
349
- const ciphertext = payload.slice(0, payload.length - 16);
350
- const tag = payload.slice(payload.length - 16);
351
- const decipher = createDecipheriv("aes-256-gcm", sharedSecret, nonce);
352
- if (options.envelope.associatedData) {
353
- decipher.setAAD(Buffer.from(options.envelope.associatedData, "base64"));
354
- }
355
- decipher.setAuthTag(tag);
356
- const plaintext = Buffer.concat([
357
- decipher.update(ciphertext),
358
- decipher.final()
359
- ]);
360
- return plaintext.toString(options.encoding ?? "utf8");
361
- }
362
- normalizeSharedSecret(input) {
363
- if (Buffer.isBuffer(input)) {
364
- return Buffer.from(input);
365
- }
366
- if (input instanceof Uint8Array) {
367
- return Buffer.from(input);
368
- }
369
- if (typeof input === "string") {
370
- return this.bufferFromString(input);
371
- }
372
- throw new Error("Unsupported shared secret input");
373
- }
374
- bufferFromString(value) {
375
- const trimmed = value.trim();
376
- if (!trimmed) {
377
- throw new Error("sharedSecret string cannot be empty");
378
- }
379
- const normalized = trimmed.startsWith("0x") ? trimmed.slice(2) : trimmed;
380
- if (/^[0-9a-fA-F]+$/.test(normalized) && normalized.length % 2 === 0) {
381
- return Buffer.from(normalized, "hex");
382
- }
383
- return Buffer.from(trimmed, "base64");
384
- }
385
- hexToBuffer(value) {
386
- const normalized = value.startsWith("0x") ? value.slice(2) : value;
387
- if (!/^[0-9a-fA-F]+$/.test(normalized) || normalized.length % 2 !== 0) {
388
- throw new Error("Expected hex-encoded value");
389
- }
390
- return Buffer.from(normalized, "hex");
391
- }
392
- extractInsufficientCreditsDetails(error) {
393
- if (!(error instanceof RegistryBrokerError) || error.status !== 402) {
394
- return null;
395
- }
396
- const body = error.body;
397
- if (!body || typeof body !== "object" || Array.isArray(body)) {
398
- return null;
399
- }
400
- const maybeShortfall = body["shortfallCredits"];
401
- if (typeof maybeShortfall !== "number" || maybeShortfall <= 0) {
402
- return null;
403
- }
404
- return { shortfallCredits: maybeShortfall };
405
- }
406
- extractErrorMessage(body) {
407
- if (typeof body === "string") {
408
- return body;
409
- }
410
- if (isJsonObject(body) && typeof body.error === "string") {
411
- return body.error;
412
- }
413
- if (isJsonObject(body) && typeof body.message === "string") {
414
- return body.message;
415
- }
416
- return void 0;
417
- }
418
- shouldAutoTopUpHistory(payload, error) {
419
- if (!this.historyAutoTopUp || payload.historyTtlSeconds === void 0) {
420
- return false;
421
- }
422
- if (!(error instanceof RegistryBrokerError)) {
423
- return false;
424
- }
425
- if (error.status !== 402) {
426
- return false;
427
- }
428
- const message = this.extractErrorMessage(error.body);
429
- if (!message) {
430
- return true;
431
- }
432
- const normalised = message.toLowerCase();
433
- return normalised.includes("history") || normalised.includes("chat history");
434
- }
435
- async executeHistoryAutoTopUp(reason) {
436
- if (!this.historyAutoTopUp) {
437
- return;
438
- }
439
- const hbarAmount = this.historyAutoTopUp.hbarAmount && this.historyAutoTopUp.hbarAmount > 0 ? this.historyAutoTopUp.hbarAmount : DEFAULT_HISTORY_TOP_UP_HBAR;
440
- await this.purchaseCreditsWithHbar({
441
- accountId: this.historyAutoTopUp.accountId,
442
- privateKey: this.historyAutoTopUp.privateKey,
443
- hbarAmount,
444
- memo: this.historyAutoTopUp.memo ?? "registry-broker-client:chat-history-topup",
445
- metadata: {
446
- purpose: "chat-history",
447
- reason
448
- }
449
- });
450
- }
451
- initializeEncryptionBootstrap(options) {
452
- return this.bootstrapEncryptionOptions(options).then(() => void 0);
43
+ }
44
+ function extractReferenceId(input) {
45
+ const trimmed = input.trim();
46
+ const exactMatch = trimmed.match(/^content-ref:([a-f0-9]+)$/);
47
+ if (exactMatch) {
48
+ return exactMatch[1];
453
49
  }
454
- bootstrapEncryptionOptions(_options) {
455
- return Promise.resolve(null);
50
+ const embeddedMatch = trimmed.match(/content-ref:([a-f0-9]+)/);
51
+ if (embeddedMatch) {
52
+ return embeddedMatch[1];
456
53
  }
54
+ return null;
55
+ }
56
+ function shouldUseReference(content) {
57
+ const size = typeof content === "string" ? Buffer.byteLength(content, "utf8") : content.length;
58
+ return size > REFERENCE_THRESHOLD;
457
59
  }
458
- const isPendingRegisterAgentResponse = (response) => response.status === "pending";
459
- const isPartialRegisterAgentResponse = (response) => response.status === "partial" && response.success === false;
460
- const isSuccessRegisterAgentResponse = (response) => response.success === true && response.status !== "pending";
60
+ const ContentStoreService = ContentStoreServiceImpl.getInstance();
461
61
  export {
462
- RegistryBrokerClient,
463
- isPartialRegisterAgentResponse,
464
- isPendingRegisterAgentResponse,
465
- isSuccessRegisterAgentResponse
62
+ ContentStoreService,
63
+ ContentStoreServiceImpl,
64
+ REFERENCE_THRESHOLD,
65
+ extractReferenceId,
66
+ shouldUseReference
466
67
  };
467
68
  //# sourceMappingURL=standards-sdk.es135.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es135.js","sources":["../../src/services/registry-broker/client/base-client.ts"],"sourcesContent":["import { Buffer } from 'buffer';\nimport {\n createCipheriv,\n createDecipheriv,\n createHash,\n randomBytes,\n} from 'crypto';\nimport { secp256k1 } from '@noble/curves/secp256k1.js';\nimport { ZodError, z } from 'zod';\nimport type {\n AgentFeedbackEligibilityRequest,\n AgentFeedbackEligibilityResponse,\n AgentFeedbackIndexResponse,\n AgentFeedbackEntriesIndexResponse,\n AgentFeedbackQuery,\n AgentFeedbackResponse,\n AgentFeedbackSubmissionRequest,\n AgentFeedbackSubmissionResponse,\n AutoTopUpOptions,\n ClientEncryptionOptions,\n CreateSessionRequestPayload,\n DeriveSharedSecretOptions,\n DecryptCipherEnvelopeOptions,\n EncryptCipherEnvelopeOptions,\n EphemeralKeyPair,\n HistoryAutoTopUpOptions,\n InitializeAgentClientOptions,\n JsonObject,\n JsonValue,\n RegisterAgentResponse,\n RegisterAgentPartialResponse,\n RegisterAgentPendingResponse,\n RegisterAgentSuccessResponse,\n RegistryBrokerClientOptions,\n SharedSecretInput,\n} from '../types';\nimport {\n agentFeedbackEligibilityResponseSchema,\n agentFeedbackEntriesIndexResponseSchema,\n agentFeedbackIndexResponseSchema,\n agentFeedbackResponseSchema,\n agentFeedbackSubmissionResponseSchema,\n} from '../schemas';\nimport {\n createAbortError,\n DEFAULT_BASE_URL,\n DEFAULT_HISTORY_TOP_UP_HBAR,\n DEFAULT_USER_AGENT,\n JSON_CONTENT_TYPE,\n isJsonObject,\n isBrowserRuntime,\n normaliseBaseUrl,\n normaliseHeaderName,\n} from './utils';\nimport {\n RegistryBrokerError,\n RegistryBrokerParseError,\n type ErrorDetails,\n} from './errors';\nexport interface InitializedAgentClient {\n client: RegistryBrokerClient;\n encryption?: { publicKey: string; privateKey?: string } | null;\n}\nexport interface GenerateEncryptionKeyPairOptions {\n keyType?: 'secp256k1';\n envVar?: string;\n envPath?: string;\n overwrite?: boolean;\n}\nexport interface RequestConfig {\n method?: string;\n body?: unknown;\n headers?: Record<string, string>;\n}\nexport class RegistryBrokerClient {\n static async initializeAgent(\n options: InitializeAgentClientOptions,\n ): Promise<InitializedAgentClient> {\n const { uaid, ensureEncryptionKey = true, ...clientOptions } = options;\n const client = new RegistryBrokerClient(clientOptions);\n let encryption: { publicKey: string; privateKey?: string } | null = null;\n if (ensureEncryptionKey) {\n const ensureOptions =\n typeof ensureEncryptionKey === 'object'\n ? ensureEncryptionKey\n : { generateIfMissing: true };\n encryption = await client.encryption.ensureAgentKey({\n uaid,\n ...ensureOptions,\n });\n }\n return { client, encryption };\n }\n readonly baseUrl: string;\n readonly fetchImpl: typeof fetch;\n readonly defaultHeaders: Record<string, string>;\n readonly registrationAutoTopUp?: AutoTopUpOptions;\n readonly historyAutoTopUp?: HistoryAutoTopUpOptions;\n readonly encryptionOptions?: ClientEncryptionOptions;\n encryptionBootstrapPromise: Promise<void> | null = null;\n constructor(options: RegistryBrokerClientOptions = {}) {\n const {\n baseUrl = DEFAULT_BASE_URL,\n fetchImplementation,\n defaultHeaders,\n apiKey,\n ledgerApiKey,\n registrationAutoTopUp,\n historyAutoTopUp,\n encryption,\n } = options;\n this.baseUrl = normaliseBaseUrl(baseUrl);\n this.fetchImpl = fetchImplementation ?? fetch;\n this.defaultHeaders = {\n ...(defaultHeaders ?? {}),\n };\n Object.entries(this.defaultHeaders).forEach(([key, value]) => {\n const headerName = normaliseHeaderName(key);\n if (headerName !== key) {\n delete this.defaultHeaders[key];\n this.defaultHeaders[headerName] = value;\n }\n });\n if (apiKey) {\n this.defaultHeaders['x-api-key'] = apiKey;\n }\n if (ledgerApiKey) {\n this.defaultHeaders['x-ledger-api-key'] = ledgerApiKey;\n }\n this.registrationAutoTopUp = registrationAutoTopUp;\n this.historyAutoTopUp = historyAutoTopUp;\n this.encryptionOptions = encryption;\n\n if (this.encryptionOptions) {\n this.encryptionBootstrapPromise = this.initializeEncryptionBootstrap(\n this.encryptionOptions,\n );\n }\n }\n\n setApiKey(apiKey?: string): void {\n this.setDefaultHeader('x-api-key', apiKey);\n }\n\n setLedgerApiKey(apiKey?: string): void {\n this.setDefaultHeader('x-ledger-api-key', apiKey);\n }\n\n setDefaultHeader(name: string, value?: string | null): void {\n if (!name || name.trim().length === 0) {\n return;\n }\n const headerName = normaliseHeaderName(name);\n if (!value || value.trim().length === 0) {\n delete this.defaultHeaders[headerName];\n return;\n }\n this.defaultHeaders[headerName] = value.trim();\n }\n\n getDefaultHeaders(): Record<string, string> {\n return { ...this.defaultHeaders };\n }\n\n async encryptionReady(): Promise<void> {\n if (!this.encryptionBootstrapPromise) {\n return;\n }\n await this.encryptionBootstrapPromise;\n }\n\n buildUrl(path: string): string {\n const normalisedPath = path.startsWith('/') ? path : `/${path}`;\n return `${this.baseUrl}${normalisedPath}`;\n }\n\n async request(path: string, config: RequestConfig): Promise<Response> {\n const headers = new Headers();\n Object.entries(this.defaultHeaders).forEach(([key, value]) => {\n headers.set(key, value);\n });\n if (config.headers) {\n Object.entries(config.headers).forEach(([key, value]) => {\n headers.set(key, value);\n });\n }\n if (!headers.has('accept')) {\n headers.set('accept', 'application/json');\n }\n if (!headers.has('user-agent') && !isBrowserRuntime()) {\n headers.set('user-agent', DEFAULT_USER_AGENT);\n }\n\n const init: RequestInit = {\n method: config.method ?? 'GET',\n headers,\n };\n\n if (config.body !== undefined) {\n init.body = JSON.stringify(config.body);\n if (!headers.has('content-type')) {\n headers.set('content-type', 'application/json');\n }\n }\n\n const response = await this.fetchImpl(this.buildUrl(path), init);\n if (response.ok) {\n return response;\n }\n const errorBody = await this.extractErrorBody(response);\n throw new RegistryBrokerError('Registry broker request failed', {\n status: response.status,\n statusText: response.statusText,\n body: errorBody,\n });\n }\n\n async requestJson<T extends JsonValue = JsonValue>(\n path: string,\n config: RequestConfig,\n ): Promise<T> {\n const response = await this.request(path, config);\n const contentType = response.headers?.get('content-type') ?? '';\n if (!JSON_CONTENT_TYPE.test(contentType)) {\n const body = await response.text();\n throw new RegistryBrokerParseError(\n 'Expected JSON response from registry broker',\n body,\n );\n }\n return (await response.json()) as T;\n }\n\n async getAgentFeedback(\n uaid: string,\n options: AgentFeedbackQuery = {},\n ): Promise<AgentFeedbackResponse> {\n const normalized = uaid.trim();\n if (!normalized) {\n throw new Error('uaid is required');\n }\n const query = options.includeRevoked === true ? '?includeRevoked=true' : '';\n const raw = await this.requestJson<JsonValue>(\n `/agents/${encodeURIComponent(normalized)}/feedback${query}`,\n { method: 'GET' },\n );\n return this.parseWithSchema(\n raw,\n agentFeedbackResponseSchema,\n 'agent feedback response',\n );\n }\n\n async listAgentFeedbackIndex(\n options: { page?: number; limit?: number; registries?: string[] } = {},\n ): Promise<AgentFeedbackIndexResponse> {\n const params = new URLSearchParams();\n if (typeof options.page === 'number' && Number.isFinite(options.page)) {\n params.set('page', String(Math.trunc(options.page)));\n }\n if (typeof options.limit === 'number' && Number.isFinite(options.limit)) {\n params.set('limit', String(Math.trunc(options.limit)));\n }\n if (options.registries?.length) {\n params.set('registry', options.registries.join(','));\n }\n const suffix = params.size > 0 ? `?${params.toString()}` : '';\n\n const raw = await this.requestJson<JsonValue>(`/agents/feedback${suffix}`, {\n method: 'GET',\n });\n return this.parseWithSchema(\n raw,\n agentFeedbackIndexResponseSchema,\n 'agent feedback index response',\n );\n }\n\n async listAgentFeedbackEntriesIndex(\n options: { page?: number; limit?: number; registries?: string[] } = {},\n ): Promise<AgentFeedbackEntriesIndexResponse> {\n const params = new URLSearchParams();\n if (typeof options.page === 'number' && Number.isFinite(options.page)) {\n params.set('page', String(Math.trunc(options.page)));\n }\n if (typeof options.limit === 'number' && Number.isFinite(options.limit)) {\n params.set('limit', String(Math.trunc(options.limit)));\n }\n if (options.registries?.length) {\n params.set('registry', options.registries.join(','));\n }\n const suffix = params.size > 0 ? `?${params.toString()}` : '';\n\n const raw = await this.requestJson<JsonValue>(\n `/agents/feedback/entries${suffix}`,\n { method: 'GET' },\n );\n return this.parseWithSchema(\n raw,\n agentFeedbackEntriesIndexResponseSchema,\n 'agent feedback entries index response',\n );\n }\n\n async checkAgentFeedbackEligibility(\n uaid: string,\n payload: AgentFeedbackEligibilityRequest,\n ): Promise<AgentFeedbackEligibilityResponse> {\n const normalized = uaid.trim();\n if (!normalized) {\n throw new Error('uaid is required');\n }\n const raw = await this.requestJson<JsonValue>(\n `/agents/${encodeURIComponent(normalized)}/feedback/eligibility`,\n {\n method: 'POST',\n body: payload,\n headers: { 'content-type': 'application/json' },\n },\n );\n return this.parseWithSchema(\n raw,\n agentFeedbackEligibilityResponseSchema,\n 'agent feedback eligibility response',\n );\n }\n\n async submitAgentFeedback(\n uaid: string,\n payload: AgentFeedbackSubmissionRequest,\n ): Promise<AgentFeedbackSubmissionResponse> {\n const normalized = uaid.trim();\n if (!normalized) {\n throw new Error('uaid is required');\n }\n const raw = await this.requestJson<JsonValue>(\n `/agents/${encodeURIComponent(normalized)}/feedback`,\n {\n method: 'POST',\n body: payload,\n headers: { 'content-type': 'application/json' },\n },\n );\n return this.parseWithSchema(\n raw,\n agentFeedbackSubmissionResponseSchema,\n 'agent feedback submission response',\n );\n }\n\n private async extractErrorBody(response: Response): Promise<JsonValue> {\n const contentType = response.headers?.get('content-type') ?? '';\n if (JSON_CONTENT_TYPE.test(contentType)) {\n try {\n return (await response.json()) as JsonValue;\n } catch (error) {\n return { parseError: String(error) };\n }\n }\n try {\n return await response.text();\n } catch (error) {\n return { parseError: String(error) };\n }\n }\n\n parseWithSchema<T>(\n value: JsonValue,\n schema: z.ZodSchema<T>,\n context: string,\n ): T {\n try {\n return schema.parse(value);\n } catch (error) {\n throw new RegistryBrokerParseError(\n `Failed to parse ${context}`,\n error instanceof ZodError || error instanceof Error\n ? error\n : String(error),\n value,\n );\n }\n }\n\n async delay(ms: number, signal?: AbortSignal): Promise<void> {\n if (ms <= 0) {\n if (signal?.aborted) {\n throw createAbortError();\n }\n return;\n }\n\n await new Promise<void>((resolve, reject) => {\n const timer = setTimeout(() => {\n if (signal) {\n signal.removeEventListener('abort', onAbort);\n }\n resolve();\n }, ms);\n\n const onAbort = (): void => {\n clearTimeout(timer);\n signal?.removeEventListener('abort', onAbort);\n reject(createAbortError());\n };\n\n if (signal) {\n if (signal.aborted) {\n clearTimeout(timer);\n reject(createAbortError());\n return;\n }\n signal.addEventListener('abort', onAbort, { once: true });\n }\n });\n }\n\n assertNodeRuntime(feature: string): void {\n if (typeof process === 'undefined' || !process.versions?.node) {\n throw new Error(`${feature} is only available in Node.js environments`);\n }\n }\n\n createEphemeralKeyPair(): EphemeralKeyPair {\n this.assertNodeRuntime('generateEphemeralKeyPair');\n const privateKeyBytes = randomBytes(32);\n const publicKey = secp256k1.getPublicKey(privateKeyBytes, true);\n return {\n privateKey: Buffer.from(privateKeyBytes).toString('hex'),\n publicKey: Buffer.from(publicKey).toString('hex'),\n };\n }\n\n deriveSharedSecret(options: DeriveSharedSecretOptions): Buffer {\n this.assertNodeRuntime('deriveSharedSecret');\n const privateKey = this.hexToBuffer(options.privateKey);\n const peerPublicKey = this.hexToBuffer(options.peerPublicKey);\n const shared = secp256k1.getSharedSecret(privateKey, peerPublicKey, true);\n return createHash('sha256').update(Buffer.from(shared)).digest();\n }\n\n buildCipherEnvelope(options: EncryptCipherEnvelopeOptions) {\n this.assertNodeRuntime('encryptCipherEnvelope');\n const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);\n const iv = randomBytes(12);\n const cipher = createCipheriv('aes-256-gcm', sharedSecret, iv);\n const aadSource = options.associatedData ?? options.sessionId;\n const associatedDataEncoded = aadSource\n ? Buffer.from(aadSource, 'utf8').toString('base64')\n : undefined;\n if (aadSource) {\n cipher.setAAD(Buffer.from(aadSource, 'utf8'));\n }\n const ciphertext = Buffer.concat([\n cipher.update(Buffer.from(options.plaintext, 'utf8')),\n cipher.final(),\n ]);\n const tag = cipher.getAuthTag();\n const payload = Buffer.concat([ciphertext, tag]);\n\n return {\n algorithm: 'aes-256-gcm',\n ciphertext: payload.toString('base64'),\n nonce: iv.toString('base64'),\n associatedData: associatedDataEncoded,\n keyLocator: {\n sessionId: options.sessionId,\n revision: options.revision ?? 1,\n },\n recipients: options.recipients.map(recipient => ({\n ...recipient,\n encryptedShare: '',\n })),\n };\n }\n\n openCipherEnvelope(options: DecryptCipherEnvelopeOptions): string {\n this.assertNodeRuntime('decryptCipherEnvelope');\n const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);\n const payload = Buffer.from(options.envelope.ciphertext, 'base64');\n const nonce = Buffer.from(options.envelope.nonce, 'base64');\n const ciphertext = payload.slice(0, payload.length - 16);\n const tag = payload.slice(payload.length - 16);\n const decipher = createDecipheriv('aes-256-gcm', sharedSecret, nonce);\n if (options.envelope.associatedData) {\n decipher.setAAD(Buffer.from(options.envelope.associatedData, 'base64'));\n }\n decipher.setAuthTag(tag);\n const plaintext = Buffer.concat([\n decipher.update(ciphertext),\n decipher.final(),\n ]);\n return plaintext.toString(options.encoding ?? 'utf8');\n }\n\n normalizeSharedSecret(input: SharedSecretInput): Buffer {\n if (Buffer.isBuffer(input)) {\n return Buffer.from(input);\n }\n if (input instanceof Uint8Array) {\n return Buffer.from(input);\n }\n if (typeof input === 'string') {\n return this.bufferFromString(input);\n }\n throw new Error('Unsupported shared secret input');\n }\n\n bufferFromString(value: string): Buffer {\n const trimmed = value.trim();\n if (!trimmed) {\n throw new Error('sharedSecret string cannot be empty');\n }\n const normalized = trimmed.startsWith('0x') ? trimmed.slice(2) : trimmed;\n if (/^[0-9a-fA-F]+$/.test(normalized) && normalized.length % 2 === 0) {\n return Buffer.from(normalized, 'hex');\n }\n return Buffer.from(trimmed, 'base64');\n }\n\n hexToBuffer(value: string): Uint8Array {\n const normalized = value.startsWith('0x') ? value.slice(2) : value;\n if (!/^[0-9a-fA-F]+$/.test(normalized) || normalized.length % 2 !== 0) {\n throw new Error('Expected hex-encoded value');\n }\n return Buffer.from(normalized, 'hex');\n }\n\n extractInsufficientCreditsDetails(error: unknown): {\n shortfallCredits: number;\n } | null {\n if (!(error instanceof RegistryBrokerError) || error.status !== 402) {\n return null;\n }\n\n const body = error.body;\n if (!body || typeof body !== 'object' || Array.isArray(body)) {\n return null;\n }\n\n const maybeShortfall = (body as JsonObject)['shortfallCredits'];\n if (typeof maybeShortfall !== 'number' || maybeShortfall <= 0) {\n return null;\n }\n\n return { shortfallCredits: maybeShortfall };\n }\n\n private extractErrorMessage(body: JsonValue): string | undefined {\n if (typeof body === 'string') {\n return body;\n }\n if (isJsonObject(body) && typeof body.error === 'string') {\n return body.error;\n }\n if (isJsonObject(body) && typeof body.message === 'string') {\n return body.message;\n }\n return undefined;\n }\n\n shouldAutoTopUpHistory(\n payload: CreateSessionRequestPayload,\n error: Error | null,\n ): boolean {\n if (!this.historyAutoTopUp || payload.historyTtlSeconds === undefined) {\n return false;\n }\n if (!(error instanceof RegistryBrokerError)) {\n return false;\n }\n if (error.status !== 402) {\n return false;\n }\n const message = this.extractErrorMessage(error.body);\n if (!message) {\n return true;\n }\n const normalised = message.toLowerCase();\n return (\n normalised.includes('history') || normalised.includes('chat history')\n );\n }\n\n async executeHistoryAutoTopUp(reason: string): Promise<void> {\n if (!this.historyAutoTopUp) {\n return;\n }\n const hbarAmount =\n this.historyAutoTopUp.hbarAmount && this.historyAutoTopUp.hbarAmount > 0\n ? this.historyAutoTopUp.hbarAmount\n : DEFAULT_HISTORY_TOP_UP_HBAR;\n await this.purchaseCreditsWithHbar({\n accountId: this.historyAutoTopUp.accountId,\n privateKey: this.historyAutoTopUp.privateKey,\n hbarAmount,\n memo:\n this.historyAutoTopUp.memo ??\n 'registry-broker-client:chat-history-topup',\n metadata: {\n purpose: 'chat-history',\n reason,\n },\n });\n }\n\n initializeEncryptionBootstrap(\n options: ClientEncryptionOptions,\n ): Promise<void> {\n return this.bootstrapEncryptionOptions(options).then((): void => undefined);\n }\n\n bootstrapEncryptionOptions(\n _options?: ClientEncryptionOptions,\n ): Promise<{ publicKey: string; privateKey?: string } | null> {\n return Promise.resolve(null);\n }\n}\n\nexport const isPendingRegisterAgentResponse = (\n response: RegisterAgentResponse,\n): response is RegisterAgentPendingResponse => response.status === 'pending';\n\nexport const isPartialRegisterAgentResponse = (\n response: RegisterAgentResponse,\n): response is RegisterAgentPartialResponse =>\n response.status === 'partial' && response.success === false;\n\nexport const isSuccessRegisterAgentResponse = (\n response: RegisterAgentResponse,\n): response is RegisterAgentSuccessResponse =>\n response.success === true && response.status !== 'pending';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"standards-sdk.es135.js","sources":["../../src/content-store/ContentStoreService.ts"],"sourcesContent":["/**\n * Content Store Service\n *\n * Provides utility functions for content storage and reference handling.\n */\n\nimport type { ContentStoreInterface } from './types';\nimport { Logger } from '../utils/logger';\n\n/**\n * Maximum content size before using references (50KB)\n */\nexport const REFERENCE_THRESHOLD = 50 * 1024;\n\n/**\n * Content store service for managing large content\n */\nexport class ContentStoreServiceImpl {\n private static _instance: ContentStoreServiceImpl;\n private contentStore: ContentStoreInterface | null = null;\n private logger = Logger.getInstance({ module: 'ContentStoreService' });\n\n static getInstance(): ContentStoreServiceImpl {\n if (!ContentStoreServiceImpl._instance) {\n ContentStoreServiceImpl._instance = new ContentStoreServiceImpl();\n }\n return ContentStoreServiceImpl._instance;\n }\n\n /**\n * Set the content store instance\n */\n async setInstance(store: ContentStoreInterface): Promise<void> {\n if (this.contentStore) {\n this.logger.warn('Content store already set, replacing');\n }\n this.contentStore = store;\n this.logger.info('Content store instance set');\n }\n\n /**\n * Get the content store instance\n */\n getInstance(): ContentStoreInterface | null {\n return this.contentStore;\n }\n\n /**\n * Clear the content store instance\n */\n dispose(): void {\n this.contentStore = null;\n this.logger.info('Content store disposed');\n }\n\n /**\n * Check if content store is available\n */\n isAvailable(): boolean {\n return this.contentStore !== null;\n }\n}\n\n/**\n * Extract reference ID from input string\n */\nexport function extractReferenceId(input: string): string | null {\n const trimmed = input.trim();\n\n const exactMatch = trimmed.match(/^content-ref:([a-f0-9]+)$/);\n if (exactMatch) {\n return exactMatch[1];\n }\n\n const embeddedMatch = trimmed.match(/content-ref:([a-f0-9]+)/);\n if (embeddedMatch) {\n return embeddedMatch[1];\n }\n\n return null;\n}\n\n/**\n * Check if content should use reference based on size\n */\nexport function shouldUseReference(content: string | Buffer): boolean {\n const size =\n typeof content === 'string'\n ? Buffer.byteLength(content, 'utf8')\n : content.length;\n\n return size > REFERENCE_THRESHOLD;\n}\n\nexport const ContentStoreService = ContentStoreServiceImpl.getInstance();\n"],"names":[],"mappings":";AAYO,MAAM,sBAAsB,KAAK;AAKjC,MAAM,wBAAwB;AAAA,EAA9B,cAAA;AAEL,SAAQ,eAA6C;AACrD,SAAQ,SAAS,OAAO,YAAY,EAAE,QAAQ,uBAAuB;AAAA,EAAA;AAAA,EAErE,OAAO,cAAuC;AAC5C,QAAI,CAAC,wBAAwB,WAAW;AACtC,8BAAwB,YAAY,IAAI,wBAAA;AAAA,IAC1C;AACA,WAAO,wBAAwB;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,OAA6C;AAC7D,QAAI,KAAK,cAAc;AACrB,WAAK,OAAO,KAAK,sCAAsC;AAAA,IACzD;AACA,SAAK,eAAe;AACpB,SAAK,OAAO,KAAK,4BAA4B;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA,EAKA,cAA4C;AAC1C,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,UAAgB;AACd,SAAK,eAAe;AACpB,SAAK,OAAO,KAAK,wBAAwB;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA,EAKA,cAAuB;AACrB,WAAO,KAAK,iBAAiB;AAAA,EAC/B;AACF;AAKO,SAAS,mBAAmB,OAA8B;AAC/D,QAAM,UAAU,MAAM,KAAA;AAEtB,QAAM,aAAa,QAAQ,MAAM,2BAA2B;AAC5D,MAAI,YAAY;AACd,WAAO,WAAW,CAAC;AAAA,EACrB;AAEA,QAAM,gBAAgB,QAAQ,MAAM,yBAAyB;AAC7D,MAAI,eAAe;AACjB,WAAO,cAAc,CAAC;AAAA,EACxB;AAEA,SAAO;AACT;AAKO,SAAS,mBAAmB,SAAmC;AACpE,QAAM,OACJ,OAAO,YAAY,WACf,OAAO,WAAW,SAAS,MAAM,IACjC,QAAQ;AAEd,SAAO,OAAO;AAChB;AAEO,MAAM,sBAAsB,wBAAwB,YAAA;"}
@@ -1,20 +1,33 @@
1
- class RegistryBrokerError extends Error {
2
- constructor(message, details) {
3
- super(message);
4
- this.status = details.status;
5
- this.statusText = details.statusText;
6
- this.body = details.body;
7
- }
8
- }
9
- class RegistryBrokerParseError extends Error {
10
- constructor(message, cause, rawValue) {
11
- super(message);
12
- this.cause = cause;
13
- this.rawValue = rawValue;
14
- }
15
- }
1
+ import { HCS10BaseClient, HCS10Cache, Hcs10MemoType } from "./standards-sdk.es16.js";
2
+ import { AccountCreationError, ConnectionConfirmationError, PayloadSizeError, TopicCreationError } from "./standards-sdk.es17.js";
3
+ import { HCS10Client } from "./standards-sdk.es18.js";
4
+ import { BrowserHCSClient } from "./standards-sdk.es19.js";
5
+ import { Registration } from "./standards-sdk.es20.js";
6
+ import { ConnectionsManager } from "./standards-sdk.es21.js";
7
+ import { buildHcs10ConfirmConnectionTx, buildHcs10CreateConnectionTopicTx, buildHcs10CreateInboundTopicTx, buildHcs10CreateOutboundTopicTx, buildHcs10CreateRegistryTopicTx, buildHcs10OutboundConnectionCreatedRecordTx, buildHcs10OutboundConnectionRequestRecordTx, buildHcs10RegistryDeleteTx, buildHcs10RegistryMigrateTx, buildHcs10RegistryRegisterTx, buildHcs10SendMessageTx, buildHcs10SubmitConnectionRequestTx } from "./standards-sdk.es22.js";
16
8
  export {
17
- RegistryBrokerError,
18
- RegistryBrokerParseError
9
+ AccountCreationError,
10
+ BrowserHCSClient,
11
+ ConnectionConfirmationError,
12
+ ConnectionsManager,
13
+ HCS10BaseClient,
14
+ HCS10Cache,
15
+ HCS10Client,
16
+ Hcs10MemoType,
17
+ PayloadSizeError,
18
+ Registration,
19
+ TopicCreationError,
20
+ buildHcs10ConfirmConnectionTx,
21
+ buildHcs10CreateConnectionTopicTx,
22
+ buildHcs10CreateInboundTopicTx,
23
+ buildHcs10CreateOutboundTopicTx,
24
+ buildHcs10CreateRegistryTopicTx,
25
+ buildHcs10OutboundConnectionCreatedRecordTx,
26
+ buildHcs10OutboundConnectionRequestRecordTx,
27
+ buildHcs10RegistryDeleteTx,
28
+ buildHcs10RegistryMigrateTx,
29
+ buildHcs10RegistryRegisterTx,
30
+ buildHcs10SendMessageTx,
31
+ buildHcs10SubmitConnectionRequestTx
19
32
  };
20
33
  //# sourceMappingURL=standards-sdk.es136.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es136.js","sources":["../../src/services/registry-broker/client/errors.ts"],"sourcesContent":["import type { JsonValue } from '../types';\nimport { ZodError } from 'zod';\n\nexport interface ErrorDetails {\n status: number;\n statusText: string;\n body: JsonValue;\n}\n\nexport class RegistryBrokerError extends Error {\n readonly status: number;\n readonly statusText: string;\n readonly body: JsonValue;\n\n constructor(message: string, details: ErrorDetails) {\n super(message);\n this.status = details.status;\n this.statusText = details.statusText;\n this.body = details.body;\n }\n}\n\nexport class RegistryBrokerParseError extends Error {\n readonly cause: ZodError | Error | string;\n readonly rawValue?: JsonValue;\n\n constructor(\n message: string,\n cause: ZodError | Error | string,\n rawValue?: JsonValue,\n ) {\n super(message);\n this.cause = cause;\n this.rawValue = rawValue;\n }\n}\n"],"names":[],"mappings":"AASO,MAAM,4BAA4B,MAAM;AAAA,EAK7C,YAAY,SAAiB,SAAuB;AAClD,UAAM,OAAO;AACb,SAAK,SAAS,QAAQ;AACtB,SAAK,aAAa,QAAQ;AAC1B,SAAK,OAAO,QAAQ;AAAA,EACtB;AACF;AAEO,MAAM,iCAAiC,MAAM;AAAA,EAIlD,YACE,SACA,OACA,UACA;AACA,UAAM,OAAO;AACb,SAAK,QAAQ;AACb,SAAK,WAAW;AAAA,EAClB;AACF;"}
1
+ {"version":3,"file":"standards-sdk.es136.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}