@hashgraphonline/standards-sdk 0.0.67 → 0.0.69

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 (181) hide show
  1. package/dist/es/hcs-10/base-client.d.ts +20 -5
  2. package/dist/es/hcs-10/base-client.d.ts.map +1 -1
  3. package/dist/es/hcs-10/browser.d.ts.map +1 -1
  4. package/dist/es/hcs-10/sdk.d.ts +12 -2
  5. package/dist/es/hcs-10/sdk.d.ts.map +1 -1
  6. package/dist/es/standards-sdk.es102.js +1 -1
  7. package/dist/es/standards-sdk.es104.js +1 -1
  8. package/dist/es/standards-sdk.es105.js +6 -6
  9. package/dist/es/standards-sdk.es106.js +3 -3
  10. package/dist/es/standards-sdk.es113.js +1 -1
  11. package/dist/es/standards-sdk.es114.js +2 -2
  12. package/dist/es/standards-sdk.es12.js +2 -2
  13. package/dist/es/standards-sdk.es14.js +1 -1
  14. package/dist/es/standards-sdk.es17.js +1 -1
  15. package/dist/es/standards-sdk.es18.js +2 -2
  16. package/dist/es/standards-sdk.es20.js +10 -10
  17. package/dist/es/standards-sdk.es22.js +36 -3
  18. package/dist/es/standards-sdk.es22.js.map +1 -1
  19. package/dist/es/standards-sdk.es23.js +48 -4167
  20. package/dist/es/standards-sdk.es23.js.map +1 -1
  21. package/dist/es/standards-sdk.es24.js +6627 -36
  22. package/dist/es/standards-sdk.es24.js.map +1 -1
  23. package/dist/es/standards-sdk.es25.js +3 -48
  24. package/dist/es/standards-sdk.es25.js.map +1 -1
  25. package/dist/es/standards-sdk.es26.js +2 -6627
  26. package/dist/es/standards-sdk.es26.js.map +1 -1
  27. package/dist/es/standards-sdk.es27.js +5 -2
  28. package/dist/es/standards-sdk.es27.js.map +1 -1
  29. package/dist/es/standards-sdk.es28.js +4167 -5
  30. package/dist/es/standards-sdk.es28.js.map +1 -1
  31. package/dist/es/standards-sdk.es29.js +419 -3
  32. package/dist/es/standards-sdk.es29.js.map +1 -1
  33. package/dist/es/standards-sdk.es30.js +1 -163
  34. package/dist/es/standards-sdk.es30.js.map +1 -1
  35. package/dist/es/standards-sdk.es31.js +112 -93
  36. package/dist/es/standards-sdk.es31.js.map +1 -1
  37. package/dist/es/standards-sdk.es32.js +3 -2
  38. package/dist/es/standards-sdk.es32.js.map +1 -1
  39. package/dist/es/standards-sdk.es33.js +163 -15
  40. package/dist/es/standards-sdk.es33.js.map +1 -1
  41. package/dist/es/standards-sdk.es34.js +2 -409
  42. package/dist/es/standards-sdk.es34.js.map +1 -1
  43. package/dist/es/standards-sdk.es35.js +189 -413
  44. package/dist/es/standards-sdk.es35.js.map +1 -1
  45. package/dist/es/standards-sdk.es36.js +438 -2
  46. package/dist/es/standards-sdk.es36.js.map +1 -1
  47. package/dist/es/standards-sdk.es37.js +20 -115
  48. package/dist/es/standards-sdk.es37.js.map +1 -1
  49. package/dist/es/standards-sdk.es38.js +139 -2282
  50. package/dist/es/standards-sdk.es38.js.map +1 -1
  51. package/dist/es/standards-sdk.es39.js +17 -3
  52. package/dist/es/standards-sdk.es39.js.map +1 -1
  53. package/dist/es/standards-sdk.es40.js +29 -2
  54. package/dist/es/standards-sdk.es40.js.map +1 -1
  55. package/dist/es/standards-sdk.es41.js +25 -80
  56. package/dist/es/standards-sdk.es41.js.map +1 -1
  57. package/dist/es/standards-sdk.es42.js +20 -22
  58. package/dist/es/standards-sdk.es42.js.map +1 -1
  59. package/dist/es/standards-sdk.es43.js +38 -142
  60. package/dist/es/standards-sdk.es43.js.map +1 -1
  61. package/dist/es/standards-sdk.es44.js +13 -86
  62. package/dist/es/standards-sdk.es44.js.map +1 -1
  63. package/dist/es/standards-sdk.es45.js +55 -168
  64. package/dist/es/standards-sdk.es45.js.map +1 -1
  65. package/dist/es/standards-sdk.es46.js +1288 -5
  66. package/dist/es/standards-sdk.es46.js.map +1 -1
  67. package/dist/es/standards-sdk.es47.js +132 -127
  68. package/dist/es/standards-sdk.es47.js.map +1 -1
  69. package/dist/es/standards-sdk.es48.js +81 -185
  70. package/dist/es/standards-sdk.es48.js.map +1 -1
  71. package/dist/es/standards-sdk.es49.js +75 -429
  72. package/dist/es/standards-sdk.es49.js.map +1 -1
  73. package/dist/es/standards-sdk.es5.js +67 -18
  74. package/dist/es/standards-sdk.es5.js.map +1 -1
  75. package/dist/es/standards-sdk.es50.js +28 -21
  76. package/dist/es/standards-sdk.es50.js.map +1 -1
  77. package/dist/es/standards-sdk.es51.js +5 -138
  78. package/dist/es/standards-sdk.es51.js.map +1 -1
  79. package/dist/es/standards-sdk.es52.js +154 -13
  80. package/dist/es/standards-sdk.es52.js.map +1 -1
  81. package/dist/es/standards-sdk.es53.js +21 -27
  82. package/dist/es/standards-sdk.es53.js.map +1 -1
  83. package/dist/es/standards-sdk.es54.js +784 -20
  84. package/dist/es/standards-sdk.es54.js.map +1 -1
  85. package/dist/es/standards-sdk.es55.js +170 -17
  86. package/dist/es/standards-sdk.es55.js.map +1 -1
  87. package/dist/es/standards-sdk.es56.js +134 -35
  88. package/dist/es/standards-sdk.es56.js.map +1 -1
  89. package/dist/es/standards-sdk.es57.js +3 -17
  90. package/dist/es/standards-sdk.es57.js.map +1 -1
  91. package/dist/es/standards-sdk.es58.js +11 -51
  92. package/dist/es/standards-sdk.es58.js.map +1 -1
  93. package/dist/es/standards-sdk.es59.js +22 -1284
  94. package/dist/es/standards-sdk.es59.js.map +1 -1
  95. package/dist/es/standards-sdk.es60.js +23 -29
  96. package/dist/es/standards-sdk.es60.js.map +1 -1
  97. package/dist/es/standards-sdk.es61.js +37 -158
  98. package/dist/es/standards-sdk.es61.js.map +1 -1
  99. package/dist/es/standards-sdk.es62.js +346 -775
  100. package/dist/es/standards-sdk.es62.js.map +1 -1
  101. package/dist/es/standards-sdk.es63.js +5 -26
  102. package/dist/es/standards-sdk.es63.js.map +1 -1
  103. package/dist/es/standards-sdk.es64.js +177 -24
  104. package/dist/es/standards-sdk.es64.js.map +1 -1
  105. package/dist/es/standards-sdk.es65.js +79 -36
  106. package/dist/es/standards-sdk.es65.js.map +1 -1
  107. package/dist/es/standards-sdk.es66.js +112 -19
  108. package/dist/es/standards-sdk.es66.js.map +1 -1
  109. package/dist/es/standards-sdk.es67.js +42 -354
  110. package/dist/es/standards-sdk.es67.js.map +1 -1
  111. package/dist/es/standards-sdk.es68.js +9 -5
  112. package/dist/es/standards-sdk.es68.js.map +1 -1
  113. package/dist/es/standards-sdk.es69.js +82 -164
  114. package/dist/es/standards-sdk.es69.js.map +1 -1
  115. package/dist/es/standards-sdk.es7.js +52 -7
  116. package/dist/es/standards-sdk.es7.js.map +1 -1
  117. package/dist/es/standards-sdk.es70.js +3 -80
  118. package/dist/es/standards-sdk.es70.js.map +1 -1
  119. package/dist/es/standards-sdk.es71.js +2 -114
  120. package/dist/es/standards-sdk.es71.js.map +1 -1
  121. package/dist/es/standards-sdk.es72.js +104 -43
  122. package/dist/es/standards-sdk.es72.js.map +1 -1
  123. package/dist/es/standards-sdk.es73.js +72 -8
  124. package/dist/es/standards-sdk.es73.js.map +1 -1
  125. package/dist/es/standards-sdk.es74.js +5 -96
  126. package/dist/es/standards-sdk.es74.js.map +1 -1
  127. package/dist/es/standards-sdk.es75.js +4 -3
  128. package/dist/es/standards-sdk.es75.js.map +1 -1
  129. package/dist/es/standards-sdk.es76.js +221 -2
  130. package/dist/es/standards-sdk.es76.js.map +1 -1
  131. package/dist/es/standards-sdk.es77.js +53 -108
  132. package/dist/es/standards-sdk.es77.js.map +1 -1
  133. package/dist/es/standards-sdk.es78.js +68 -73
  134. package/dist/es/standards-sdk.es78.js.map +1 -1
  135. package/dist/es/standards-sdk.es79.js +100 -5
  136. package/dist/es/standards-sdk.es79.js.map +1 -1
  137. package/dist/es/standards-sdk.es8.js +17 -3
  138. package/dist/es/standards-sdk.es8.js.map +1 -1
  139. package/dist/es/standards-sdk.es80.js +2 -5
  140. package/dist/es/standards-sdk.es80.js.map +1 -1
  141. package/dist/es/standards-sdk.es81.js +15 -220
  142. package/dist/es/standards-sdk.es81.js.map +1 -1
  143. package/dist/es/standards-sdk.es82.js +403 -52
  144. package/dist/es/standards-sdk.es82.js.map +1 -1
  145. package/dist/es/standards-sdk.es83.js +32 -69
  146. package/dist/es/standards-sdk.es83.js.map +1 -1
  147. package/dist/es/standards-sdk.es84.js +57 -26
  148. package/dist/es/standards-sdk.es84.js.map +1 -1
  149. package/dist/es/standards-sdk.es85.js +45 -58
  150. package/dist/es/standards-sdk.es85.js.map +1 -1
  151. package/dist/es/standards-sdk.es86.js +8 -48
  152. package/dist/es/standards-sdk.es86.js.map +1 -1
  153. package/dist/es/standards-sdk.es87.js +63 -8
  154. package/dist/es/standards-sdk.es87.js.map +1 -1
  155. package/dist/es/standards-sdk.es88.js +5 -64
  156. package/dist/es/standards-sdk.es88.js.map +1 -1
  157. package/dist/es/standards-sdk.es89.js +15 -6
  158. package/dist/es/standards-sdk.es89.js.map +1 -1
  159. package/dist/es/standards-sdk.es9.js +1 -1
  160. package/dist/es/standards-sdk.es90.js +7 -15
  161. package/dist/es/standards-sdk.es90.js.map +1 -1
  162. package/dist/es/standards-sdk.es91.js +44 -6
  163. package/dist/es/standards-sdk.es91.js.map +1 -1
  164. package/dist/es/standards-sdk.es92.js +2 -45
  165. package/dist/es/standards-sdk.es92.js.map +1 -1
  166. package/dist/es/standards-sdk.es93.js +136 -2
  167. package/dist/es/standards-sdk.es93.js.map +1 -1
  168. package/dist/es/standards-sdk.es94.js +162 -126
  169. package/dist/es/standards-sdk.es94.js.map +1 -1
  170. package/dist/es/standards-sdk.es95.js +2281 -171
  171. package/dist/es/standards-sdk.es95.js.map +1 -1
  172. package/dist/es/standards-sdk.es98.js +1 -1
  173. package/dist/es/standards-sdk.es99.js +3 -3
  174. package/dist/umd/hcs-10/base-client.d.ts +20 -5
  175. package/dist/umd/hcs-10/base-client.d.ts.map +1 -1
  176. package/dist/umd/hcs-10/browser.d.ts.map +1 -1
  177. package/dist/umd/hcs-10/sdk.d.ts +12 -2
  178. package/dist/umd/hcs-10/sdk.d.ts.map +1 -1
  179. package/dist/umd/standards-sdk.umd.js +1 -1
  180. package/dist/umd/standards-sdk.umd.js.map +1 -1
  181. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es78.js","sources":["../../node_modules/axios/lib/core/AxiosError.js"],"sourcesContent":["'use strict';\n\nimport utils from '../utils.js';\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [config] The config.\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n *\n * @returns {Error} The created error.\n */\nfunction AxiosError(message, code, config, request, response) {\n Error.call(this);\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n } else {\n this.stack = (new Error()).stack;\n }\n\n this.message = message;\n this.name = 'AxiosError';\n code && (this.code = code);\n config && (this.config = config);\n request && (this.request = request);\n if (response) {\n this.response = response;\n this.status = response.status ? response.status : null;\n }\n}\n\nutils.inherits(AxiosError, Error, {\n toJSON: function toJSON() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: utils.toJSONObject(this.config),\n code: this.code,\n status: this.status\n };\n }\n});\n\nconst prototype = AxiosError.prototype;\nconst descriptors = {};\n\n[\n 'ERR_BAD_OPTION_VALUE',\n 'ERR_BAD_OPTION',\n 'ECONNABORTED',\n 'ETIMEDOUT',\n 'ERR_NETWORK',\n 'ERR_FR_TOO_MANY_REDIRECTS',\n 'ERR_DEPRECATED',\n 'ERR_BAD_RESPONSE',\n 'ERR_BAD_REQUEST',\n 'ERR_CANCELED',\n 'ERR_NOT_SUPPORT',\n 'ERR_INVALID_URL'\n// eslint-disable-next-line func-names\n].forEach(code => {\n descriptors[code] = {value: code};\n});\n\nObject.defineProperties(AxiosError, descriptors);\nObject.defineProperty(prototype, 'isAxiosError', {value: true});\n\n// eslint-disable-next-line func-names\nAxiosError.from = (error, code, config, request, response, customProps) => {\n const axiosError = Object.create(prototype);\n\n utils.toFlatObject(error, axiosError, function filter(obj) {\n return obj !== Error.prototype;\n }, prop => {\n return prop !== 'isAxiosError';\n });\n\n AxiosError.call(axiosError, error.message, code, config, request, response);\n\n axiosError.cause = error;\n\n axiosError.name = error.name;\n\n customProps && Object.assign(axiosError, customProps);\n\n return axiosError;\n};\n\nexport default AxiosError;\n"],"names":[],"mappings":";AAeA,SAAS,WAAW,SAAS,MAAM,QAAQ,SAAS,UAAU;AAC5D,QAAM,KAAK,IAAI;AAEf,MAAI,MAAM,mBAAmB;AAC3B,UAAM,kBAAkB,MAAM,KAAK,WAAW;AAAA,EAClD,OAAS;AACL,SAAK,QAAS,IAAI,MAAO,EAAE;AAAA,EAC/B;AAEE,OAAK,UAAU;AACf,OAAK,OAAO;AACZ,WAAS,KAAK,OAAO;AACrB,aAAW,KAAK,SAAS;AACzB,cAAY,KAAK,UAAU;AAC3B,MAAI,UAAU;AACZ,SAAK,WAAW;AAChB,SAAK,SAAS,SAAS,SAAS,SAAS,SAAS;AAAA,EACtD;AACA;AAEA,MAAM,SAAS,YAAY,OAAO;AAAA,EAChC,QAAQ,SAAS,SAAS;AACxB,WAAO;AAAA;AAAA,MAEL,SAAS,KAAK;AAAA,MACd,MAAM,KAAK;AAAA;AAAA,MAEX,aAAa,KAAK;AAAA,MAClB,QAAQ,KAAK;AAAA;AAAA,MAEb,UAAU,KAAK;AAAA,MACf,YAAY,KAAK;AAAA,MACjB,cAAc,KAAK;AAAA,MACnB,OAAO,KAAK;AAAA;AAAA,MAEZ,QAAQ,MAAM,aAAa,KAAK,MAAM;AAAA,MACtC,MAAM,KAAK;AAAA,MACX,QAAQ,KAAK;AAAA,IACd;AAAA,EACL;AACA,CAAC;AAED,MAAM,YAAY,WAAW;AAC7B,MAAM,cAAc,CAAE;AAEtB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA;AAEF,EAAE,QAAQ,UAAQ;AAChB,cAAY,IAAI,IAAI,EAAC,OAAO,KAAI;AAClC,CAAC;AAED,OAAO,iBAAiB,YAAY,WAAW;AAC/C,OAAO,eAAe,WAAW,gBAAgB,EAAC,OAAO,KAAI,CAAC;AAG9D,WAAW,OAAO,CAAC,OAAO,MAAM,QAAQ,SAAS,UAAU,gBAAgB;AACzE,QAAM,aAAa,OAAO,OAAO,SAAS;AAE1C,QAAM,aAAa,OAAO,YAAY,SAAS,OAAO,KAAK;AACzD,WAAO,QAAQ,MAAM;AAAA,EACtB,GAAE,UAAQ;AACT,WAAO,SAAS;AAAA,EACpB,CAAG;AAED,aAAW,KAAK,YAAY,MAAM,SAAS,MAAM,QAAQ,SAAS,QAAQ;AAE1E,aAAW,QAAQ;AAEnB,aAAW,OAAO,MAAM;AAExB,iBAAe,OAAO,OAAO,YAAY,WAAW;AAEpD,SAAO;AACT;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es78.js","sources":["../../node_modules/axios/lib/helpers/HttpStatusCode.js"],"sourcesContent":["const HttpStatusCode = {\n Continue: 100,\n SwitchingProtocols: 101,\n Processing: 102,\n EarlyHints: 103,\n Ok: 200,\n Created: 201,\n Accepted: 202,\n NonAuthoritativeInformation: 203,\n NoContent: 204,\n ResetContent: 205,\n PartialContent: 206,\n MultiStatus: 207,\n AlreadyReported: 208,\n ImUsed: 226,\n MultipleChoices: 300,\n MovedPermanently: 301,\n Found: 302,\n SeeOther: 303,\n NotModified: 304,\n UseProxy: 305,\n Unused: 306,\n TemporaryRedirect: 307,\n PermanentRedirect: 308,\n BadRequest: 400,\n Unauthorized: 401,\n PaymentRequired: 402,\n Forbidden: 403,\n NotFound: 404,\n MethodNotAllowed: 405,\n NotAcceptable: 406,\n ProxyAuthenticationRequired: 407,\n RequestTimeout: 408,\n Conflict: 409,\n Gone: 410,\n LengthRequired: 411,\n PreconditionFailed: 412,\n PayloadTooLarge: 413,\n UriTooLong: 414,\n UnsupportedMediaType: 415,\n RangeNotSatisfiable: 416,\n ExpectationFailed: 417,\n ImATeapot: 418,\n MisdirectedRequest: 421,\n UnprocessableEntity: 422,\n Locked: 423,\n FailedDependency: 424,\n TooEarly: 425,\n UpgradeRequired: 426,\n PreconditionRequired: 428,\n TooManyRequests: 429,\n RequestHeaderFieldsTooLarge: 431,\n UnavailableForLegalReasons: 451,\n InternalServerError: 500,\n NotImplemented: 501,\n BadGateway: 502,\n ServiceUnavailable: 503,\n GatewayTimeout: 504,\n HttpVersionNotSupported: 505,\n VariantAlsoNegotiates: 506,\n InsufficientStorage: 507,\n LoopDetected: 508,\n NotExtended: 510,\n NetworkAuthenticationRequired: 511,\n};\n\nObject.entries(HttpStatusCode).forEach(([key, value]) => {\n HttpStatusCode[value] = key;\n});\n\nexport default HttpStatusCode;\n"],"names":[],"mappings":"AAAK,MAAC,iBAAiB;AAAA,EACrB,UAAU;AAAA,EACV,oBAAoB;AAAA,EACpB,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,IAAI;AAAA,EACJ,SAAS;AAAA,EACT,UAAU;AAAA,EACV,6BAA6B;AAAA,EAC7B,WAAW;AAAA,EACX,cAAc;AAAA,EACd,gBAAgB;AAAA,EAChB,aAAa;AAAA,EACb,iBAAiB;AAAA,EACjB,QAAQ;AAAA,EACR,iBAAiB;AAAA,EACjB,kBAAkB;AAAA,EAClB,OAAO;AAAA,EACP,UAAU;AAAA,EACV,aAAa;AAAA,EACb,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,mBAAmB;AAAA,EACnB,mBAAmB;AAAA,EACnB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,iBAAiB;AAAA,EACjB,WAAW;AAAA,EACX,UAAU;AAAA,EACV,kBAAkB;AAAA,EAClB,eAAe;AAAA,EACf,6BAA6B;AAAA,EAC7B,gBAAgB;AAAA,EAChB,UAAU;AAAA,EACV,MAAM;AAAA,EACN,gBAAgB;AAAA,EAChB,oBAAoB;AAAA,EACpB,iBAAiB;AAAA,EACjB,YAAY;AAAA,EACZ,sBAAsB;AAAA,EACtB,qBAAqB;AAAA,EACrB,mBAAmB;AAAA,EACnB,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,qBAAqB;AAAA,EACrB,QAAQ;AAAA,EACR,kBAAkB;AAAA,EAClB,UAAU;AAAA,EACV,iBAAiB;AAAA,EACjB,sBAAsB;AAAA,EACtB,iBAAiB;AAAA,EACjB,6BAA6B;AAAA,EAC7B,4BAA4B;AAAA,EAC5B,qBAAqB;AAAA,EACrB,gBAAgB;AAAA,EAChB,YAAY;AAAA,EACZ,oBAAoB;AAAA,EACpB,gBAAgB;AAAA,EAChB,yBAAyB;AAAA,EACzB,uBAAuB;AAAA,EACvB,qBAAqB;AAAA,EACrB,cAAc;AAAA,EACd,aAAa;AAAA,EACb,+BAA+B;AACjC;AAEA,OAAO,QAAQ,cAAc,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AACvD,iBAAe,KAAK,IAAI;AAC1B,CAAC;","x_google_ignoreList":[0]}
@@ -1,9 +1,104 @@
1
- function spread(callback) {
2
- return function wrap(arr) {
3
- return callback.apply(null, arr);
4
- };
1
+ import { __exports as mimeTypes } from "./standards-sdk.es80.js";
2
+ import { __require as requireMimeDb } from "./standards-sdk.es81.js";
3
+ import { __require as requirePathBrowserify } from "./standards-sdk.es82.js";
4
+ /*!
5
+ * mime-types
6
+ * Copyright(c) 2014 Jonathan Ong
7
+ * Copyright(c) 2015 Douglas Christopher Wilson
8
+ * MIT Licensed
9
+ */
10
+ var hasRequiredMimeTypes;
11
+ function requireMimeTypes() {
12
+ if (hasRequiredMimeTypes) return mimeTypes;
13
+ hasRequiredMimeTypes = 1;
14
+ (function(exports) {
15
+ var db = requireMimeDb();
16
+ var extname = requirePathBrowserify().extname;
17
+ var EXTRACT_TYPE_REGEXP = /^\s*([^;\s]*)(?:;|\s|$)/;
18
+ var TEXT_TYPE_REGEXP = /^text\//i;
19
+ exports.charset = charset;
20
+ exports.charsets = { lookup: charset };
21
+ exports.contentType = contentType;
22
+ exports.extension = extension;
23
+ exports.extensions = /* @__PURE__ */ Object.create(null);
24
+ exports.lookup = lookup;
25
+ exports.types = /* @__PURE__ */ Object.create(null);
26
+ populateMaps(exports.extensions, exports.types);
27
+ function charset(type) {
28
+ if (!type || typeof type !== "string") {
29
+ return false;
30
+ }
31
+ var match = EXTRACT_TYPE_REGEXP.exec(type);
32
+ var mime = match && db[match[1].toLowerCase()];
33
+ if (mime && mime.charset) {
34
+ return mime.charset;
35
+ }
36
+ if (match && TEXT_TYPE_REGEXP.test(match[1])) {
37
+ return "UTF-8";
38
+ }
39
+ return false;
40
+ }
41
+ function contentType(str) {
42
+ if (!str || typeof str !== "string") {
43
+ return false;
44
+ }
45
+ var mime = str.indexOf("/") === -1 ? exports.lookup(str) : str;
46
+ if (!mime) {
47
+ return false;
48
+ }
49
+ if (mime.indexOf("charset") === -1) {
50
+ var charset2 = exports.charset(mime);
51
+ if (charset2) mime += "; charset=" + charset2.toLowerCase();
52
+ }
53
+ return mime;
54
+ }
55
+ function extension(type) {
56
+ if (!type || typeof type !== "string") {
57
+ return false;
58
+ }
59
+ var match = EXTRACT_TYPE_REGEXP.exec(type);
60
+ var exts = match && exports.extensions[match[1].toLowerCase()];
61
+ if (!exts || !exts.length) {
62
+ return false;
63
+ }
64
+ return exts[0];
65
+ }
66
+ function lookup(path) {
67
+ if (!path || typeof path !== "string") {
68
+ return false;
69
+ }
70
+ var extension2 = extname("x." + path).toLowerCase().substr(1);
71
+ if (!extension2) {
72
+ return false;
73
+ }
74
+ return exports.types[extension2] || false;
75
+ }
76
+ function populateMaps(extensions, types) {
77
+ var preference = ["nginx", "apache", void 0, "iana"];
78
+ Object.keys(db).forEach(function forEachMimeType(type) {
79
+ var mime = db[type];
80
+ var exts = mime.extensions;
81
+ if (!exts || !exts.length) {
82
+ return;
83
+ }
84
+ extensions[type] = exts;
85
+ for (var i = 0; i < exts.length; i++) {
86
+ var extension2 = exts[i];
87
+ if (types[extension2]) {
88
+ var from = preference.indexOf(db[types[extension2]].source);
89
+ var to = preference.indexOf(mime.source);
90
+ if (types[extension2] !== "application/octet-stream" && (from > to || from === to && types[extension2].substr(0, 12) === "application/")) {
91
+ continue;
92
+ }
93
+ }
94
+ types[extension2] = type;
95
+ }
96
+ });
97
+ }
98
+ })(mimeTypes);
99
+ return mimeTypes;
5
100
  }
6
101
  export {
7
- spread as default
102
+ requireMimeTypes as __require
8
103
  };
9
104
  //# sourceMappingURL=standards-sdk.es79.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es79.js","sources":["../../node_modules/axios/lib/helpers/spread.js"],"sourcesContent":["'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n *\n * @returns {Function}\n */\nexport default function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n}\n"],"names":[],"mappings":"AAuBe,SAAS,OAAO,UAAU;AACvC,SAAO,SAAS,KAAK,KAAK;AACxB,WAAO,SAAS,MAAM,MAAM,GAAG;AAAA,EAChC;AACH;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es79.js","sources":["../../node_modules/mime-types/index.js"],"sourcesContent":["/*!\n * mime-types\n * Copyright(c) 2014 Jonathan Ong\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict'\n\n/**\n * Module dependencies.\n * @private\n */\n\nvar db = require('mime-db')\nvar extname = require('path').extname\n\n/**\n * Module variables.\n * @private\n */\n\nvar EXTRACT_TYPE_REGEXP = /^\\s*([^;\\s]*)(?:;|\\s|$)/\nvar TEXT_TYPE_REGEXP = /^text\\//i\n\n/**\n * Module exports.\n * @public\n */\n\nexports.charset = charset\nexports.charsets = { lookup: charset }\nexports.contentType = contentType\nexports.extension = extension\nexports.extensions = Object.create(null)\nexports.lookup = lookup\nexports.types = Object.create(null)\n\n// Populate the extensions/types maps\npopulateMaps(exports.extensions, exports.types)\n\n/**\n * Get the default charset for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction charset (type) {\n if (!type || typeof type !== 'string') {\n return false\n }\n\n // TODO: use media-typer\n var match = EXTRACT_TYPE_REGEXP.exec(type)\n var mime = match && db[match[1].toLowerCase()]\n\n if (mime && mime.charset) {\n return mime.charset\n }\n\n // default text/* to utf-8\n if (match && TEXT_TYPE_REGEXP.test(match[1])) {\n return 'UTF-8'\n }\n\n return false\n}\n\n/**\n * Create a full Content-Type header given a MIME type or extension.\n *\n * @param {string} str\n * @return {boolean|string}\n */\n\nfunction contentType (str) {\n // TODO: should this even be in this module?\n if (!str || typeof str !== 'string') {\n return false\n }\n\n var mime = str.indexOf('/') === -1\n ? exports.lookup(str)\n : str\n\n if (!mime) {\n return false\n }\n\n // TODO: use content-type or other module\n if (mime.indexOf('charset') === -1) {\n var charset = exports.charset(mime)\n if (charset) mime += '; charset=' + charset.toLowerCase()\n }\n\n return mime\n}\n\n/**\n * Get the default extension for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction extension (type) {\n if (!type || typeof type !== 'string') {\n return false\n }\n\n // TODO: use media-typer\n var match = EXTRACT_TYPE_REGEXP.exec(type)\n\n // get extensions\n var exts = match && exports.extensions[match[1].toLowerCase()]\n\n if (!exts || !exts.length) {\n return false\n }\n\n return exts[0]\n}\n\n/**\n * Lookup the MIME type for a file path/extension.\n *\n * @param {string} path\n * @return {boolean|string}\n */\n\nfunction lookup (path) {\n if (!path || typeof path !== 'string') {\n return false\n }\n\n // get the extension (\"ext\" or \".ext\" or full path)\n var extension = extname('x.' + path)\n .toLowerCase()\n .substr(1)\n\n if (!extension) {\n return false\n }\n\n return exports.types[extension] || false\n}\n\n/**\n * Populate the extensions and types maps.\n * @private\n */\n\nfunction populateMaps (extensions, types) {\n // source preference (least -> most)\n var preference = ['nginx', 'apache', undefined, 'iana']\n\n Object.keys(db).forEach(function forEachMimeType (type) {\n var mime = db[type]\n var exts = mime.extensions\n\n if (!exts || !exts.length) {\n return\n }\n\n // mime -> extensions\n extensions[type] = exts\n\n // extension -> mime\n for (var i = 0; i < exts.length; i++) {\n var extension = exts[i]\n\n if (types[extension]) {\n var from = preference.indexOf(db[types[extension]].source)\n var to = preference.indexOf(mime.source)\n\n if (types[extension] !== 'application/octet-stream' &&\n (from > to || (from === to && types[extension].substr(0, 12) === 'application/'))) {\n // skip the remapping\n continue\n }\n }\n\n // set the extension -> mime\n types[extension] = type\n }\n })\n}\n"],"names":["require$$0","require$$1","charset","extension"],"mappings":";;;;;;;;;;;;;;AAcA,QAAI,KAAKA,cAAA;AACT,QAAI,UAAUC,wBAAgB;AAO9B,QAAI,sBAAsB;AAC1B,QAAI,mBAAmB;AAOvB,YAAkB,UAAA;AAClB,YAAmB,WAAA,EAAE,QAAQ,QAAO;AACpC,YAAsB,cAAA;AACtB,YAAoB,YAAA;AACpB,YAAA,aAAqB,uBAAO,OAAO,IAAI;AACvC,YAAiB,SAAA;AACjB,YAAA,QAAgB,uBAAO,OAAO,IAAI;AAGlC,iBAAa,QAAQ,YAAY,QAAQ,KAAK;AAS9C,aAAS,QAAS,MAAM;AACtB,UAAI,CAAC,QAAQ,OAAO,SAAS,UAAU;AACrC,eAAO;AAAA,MACX;AAGE,UAAI,QAAQ,oBAAoB,KAAK,IAAI;AACzC,UAAI,OAAO,SAAS,GAAG,MAAM,CAAC,EAAE,YAAa,CAAA;AAE7C,UAAI,QAAQ,KAAK,SAAS;AACxB,eAAO,KAAK;AAAA,MAChB;AAGE,UAAI,SAAS,iBAAiB,KAAK,MAAM,CAAC,CAAC,GAAG;AAC5C,eAAO;AAAA,MACX;AAEE,aAAO;AAAA,IACT;AASA,aAAS,YAAa,KAAK;AAEzB,UAAI,CAAC,OAAO,OAAO,QAAQ,UAAU;AACnC,eAAO;AAAA,MACX;AAEE,UAAI,OAAO,IAAI,QAAQ,GAAG,MAAM,KAC5B,QAAQ,OAAO,GAAG,IAClB;AAEJ,UAAI,CAAC,MAAM;AACT,eAAO;AAAA,MACX;AAGE,UAAI,KAAK,QAAQ,SAAS,MAAM,IAAI;AAClC,YAAIC,WAAU,QAAQ,QAAQ,IAAI;AAClC,YAAIA,SAAS,SAAQ,eAAeA,SAAQ,YAAW;AAAA,MAC3D;AAEE,aAAO;AAAA,IACT;AASA,aAAS,UAAW,MAAM;AACxB,UAAI,CAAC,QAAQ,OAAO,SAAS,UAAU;AACrC,eAAO;AAAA,MACX;AAGE,UAAI,QAAQ,oBAAoB,KAAK,IAAI;AAGzC,UAAI,OAAO,SAAS,QAAQ,WAAW,MAAM,CAAC,EAAE,YAAa,CAAA;AAE7D,UAAI,CAAC,QAAQ,CAAC,KAAK,QAAQ;AACzB,eAAO;AAAA,MACX;AAEE,aAAO,KAAK,CAAC;AAAA,IACf;AASA,aAAS,OAAQ,MAAM;AACrB,UAAI,CAAC,QAAQ,OAAO,SAAS,UAAU;AACrC,eAAO;AAAA,MACX;AAGE,UAAIC,aAAY,QAAQ,OAAO,IAAI,EAChC,YAAW,EACX,OAAO,CAAC;AAEX,UAAI,CAACA,YAAW;AACd,eAAO;AAAA,MACX;AAEE,aAAO,QAAQ,MAAMA,UAAS,KAAK;AAAA,IACrC;AAOA,aAAS,aAAc,YAAY,OAAO;AAExC,UAAI,aAAa,CAAC,SAAS,UAAU,QAAW,MAAM;AAEtD,aAAO,KAAK,EAAE,EAAE,QAAQ,SAAS,gBAAiB,MAAM;AACtD,YAAI,OAAO,GAAG,IAAI;AAClB,YAAI,OAAO,KAAK;AAEhB,YAAI,CAAC,QAAQ,CAAC,KAAK,QAAQ;AACzB;AAAA,QACN;AAGI,mBAAW,IAAI,IAAI;AAGnB,iBAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AACpC,cAAIA,aAAY,KAAK,CAAC;AAEtB,cAAI,MAAMA,UAAS,GAAG;AACpB,gBAAI,OAAO,WAAW,QAAQ,GAAG,MAAMA,UAAS,CAAC,EAAE,MAAM;AACzD,gBAAI,KAAK,WAAW,QAAQ,KAAK,MAAM;AAEvC,gBAAI,MAAMA,UAAS,MAAM,+BACtB,OAAO,MAAO,SAAS,MAAM,MAAMA,UAAS,EAAE,OAAO,GAAG,EAAE,MAAM,iBAAkB;AAEnF;AAAA,YACV;AAAA,UACA;AAGM,gBAAMA,UAAS,IAAI;AAAA,QACzB;AAAA,MACG,CAAA;AAAA,IACH;AAAA;;;","x_google_ignoreList":[0]}
@@ -1,9 +1,9 @@
1
1
  import Buffer from "./standards-sdk.es21.js";
2
2
  import { KeyList, TopicCreateTransaction, Transaction, TopicMessageSubmitTransaction, Hbar } from "@hashgraph/sdk";
3
3
  import { Logger } from "./standards-sdk.es14.js";
4
- import { InscriptionSDK } from "./standards-sdk.es26.js";
4
+ import { InscriptionSDK } from "./standards-sdk.es24.js";
5
5
  import { HCS10BaseClient, Hcs10MemoType } from "./standards-sdk.es5.js";
6
- import { m as mimeTypesExports } from "./standards-sdk.es22.js";
6
+ import { m as mimeTypesExports } from "./standards-sdk.es25.js";
7
7
  import { AgentBuilder } from "./standards-sdk.es10.js";
8
8
  import { HCS11Client } from "./standards-sdk.es12.js";
9
9
  import { ProgressReporter } from "./standards-sdk.es16.js";
@@ -130,7 +130,7 @@ class BrowserHCSClient extends HCS10BaseClient {
130
130
  this.logger.info(
131
131
  `Submitted connection request to topic ID: ${inboundTopicId}`
132
132
  );
133
- const outboundTopic = await this.retrieveOutboundConnectTopic(accountId);
133
+ const outboundTopic = await this.retrieveCommunicationTopics(accountId);
134
134
  if (!outboundTopic?.outboundTopic) {
135
135
  this.logger.error(
136
136
  `Failed to retrieve outbound topic for account ID: ${accountId}`
@@ -200,6 +200,20 @@ class BrowserHCSClient extends HCS10BaseClient {
200
200
  operatorId,
201
201
  connectionMemo
202
202
  );
203
+ const accountTopics = await this.retrieveCommunicationTopics(userAccountId);
204
+ const requestingAccountTopics = await this.retrieveCommunicationTopics(
205
+ requestingAccountId
206
+ );
207
+ const requestingAccountOperatorId = `${requestingAccountTopics.inboundTopic}@${requestingAccountId}`;
208
+ await this.recordOutboundConnectionConfirmation({
209
+ outboundTopicId: accountTopics.outboundTopic,
210
+ requestorOutboundTopicId: requestingAccountTopics.outboundTopic,
211
+ connectionRequestId: connectionId,
212
+ confirmedRequestId: confirmedConnectionSequenceNumber,
213
+ connectionTopicId,
214
+ operatorId: requestingAccountOperatorId,
215
+ memo: `Connection established with ${requestingAccountId}`
216
+ });
203
217
  return {
204
218
  connectionTopicId,
205
219
  confirmedConnectionSequenceNumber,
@@ -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 submitConnectionRequest(\n inboundTopicId: string,\n memo: string\n ): Promise<TransactionReceipt | undefined> {\n this.logger.info('Submitting connection request');\n const accountResponse = this.getAccountAndSigner();\n if (!accountResponse.accountId) {\n throw new Error('Failed to retrieve user account ID');\n }\n const operatorId = await this.getOperatorId();\n const accountId = accountResponse.accountId;\n const connectionRequestMessage = {\n p: 'hcs-10',\n op: 'connection_request',\n operator_id: operatorId,\n m: memo,\n };\n\n const response = await this.submitPayload(\n inboundTopicId,\n connectionRequestMessage\n );\n this.logger.info(\n `Submitted connection request to topic ID: ${inboundTopicId}`\n );\n\n const outboundTopic = await this.retrieveOutboundConnectTopic(accountId);\n\n if (!outboundTopic?.outboundTopic) {\n this.logger.error(\n `Failed to retrieve outbound topic for account ID: ${accountId}`\n );\n throw new Error(\n `Failed to retrieve outbound topic for account ID: ${accountId}`\n );\n }\n\n this.logger.info(\n `Retrieved outbound topic ID: ${outboundTopic.outboundTopic} for account ID: ${accountId}`\n );\n const responseSequenceNumber = response?.topicSequenceNumber?.toNumber();\n\n if (!responseSequenceNumber) {\n throw new Error('Failed to get response sequence number');\n }\n\n await this.submitPayload(outboundTopic.outboundTopic, {\n ...connectionRequestMessage,\n outbound_topic_id: inboundTopicId,\n connection_request_id: responseSequenceNumber,\n });\n\n return response;\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 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 transaction.setTransactionMemo('HIP-991 Fee Payment');\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":";;;;;;;;;;AA4CA,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,wBACJ,gBACA,MACyC;AACpC,SAAA,OAAO,KAAK,+BAA+B;AAC1C,UAAA,kBAAkB,KAAK,oBAAoB;AAC7C,QAAA,CAAC,gBAAgB,WAAW;AACxB,YAAA,IAAI,MAAM,oCAAoC;AAAA,IAAA;AAEhD,UAAA,aAAa,MAAM,KAAK,cAAc;AAC5C,UAAM,YAAY,gBAAgB;AAClC,UAAM,2BAA2B;AAAA,MAC/B,GAAG;AAAA,MACH,IAAI;AAAA,MACJ,aAAa;AAAA,MACb,GAAG;AAAA,IACL;AAEM,UAAA,WAAW,MAAM,KAAK;AAAA,MAC1B;AAAA,MACA;AAAA,IACF;AACA,SAAK,OAAO;AAAA,MACV,6CAA6C,cAAc;AAAA,IAC7D;AAEA,UAAM,gBAAgB,MAAM,KAAK,6BAA6B,SAAS;AAEnE,QAAA,CAAC,eAAe,eAAe;AACjC,WAAK,OAAO;AAAA,QACV,qDAAqD,SAAS;AAAA,MAChE;AACA,YAAM,IAAI;AAAA,QACR,qDAAqD,SAAS;AAAA,MAChE;AAAA,IAAA;AAGF,SAAK,OAAO;AAAA,MACV,gCAAgC,cAAc,aAAa,oBAAoB,SAAS;AAAA,IAC1F;AACM,UAAA,yBAAyB,UAAU,qBAAqB,SAAS;AAEvE,QAAI,CAAC,wBAAwB;AACrB,YAAA,IAAI,MAAM,wCAAwC;AAAA,IAAA;AAGpD,UAAA,KAAK,cAAc,cAAc,eAAe;AAAA,MACpD,GAAG;AAAA,MACH,mBAAmB;AAAA,MACnB,uBAAuB;AAAA,IAAA,CACxB;AAEM,WAAA;AAAA,EAAA;AAAA,EAGT,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;AAEK,UAAA,cAAc,IAAI,uBACrB,EAAA,aAAa,IAAI,EACjB,YAAY,YAAY,EACxB,aAAa,YAAY;AAEvB,SAAA,OAAO,MAAM,sCAAsC;AAClD,UAAA,aAAa,MAAM,KAAK,IAAI;AAAA,MAChC;AAAA,MACA;AAAA,IACF;AACA,QAAI,WAAW,OAAO;AACf,WAAA,OAAO,MAAM,WAAW,KAAK;AAC5B,YAAA,IAAI,MAAM,WAAW,KAAK;AAAA,IAAA;AAGlC,UAAM,gBAAgB,WAAW;AAC7B,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;AAEO,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;AACzD,kBAAY,mBAAmB,qBAAqB;AAAA,IAAA;AAGtD,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;"}
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 submitConnectionRequest(\n inboundTopicId: string,\n memo: string\n ): Promise<TransactionReceipt | undefined> {\n this.logger.info('Submitting connection request');\n const accountResponse = this.getAccountAndSigner();\n if (!accountResponse.accountId) {\n throw new Error('Failed to retrieve user account ID');\n }\n const operatorId = await this.getOperatorId();\n const accountId = accountResponse.accountId;\n const connectionRequestMessage = {\n p: 'hcs-10',\n op: 'connection_request',\n operator_id: operatorId,\n m: memo,\n };\n\n const response = await this.submitPayload(\n inboundTopicId,\n connectionRequestMessage\n );\n this.logger.info(\n `Submitted connection request to topic ID: ${inboundTopicId}`\n );\n\n const outboundTopic = await this.retrieveCommunicationTopics(accountId);\n\n if (!outboundTopic?.outboundTopic) {\n this.logger.error(\n `Failed to retrieve outbound topic for account ID: ${accountId}`\n );\n throw new Error(\n `Failed to retrieve outbound topic for account ID: ${accountId}`\n );\n }\n\n this.logger.info(\n `Retrieved outbound topic ID: ${outboundTopic.outboundTopic} for account ID: ${accountId}`\n );\n const responseSequenceNumber = response?.topicSequenceNumber?.toNumber();\n\n if (!responseSequenceNumber) {\n throw new Error('Failed to get response sequence number');\n }\n\n await this.submitPayload(outboundTopic.outboundTopic, {\n ...connectionRequestMessage,\n outbound_topic_id: inboundTopicId,\n connection_request_id: responseSequenceNumber,\n });\n\n return response;\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 transaction.setTransactionMemo('HIP-991 Fee Payment');\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,8 +1,5 @@
1
- import utils from "./standards-sdk.es67.js";
2
- function isAxiosError(payload) {
3
- return utils.isObject(payload) && payload.isAxiosError === true;
4
- }
1
+ var mimeTypes = {};
5
2
  export {
6
- isAxiosError as default
3
+ mimeTypes as __exports
7
4
  };
8
5
  //# sourceMappingURL=standards-sdk.es80.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es80.js","sources":["../../node_modules/axios/lib/helpers/isAxiosError.js"],"sourcesContent":["'use strict';\n\nimport utils from './../utils.js';\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n *\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nexport default function isAxiosError(payload) {\n return utils.isObject(payload) && (payload.isAxiosError === true);\n}\n"],"names":[],"mappings":";AAWe,SAAS,aAAa,SAAS;AAC5C,SAAO,MAAM,SAAS,OAAO,KAAM,QAAQ,iBAAiB;AAC9D;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es80.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}