@isdk/ai-tool 0.7.0 → 0.8.0

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 (359) hide show
  1. package/dist/chunk-4FKBOPZI.mjs +1 -0
  2. package/dist/{chunk-VIG2GB47.mjs → chunk-TGTHY57V.mjs} +1 -1
  3. package/dist/funcs.d.mts +1 -2
  4. package/dist/funcs.d.ts +1 -2
  5. package/dist/funcs.js +1 -1
  6. package/dist/funcs.mjs +1 -1
  7. package/dist/{index-BCco-g_I.d.mts → index-BLW3R7VS.d.mts} +114 -69
  8. package/dist/{index-BCco-g_I.d.ts → index-BLW3R7VS.d.ts} +114 -69
  9. package/dist/index.d.mts +101 -38
  10. package/dist/index.d.ts +101 -38
  11. package/dist/index.js +1 -1
  12. package/dist/index.mjs +1 -1
  13. package/dist/test/util.js +1 -1
  14. package/dist/test/util.mjs +1 -1
  15. package/docs/api/{namespaces → @isdk/namespaces}/EventStates/README.md +2 -2
  16. package/docs/api/{namespaces → @isdk/namespaces}/EventStates/variables/ABORT.md +2 -2
  17. package/docs/api/{namespaces → @isdk/namespaces}/EventStates/variables/CONTINUE.md +2 -2
  18. package/docs/api/{namespaces → @isdk/namespaces}/EventStates/variables/DONE.md +2 -2
  19. package/docs/api/{namespaces → @isdk/namespaces}/EventStates/variables/STOPPED.md +2 -2
  20. package/docs/api/@isdk/namespaces/uuidv5/README.md +12 -0
  21. package/docs/api/{namespaces → @isdk/namespaces}/uuidv5/variables/DNS.md +2 -2
  22. package/docs/api/{namespaces → @isdk/namespaces}/uuidv5/variables/URL.md +2 -2
  23. package/docs/api/_media/pubsub.md +427 -105
  24. package/docs/api/_media/server_client_tools.md +5 -3
  25. package/docs/api/_media/toolFunc.md +3 -1
  26. package/docs/api/classes/AbortError.md +8 -8
  27. package/docs/api/classes/AlreadyExistsError.md +8 -8
  28. package/docs/api/classes/BaseError.md +14 -14
  29. package/docs/api/classes/BinarySemaphore.md +39 -39
  30. package/docs/api/classes/CancelableAbility.md +43 -39
  31. package/docs/api/classes/ClientToolTransport.md +22 -22
  32. package/docs/api/classes/ClientTools.md +182 -154
  33. package/docs/api/classes/CommonError.md +12 -12
  34. package/docs/api/classes/ConfigFile.md +6 -6
  35. package/docs/api/classes/EnvPromptTemplate.md +14 -14
  36. package/docs/api/classes/EventClient.md +258 -201
  37. package/docs/api/classes/EventEmitter.md +14 -14
  38. package/docs/api/classes/EventServer.md +220 -237
  39. package/docs/api/classes/EventToolFunc.md +144 -116
  40. package/docs/api/classes/FStringPromptTemplate.md +14 -14
  41. package/docs/api/classes/FewShotPromptTemplate.md +30 -26
  42. package/docs/api/classes/GolangPromptTemplate.md +13 -13
  43. package/docs/api/classes/HttpClientToolTransport.md +23 -23
  44. package/docs/api/classes/HttpServerToolTransport.md +40 -27
  45. package/docs/api/classes/IntSet.md +21 -21
  46. package/docs/api/classes/LRUCache.md +18 -18
  47. package/docs/api/classes/NotFoundError.md +8 -8
  48. package/docs/api/classes/NotImplementationError.md +8 -8
  49. package/docs/api/classes/PromptExampleSelector.md +17 -15
  50. package/docs/api/classes/PromptTemplate.md +15 -15
  51. package/docs/api/classes/ReadableStreamError.md +12 -12
  52. package/docs/api/classes/ResClientTools.md +658 -143
  53. package/docs/api/classes/ResServerTools.md +643 -133
  54. package/docs/api/classes/RpcMethodsClientTool.md +3303 -0
  55. package/docs/api/classes/RpcMethodsServerTool.md +3248 -0
  56. package/docs/api/classes/SSEChannel.md +142 -52
  57. package/docs/api/classes/Semaphore.md +40 -40
  58. package/docs/api/classes/ServerToolTransport.md +32 -27
  59. package/docs/api/classes/ServerTools.md +167 -139
  60. package/docs/api/classes/SignalGate.md +19 -17
  61. package/docs/api/classes/SseClientPubSubTransport.md +38 -10
  62. package/docs/api/classes/SseServerPubSubTransport.md +115 -42
  63. package/docs/api/classes/TaskAbortController.md +13 -13
  64. package/docs/api/classes/ToolFunc.md +157 -129
  65. package/docs/api/classes/ToolTransport.md +13 -13
  66. package/docs/api/classes/YamlTypeBaseObject.md +5 -5
  67. package/docs/api/enumerations/AsyncFeatureBits.md +4 -4
  68. package/docs/api/enumerations/AsyncFeatures.md +4 -4
  69. package/docs/api/enumerations/HashAlgorithm.md +12 -12
  70. package/docs/api/functions/AIArgProcessor.md +2 -2
  71. package/docs/api/functions/AIStream.md +8 -4
  72. package/docs/api/functions/ChoiceArgProcessor.md +2 -2
  73. package/docs/api/functions/DefaultDateFormat.md +2 -2
  74. package/docs/api/functions/ObjectArgsToArgsInfo.md +1 -1
  75. package/docs/api/functions/RateLimit.md +2 -2
  76. package/docs/api/functions/TemplateArgProcessor.md +2 -2
  77. package/docs/api/functions/addDate.md +7 -3
  78. package/docs/api/functions/assignDirs.md +1 -1
  79. package/docs/api/functions/beforeShutdown.md +1 -1
  80. package/docs/api/functions/calcPerplexity.md +2 -2
  81. package/docs/api/functions/calcPerplexitySimple.md +1 -1
  82. package/docs/api/functions/canonicalize.md +1 -1
  83. package/docs/api/functions/completeSentences.md +1 -1
  84. package/docs/api/functions/concatText.md +1 -1
  85. package/docs/api/functions/countLLMTokens.md +1 -1
  86. package/docs/api/functions/countRegexMatches.md +1 -1
  87. package/docs/api/functions/createAbilityInjector.md +16 -8
  88. package/docs/api/functions/createCallbacksTransformer.md +7 -3
  89. package/docs/api/functions/createEmptyReadableStream.md +1 -1
  90. package/docs/api/functions/createEndWithRepetitionDetector.md +2 -2
  91. package/docs/api/functions/createError.md +1 -1
  92. package/docs/api/functions/createEventStreamTransformer.md +8 -4
  93. package/docs/api/functions/createHfValueFunc.md +1 -1
  94. package/docs/api/functions/createLRUCache.md +2 -2
  95. package/docs/api/functions/createYamlObjectTag.md +1 -1
  96. package/docs/api/functions/dateToText.md +1 -1
  97. package/docs/api/functions/decodeCharset.md +2 -2
  98. package/docs/api/functions/defaultsWithConcat.md +1 -1
  99. package/docs/api/functions/detectCharset.md +2 -2
  100. package/docs/api/functions/encodeLLMTokens.md +1 -1
  101. package/docs/api/functions/ensureQuoted.md +1 -1
  102. package/docs/api/functions/eventable.md +6 -8
  103. package/docs/api/functions/expandConfig.md +2 -2
  104. package/docs/api/functions/expandObjEnv.md +1 -1
  105. package/docs/api/functions/expandPath.md +2 -2
  106. package/docs/api/functions/expandPathInObject.md +2 -2
  107. package/docs/api/functions/expandPaths.md +2 -2
  108. package/docs/api/functions/fileIsExists.md +1 -1
  109. package/docs/api/functions/filterValidFnScope.md +2 -2
  110. package/docs/api/functions/findIndexNonEmptyFrom.md +1 -1
  111. package/docs/api/functions/findPort.md +1 -1
  112. package/docs/api/functions/formatISO.md +1 -1
  113. package/docs/api/functions/formatTextWithSpace.md +2 -2
  114. package/docs/api/functions/funcGetMeta.md +1 -1
  115. package/docs/api/functions/funcWithMeta.md +2 -2
  116. package/docs/api/functions/genUrlParamsStr.md +8 -2
  117. package/docs/api/functions/getAllEnumKeys.md +4 -2
  118. package/docs/api/functions/getConfigFileNames.md +2 -2
  119. package/docs/api/functions/getConfigs.md +2 -2
  120. package/docs/api/functions/getFileMetaInfo.md +1 -1
  121. package/docs/api/functions/getHashAlgoBySize.md +1 -1
  122. package/docs/api/functions/getKeysPath.md +4 -2
  123. package/docs/api/functions/getLLMTokenizer.md +1 -1
  124. package/docs/api/functions/getMultiLevelExtname.md +1 -1
  125. package/docs/api/functions/getPackageDir.md +1 -1
  126. package/docs/api/functions/getRealFilepath.md +1 -1
  127. package/docs/api/functions/getResponseErrorReadableStream.md +2 -2
  128. package/docs/api/functions/getXDGConfigs.md +1 -1
  129. package/docs/api/functions/hasDirectoryIn.md +2 -2
  130. package/docs/api/functions/hash.md +1 -1
  131. package/docs/api/functions/hashFile.md +2 -2
  132. package/docs/api/functions/hashObject.md +2 -2
  133. package/docs/api/functions/hashStream.md +1 -1
  134. package/docs/api/functions/initShutdown.md +1 -1
  135. package/docs/api/functions/isLangUsingSpaces.md +1 -1
  136. package/docs/api/functions/isListItemString.md +1 -1
  137. package/docs/api/functions/isModelNameMatched.md +2 -2
  138. package/docs/api/functions/isPunctuationChar.md +1 -1
  139. package/docs/api/functions/isQuoted.md +1 -1
  140. package/docs/api/functions/isRegExp.md +1 -1
  141. package/docs/api/functions/isSameString.md +1 -1
  142. package/docs/api/functions/isSectionString.md +2 -2
  143. package/docs/api/functions/isSentenceEnding.md +1 -1
  144. package/docs/api/functions/isSepLineString.md +1 -1
  145. package/docs/api/functions/isStrWrapped.md +1 -1
  146. package/docs/api/functions/isSubdirectory.md +1 -1
  147. package/docs/api/functions/isTitleString.md +2 -2
  148. package/docs/api/functions/isWebStream.md +1 -1
  149. package/docs/api/functions/joinSplitWords.md +1 -1
  150. package/docs/api/functions/jsonFilterToWhere.md +2 -2
  151. package/docs/api/functions/jsonToMarkdownStr.md +2 -2
  152. package/docs/api/functions/loadAIConfig.md +1 -1
  153. package/docs/api/functions/loadConfig.md +1 -1
  154. package/docs/api/functions/loadConfigFile.md +1 -1
  155. package/docs/api/functions/loadFileFromPaths.md +2 -2
  156. package/docs/api/functions/loadTextFromPaths.md +3 -3
  157. package/docs/api/functions/lrucache.md +1 -1
  158. package/docs/api/functions/matchUrlProtocol.md +1 -1
  159. package/docs/api/functions/memoize.md +5 -3
  160. package/docs/api/functions/mergeArray.md +1 -1
  161. package/docs/api/functions/messagesToText.md +1 -1
  162. package/docs/api/functions/nanoid.md +45 -0
  163. package/docs/api/functions/normalizePath.md +1 -1
  164. package/docs/api/functions/paramsSizeToScaleStr.md +1 -1
  165. package/docs/api/functions/parseCommand.md +3 -3
  166. package/docs/api/functions/parseDateFormat.md +7 -3
  167. package/docs/api/functions/parseISO.md +7 -3
  168. package/docs/api/functions/parseJsJson.md +2 -2
  169. package/docs/api/functions/parseJsJsonSimpleSync.md +2 -2
  170. package/docs/api/functions/parseObjectArgInfo.md +2 -2
  171. package/docs/api/functions/parseObjectArgumentInfos.md +2 -2
  172. package/docs/api/functions/parseObjectArguments.md +2 -2
  173. package/docs/api/functions/parseObjectArgumentsAsArgInfos.md +2 -2
  174. package/docs/api/functions/parseYaml.md +1 -1
  175. package/docs/api/functions/pruneSubdirectories.md +1 -1
  176. package/docs/api/functions/pruneSubdirectoriesInPlace.md +1 -1
  177. package/docs/api/functions/quoteStr.md +1 -1
  178. package/docs/api/functions/readFilenamesRecursiveSync.md +2 -2
  179. package/docs/api/functions/readTextFileChunks.md +2 -2
  180. package/docs/api/functions/readTextFileChunksEx.md +2 -2
  181. package/docs/api/functions/readableFromAsyncIterable.md +4 -2
  182. package/docs/api/functions/registerCoreTools.md +1 -1
  183. package/docs/api/functions/removeMarkdownBold.md +2 -2
  184. package/docs/api/functions/removeMarkdownBoldAndItalic.md +2 -2
  185. package/docs/api/functions/removeMarkdownItalic.md +2 -2
  186. package/docs/api/functions/replaceWithPlaceholder.md +2 -2
  187. package/docs/api/functions/restoreFromPlacehoders.md +2 -2
  188. package/docs/api/functions/sanitizeFilename.md +1 -1
  189. package/docs/api/functions/sanitizeFilepath.md +1 -1
  190. package/docs/api/functions/saveConfigFile.md +1 -1
  191. package/docs/api/functions/scaleStrToParamsSize.md +1 -1
  192. package/docs/api/functions/shutdown.md +1 -1
  193. package/docs/api/functions/simplifyObjectArguments.md +1 -1
  194. package/docs/api/functions/sleep.md +1 -1
  195. package/docs/api/functions/sortedValues.md +4 -2
  196. package/docs/api/functions/splitChunks.md +2 -2
  197. package/docs/api/functions/splitParagraph.md +2 -2
  198. package/docs/api/functions/splitSentence.md +1 -1
  199. package/docs/api/functions/splitWords.md +1 -1
  200. package/docs/api/functions/stringifyYaml.md +1 -1
  201. package/docs/api/functions/stripConsoleColor.md +1 -1
  202. package/docs/api/functions/textToDate.md +1 -1
  203. package/docs/api/functions/throwError.md +1 -1
  204. package/docs/api/functions/toDate.md +7 -3
  205. package/docs/api/functions/toDateTime.md +1 -1
  206. package/docs/api/functions/trimStartOfStreamHelper.md +3 -3
  207. package/docs/api/functions/truncTo.md +1 -1
  208. package/docs/api/functions/truncateByToken.md +2 -2
  209. package/docs/api/functions/truncateToTokenLimit.md +2 -2
  210. package/docs/api/functions/truncateToTokenLimitEx.md +2 -2
  211. package/docs/api/functions/uuid.md +15 -6
  212. package/docs/api/functions/uuidStringify.md +1 -1
  213. package/docs/api/functions/uuidv1.md +5 -3
  214. package/docs/api/functions/uuidv4.md +5 -3
  215. package/docs/api/functions/uuidv5.md +5 -3
  216. package/docs/api/functions/uuidv6.md +61 -0
  217. package/docs/api/functions/uuidv7.md +61 -0
  218. package/docs/api/functions/wrapEventEmitter.md +1 -1
  219. package/docs/api/functions/xxhash.md +1 -1
  220. package/docs/api/functions/xxhash32.md +1 -1
  221. package/docs/api/functions/xxhash64.md +1 -1
  222. package/docs/api/functions/xxhashAsStr.md +1 -1
  223. package/docs/api/functions/yieldExec.md +1 -1
  224. package/docs/api/globals.md +17 -6
  225. package/docs/api/interfaces/AIChatAssistantMessageParam.md +12 -12
  226. package/docs/api/interfaces/AIChatContentPartImage.md +3 -3
  227. package/docs/api/interfaces/AIChatContentPartText.md +3 -3
  228. package/docs/api/interfaces/AIChatMessageParamBase.md +7 -7
  229. package/docs/api/interfaces/AIChatMessageToolCall.md +4 -4
  230. package/docs/api/interfaces/AIChatSystemMessageParam.md +9 -9
  231. package/docs/api/interfaces/AIChatToolChoiceFuncObject.md +3 -3
  232. package/docs/api/interfaces/AIChatToolChoiceObject.md +2 -2
  233. package/docs/api/interfaces/AIChatToolFunc.md +5 -5
  234. package/docs/api/interfaces/AIChatToolFuncParam.md +3 -3
  235. package/docs/api/interfaces/AIChatToolMessageParam.md +10 -10
  236. package/docs/api/interfaces/AIChatToolParam.md +2 -2
  237. package/docs/api/interfaces/AIChatToolTypeObject.md +2 -2
  238. package/docs/api/interfaces/AIChatUserMessageParam.md +13 -13
  239. package/docs/api/interfaces/AIChoiceConfig.md +8 -8
  240. package/docs/api/interfaces/AIResult.md +12 -8
  241. package/docs/api/interfaces/AIStreamParser.md +8 -6
  242. package/docs/api/interfaces/AIStreamParserOptions.md +2 -2
  243. package/docs/api/interfaces/BaseFunc.md +17 -17
  244. package/docs/api/interfaces/BaseFuncItem.md +15 -15
  245. package/docs/api/interfaces/BinarySemaphoreAcquireOptions.md +2 -2
  246. package/docs/api/interfaces/BinarySemaphoreOptions.md +5 -5
  247. package/docs/api/interfaces/BinarySemaphoreReleaseOptions.md +2 -2
  248. package/docs/api/interfaces/BinarySemaphoreReleaserFunc.md +3 -3
  249. package/docs/api/interfaces/CancelableAbilityOptions.md +4 -4
  250. package/docs/api/interfaces/ClientFuncItem.md +21 -25
  251. package/docs/api/interfaces/EventClientFuncParams.md +5 -5
  252. package/docs/api/interfaces/EventServerFuncParams.md +14 -6
  253. package/docs/api/interfaces/FewShotPromptTemplateOptions.md +9 -7
  254. package/docs/api/interfaces/FuncItem.md +18 -18
  255. package/docs/api/interfaces/FuncParam.md +5 -5
  256. package/docs/api/interfaces/FuncParams.md +1 -1
  257. package/docs/api/interfaces/Funcs.md +1 -1
  258. package/docs/api/interfaces/HashAlgoParams.md +4 -4
  259. package/docs/api/interfaces/IClientToolTransport.md +9 -9
  260. package/docs/api/interfaces/IFileMetaInfo.md +8 -8
  261. package/docs/api/interfaces/IPubSubClientTransport.md +31 -7
  262. package/docs/api/interfaces/IPubSubServerTransport.md +92 -47
  263. package/docs/api/interfaces/IReadTextFileChunksOptions.md +13 -13
  264. package/docs/api/interfaces/IServerToolTransport.md +19 -14
  265. package/docs/api/interfaces/IToolTransport.md +6 -6
  266. package/docs/api/interfaces/ITruncateToTokenLimitOptions.md +11 -11
  267. package/docs/api/interfaces/JsonFilter.md +1 -1
  268. package/docs/api/interfaces/ParseObjectArgumentOptions.md +11 -11
  269. package/docs/api/interfaces/ProbabilityItem.md +4 -4
  270. package/docs/api/interfaces/PromptExampleSelectorOptions.md +3 -3
  271. package/docs/api/interfaces/PubSubClientStream.md +26 -14
  272. package/docs/api/interfaces/PubSubServerSession.md +8 -8
  273. package/docs/api/interfaces/RemoteFuncItem.md +21 -25
  274. package/docs/api/interfaces/ReplacePlacehoderOptions.md +5 -5
  275. package/docs/api/interfaces/ResClientFuncParams.md +5 -5
  276. package/docs/api/interfaces/ResServerFuncParams.md +14 -10
  277. package/docs/api/interfaces/RpcMethodsClientFuncParams.md +25 -0
  278. package/docs/api/interfaces/RpcMethodsServerFuncParams.md +61 -0
  279. package/docs/api/interfaces/SectionStringOptions.md +3 -3
  280. package/docs/api/interfaces/SemaphoreOptions.md +7 -7
  281. package/docs/api/interfaces/SemaphoreTaskItem.md +6 -6
  282. package/docs/api/interfaces/ServerFuncItem.md +22 -26
  283. package/docs/api/interfaces/ServerFuncParams.md +4 -3
  284. package/docs/api/interfaces/SplitSentenceOptions.md +5 -5
  285. package/docs/api/interfaces/StreamCallbacksAndOptions.md +11 -7
  286. package/docs/api/interfaces/TaskAbortControllers.md +1 -1
  287. package/docs/api/interfaces/TaskPromise.md +17 -9
  288. package/docs/api/interfaces/ToolFuncPackage.md +5 -5
  289. package/docs/api/type-aliases/AIChatContentPart.md +2 -2
  290. package/docs/api/type-aliases/AIChatMessageParam.md +2 -2
  291. package/docs/api/type-aliases/AIChatRole.md +2 -2
  292. package/docs/api/type-aliases/AIChatToolChoiceParam.md +2 -2
  293. package/docs/api/type-aliases/AIMessageType.md +2 -2
  294. package/docs/api/type-aliases/AIModelNameRule.md +2 -2
  295. package/docs/api/type-aliases/AIModelNameRuleFn.md +2 -2
  296. package/docs/api/type-aliases/AIModelNameRules.md +2 -2
  297. package/docs/api/type-aliases/AITextGenerationFinishReason.md +2 -2
  298. package/docs/api/type-aliases/ActionName.md +2 -2
  299. package/docs/api/type-aliases/ArrayMergeWay.md +2 -2
  300. package/docs/api/type-aliases/AsyncTaskId.md +2 -2
  301. package/docs/api/type-aliases/BeforeShutdownListener.md +2 -2
  302. package/docs/api/type-aliases/EventErrorListenerFn.md +2 -2
  303. package/docs/api/type-aliases/EventListenerFn.md +2 -2
  304. package/docs/api/type-aliases/FuncParamType.md +2 -2
  305. package/docs/api/type-aliases/PromptExamples.md +5 -3
  306. package/docs/api/type-aliases/PubSubClientId.md +2 -2
  307. package/docs/api/type-aliases/PubSubCtx.md +24 -4
  308. package/docs/api/type-aliases/RpcMethodHandler.md +2 -2
  309. package/docs/api/type-aliases/SSEClient.md +53 -0
  310. package/docs/api/type-aliases/SemaphoreIsReadyFuncType.md +2 -2
  311. package/docs/api/type-aliases/TFunc.md +2 -2
  312. package/docs/api/type-aliases/UUIDVersions.md +11 -0
  313. package/docs/api/variables/AIChatRoles.md +1 -1
  314. package/docs/api/variables/AIMessageTypes.md +1 -1
  315. package/docs/api/variables/AITextGenerationFinishReasons.md +1 -1
  316. package/docs/api/variables/ActionNames.md +1 -1
  317. package/docs/api/variables/ArrayMergeWay.md +2 -2
  318. package/docs/api/variables/ArrayMergeWaySymbol.md +2 -2
  319. package/docs/api/variables/ClientEventPrefix.md +11 -0
  320. package/docs/api/variables/ClientToolFuncSchema.md +4 -2
  321. package/docs/api/variables/DEFAULT_CONFIG_NAME.md +1 -1
  322. package/docs/api/variables/DefaultAsyncSemaphoreCapacity.md +1 -1
  323. package/docs/api/variables/EventBusName.md +1 -1
  324. package/docs/api/variables/EventName.md +1 -1
  325. package/docs/api/variables/FuncMetaSymbol.md +2 -2
  326. package/docs/api/variables/LLM_TOKENIZER_NAMES.md +4 -4
  327. package/docs/api/variables/LLM_TOKENIZER_NAMES_MAP.md +1 -1
  328. package/docs/api/variables/PASSING_SCORE.md +1 -1
  329. package/docs/api/variables/RStreamErrCode.md +1 -1
  330. package/docs/api/variables/RemoteToolFuncSchema.md +4 -2
  331. package/docs/api/variables/ResponseRStreamErrCode.md +1 -1
  332. package/docs/api/variables/RpcMethodsClientToolSchema.md +51 -0
  333. package/docs/api/variables/RpcMethodsServerToolSchema.md +21 -0
  334. package/docs/api/variables/SHUTDOWN_SIGNALS.md +1 -1
  335. package/docs/api/variables/SSEChannelAlreadyClosedErrCode.md +1 -1
  336. package/docs/api/variables/SecondaryCache.md +1 -1
  337. package/docs/api/variables/ServerToolFuncSchema.md +4 -2
  338. package/docs/api/variables/StrangeHumanName.md +1 -1
  339. package/docs/api/variables/ToolAsyncCancelableBit.md +1 -1
  340. package/docs/api/variables/ToolAsyncMultiTaskBit.md +1 -1
  341. package/docs/api/variables/ToolAsyncPriorityBit.md +1 -1
  342. package/docs/api/variables/ToolFuncSchema.md +4 -2
  343. package/docs/api/variables/backendEventable.md +11 -0
  344. package/docs/api/variables/base32768.md +1 -1
  345. package/docs/api/variables/event.md +1 -1
  346. package/docs/api/variables/eventClient.md +1 -1
  347. package/docs/api/variables/eventServer.md +1 -1
  348. package/docs/api/variables/lrucache.md +1 -1
  349. package/docs/api/variables/makeToolFuncCancelable.md +11 -0
  350. package/docs/api/{functions → variables}/wait.md +16 -14
  351. package/docs/pubsub.md +427 -105
  352. package/docs/server_client_tools.md +5 -3
  353. package/docs/toolFunc.md +3 -1
  354. package/package.json +10 -9
  355. package/dist/chunk-LNTIQQNN.mjs +0 -1
  356. package/docs/api/functions/backendEventable.md +0 -29
  357. package/docs/api/functions/makeToolFuncCancelable.md +0 -29
  358. package/docs/api/interfaces/PubSubClient.md +0 -27
  359. package/docs/api/namespaces/uuidv5/README.md +0 -12
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";var t,e=Object.create,n=Object.defineProperty,r=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,s=Object.getPrototypeOf,o=Object.prototype.hasOwnProperty,a=(t,e,s,a)=>{if(e&&"object"==typeof e||"function"==typeof e)for(let c of i(e))o.call(t,c)||c===s||n(t,c,{get:()=>e[c],enumerable:!(a=r(e,c))||a.enumerable});return t},c=(t,r,i)=>(i=null!=t?e(s(t)):{},a(!r&&t&&t.__esModule?i:n(i,"default",{value:t,enumerable:!0}),t)),u={};((t,e)=>{for(var r in e)n(t,r,{get:e[r],enumerable:!0})})(u,{AIArgProcessor:()=>Te,AIChatRoles:()=>A,AIMessageTypes:()=>$,AIStream:()=>Rt,AITextGenerationFinishReasons:()=>k,AbortError:()=>y.AbortError,AbortErrorCode:()=>y.AbortErrorCode,ActionNames:()=>p,AlreadyExistsError:()=>y.AlreadyExistsError,AlreadyExistsErrorCode:()=>y.AlreadyExistsErrorCode,ArrayMergeWay:()=>gi,ArrayMergeWaySymbol:()=>vi,AsyncFeatureBits:()=>Wn,AsyncFeatures:()=>Hn,BaseError:()=>y.BaseError,BinarySemaphore:()=>Fn,CancelableAbility:()=>Kn,ChoiceArgProcessor:()=>be,ClientToolFuncSchema:()=>Mi,ClientToolTransport:()=>os,ClientTools:()=>Ri,CommonError:()=>y.CommonError,ConfigFile:()=>pn.ConfigFile,DEFAULT_CONFIG_NAME:()=>Jr,DefaultAsyncSemaphoreCapacity:()=>qn,DefaultDateFormat:()=>b,EnvPromptTemplate:()=>O.EnvStringTemplate,ErrorCode:()=>y.ErrorCode,EventBusName:()=>bt,EventClient:()=>Ki,EventEmitter:()=>vt.EventEmitter,EventName:()=>gt,EventServer:()=>ns,EventStates:()=>vt.states,EventToolFunc:()=>zi,FStringPromptTemplate:()=>O.FStringTemplate,FewShotPromptTemplate:()=>I,FilenameReservedRegex:()=>ae.FilenameReservedRegex,FuncMetaSymbol:()=>Ni,GolangPromptTemplate:()=>O.GolangStringTemplate,HashAlgorithm:()=>Wt,HttpClientToolTransport:()=>ds,HttpServerToolTransport:()=>fs,IntSet:()=>xn,InternalErrorCode:()=>y.InternalErrorCode,LLM_TOKENIZER_NAMES:()=>$r,LLM_TOKENIZER_NAMES_MAP:()=>Ar,LRUCache:()=>Bi.LRUCache,NotFoundError:()=>y.NotFoundError,NotFoundErrorCode:()=>y.NotFoundErrorCode,NotImplementationError:()=>y.NotImplementationError,NotImplementedErrorCode:()=>y.NotImplementedErrorCode,ObjectArgsToArgsInfo:()=>we,PASSING_SCORE:()=>d,PromptExampleSelector:()=>M,PromptTemplate:()=>O.StringTemplate,RStreamErrCode:()=>At,RateLimit:()=>Ln,ReadableStreamError:()=>Ct,RemoteToolFuncSchema:()=>m,ResClientTools:()=>Zi,ResServerTools:()=>ts,ResponseRStreamErrCode:()=>xt,SHUTDOWN_SIGNALS:()=>ni,SSEChannel:()=>kt,SSEChannelAlreadyClosedErrCode:()=>Et,SecondaryCache:()=>Xi,Semaphore:()=>Pn,ServerToolFuncSchema:()=>Pi,ServerToolTransport:()=>cs,ServerTools:()=>Fi,SignalGate:()=>Dn,SseClientPubSubTransport:()=>ms,SseServerPubSubTransport:()=>ps,StrangeHumanName:()=>x,TaskAbortController:()=>Zn,TemplateArgProcessor:()=>Se,ToolAsyncCancelableBit:()=>Gn,ToolAsyncMultiTaskBit:()=>Jn,ToolAsyncPriorityBit:()=>Un,ToolFunc:()=>Ci,ToolFuncSchema:()=>Oi,ToolTransport:()=>ss,WindowsReservedNameRegex:()=>ae.WindowsReservedNameRegex,YamlTypeBaseObject:()=>zr,_lrucache:()=>Ji,addDate:()=>v.add,assignDirs:()=>lr,backendEventable:()=>St,base32768:()=>re,beforeShutdown:()=>ci,calcPerplexity:()=>pi,calcPerplexitySimple:()=>mi,canonicalize:()=>ee.canonicalize,completeSentences:()=>V,concatText:()=>Y,countLLMTokens:()=>Or,countRegexMatches:()=>Yn,createAbilityInjector:()=>l.createAbilityInjector,createCallbacksTransformer:()=>Ft,createEmptyReadableStream:()=>Nt,createEndWithRepetitionDetector:()=>Ue,createError:()=>y.createError,createEventStreamTransformer:()=>It,createHfValueFunc:()=>O.createHfValueFunc,createLRUCache:()=>Gi,createYamlObjectTag:()=>_r,dateToText:()=>E,decodeCharset:()=>en,defaultTemplateFormat:()=>O.defaultTemplateFormat,defaultsWithConcat:()=>bi,detectCharset:()=>cn,encodeLLMTokens:()=>Cr,ensureQuoted:()=>$e,event:()=>_i,eventClient:()=>Vi,eventServer:()=>rs,eventable:()=>vt.eventable,expandConfig:()=>Ur,expandEnv:()=>O.expandEnv,expandObjEnv:()=>O.expandObjEnv,expandPath:()=>Kr,expandPathInObject:()=>Qr,expandPaths:()=>Vr,extNameLevel:()=>ae.extNameLevel,fileIsExists:()=>Ve,filterValidFnScope:()=>Xe,findIndexNonEmptyFrom:()=>ct,findPort:()=>ir,formatISO:()=>v.formatISO,formatTextWithSpace:()=>Nr,funcGetMeta:()=>Ii,funcWithMeta:()=>ji,genUrlParamsStr:()=>ki,getAllEnumKeys:()=>he,getConfigFileNames:()=>mn,getConfigs:()=>yn,getEnvVairables:()=>O.getEnvVairables,getFileMetaInfo:()=>on,getHashAlgoBySize:()=>an,getKeysPath:()=>Je,getLLMTokenizer:()=>xr,getMultiLevelExtname:()=>ae.getMultiLevelExtname,getPackageDir:()=>ar,getRealFilepath:()=>rn,getResponseErrorReadableStream:()=>Ot,getXDGConfigs:()=>Zr,hasDirectoryIn:()=>hr,hash:()=>se,hashFile:()=>sn,hashObject:()=>oe,hashStream:()=>ie,initShutdown:()=>ui,isLangUsingSpaces:()=>at,isListItemString:()=>rt,isModelNameMatched:()=>ue,isPunctuationChar:()=>st,isQuoted:()=>Ee,isRegExp:()=>yr,isSameString:()=>Dr,isSectionString:()=>et,isSentenceEnding:()=>tt,isSepLineString:()=>it,isStrWrapped:()=>ke,isSubdirectory:()=>ur,isTitleString:()=>nt,isValidFilename:()=>ae.isValidFilename,isValidFilepath:()=>ae.isValidFilepath,isWebStream:()=>$t,joinSplitWords:()=>Ti,jsonFilterToWhere:()=>Tn,jsonToMarkdownStr:()=>An,loadAIConfig:()=>Hr,loadConfig:()=>Wr,loadConfigFile:()=>Gr,loadFileFromPaths:()=>Qe,loadTextFromPaths:()=>tn,lrucache:()=>Ui,makeToolFuncCancelable:()=>Qn,matchUrlProtocol:()=>En,memoize:()=>nr,mergeArray:()=>Si,messagesToText:()=>C,mimeType:()=>dn.mimeType,normalizePath:()=>pr,paramsSizeToScaleStr:()=>kn,parseCommand:()=>Ie,parseDateFormat:()=>w.parse,parseISO:()=>v.parseISO,parseJsJson:()=>ze,parseJsJsonSimpleSync:()=>_e,parseObjectArgInfo:()=>Ne,parseObjectArgumentInfos:()=>ge,parseObjectArguments:()=>me,parseObjectArgumentsAsArgInfos:()=>je,parseYaml:()=>pn.parseYaml,pruneSubdirectories:()=>fr,pruneSubdirectoriesInPlace:()=>dr,quoteStr:()=>Ae,readFilenamesRecursiveSync:()=>nn,readTextFileChunks:()=>Mr,readTextFileChunksEx:()=>Fr,readableFromAsyncIterable:()=>Mt,registerCoreTools:()=>is,registerYamlTag:()=>pn.registerYamlTag,removeMarkdownBold:()=>ut,removeMarkdownBoldAndItalic:()=>lt,removeMarkdownItalic:()=>ht,replaceWithPlaceholder:()=>Re,restoreFromPlacehoders:()=>Me,sanitizeFilename:()=>ae.sanitizeFilename,sanitizeFilepath:()=>ae.sanitizeFilepath,saveConfigFile:()=>wn,scaleStrToParamsSize:()=>$n,shutdown:()=>ai,simplifyObjectArguments:()=>ve,sleep:()=>pt,sortedValues:()=>j,splitChunks:()=>Pr,splitParagraph:()=>ft,splitSentence:()=>K,splitWords:()=>Ei,stringifyYaml:()=>pn.stringifyYaml,stripConsoleColor:()=>wr,textToDate:()=>T,throwError:()=>y.throwError,toDate:()=>v.toDate,toDateTime:()=>S,toRegExp:()=>f.toRegExp,trimStartOfStreamHelper:()=>qt,truncTo:()=>dt,truncateByToken:()=>qr,truncateToTokenLimit:()=>jr,truncateToTokenLimitEx:()=>Ir,uuid:()=>Dt,uuidNIL:()=>zt.NIL,uuidParse:()=>zt.parse,uuidStringify:()=>zt.stringify,uuidValidate:()=>zt.validate,uuidVersion:()=>zt.version,uuidv1:()=>zt.v1,uuidv4:()=>zt.v4,uuidv5:()=>zt.v5,wait:()=>mt,wrapEventEmitter:()=>vt.wrapEventEmitter,xxhash:()=>Yt,xxhash32:()=>Vt,xxhash64:()=>Qt,xxhashAsStr:()=>te,yieldExec:()=>yt}),module.exports=(t=u,a(n({},"__esModule",{value:!0}),t));var h=(()=>"undefined"==typeof document?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.src||new URL("main.js",document.baseURI).href)(),l=require("custom-ability"),f=require("util-ex"),d=.618,p=["get","post","put","delete","patch","list","res"],m={action:{type:"string",assign:(t,e,n,r,i)=>t||"post"},fetchOptions:{type:"object"},allowExportFunc:{type:"boolean"}},y=require("@isdk/common-error"),w=require("date-fns"),v=require("date-fns"),g="MMMM d, y 'at' h:m:s b 'GMT'x";function b(t){return t&&(g=t),g}function S(t){let e;try{"string"==typeof t?e=(0,w.parseISO)(t):"number"==typeof t?e=new Date(t):t instanceof Date&&(e=t)}catch(t){console.error(t)}return e}function T(t,e=g){return(0,w.parse)(t,e,new Date)}function E(t,e=g){return(0,w.format)(t,e)}var k=["stop","length","content_filter","tool_calls","function_call","abort","error","other",null],$=["human","ai","generic","system","tool"],A=["user","assistant","system","tool","tool_calls"],x="陌生人";function C(t){let e="";for(const n of t)if(n.content){e+=n.role.toLowerCase()+":";let t=n.createdAt;if(t){const n=S(t);n&&(e+=" ["+E(n)+"]")}e+=" "+n.content+"\n"}return e}var O=require("@isdk/template-engines"),N=require("@isdk/template-engines");function j(t){return Object.keys(t).sort().map(e=>t[e])}var I=class extends N.StringTemplate{static from(t){return new this(t)}constructor(t){super(t)}_initialize(t){t&&(t.suffix&&(this.suffix=t.suffix),t.exampleSeparator&&(this.exampleSeparator=t.exampleSeparator),t.prefix&&(this.prefix=t.prefix),t.examplePrompt&&(this.examplePrompt=t.examplePrompt instanceof N.StringTemplate?t.examplePrompt:N.StringTemplate.from(t.examplePrompt)),t.examples&&(this.examples=t.examples)),this.prefix||(this.prefix=""),this.exampleSeparator||(this.exampleSeparator="\n\n"),this.suffix||(this.suffix="")}async _format(t){const e=[];for await(const t of this.examples)if(this.examplePrompt){const n=await this.examplePrompt.format(t);e.push(n)}else if("string"==typeof t)e.push(t);else if(t){const n=j(t);n.length>0&&e.push(...n)}const n=[this.prefix,...e,this.suffix].join(this.exampleSeparator),r=this.templateFormat;return await N.StringTemplate.format({template:n,data:t,templateFormat:r})}toJSON(t=this){const e=super.toJSON(t);return t.suffix&&(e.suffix=t.suffix),t.exampleSeparator&&(e.exampleSeparator=t.exampleSeparator),t.prefix&&(e.prefix=t.prefix),t.examplePrompt&&(e.examplePrompt=t.examplePrompt),t.examples&&(e.examples=t.examples),e}};function q(t){return(e=t)&&"function"==typeof e[Symbol.iterator]?async function*(t){const e=t[Symbol.iterator]();let n;try{for(;;){n=!1;const t=e.next();if(n=!0,t.done)return n=!1,await t.value;yield await t.value}}finally{n&&await(e.return?.().value)}}(t):t;var e}N.StringTemplate.register(I,{name:"fewshot",aliases:["few_shot"]});var R=!1;(async function(){let t=!1,e=!1;try{for await(const e of function*(){try{yield Promise.reject()}finally{t=!0}}())throw new Error("impossible")}catch{e=!0}return e&&t})().then(t=>{R=t});var M=class{constructor(t,e){this.initialize(t,e)}initialize(t,e){const n=e?.maxLength;var r;n>0&&(this.maxLength=n),void 0!==e?.threshold&&(!0===e.threshold?this.threshold=.5:!1!==e.threshold&&(this.threshold=e.threshold)),this.examples=(r=t,R?r:q(r))}selectExample(t,e){if(void 0===e||e<=this.threshold)return t}async*selectExamples(t=this.examples){let e=this.maxLength||1/0;for await(const n of t){const t="number"==typeof this.threshold?Math.random():void 0;if(this.selectExample(n,t)){if(--e<0)break;yield n}}}async*[Symbol.asyncIterator](){yield*this.selectExamples()}},F=require("@isdk/detect-text-language"),P="@",L=/(\S.+?[.!?])(?=\s+|$)|(\S.+?)(?=[\n]|$)/g,z=/([A-Z][a-z]{1,2}\.)\s(\w)/g,_=/(\.[a-zA-Z]\.)\s(\w)/g,D=new RegExp("([A-Z][a-z]{1,2}\\.)"+P+"(\\w)","g"),B=new RegExp("(\\.[a-zA-Z]\\.)"+P+"(\\w)","g"),X=/(```)([\s\S]*?)(```)/g,J=">>>CODE_BLOCK<<<",G=/([*_`]{1,3})(\S.*?\S)\1/,U=">>> INLINE_BLOCK ",W=/>>> INLINE_BLOCK (\d+) <<</,H=1e4;function Z(t,e,n){const r="$1"+e+"$2";let i=t;for(let t=0;t<n.length;t++)i=i.replace(n[t],r);return i}function K(t,{best:e=!0,completeSentence:n,isMarkdown:r,ignoreEmptyLine:i}={}){const s=[],o=[];let a,c=0;for(;c++<H&&(a=X.exec(t));){const e=a[0];s.push(e),t=t.replace(e,"\n"+J+(s.length-1)+"\n")}for(c=0;c++<H&&(a=G.exec(t));){const e=a[0];o.push(e),t=t.replace(e,U+(o.length-1)+" <<<")}if(r){const e=t.split("\n");for(let t=0;t<e.length;t++){const n=e[t];nt(n,{isMarkdown:r,nextLine:e[t+1]})&&(s.push(n),e[t]=J+(s.length-1))}t=e.join("\n")}const u=(t=(t=(t=(t=(t=t.replace(/([。!??])\1+/g,"$1")).replace(/([。!??])([^”’])/g,"$1\n$2")).replace(/(\.{6})([^”’])/g,"$1\n$2")).replace(/(…{2})([^”’])/g,"$1\n$2")).replace(/([。!??][”’])([^,。!??])/g,"$1\n$2")).split("\n");let h=[];for(let t=0;t<u.length;t++){let n=u[t].trimEnd();if(!n){!r&&i||h.push("");continue}if(n.startsWith(J)){h.push(s[Number(n.slice(J.length))]);continue}if(r&&nt(n,{isMarkdown:r,nextLine:u[t+1]})){h.push(n);continue}if(!e){h.push(n);continue}let a=Z(n,P,[z,_]),c=Array.from(a.matchAll(L)),l=[];if(c.length)for(let t=0;t<c.length;t++)l.push(Z(c[t][0]," ",[D,B]));else l.push(n);h.push(...l.map(t=>ot(o,t)))}return n&&(h=V(h,{isMarkdown:r,ignoreEmptyLine:i})),h}function V(t,{isMarkdown:e,ignoreEmptyLine:n}={}){const r=[];let i=0,s="";for(n=!e&&n;i<t.length;){let o=t[i];if(o){let a;if(n){const n=ct(t,i+1);a=et(t[n],{isMarkdown:e,nextLine:-1===n?"":t[n+1]})}else a=et(t[i+1],{isMarkdown:e,nextLine:t[i+2]});Q(o,{isMarkdown:e,nextLine:t[i+1]})||""===t[i+1]||a?(s&&(o=Y(s,o),s=""),r.push(o)):(s&&(o=Y(s,o)),s=o)}else n||r[r.length-1]&&r.push(o);i++}return s&&r.push(s),r}function Q(t,e){return tt(t)||et(t,e)}function Y(t,e){const n=t+" "+e,r=(0,F.detectTextLanguage)(n,{isoCode:!0});return r&&!at(r)?(st(t)&&(t+=" "),e=t+e):e=t.endsWith("-")?(t=t.slice(0,-1))+e:n,e}function tt(t){if(!t)return!1;return/(([.。!!??]\s*['"”’]?)|```)\s*$/.test(t)}function et(t,e){let n=nt(t,e);return n||(n=rt(t)),n||(n=it(t)),n}function nt(t,e){if(!t)return null;let n=/^\s*第?\s*[壹贰叁肆伍陆柒捌玖拾一二三四五六七八九十百千萬万\d]+\s*([章節节编回部篇卷幕场場辑集段册冊期片題]|片段|段落|篇[章目]|小[节節]|(子)?部分|卷[册冊]|[单單]元|章[节節回]|[.、])[ \t]*(?<title>.*)(?=\n|$)/.exec(t);if(n||(n=/^\s*(Chapter|Book|Article|Part|Paragraph|Subsection|Subpart|Volume|Episode|Issue|Unit|Section|Segment|Act|Scene)\s*\d+.*(?=\n|$)/i.exec(t)),!n&&e?.isMarkdown){n=/^[ \t]{0,3}(#+)\s+(?<title>\S.*)$/.exec(t);const r=/^[ \t]{0,3}([-=]+)(?=\n|$)/;!n&&e.nextLine&&!r.test(t)&&/^[ \t]{0,3}\S/.test(t)&&r.test(e.nextLine)&&(n=/^\s*(?<title>.*)(?=\n|$)/.exec(t))}return n}function rt(t){return/^\s*([*+-]|\d+[.、])\s*(?<item>.*)(?=\n|$)/.exec(t)}function it(t){return/^[-=_]{3,}$/.exec(t)}function st(t){return/[。!??,、;;::'""“”‘’~~《》<>〈〉【】(){}【】\[\]\(\)…·]$/.test(t)}function ot(t,e){let n,r=0;for(;r++<H&&(n=W.exec(e));){const r=Number(n[1]);e=e.replace(n[0],t[r])}return e}function at(t){return!["zh","ja","th","lo","ta","ko"].includes(t)}function ct(t,e=0){for(let n=e;n<t.length;n++){const e=t[n];if(null!=e&&""!==e)return n}return-1}function ut(t,e){const n=/(?!\\)([*_])\1(?![ \t]|\1)(.+?)(?<!\\)\1{2}/;let r;for(;(r=n.exec(t))&&(t=t.slice(0,r.index)+r[2]+t.slice(r.index+r[0].length),!e););return t}function ht(t,e){const n=/(?!\\)([*_])(?![ \t]|\1)(.+?)(?<!\\)\1/;let r;for(;(r=n.exec(t))&&(t=t.slice(0,r.index)+r[2]+t.slice(r.index+r[0].length),!e););return t}function lt(t,e){return t=ht(t=ut(t,e),e)}function ft(t,e){const n=[],r=[],i=t.split("\n");for(let t=0;t<i.length;t++){let s=i[t];const o=0===s.trim().length;o||nt(s,{...e,nextLine:i[t+1]})?(r.length&&n.push([...r]),r.length=0,o||r.push(s)):r.push(s)}return r.length&&n.push([...r]),n}function dt(t,e=2,n=.5){const r=10**e;return Math.trunc((t+Number.EPSILON+n/r)*r)/r}async function pt(t){return new Promise(e=>setTimeout(e,t))}var mt=pt;async function yt(){return new Promise(t=>{setImmediate(t)})}var wt=require("custom-ability"),vt=require("events-ex"),gt="event",bt="event-bus";var St=(0,wt.createAbilityInjector)(function(t){return class{static get emitter(){if(!this._emitter){const t=this.get(bt)?.emitter;t&&(this._emitter=t,this.prototype._events=t._events)}return this._emitter}get emitter(){return this.constructor._emitter}on(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.on(e,n)}once(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.once(e,n)}off(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.off(e,n)}emit(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return"error"===e?this.emitError.apply(this,n):r.emit.call(this,e,this.name,...n)}emitError(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.emit.call(this,"error",e,this.name,...n)}async emitAsync(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.emitAsync.call(this,e,this.name,...n)}}},!0);function Tt(t,e){return!t||t.some(t=>t instanceof RegExp?t.test(e):t===e)}var Et=498,kt=class{get active(){return this._active}set active(t){t!==this._active&&(t?(this.pingTimer&&(clearInterval(this.pingTimer),this.pingTimer=void 0),this.options.pingInterval>0&&(this.pingTimer=setInterval(()=>this.publish(),this.options.pingInterval))):(this.clients.size&&this.clearClients(),this.pingTimer&&(clearInterval(this.pingTimer),this.pingTimer=void 0)),this._active=t)}constructor(t){this.options=Object.assign({},{pingInterval:3e3,maxStreamDuration:3e4,clientRetryInterval:1e3,startId:1,historySize:100,rewind:0,cors:!1},t),this.nextID=this.options.startId,this.clients=new Set,this.messages=[],this.active=!0}publish(t,e,n){let r,i;this.active||(0,y.throwError)("Channel closed","SSEChannel",Et);let s=e;if(t||e)i=this.nextID++,"object"==typeof t&&(t.event?(s=t.event,void 0!==t.data&&(t=JSON.stringify(t.data))):t=JSON.stringify(t)),t=t?t.split(/[\r\n]+/).map(t=>"data: "+t).join("\n"):"",r="id: "+i+"\n"+(e?"event: "+e+"\n":"")+(t||"data: ")+"\n\n",this.messages.push({id:i,_eventName:s,output:r});else{if(!this.clients.size)return;r="data: \n\n"}if(n?.clientId){const t=Array.isArray(n.clientId)?n.clientId:[n.clientId];[...this.clients].filter(e=>e.clientId&&t.includes(e.clientId)).forEach(t=>t.res.write(r))}else[...this.clients].filter(t=>!s||Tt(t.events,s)).forEach((t,e)=>{t.res.write(r)});for(;this.messages.length>this.options.historySize;)this.messages.shift();return i}subscribe(t,e,n,r){if(this.active||(0,y.throwError)("Channel closed","SSEChannel",Et),!r){const{remoteAddress:e,remotePort:n}=t.socket;e&&n&&(r=`${e}:${n}`)}const i={req:t,res:e,events:n,clientId:r},s=this.options.maxStreamDuration;let o="max-age=0, stale-while-revalidate=0, stale-if-error=0, no-transform";s>0&&(o+=", s-maxage="+(Math.floor(s/1e3)-1));const a={"Content-Type":"text/event-stream","Cache-Control":o,Connection:"keep-alive"};this.options.cors&&(a["access-control-allow-origin"]="*"),i.req.socket.setNoDelay(!0),i.res.writeHead(200,a);let c="retry: "+this.options.clientRetryInterval+"\n\n";const u=Number.parseInt(t.headers["last-event-id"],10),h=Number.isNaN(u)?this.options.rewind:this.nextID-1-u;return h&&this.messages.filter(t=>Tt(i.events,t.eventName)).slice(0-h).forEach(t=>{c+=t.output}),i.res.write(c),this.clients.add(i),s>0&&setTimeout(()=>{i.res.writableEnded||this.unsubscribe(i)},s),i.res.on("close",()=>this.unsubscribe(i)),i}unsubscribe(t){t.res.end(),this.clients.delete(t)}clearClients(){this.clients.forEach(t=>t.res.end()),this.clients.clear()}listClients(){const t={};return this.clients.forEach(e=>{const n=e.req.socket.remoteAddress??"";n in t||(t[n]=0),t[n]++}),t}getSubscriberCount(){return this.clients.size}};function $t(t){return t instanceof ReadableStream||t instanceof WritableStream}var At=600,xt=601,Ct=class extends y.BaseError{constructor(t,e=At){super(t,500)}};function Ot(t){if(t){const e=t.getReader();return new ReadableStream({async start(t){const{done:n,value:r}=await e.read();if(!n){const e=(new TextDecoder).decode(r);t.error(new Ct(`Response error: ${e}`,xt))}}})}return new ReadableStream({start(t){t.error(new Ct("Response error: No response body",xt))}})}function Nt(){return new ReadableStream({start(t){t.close()}})}var jt=require("eventsource-parser");function It(t){const e=new TextDecoder;let n;return new TransformStream({async start(e){n=(0,jt.createParser)({onEvent:n=>{if("data"in n&&"[DONE]"===n.data||"done"===n.event)e.terminate();else if("data"in n){const r=t?t(n.data,{event:n.event}):n.data;r&&e.enqueue(r)}}})},transform(t){n.feed(e.decode(t))}})}function qt(){let t=!0;return e=>(t&&(e=e.trimStart())&&(t=!1),e)}function Rt(t,e){if(!t.ok)return Ot(t.body);let n=t.body||new ReadableStream({start(t){t.close()}});return n instanceof ReadableStream||(n=ReadableStream.from(n)),n.pipeThrough(It(e))}function Mt(t){let e=t[Symbol.asyncIterator]();return new ReadableStream({async pull(t){const{done:n,value:r}=await e.next();n?t.close():t.enqueue(r)},async cancel(t){await(e.return?.(t))}})}function Ft(t){const e=t||{};return new TransformStream({async start(t){const n=t.error;if(t.error=r=>{n.call(t,r),e.onError&&e.onError(r)},e.onStart)try{await e.onStart(t)}catch(e){t.error(e)}},async transform(t,n){try{let r;e.onTransform&&(r=await e.onTransform(t,n)),r||(r=t),n.enqueue(r)}catch(t){n.error(t)}},async flush(t){if(e.onFinal)try{await e.onFinal(t)}catch(e){return t.error(e)}t.terminate()}})}var Pt=require("uuid"),Lt=c(require("base32768")),zt=require("uuid"),_t={1:Pt.v1,4:Pt.v4,5:Pt.v5};function Dt(t=1,e){const n=_t[t];return e?Lt.encode(n(null,[])):n()}var Bt=c(require("xxhashjs")),Xt=c(require("base32768")),Jt=require("json-canonicalize"),Gt=require("hash-wasm"),Ut=588213,Wt=(t=>(t[t.md5=1]="md5",t[t.sha1=2]="sha1",t[t.ripemd=3]="ripemd",t[t.sha256=8]="sha256",t[t.sha384=9]="sha384",t[t.sha512=10]="sha512",t[t.sha224=11]="sha224",t[t.xxhash=111]="xxhash",t[t.xxhash64=111]="xxhash64",t[t.xxhash32=112]="xxhash32",t[t.xxhash128=113]="xxhash128",t))(Wt||{}),Ht={1:Gt.createMD5,2:Gt.createSHA1,8:Gt.createSHA256,10:Gt.createSHA512,11:Gt.createSHA224,3:Gt.createRIPEMD160,112:Gt.createXXHash32,111:Gt.createXXHash64,113:Gt.createXXHash128},{h32:Zt,h64:Kt}=Bt.default;function Vt(t,e=16){return"object"==typeof t&&(t=(0,Jt.canonicalize)(t)),Zt(t.normalize(),Ut).toString(e)}function Qt(t,e=16){return"object"==typeof t&&(t=(0,Jt.canonicalize)(t)),Kt(t.normalize(),Ut).toString(e)}function Yt(t,e=111,n=Ut){let r;return t.buffer&&(t=t.buffer),112!==e?(r=Kt(t,n),r=new Uint16Array([r._a00,r._a16,r._a32,r._a48]),r=new Uint8Array(r.buffer)):(r=Zt(t,n),r=new Uint16Array([r._low,r._high]),r=new Uint8Array(r.buffer)),r}function te(t,e=111,n=Ut){return Xt.encode(Yt(t,e,n))}var ee=require("json-canonicalize"),ne=c(require("base32768")),re=ne;async function ie(t,{hashAlgo:e=111,seed:n=Ut,outputType:r="string"}={}){const i=await Ht[e](n);i.init();const s=t.getReader();for(;;){const{done:t,value:e}=await s.read();if(t)break;i.update(e)}return"string"!==r?i.digest(r):ne.encode(i.digest("binary"))}async function se(t,{hashAlgo:e=111,seed:n=Ut,outputType:r="string"}={}){const i=await Ht[e](n);i.init(),i.update(t);return"string"!==r?i.digest(r):ne.encode(i.digest("binary"))}async function oe(t,e){return se(t=(0,ee.canonicalize)(t),e)}var ae=require("@isdk/util"),ce=require("util-ex");function ue(t,e){if("string"!=typeof t)throw new y.CommonError("modelName must be a string","isModelNameMatched",y.ErrorCode.InvalidArgument);switch(typeof e){case"string":if((0,ce.isRegExpStr)(e)){const n=(e=(0,ce.toRegExp)(e)).exec(t);if(n)return n}else if(t.toLowerCase()===e.toLowerCase())return e;break;case"object":if(Array.isArray(e)){for(const n of e)if("string"==typeof n){if((0,ce.isRegExpStr)(n)){const r=(e=(0,ce.toRegExp)(n)).exec(t);if(r)return r}else if(t.toLowerCase()===n.toLowerCase())return n}else if(n instanceof RegExp){const e=n.exec(t);if(e)return e}else if("function"==typeof n){const e=n.call(this,t);if(e)return e}}else if(e instanceof RegExp){const n=e.exec(t);if(n)return n}break;case"function":const n=e.call(this,t);if(n)return n}}function he(t){return Object.keys(t).filter(t=>Number.isNaN(Number(t)))}var le=require("lodash-es"),fe=require("util-ex"),de=require("lodash-es"),pe=require("util-ex");async function me(t,e,n){return ge(je(t,e,n),e,n)}function ye(t){for(let e=1;e<t.length;e++)if(t[e]<=t[e-1])return!1;return!0}function we(t){if(t&&!Array.isArray(t)&&"object"==typeof t){const e=Object.entries(t),n=Object.keys(t),r=n.filter(t=>!isNaN(parseInt(t)));if(1===e.length)void 0!==t[0]&&(t=[t[0]]);else if(n.every(t=>!isNaN(parseInt(t)))&&ye(n.map(t=>parseInt(t))))t=Object.values(t);else if("0"===r[0]&&ye(r.map(t=>parseInt(t)))){const n=e.filter(([t,e])=>isNaN(parseInt(t)));t=e.filter(([t,e])=>!isNaN(parseInt(t))).map(([t,e])=>e);let r=0;const i=[];for(;r<n.length&&n[r][1]===t[r];)i.push(r),r++;for(;i.length;)n.splice(i.pop(),1);t={args:t,kvArgs:Object.fromEntries(n)}}else t={args:[],kvArgs:t}}return Array.isArray(t)&&(t={args:t}),t}function ve(t){if(t&&!Array.isArray(t)&&"object"==typeof t){const e=Object.entries(t),n=Object.keys(t);1===e.length&&void 0!==t[0]?t=t[0]:n.every(t=>!isNaN(parseInt(t)))?t=n.sort((t,e)=>parseInt(t)-parseInt(e)).map(e=>t[e]):2===e.length&&"0"===e[0][0]&&e[0][1]===e[1][1]&&(t=t[0])}return t}async function ge(t,e,n){if(t.length){const r=await Promise.all(t.map((t,r)=>Ne(t,r,e,n))),i=n?.returnArrayOnly;let s;if(r?.length){s=_e(`{${r.map(t=>t).join(",")}}`,e)}return s&&!i&&(s=ve(s)),s}}function be(t,e,n,r){const[i,s]=t;if(!i&&"|"===s[0])return"choice: {"+function(t,e,n){const r=je(t,e,{...n,delimiter:":"}),i={},s=r.map(([t,e],n)=>{if(t){const t=e.indexOf(":"),n=e.slice(0,t).trim();if(i[n])throw new Error("Only one "+n+" is allowed");return i[n]=!0,e}{if("|"===e[0]){if(i.items)throw new Error("Only one items is allowed");return i.items=!0,"items:["+function(t,e='"'){return t.map(t=>$e(t,e))}(e.split("|").filter(Boolean))+"]"}const t=parseInt(e.trim());if(!isNaN(t)){if(i.maxPick)throw new Error("Only one maxPick is allowed");return i.maxPick=!0,"maxPick:"+t}if("random"===e||"ai"===e)return i.type=!0,'type:"'+e+'"';if(Ee(e)){if(i.separator)throw new Error("Only one separator is allowed");return i.separator=!0,"separator:"+e}}});return s}(s,n,r)+"}"}async function Se([t,e],n,r,i){let s,o;if(r||(r={}),t){const t=e.split(":");s=t[0].trim(),o=t[1].trim()}else o=e,s=n+"";const a={template:o,data:{...(0,de.omitBy)(r,(t,e)=>!e||"_"===e[0]||"function"==typeof t),...i?.templateData}};i?.templateFormat&&(a.templateFormat=i.templateFormat);const c=await O.StringTemplate.formatIf(a);if(c)return o=Ee(c)?c:JSON.stringify(c),s+":"+o}async function Te(t,e,n,r){let i=be(t,0,n,r);return i||(i=await Se(t,e,n,r)),i}function Ee(t){const e=t[0];return('"'===e||"'"===e)&&t[t.length-1]===e}function ke(t,e=['""',"''","{}"]){return e.some(e=>t[0]===e[0]&&t[t.length-1]===e[1])}function $e(t,e='"'){return Ee(t)?t:e+t+e}function Ae(t){return'"'+t.replace(/(?<!\\)"(?!\\)/g,'\\"')+'"'}var xe=["true","false","null","undefined","NaN","Infinity"];async function Ce(t,e,n){const r=(0,pe.newFunction)("async expression",[],`return ${t};`,Xe(e));let i;try{i=await r.call(this)}catch(t){if(n||!(t instanceof ReferenceError))throw t}switch(typeof i){case"number":case"boolean":case"undefined":return i;case"function":return r.toString();default:return JSON.stringify(i)}}async function Oe(t,e,n){let r=t;if(["true","false"].includes(t.toLowerCase()))r=r.toLowerCase();else if(!(i=t,ke(i)||!Number.isNaN(parseFloat(i))||xe.includes(i)||Le(i)||e&&void 0!==(0,de.get)(e,t)||Le(t)))try{r=n?.skipExpression?Ae(t):await Ce.call(this,t,e,n?.preserveUnresolvedName)}catch(e){r=Ae(t)}var i;return r}async function Ne(t,e,n,r){const[i,s]=t,o=r?.argProcessor,a=r?.ignoreIndexNamed;if("function"==typeof o){const i=await o(t,e,n,r);if(i)return i}if(i){const t=s.indexOf(":");return s.slice(0,t).trim()+":"+await Oe(s.slice(t+1).trim(),n,r)}{const t=s.trim();if(n&&void 0!==(0,de.get)(n,t)){return(a?"":e+":"+t+",")+'"'+t+'":'+t}return e+":"+await Oe(s.trim(),n,r)}}function je(t,e,n){const r=n?.delimiter??",",i=n?.assigner??"=";let s=[],o=!1,a="",c="",u=!1,h="";for(let e=0;e<t.length;e++){const n=t[e];if(n!==r||o||h)if("\\"===n)c+=n,e++,c+=t[e];else if("("!==n&&"["!==n||o)if(h&&n===h)h="",c+=n;else if("{"!==n||o)'"'===n||"'"===n?(o&&n===a?o=!1:o||(o=!0,a=n),c+=n):n!==i||o||u||!/^[\p{L}\p{N}_ ]+$/u.test(c)?c+=n:(c+=":",u=!0);else{let r,i=e,s=!1,o="",a=-1;for(;i<t.length&&("}"!==(r=t[i])||s||a>0);)"\\"===r?i++:"{"!==r||s?"}"!==r||s?'"'!==r&&"'"!==r||(s&&n===o?s=!1:s||(s=!0,o=n)):a--:a++,i++;i<t.length&&(c+=t.substring(e,i+1),e=i)}else h="("===n?")":"]",c+=n;else c=c.trim(),c.endsWith(":")&&(c+="undefined"),s.push([u,c]),c="",u=!1}return c&&(c=c.trim(),c.endsWith(":")&&(c+="undefined"),s.push([u,c])),s}async function Ie(t,e,n){const r=t.match(/^([^(]+)(?:\((.*)\))?$/);if(!r){if(n?.raiseError)throw new Error("Invalid command format");return}const[,i,s]=r;let o;return s&&(o=await me(s,e,n)),{command:i.trim(),args:o}}var qe="__PlacEhoLdeR_";function Re(t,e){let n=e?.startChar?Array.isArray(e.startChar)?e.startChar:[e.startChar]:['"',"'"],r=e?.endChar?Array.isArray(e.endChar)?e.endChar:[e.endChar]:n;if(n.length!==r.length)throw new Error("start and end characters must have the same length");const i=e?.placeholder??qe,s=n.every((t,e)=>t===r[e]),o=e?.placehoders??[];if(s){n=n.map(t=>"\\"+t);const e=new RegExp(`(?<!\\\\)(${n.join("|")}).*?(?<!\\\\)\\1`);let r;for(;null!==(r=e.exec(t));){const e=`${i}${o.length}`;t=t.replace(r[0],e),o.push(r[0])}}else{n=n.map(t=>"\\"+t),r=r.map(t=>"\\"+t);for(let e=0;e<n.length;e++){const s=new RegExp(`(?<!\\\\)${n[e]}.*?(?<!\\\\)${r[e]}`);let a;for(;null!==(a=s.exec(t));){const e=`${i}${o.length}`;t=t.replace(a[0],e),o.push(a[0])}}}return[t,o]}function Me(t,e,n){const r=n?.placeholder??qe;return e.reduce((t,e,n)=>t.replace(new RegExp(r+n,"g"),e),t)}var Fe="[a-zA-Z_$][a-zA-Z_\\d$]*",Pe=new RegExp(`^\\s*(\\(\\s*\\)|${Fe}|\\(${`${Fe}\\s*(,\\s*${Fe})*`}\\))\\s*=>`);function Le(t){return Pe.test(t)}async function ze(t,e){if(e&&(e=Xe(e)),e&&(t=t.trim()).startsWith("{")&&t.endsWith("}")){return await me(t.slice(1,-1),e,{assigner:":",ignoreIndexNamed:!0})}return _e(t,e)}function _e(t,e){if(e&&(e=Xe(e)),e){const n=Object.keys(e);if(n.length){const r=Object.values(e);let i=0;for(;i++<100;)try{return(0,fe.newFunction)("expression",n,`return ${t}`)(...r)}catch(t){if(!(t instanceof ReferenceError))throw t;{const e=/(.+)\s+is not defined/.exec(t.message);if(!e)throw t;n.push(e[1]),r.push(void 0)}}}}return(0,fe.newFunction)("expression",[],`return ${t}`)()}var De=/^[a-zA-Z_$][0-9a-zA-Z_$.]*$/,Be=t=>De.test(t);function Xe(t){if(t){const e=Object.keys(t),n=e.length,r=e.filter(e=>Be(e)&&null!==t[e]);if(n===r.length)return t;if(r.length)return t=(0,le.pick)(t,r)}}function Je(t){return t?Ge(t,[],{dot:""}):[]}function Ge(t,e,{dot:n=".",visited:r=new Set}={}){return r.has(t)?[e.join("")]:Array.isArray(t)?(r.add(t),t.flatMap((t,n)=>Ge(t,[...e,`[${n}]`],{dot:".",visited:r}))):(i=t)&&i.constructor===Object?(r.add(t),Object.entries(t).flatMap(([t,i])=>Ge(i,[...e,n+t],{dot:".",visited:r}))):[e.join("")];var i}function Ue(t){if(t<2)throw new y.CommonError("repetitionThreshold must be greater than 1","createEndWithRepetitionDetector",y.ErrorCode.InvalidArgument);const e=new RegExp(`([\\S\\s]+)(\\1{${t-1},})$`);return function(t){return e.exec(t)}}var We=c(require("path")),He=c(require("fs")),Ze=c(require("mime-type/with-db")),Ke=c(require("jschardet"));function Ve(t){const e=He.statSync(t,{throwIfNoEntry:!1});return e?.isFile()}function Qe(t,e,n,r){const i=r?.signal,s=r?.exclude;let o;if(We.default.isAbsolute(t)?o=Ve(t)?t:Ye(We.default.basename(t),[We.default.dirname(t)],{extNames:n,exclude:s,signal:i}):(e||(e=["."]),o=Ye(t,e,{extNames:n,exclude:s,signal:i})),!o)throw new y.NotFoundError(t,"loadFileFromPaths");{const t=o;o=He.readFileSync(o),r&&(r.filepath=t)}return o}function Ye(t,e,{extNames:n,signal:r,exclude:i=[]}){let s;const o=n?n.map(e=>(0,ae.getMultiLevelExtname)(t,(0,ae.extNameLevel)(e))):void 0;"string"==typeof i&&(i=[i]);for(const a of e){if(r?.aborted)throw r.reason;const e=We.default.resolve(a,t);if(o)for(let t=0;t<o.length;t++){const r=e+(o[t]!==n[t]?n[t]:"");if(!i.includes(r)&&Ve(r)){s=r;break}}else if(!i.includes(e)&&Ve(e)){s=e;break}}return s}function tn(t,e,n,r,i){let s;"string"==typeof r?(s=r,r=void 0):s=r?.encoding;return en(Qe(t,e,n,r),s)}function en(t,e){void 0===e&&(e=cn(t)??"utf8");return new TextDecoder(e).decode(t)}function nn(t,e){const n=[],r="string"==typeof t?[{dir:t,level:0}]:[...t.map(t=>({dir:t,level:0}))],i=new Set,s=e?.signal,o=e?.isFileMatched,a=e?.level,c=e?.resolveSymlinks??!0;let u=0;for(;r.length>0;){if(s?.aborted)throw s.reason;const t=r.pop(),e=c?rn(t.dir):t.dir,h=We.default.resolve(e);if(i.has(h))continue;i.add(h);const l=He.statSync(e,{throwIfNoEntry:!1});if(l?.isDirectory()){u=t.level+1;const i=He.readdirSync(e,{withFileTypes:!0});for(let t=0;t<i.length;t++){let s=i[t],h=We.default.join(e,s.name);const l=h;if(s.isSymbolicLink()){const t=We.default.dirname(h);if(h=He.readlinkSync(h),h=We.default.resolve(t,h),s=He.statSync(h,{throwIfNoEntry:!1}),!s)continue}if(s.isDirectory())(!a||u<a)&&(o&&!o(h,s)||r.push({dir:h,level:u}));else if(s.isFile()&&(!o||o(h,s))){const t=c?h:l;n.includes(t)||n.push(t)}}}}return n}function rn(t){const e=He.lstatSync(t,{throwIfNoEntry:!1});return e?.isSymbolicLink()&&(t=He.readlinkSync(t)),t}async function sn(t,e){return ie(ReadableStream.from(He.createReadStream(t)),e)}async function on(t){const e=We.default.basename(t);t=We.default.resolve(t);const n=await He.promises.stat(t),r=n.mtime,i=n.ctime,s=n.size,o=an(s),a=await sn(t,{hashAlgo:o}),c=Ze.default.lookup(t);return{name:e,mtime:r,ctime:i,size:s,hash:Wt[o]+":"+a,mimeType:c,id:"file://"+t}}function an(t){let e=111;return t<=2048?e=112:t<=1048576?e=111:t<=10485760?e=113:t>10485760&&(e=10),e}function cn(t,e){return Ke.default.detect(t,e).encoding}var un=require("fs"),hn=c(require("path")),ln=require("@isdk/util"),fn=require("yaml-types"),dn=require("mime-type/with-db"),pn=require("@isdk/util");function mn(t,e){const n=[],r=e?.after,i=e?.exclude?"string"==typeof e.exclude?[e.exclude]:e.exclude:void 0,s=e?.extensions?"string"==typeof e.extensions?[e.extensions]:e.extensions.map(t=>t.startsWith(".")?t:"."+t):[".yml",".yaml",".json"];return(0,ln.traverseFolderSync)(t,(t,e)=>{if(i?.includes(t)||!e.isFile())return;const o=hn.default.extname(t),a=(0,un.statSync)(t);if(s.includes(o)){if(r?.hasOwnProperty(t)&&a.mtimeMs<=r[t])return;n.push(t)}}),n}function yn(t,e){return mn(t,e).map(t=>ln.ConfigFile.loadSync(t)).filter(t=>void 0!==t)}function wn(t,e,n=1){return ln.ConfigFile.saveSync(t,e,{extLevel:n})}function vn(t){t instanceof Date&&(t=t.toISOString());return function(t,e){return t?`'${e}'`:String(e)}("string"==typeof t,t)}function gn(t,e){return t.map(t=>Tn(t,e)).join(" AND ")}function bn(t,e){return t.map(t=>Tn(t,e)).join(" OR ")}function Sn(t,e){const n=[];return Object.keys(e).forEach(r=>{const i=e[r];switch(r){case"$lt":case"<":n.push(`${t} < ${vn(i)}`);break;case"<=":case"$lte":n.push(`${t} <= ${vn(i)}`);break;case"$gt":case">":n.push(`${t} > ${vn(i)}`);break;case"$gte":case">=":n.push(`${t} >= ${vn(i)}`);break;case"$ne":case"!=":n.push(`${t} != ${vn(i)}`);break;case"=":case"$eq":n.push(`${t} = ${vn(i)}`);break;case"$in":n.push(`${t} IN (${i.map(t=>vn(t)).join(", ")})`);break;case"$nin":n.push(`${t} NOT IN (${i.map(t=>vn(t)).join(", ")})`);break;case"$regex":n.push(`${t} REGEXP '${i.source}'`);break;case"$like":n.push(`${t} LIKE '${i}'`);break;case"$nlike":n.push(`${t} NOT LIKE '${i}'`);break;case"$glob":n.push(`${t} GLOB '${i}'`);break;case"$nglob":n.push(`${t} NOT GLOB '${i}'`);break;default:throw new Error(`Unsupported condition operator: ${r}`)}}),n.join(" AND ")}function Tn(t,e){const n=[];if("function"!=typeof e&&(e=t=>t),Array.isArray(t))n.push(gn(t,e));else for(const[r,i]of Object.entries(t))if("$and"===r)n.push(`(${gn(t[r],e)})`);else if("$or"===r)n.push(`(${bn(t[r],e)})`);else{const t=typeof i;if(null==i)n.push(`${e(r)} IS NULL`);else if(i instanceof Date)n.push(`${e(r)}='${i.toISOString()}'`);else if("object"!==t||Array.isArray(i))if("string"===t)n.push(`${e(r)}='${i}'`);else{if("number"!==t&&"boolean"!==t)throw new Error(`Unsupported value type for key ${r}`);n.push(`${e(r)}=${i}`)}else n.push(Sn(e(r),i))}return n.length>1?n.join(" AND "):n[0]}function En(t){const e=t.indexOf("://");if(e>0)return t.substring(0,e)}function kn(t,e=0){let n,r=t*10**e;return t>=1e12?(r=Math.round(r/1e12),n="T"):t>=1e9?(r=Math.round(r/1e9),n="B"):t>=1e6?(r=Math.round(r/1e6),n="M"):t>=1e3?(r=Math.round(r/1e3),n="K"):(r=Math.round(r),n=""),r/=10**e,r.toFixed(e)+n}function $n(t){const e=t.match(/^\s*[+]?(\d+(?:[.]\d+)?)\s*([TBMK])?\s*$/i);if(!e)throw new y.CommonError("Invalid formatted parameter size string.","scaleToSize",y.ErrorCode.InvalidArgument);const n=parseFloat(e[1]),r=e[2]?.toLowerCase();switch(r){case"t":return 1e12*n;case"b":return 1e9*n;case"m":return 1e6*n;case"k":return 1e3*n;default:return n}}function An(t,e){const n=e?.level||0,r=e?.visiting||new Set,i=e?.objectTag||"*",s=e?.arrayTag||"-",o=!0===e?.title?"name":e?.title;let a=[];const c=" ".repeat(2*n);if(null!=t)switch(typeof t){case"object":r.has(t)?a=["[Circular]"]:(r.add(t),a=Array.isArray(t)?t.map(e=>s+u(e,t)):Object.entries(t).map(([e,n])=>i+" `"+e+"`:"+u(n,t)));break;case"string":return t;default:return JSON.stringify(t)}else a=["null"];return a.length?c+a.join("\n"+c):"";function u(t,e){const i=null!=t&&"object"==typeof t;let s="";return o&&"string"==typeof o&&i&&t[o]&&"string"==typeof t[o]&&(s=" "+t[o],delete t[o]),(i?s+"\n":" ")+An(t,{level:n+1,visiting:r,parent:e})}}(0,ln.registerYamlTag)(fn.regexp);var xn=class t{constructor(t=0){this.bitField=t}static has(t,e){return!!(t&1<<e)}static add(t,e){return t|1<<e}static delete(t,e){return t&~(1<<e)}add(t){return this.bitField|=1<<t,this}delete(t){return this.bitField&=~(1<<t),this}has(e){return t.has(this.bitField,e)}clear(){return this.bitField=0,this}valueOf(){return this.bitField}toString(){return this.bitField.toString()}toJSON(){return this.bitField}},Cn=require("util-ex"),On=require("events-ex");function Nn(t=0){return e=Math.min(Math.max(16,t),1073741824),e>>>=0,e-=1,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,1+(e|=e>>16);var e}var jn=class extends Array{constructor(t,e){Array.isArray(t)?(super(...t),this._length=t.length,t=void 0):(super(),this._length=0),this._capacity=Nn(t),this._front=0,this._disableAutoResize=e}push(t){let e=this._length;this.checkCapacity(e+1);const n=this._front+e&this._capacity-1;return this[n]=t,++e<=this._capacity&&(this._length=e),n}unshift(t){let e=this._length;this.checkCapacity(++e);const n=this._capacity,r=(this._front-1&n-1^n)-n;return this[r]=t,this._front=r,e<=this._capacity&&(this._length=e),r}pop(t){let e=this._length;if(0===e)return;let n=this._front+e-1&this._capacity-1,r=this[n];for(;--e>0&&t&&null==r;)n--,r=this[n];return this[n]=void 0,this._length=e,r}shift(t){let e=this._length;if(0===e)return;let n=this._front,r=this[n];for(;--e>0&&t&&null==r;)n=n+1&this._capacity-1,r=this[n];return this[n]=void 0,this._front=n+1&this._capacity-1,this._length=e,r}get size(){return this._length}get(t){let e;if(t===(0|t)){const n=this._length;t<0&&(t+=n),t>=0&&t<n&&(e=this[this._front+t&this._capacity-1])}return e}peekBack(){const t=this._length;if(0===t)return;return this[this._front+t-1&this._capacity-1]}peekFront(){if(0!==this._length)return this[this._front]}clear(){const t=this._length,e=this._front,n=this._capacity;for(let r=0;r<t;++r)this[e+r&n-1]=void 0;this._length=0,this._front=0}isEmpty(){return 0===this._length}removeAt(t){const e=this._length;if(t<0||t>=e)return;const n=this._front,r=this._capacity-1,i=n+t&r,s=this[i];if(t<e/2)this.copyWithin(n+1&r,n,n+t&r),this[n]=void 0,this._front=n+1&r;else{this.copyWithin(i,i+1&r,n+e&r);this[n+e-1&r]=void 0}return this._length=e-1,s}checkCapacity(t){this._capacity<t&&!this._disableAutoResize&&this.resizeTo(Nn(1.5*this._capacity+16))}resizeTo(t){const e=this._capacity;this._capacity=t;const n=this._front,r=this._length;if(n+r>e){!function(t,e,n,r,i){for(let s=0;s<i;++s)n[s+r]=t[s+e],t[s+e]=void 0}(this,0,this,e,n+r&e-1)}}},In=require("@isdk/common-error"),qn=32;function Rn(t){return"function"==typeof t}function Mn(){return"1"}var Fn=class{constructor(t={}){const{initFn:e=Mn,pauseFn:n,resumeFn:r,capacity:i=qn}=t;if(Rn(n)!==Rn(r))throw new Error("pauseFn and resumeFn must be both set for pausing");this.waiting=new jn(i),this.emitter=new On.EventEmitter,this.useDefaultTokens=e===Mn,this.pauseFn=n,this.resumeFn=r,this.initTokenFn=e,this.paused=!1,this._activeCount=0,this.initFree(t),this.init(t)}initFree(t){this.free=this.initTokenFn()}onReleased(t){const e=t?.token,n=this.waiting.shift(!0);n?this._dispatchTask(n,t):(this.resumeFn&&this.paused&&(this.paused=!1,this.resumeFn()),this.unlock(e))}init(t){this.emitter.on("release",t=>{this.onReleased(t)})}_newReleaser(t){let e=!1;const n=()=>{e||(e=!0,this.release(t))};return t&&Object.assign(n,t),n}_dispatchTask(t,e){const{resolve:n}=t;n(this._newReleaser(e))}lock(t){let e=this.free;if(e)return this.free=void 0,e}unlock(t){this.free=this.useDefaultTokens?"1":t??this.initTokenFn()}tryAcquire(t){return this.lock(t)}async acquire(t){this._activeCount++;const e=t?.signal,n=t=>{this.pauseFn&&!this.paused&&(this.paused=!0,this.pauseFn());const n=this.waiting.push(t),r=t.reject;return e&&e.addEventListener("abort",()=>{this.waiting[n]=void 0;const t=e.reason instanceof Error?e.reason:new In.AbortError(e.reason||"aborted");e.alreadyRejected=!0,r(t)}),n};let r=this.tryAcquire(t);const i=r&&(0,Cn.isAsync)(r),s=e=>new Promise((r,i)=>{const s={...t,resolve:r,reject:i,token:e};void 0===e?n(s):this._dispatchTask(s,{...t,token:e})});return i?r.then(t=>s(t)):s(r)}release(t){this._activeCount--,this.emitter.emit("release",t)}drain(){const t=[this.acquire()];return Promise.all(t)}abort(t){let e;for(;e=this.waiting.shift(!0);)e.reject(new In.AbortError(t))}get activeCount(){return this._activeCount}get pendingCount(){return this.waiting.size}},Pn=class extends Fn{constructor(t,e){if("number"==typeof t)(e=e||{}).maxConcurrency=t;else{if("number"!=typeof(e=t).maxConcurrency)throw new Error("maxConcurrency must be set");t=e.maxConcurrency}super(e),this.maxConcurrency=e.maxConcurrency,e.isReadyFn&&(this.isReady=e.isReadyFn)}initFree(t){const e=t.maxConcurrency=Math.max(1,t.maxConcurrency);this.free=new jn(e);for(let t=0;t<e;t++)this.free.push(this.initTokenFn())}tryAcquire(t){let e=this.isReady;if(e&&(0,Cn.isAsync)(e)){return e instanceof Promise||(e=e()),e.then(e=>{if(e)return this.lock(t)})}if(!e||e())return this.lock(t)}unlock(t){this.free.push(this.useDefaultTokens?"1":t??this.initTokenFn())}lock(t){return this.free.pop()}drain(){const t=new Array(this.maxConcurrency);for(let e=0;e<this.maxConcurrency;e++)t[e]=this.acquire();return Promise.all(t)}};function Ln(t,{timeUnit:e=1e3,uniformDistribution:n=!1}={}){const r=new Pn(n?1:t),i=n?e/t:e;return async function(){await r.acquire(),setTimeout(()=>r.release(),i)}}var zn,_n=require("@isdk/common-error"),Dn=class{constructor(){this._isSignaled=!1,this.waitQueue=[]}get signaled(){return this._isSignaled}signal(t){if(this._isSignaled)return;this._isSignaled=!0,this._signalValue=t;const e=this.waitQueue.slice();for(this.waitQueue.length=0;e.length>0;){const t=e.shift();t?.resolve(this._signalValue)}}reset(){this._isSignaled=!1,this._signalValue=void 0,this.waitQueue.length=0}abort(t){if(this.waitQueue.length){const e=this.waitQueue.slice();this.waitQueue.length=0;const n=new _n.AbortError(t);for(;e.length>0;){const{reject:t}=e.shift();t(n)}}}async wait(){return new Promise((t,e)=>{this._isSignaled?t(this._signalValue):this.waitQueue.push({resolve:t,reject:e})})}},Bn=require("custom-ability"),Xn=require("util-ex"),Jn=0,Gn=1,Un=2,Wn=(t=>(t[t.MultiTask=Jn]="MultiTask",t[t.Cancelable=Gn]="Cancelable",t[t.Priority=Un]="Priority",t))(Wn||{}),Hn=((zn=Hn||{})[zn.MultiTask=1<<Jn]="MultiTask",zn[zn.Cancelable=1<<Gn]="Cancelable",zn[zn.Priority=1<<Un]="Priority",zn),Zn=class extends AbortController{constructor(t){super(),(0,Xn.defineProperty)(this,"parent",t)}abort(t,e){this.signal.aborted||("string"==typeof t&&(t=new y.AbortError(t)),t&&e&&"object"==typeof t&&Object.assign(t.data,e),super.abort(t))}throwRejected(t){const e=this.signal;if(e.aborted){if(void 0===t&&(t=e.alreadyRejected),t)return!0;throw e.reason instanceof Error?e.reason:new y.AbortError(e.reason||"aborted")}}},Kn=class{get maxTaskConcurrency(){return this._maxTaskConcurrency}get semaphore(){return this.getSemaphore()}getSemaphore(t=this._isReadyFn){let e=this._maxTaskConcurrency,n=this.__task_semaphore;return e>0&&!n&&(t&&(t=t.bind(this)),n=this.__task_semaphore=new Pn(e-1,{isReadyFn:t})),n}static hasAsyncFeature(t){const e=this.prototype;let n=e.asyncFeatures;return e._asyncFeatures&&(n|=e._asyncFeatures),xn.has(n,t)}hasAsyncFeature(t){let e=this.asyncFeatures;return this._asyncFeatures&&(e|=this._asyncFeatures),xn.has(e,t)}isAborted(t){const e=this.hasAsyncFeature(Jn);let n=this.__task_aborter;if(n&&e){if(null==t)throw new y.CommonError("Missing taskId",this.name+".isAborted",y.ErrorCode.InvalidArgument);n=n[t]}return!n||n.signal.aborted}getRunningTask(t){const e=this.hasAsyncFeature(Jn);let n=this.__task_aborter;if(n&&e){if(null==t)throw new y.CommonError("Missing taskId",this.name+".getRunningTask",y.ErrorCode.InvalidArgument);n=n[t]}return n?.signal.aborted&&(e?this.__task_aborter[t]=void 0:this.__task_aborter=void 0,n=void 0),n}getRunningTaskCount(){let t;if(this.hasAsyncFeature(Jn)){const e=this.__task_aborter;t=e&&Object.entries(e).filter(([t,n])=>{if(!n?.signal.aborted)return!0;e[t]=void 0}).length}else{const e=this.__task_aborter;t=e?.signal.aborted?0:1}return t}_generateAsyncTaskId(t,e){if(e||(e=this.__task_aborter),null==t&&(t=0,e))for(;e[t];)t++;return t}$generateAsyncTaskId(t,e){const n=this.super,r=this.self||this;return t=n?n.call(r,t):this._generateAsyncTaskId(t,e)}createAborter(t,e,n=!0){const r=this.hasAsyncFeature(Jn);if(!r&&n&&this.getRunningTask())throw new y.CommonError("The task is running",this.name,y.ErrorCode.TooManyRequests);const i=t?.aborter||new Zn(this);if(!(i instanceof Zn)){if(!(i instanceof AbortController))throw new y.CommonError("aborter should be an AbortController",this.name,y.ErrorCode.InvalidArgument);Object.setPrototypeOf(i,new Zn(this))}if(r){null==this.__task_aborter&&(this.__task_aborter={});const t=this.__task_aborter;null==e&&(e=this.generateAsyncTaskId(e,t)),i.id=e,t[e]=i}else this.__task_aborter=i;const s=[...Vn(t?.signal),...Vn(t?.signals)];s.length&&function(t,e){if(!e.length)return;const n=[],r=()=>{for(const t of n)try{t()}catch{}n.length=0},i=e.find(t=>t.aborted);if(i){const e=i.reason;try{t.abort(e||"aborted")}catch{}return}for(const r of e){const e=()=>{const e=r.reason;try{t.abort(e||"aborted")}catch(t){console.log(t)}};r.addEventListener("abort",e,{once:!0}),n.push(()=>r.removeEventListener("abort",e))}const s=()=>r();t.signal.addEventListener("abort",s,{once:!0}),n.push(()=>t.signal.removeEventListener("abort",s))}(i,s);const o=t?.timeout;return o>0&&(i.timeoutId=setTimeout(()=>{i.timeoutId=void 0,this.abort("timeout",{timeout:o})},o)),i.signal.addEventListener("abort",()=>{const t=i.timeoutId;t&&(i.timeoutId=void 0,clearTimeout(t));const e=i.signal;try{this.emit&&this.emit("aborting",e.reason,e.reason?.data)}finally{try{i.streamController?.error?.(e.reason)}catch{}}}),i}$cleanMultiTaskAborter(t,e){const n=this.super,r=this.self||this;n?n.call(r,t,e):r._cleanMultiTaskAborter(t,e)}cleanTaskAborter(t){if(this.hasAsyncFeature(Jn)){const e=this.__task_aborter;this.cleanMultiTaskAborter(t.id,e)}else this.__task_aborter=void 0}_cleanMultiTaskAborter(t,e){"number"==typeof t?e[t]=void 0:delete e[t]}createTaskPromise(t,e,n){const r=this.createAborter(e,n?.taskId,n?.raiseError);void 0===e&&(e={}),"object"==typeof e&&(e.aborter=r);let i=t(e,r).then(t=>{if(t&&t instanceof ReadableStream){const e=()=>{this.cleanTaskAborter(r)},n=Ft({onStart:t=>{(0,Xn.defineProperty)(r,"streamController",t)},onFinal:e,onError:e,onTransform:(t,e)=>(t&&"object"==typeof t&&(t.taskId=r.id),t)});t=t.pipeThrough(n)}else this.cleanTaskAborter(r);return t}).catch(t=>{throw this.cleanTaskAborter(r),t}).finally(()=>{r.timeoutId&&(clearTimeout(r.timeoutId),r.timeoutId=void 0)});return i.task=r,i}runAsyncCancelableTask(t={},e,n){let r=this.createTaskPromise(e,t,n);const i=this.getSemaphore(n?.isReadyFn);if(i){const t=r,e=t.task;r=i.acquire({signal:e.signal}).then(()=>t).finally(()=>{i.release()}),r.task=e}return r}abort(t,e){let n=this.__task_aborter;if(n){const r=n;if(this.hasAsyncFeature(Jn)){const t=e?.taskId;if(null==t)throw new y.CommonError("Missing data.taskId",this.name+".abort",y.ErrorCode.InvalidArgument);n=n[t],this.cleanMultiTaskAborter(t,r)}else this.__task_aborter=void 0;n&&!n.signal.aborted&&n.abort(t,e)}}};function Vn(t){return t?Array.isArray(t)?t.filter(Boolean):[t]:[]}Kn.prototype.generateAsyncTaskId=function(t,e){return this._generateAsyncTaskId(t,e)},Kn.prototype.cleanMultiTaskAborter=function(t,e){return this._cleanMultiTaskAborter(t,e)};var Qn=(0,Bn.createAbilityInjector)(Kn,"abort",{afterInjection:function(t,e){let n=t.prototype._asyncFeatures||0;n|=Hn.Cancelable,e&&(e.asyncFeatures&&(n|=e.asyncFeatures),e.maxTaskConcurrency>0&&(t.prototype._maxTaskConcurrency=e.maxTaskConcurrency),e.isReadyFn&&"function"==typeof e.isReadyFn&&(t.prototype._isReadyFn=e.isReadyFn)),t.prototype._asyncFeatures=n}});function Yn(t,e){const n=e.global?e:new RegExp(e.source,`${e.flags}g`);let r,i=0;for(;null!==(r=n.exec(t));)i++;return i}var tr=c(require("memoizee")),er=require("json-canonicalize");function nr(t,e){var n;void 0!==e?.promise||!function(t){return"function"==typeof t&&"AsyncFunction"===t.constructor.name}(t)&&(!(n=t)||"object"!=typeof n&&"function"!=typeof n||"function"!=typeof n.then)||(e={promise:!0,...e}),void 0===e?.length&&(e={length:!1,...e});const r=e?.normalizer;return(0,tr.default)(t,{...e,normalizer:t=>{if(r){const e=r(t);if("string"===e)return e;e&&(t=e)}return te((0,er.canonicalize)(t))}})}var rr=c(require("net"));async function ir(t,e=10){return new Promise((n,r)=>{void 0===t?t=0:("string"==typeof t&&(t=parseInt(t)),t>=0||(t=0));const i=rr.default.createServer();i.on("error",n=>{"EADDRINUSE"===n.code&&(t++,--e>0)?i.listen(t):r(n)}),i.on("listening",async()=>{const t=i.address().port;i.close(),n(t)}),i.listen(t)})}var sr=c(require("path")),or=require("package-directory");function ar(t){const e=(0,or.packageDirectorySync)({cwd:t});if(e)return e;const n=t.split(sr.default.sep);let r=n.lastIndexOf("dist");if(r>0)return n.slice(0,r).join(sr.default.sep);if(r=n.lastIndexOf("src"),r>0)return n.slice(0,r).join(sr.default.sep);throw new Error("can not find package directory")}var cr=c(require("path"));function ur(t,e){try{const n=cr.default.relative(cr.default.resolve(t),cr.default.resolve(e));return!n.startsWith("..")&&!cr.default.isAbsolute(n)}catch{return!1}}function hr(t,e){return e?.some(e=>ur(e,t))}function lr(t,e){for(const n of e)hr(n,t)||t.push(n);return t}function fr(t){const e=t.slice();return dr(e),e}function dr(t){const e=t.length;if(e<=1)return;const n=new Map,r=[];for(let i=0;i<e;i++){const e=pr(t[i]);n.has(e)||(r.push(e),n.set(e,i))}const i=[...r].sort(),s=new Set;for(let t=0;t<i.length;t++){const e=i[t];let n=!1;for(const t of s)if(ur(t,e)){n=!0;break}n||s.add(e)}let o=0;for(let n=0;n<e;n++)s.has(r[n])&&(o!==n&&(t[o]=t[n]),o++);t.length=o}function pr(t){let e=cr.default.normalize(t);return e=e.split(/[/\\]/).join(cr.default.posix.sep),e.length>1&&e.endsWith("/")&&(e=e.slice(0,-1)),e}var mr=require("util-ex");function yr(t){return(0,mr.isRegExpStr)(t)||(0,mr.isRegExp)(t)}function wr(t){return t.replace(/\x1B[[(?);]{0,2}(;?\d)*./g,"")}var vr=c(require("path")),gr=require("url"),br=require("@huggingface/transformers"),Sr=(0,gr.fileURLToPath)(h),Tr=vr.default.dirname(Sr),Er=vr.default.join(ar(Tr),".cache"),kr=new Map,$r={"deepseek-ai/DeepSeek-V2-Lite-Chat":"deepseek2","Qwen/Qwen2.5-0.5B":"Qwen2.5","Xenova/gpt-4":"gpt-4 / gpt-3.5-turbo / text-embedding-ada-002","Xenova/text-davinci-003":"text-davinci-003 / text-davinci-002","Xenova/gpt-3":"gpt-3","Xenova/grok-1-tokenizer":"Grok-1","Xenova/claude-tokenizer":"Claude","Xenova/mistral-tokenizer-v3":"Mistral v3","Xenova/mistral-tokenizer-v1":"Mistral v1","Xenova/gemma-tokenizer":"Gemma","Xenova/gemma2-tokenizer":"Gemma2","Xenova/llama3-tokenizer-new":"Llama 3","unsloth/Llama-3.2-1B-Instruct":"Llama 3.2","Xenova/llama-tokenizer":"LLaMA / Llama 2","Xenova/c4ai-command-r-v01-tokenizer":"Cohere Command-R","Xenova/t5-small":"T5","Xenova/bert-base-cased":"bert-base-cased"},Ar={deepseek2:"deepseek-ai/DeepSeek-V2-Lite-Chat","qwen2.5":"Qwen/Qwen2.5-0.5B","gpt-4":"Xenova/gpt-4","gpt-3.5-turbo":"Xenova/gpt-4","text-embedding-ada-002":"Xenova/gpt-4","text-davinci-003":"Xenova/text-davinci-003","text-davinci-002":"Xenova/text-davinci-003","gpt-3":"Xenova/gpt-3","grok-1":"Xenova/grok-1-tokenizer",claude:"Xenova/claude-tokenizer",mistral:"Xenova/mistral-tokenizer-v3",mistral3:"Xenova/mistral-tokenizer-v3",mistral1:"Xenova/mistral-tokenizer-v1",gemma:"Xenova/gemma-tokenizer",gemma2:"Xenova/gemma2-tokenizer",llama3:"Xenova/llama3-tokenizer-new",llama2:"Xenova/llama-tokenizer",llama:"Xenova/llama-tokenizer","llama3.2":"unsloth/Llama-3.2-1B-Instruct","cohere-command-r":"Xenova/c4ai-command-r-v01-tokenizer",t5:"Xenova/t5-small","bert-cased":"Xenova/bert-base-cased"};async function xr(t){let e=kr.get(t);return e||(e=br.AutoTokenizer.from_pretrained(t,{cache_dir:Er}),kr.set(t,e)),e}async function Cr(t,e="qwen2.5"){Ar[e]&&(e=Ar[e]);return(await xr(e)).encode(t)}async function Or(t,e="qwen2.5"){return(await Cr(t,e)).length}function Nr(t,e){const n=e?.capitalize??!0;let r=e?.delimiter??/[_-]/g;r instanceof RegExp&&(r.flags.includes("g")||(r=new RegExp(r.source,r.flags+"g")));let i=(t=t.replace(r," ")).split(" ").map(t=>t.trim()).filter(Boolean);return n&&(i=i.map(t=>t.charAt(0).toUpperCase()+t.slice(1))),t=i.join(" ")}async function jr(t,e){let n,r=1984,i=!0,s=!1,o=!0,a=Or,c=!0;if(e&&(n=e.modelId,e.size>=0&&(r=e.size),void 0!==e.corrected&&(i=e.corrected),void 0!==e.completeSentence&&(s=e.completeSentence),void 0!==e.truncLastSection&&(o=e.truncLastSection),"function"==typeof e.countLLMTokens&&(a=e.countLLMTokens),void 0!==e.bySentence&&(c=e.bySentence)),!c)throw new y.NotImplementationError("truncateToTokenLimit only implemented by sentence","truncateToTokenLimit");if(r>0){let c=await a(t,n);const u=e?.sentences??K(t,e);if(c>r)for(c=await a(u.join("\n"),n);c>r&&u.length;){const e=u.pop();if(e){if(c-=await a(e+"\n",n),s||i)t=u.join("\n");else{const n=t.lastIndexOf(e);if(-1===n)throw new y.CommonError(`Can not find sentence: ${e}`,"truncateContentToTokenLimit");t=t.slice(0,n)}if(c<=1)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");if(c<=r&&o){const e=u[u.length-1];if(e&&et(e)){if(c-await a(e,n)>9){const n=t.lastIndexOf(e);if(-1===n)throw new y.CommonError(`Can not find sentence: ${e}`,"truncateContentToTokenLimit");t=t.slice(0,n).trimEnd()}}}}else c--}else t=u.join("\n")}if(!t)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");return t}async function Ir(t,e){let n,r=1984,i=!0,s=Or,o=!0;if(e&&(n=e.modelId,e.size>=0&&(r=e.size),void 0!==e.truncLastSection&&(i=e.truncLastSection),"function"==typeof e.countLLMTokens&&(s=e.countLLMTokens),void 0!==e.bySentence&&(o=e.bySentence)),!o)throw new y.NotImplementationError("truncateToTokenLimit only implemented by sentence","truncateToTokenLimit");if(r>0){const e=(t=t.slice()).join("\n");let o=await s(e,n);if(o>r)for(;o>r&&t.length;){const e=t.pop();if(e){if(o-=await s(e,n),o<=1)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");if(o<=r&&i){const e=t[t.length-1];if(e&&et(e)){o-await s(e,n)>9&&t.pop()}}}}}if(!t.length)throw new y.CommonError(`Empty. Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");return t}async function qr(t,e){let n,r=1984,i=Or;if(e&&(n=e.modelId,"function"==typeof e.countLLMTokens&&(e.size>=0&&(r=e.size),i=e.countLLMTokens)),r>0){await i(t,n)}}var Rr=c(require("fs"));async function*Mr(t,e){const n=(e={...e,completeSentence:!1,corrected:!1}).size??1984,r=e.modelId,i=e.metaInfo?.size??(await Rr.default.promises.stat(t)).size;let s=Math.trunc(i/2);if(s<=n){let i=en(await Rr.default.promises.readFile(t));if(s=await Or(i,r),s<=n)yield i;else do{const t=await jr(i,{...e,modelId:r,size:n});yield t,i=i.slice(t.length)}while(i)}else{const i=ReadableStream.from(Rr.default.createReadStream(t)).getReader();let s="";for(;;){const{done:t,value:o}=await i.read();if(t)break;s+=en(o);const a=K(s,e);let c=a.pop();if(c){const t=s.lastIndexOf(c);c=s.slice(t),s=s.slice(0,t)}if(s.length>=n){const t=await jr(s,{...e,modelId:r,size:n,sentences:a});s=s.slice(t.length),yield t}for(;s.length>n;){const t=K(s,e),i=await jr(s,{...e,modelId:r,size:n,sentences:t});s=s.slice(i.length),yield i}void 0!==c&&(s+=c)}for(;s;){const t=K(s,e),i=await jr(s,{...e,modelId:r,size:n,sentences:t});s=s.slice(i.length),yield i}}}async function*Fr(t,e){const n=e?.size??1984,r=e?.modelId,i=e?.metaInfo?.size??(await Rr.default.promises.stat(t)).size;let s=Math.trunc(i/2);if(s<=n){let i=en(await Rr.default.promises.readFile(t));if(s=await Or(i,r),s<=n)yield K(i,e);else{let t=K(i,e);do{const i=await Ir(t,{...e,modelId:r,size:n});yield i,t=t.slice(i.length)}while(t.length)}}else{const i=ReadableStream.from(Rr.default.createReadStream(t)).getReader();let s="";const o=e?.completeSentence,a=e?.corrected,c=!o&&!a;let u;for(;;){const{done:t,value:o}=await i.read();if(t)break;s+=en(o),u=K(s,e);let a=u.pop();if(s.length>=n){const t=await Ir(u,{...e,modelId:r,size:n});s=c?s.slice(t.length):u.join("\n"),u=u.slice(t.length),s=u.join("\n"),yield t}for(;s.length>n;){const t=await Ir(u,{...e,modelId:r,size:n});u=u.slice(t.length),s=u.join("\n"),yield t}a&&u.push(a)}if(u)for(;u.length;){const t=await Ir(u,{...e,modelId:r,size:n});u=u.slice(t.length),yield t}}}async function Pr(t,e){const n=e?.size??1984,r=e?.modelId;let i=K(t,e);const s=[];if(await Or(t,r)<=n)s.push(i);else do{const t=await Ir(i,{...e,modelId:r,size:n});s.push(t),i=i.slice(t.length)}while(i.length);return s}var Lr=require("yaml"),zr=class{constructor(t){t&&Object.assign(this,t)}};function _r(t,e){class n extends Lr.YAMLMap{constructor(){super(...arguments),this.tag=t}toJSON(t,n){n={...n,mapAsMap:!1};const r=super.toJSON(t,n);return new e(r)}}return{tag:t,collection:"map",nodeClass:n,identify:t=>t instanceof e}}function Dr(t,e){let n=t.length===e.length;if(n){const r=Yt(t),i=Yt(e);n=r.every((t,e)=>t===i[e])}return n}var Br=require("lodash-es"),Xr=c(require("path")),Jr=".ai";function Gr(t,e=["."]){if(Xr.default.isAbsolute(t))return pn.ConfigFile.loadSync(t);const n=e.map(e=>pn.ConfigFile.loadSync(Xr.default.resolve(e,t))).filter(Boolean);return(0,Br.defaultsDeep)({},...n.reverse())}function Ur(t,e){const n={...process.env,...e};return(0,O.expandObjEnv)(t,{processEnv:n,parsed:n})}function Wr(t,e){let n=pn.ConfigFile.loadSync(Xr.default.resolve(e.configDir,t));n||(n={configDirs:["$XDG_BIN_HOME",e.configDir,"$HOME"],brainDir:Xr.default.join(e.dataDir,"brain"),agentDirs:[Xr.default.join(e.dataDir,"agent")],promptDirs:[Xr.default.join(e.dataDir,"prompt")],chatsDir:Xr.default.join(e.dataDir,"log","chats"),inputsDir:Xr.default.join(e.dataDir,"log","inputs")});const r=Zr(e);for(const[t,e]of Object.entries(r))n[t]=e;Ur(n,n);const i=n.configDirs;n.AI_CONFIG_BASENAME&&(t=n.AI_CONFIG_BASENAME);const s=Ur(Gr(t,i),n);return(0,Br.defaultsDeep)(s,(0,Br.omit)(n,Object.keys(r))),Qr(s),s}function Hr(t){return Wr(Jr,t)}function Zr(t){return{XDG_CONFIG_HOME:t.configDir,XDG_DATA_HOME:t.dataDir,XDG_CACHE_HOME:t.cacheDir,XDG_BIN_HOME:Xr.default.dirname(t.options.root)}}function Kr(t,e){t.startsWith("~")&&(t="$HOME"+t.slice(1));return Ur(t,e)}function Vr(t,e){return t.map(t=>Kr(t,e))}function Qr(t,e=["configDirs","brainDir","agentDirs","promptDirs","chatsDir","inputsDir"],n){for(const r of e){const e=(0,Br.get)(t,r);if(!e)continue;let i;Array.isArray(e)&&e.length?i=Vr(e,n):"string"==typeof e&&(i=Kr(e,n)),i&&(0,Br.set)(t,r,i)}}var{exit:Yr}=process,ti=!1,ei=!1,ni=["SIGINT","SIGTERM","exit"],ri=3e5,ii=[],si=(t,e)=>t.forEach(t=>process.once(t,e)),oi=t=>()=>{setTimeout(()=>(console.warn(`Could not close resources gracefully after ${t}ms: forcing shutdown`),Yr(1)),t).unref()};async function ai(t="shutdown",e=0){if(!ti){ti=!0,"number"==typeof t&&(e=t,t="shutdown");for(const e of ii)try{await e(t)}catch(t){console.warn(`A shutdown handler failed before completing with: ${t.message||t}`)}return Yr(e)}console.warn(`Shutdown already in progress, ignoring [${t}] signal`)}function ci(t){if(ei||ui(),!ii.some(e=>e===t))return ii.push(t),t}function ui(){ei||(ei=!0,process.exit=t=>{ti||ai(void 0,t).then()},si(ni,oi(ri)),si(ni,ai))}var hi=["<BOS>","<EOS>","<PAD>","<UNK>"],li=".,!?;?!",fi=[" ","\n","\t","▁"," "],di=["the","a","an","的","是","在"];function pi(t,e){const n=e?.exclude?function(t){const e=new Set;if(t.controlSymbols&&hi.forEach(t=>e.add(t)),t.punctuation)for(let t=0;t<li.length;t++)e.add(li[t]);return t.stopWords&&di.forEach(t=>e.add(t)),t.whitespace&&fi.forEach(t=>e.add(t)),Array.isArray(t.tokens)&&t.tokens.forEach(t=>e.add(t)),[...e]}(e.exclude):void 0;return n&&n.length&&(t=t.filter(t=>!n.includes(t.token.trim()))),mi(t)}function mi(t){if(!Array.isArray(t)||0===t.length)return;const e=t.reduce((t,e)=>t+e.probability,0);return Math.exp(-e/t.length)}var yi=require("lodash-es"),wi=/^\s*@inheritMerge\s*(?:[(]\s*(?<arg>\.start|\.end|false)[)])?/,vi=Symbol("MergeWay"),gi={replace:0,start:1,end:2};function bi(t,...e){return(0,yi.mergeWith)(t,...e,(t,e)=>Array.isArray(t)&&Array.isArray(e)?Si(t,e):void 0!==t&&"object"!=typeof t?t:void 0)}function Si(t,e){let n=t[vi];return void 0===n&&(t=function(t){const e=t[0];let n=".start";if("string"==typeof e){const r=wi.exec(e);r&&(r.groups?.arg&&(n=r.groups?.arg),t=t.slice(1))}else e&&"object"==typeof e&&e.hasOwnProperty("@inheritMerge")&&(n=e["@inheritMerge"]||n,t=t.slice(1));n&&(n=n.toLowerCase());let r=gi.start;"false"===n||"no"===n||"not"===n?r=gi.replace:".end"===n&&(r=gi.end);return Object.defineProperty(t,vi,{value:r,enumerable:!1}),t}(t),n=t[vi]),t=n===gi.replace?e:n===gi.end?t.concat(e):e.concat(t),Object.defineProperty(t,vi,{value:n,enumerable:!1}),t}function Ti(t,e=" "){return Ei(t).join(e)}function Ei(t){return t.split(/(?<=[a-z])(?=[A-Z])|(?<=\d)(?=[A-Za-z])|(?<=[A-Z])(?=[A-Z][a-z])|[\s_]+/g).filter(t=>t.length>0)}function ki(t){if(void 0!==t){const e=JSON.stringify(t);if("{}"!==e&&"[]"!==e&&'""'!==e)return"?p="+encodeURIComponent(e)}return""}var $i=require("lodash-es"),Ai=require("property-manager"),xi=require("util-ex"),Ci=class t extends Ai.AdvancePropertyManager{static{this.items={}}static{this.aliases={}}static get(t){let e=this.items[t];return!e&&(t=this.aliases[t])&&(e=this.items[t]),e}static list(){return this.items}static getByTag(t){let e;for(const n in this.list()){const r=this.get(n);let i=r.tags;if("string"==typeof i){if(i===t){e=r;break}}else if(Array.isArray(i)&&i.indexOf(t)>=0){e=r;break}}return e}static getAllByTag(t){let e=[];for(const n in this.list()){const r=this.get(n);let i=r.tags;"string"==typeof i?i===t&&e.push(r):Array.isArray(i)&&i.indexOf(t)>=0&&e.push(r)}return e}static hasAsyncFeature(t){const e=this.prototype;let n=e.asyncFeatures??0;return e._asyncFeatures&&(n|=e._asyncFeatures),xn.has(n,t)}static run(t,e){const n=this.get(t);if(n)return n.run(e);throw new y.NotFoundError(`${t} to run`,this.name)}static runSync(t,e){const n=this.get(t);if(n)return n.runSync(e);throw new y.NotFoundError(`${t} to run`,this.name)}static getFunc(t){const e=this.get(t);return e?.getFunc()}static runWithPos(t,...e){const n=this.get(t);if(n)return n.runWithPos(...e);throw new y.NotFoundError(`${t} to run`,this.name)}static runWithPosSync(t,...e){const n=this.get(t);if(n)return n.runWithPosSync(...e);throw new y.NotFoundError(`${t} to run`,this.name)}static getFuncWithPos(t){const e=this.get(t);return e?.getFuncWithPos()}static register(e,n={}){switch(typeof e){case"string":n.name=e;break;case"function":n.func=e;break;case"object":n=e}e=n.name;let r=!!this.get(e);if(r)r=!1;else{if(!(n instanceof t))return r=new this(n),r.register();if(this.items[e]=n,n.alias){const t=n.alias;if("string"==typeof t)this.aliases[t]&&(0,y.throwError)(`Alias ${t} already exists for ${e}`),this.aliases[t]=e;else if(Array.isArray(t))for(const n of t)this.aliases[n]&&(0,y.throwError)(`Alias ${n} already exists for ${e}`),this.aliases[n]=e}r=n}return r}static unregister(t){const e=this.get(t);if(e&&(delete this.items[t],e.alias)){const t=e.alias;if("string"==typeof t)delete this.aliases[t];else if(Array.isArray(t))for(const e of t)delete this.aliases[e]}return e}constructor(t,e={}){switch(super(),typeof t){case"string":e.name=t;break;case"function":e.func=t;break;case"object":e=t}this.name=t=e.name,e.scope&&(this.scope=e.scope),"function"==typeof e.setup&&e.setup.call(this,e),this.initialize(e)}register(){const e=this.constructor,n=this.depends;if(n){const e=Object.keys(n);for(const r of e){const e=n[r];e instanceof t&&e.register()}}return e.register(this)}unregister(){return this.constructor.unregister(this.name)}arr2ObjParams(t){if(this.params&&(t.length>1||Array.isArray(t[0])||t[0]&&"object"!=typeof t[0])){const e={},n=Object.keys(this.params);let r=Math.min(n.length,t.length);for(let i=0;i<r;i++)e[n[i]]=t[i];t=[e]}return t}obj2ArrParams(t){const e=[];if(t&&this.params&&Array.isArray(this.params)){const n=Object.keys(t);let r=Math.min(n.length,this.params.length);for(let i=0;i<r;i++)e.push(t[n[i]])}return e}runSync(t){const e=this.params&&Array.isArray(this.params);if(Array.isArray(t)){if(e)return this.func(...t);(0,y.throwError)("the function is not support array params, the params must be object!",this.name)}return e?(t=this.obj2ArrParams(t),console.warn('Warning:Use runWithPos() instead of run() for the "'+this.name+'" is function with position params'),this.func(...t)):this.func(t)}run(t){return this.runSync(t)}runAs(t,e){return this.runAsSync(t,e)}runAsSync(t,e){return this.constructor.runSync(t,e)}getFunc(t){return t?this.constructor.getFunc(t):this.runSync.bind(this)}runWithPosSync(...t){return this.params&&!Array.isArray(this.params)&&(t=this.arr2ObjParams(t)),this.func(...t)}runWithPosAsSync(t,...e){return this.constructor.runWithPosSync(t,...e)}runWithPos(...t){return this.runWithPosSync(...t)}runWithPosAs(t,...e){return this.runWithPosAsSync(t,...e)}getFuncWithPos(t){return t?this.constructor.getFuncWithPos(t):this.runWithPosSync.bind(this)}hasAsyncFeature(t){let e=this.asyncFeatures??0;return this._asyncFeatures&&(e|=this._asyncFeatures),xn.has(e,t)}isStream(t){let e=this.stream;if(e){const n=this.params;n?.stream&&(e=t?.stream)}return e}},Oi={name:{type:"string"},description:{type:"string"},title:{type:"string"},func:{type:"function",assign(t,e,n,r,i){let s=t;const o=typeof t;return i.isExported?s="function"===o?t.toString():t:t&&("string"!==o&&(t=t.toString()),s=(0,xi._createFunction)(t,e.scope)),s}},params:{type:"object"},result:{type:"any"},setup:{type:"function"},depends:{type:"object",exported:!1},tags:{type:["array","string"]},isApi:{type:"boolean"},stream:{type:"boolean"},asyncFeatures:{type:"number"},alias:{type:["array","string"]}};Ci.defineProperties(Ci,Oi);var Ni=Symbol("meta");function ji(t,e,n=!0){if(e&&"object"==typeof e){if("function"==typeof t)return e=n?(0,$i.assign)({},t[Ni],e):(0,$i.defaultsDeep)({},t[Ni],e),t[Ni]=e,t;if(t instanceof Ci)return t.assign(e)}}function Ii(t){return"function"==typeof t?t[Ni]:t instanceof Ci?t.toObject():void 0}var qi="A client transport has not been set. Use ClientTools.setTransport() or transport.mount(ClientTools) first.",Ri=class t extends Ci{static get apiRoot(){return this._transport||(0,y.throwError)(qi,"ClientTools"),this._transport.apiRoot}static setTransport(t){if(t){this._transport=t;const e=this.constructor;t.Tools!==e&&(t.Tools=e)}}static get transport(){return this._transport}static async loadFrom(t){return t||(this._transport||(0,y.throwError)(qi,"ClientTools"),t=await this._transport.loadApis()),t&&this.loadFromSync(t),t}static loadFromSync(e){for(const n in e){const r=this.get(n),i=e[n];r?r instanceof t?r.assign(i):(0,y.throwError)(`${n} already registered as ${r.constructor.name}`,"ClientTools"):this.register(i)}}static async fetch(t,e,...n){const r=this.get(t);if(r&&r.fetch)return r.fetch(e,...n)}get apiRoot(){return this.constructor.apiRoot}async fetch(t,e,n){const r=this.constructor;if(r._transport)return r._transport.fetch(this.name,t,e,n,this.fetchOptions);(0,y.throwError)(qi,"ClientTools")}async func(t){return await this.fetch(t)}},Mi={...m};Ri.defineProperties(Ri,Mi);var Fi=class t extends Ci{static get apiRoot(){return this._apiRoot}static setApiRoot(t){this._apiRoot=t}static toJSON(){const e={};for(const n in this.items){let r=this.items[n];(r instanceof t||r.isApi)&&(r.allowExportFunc||(r=r.toJSON(),delete r.func),e[n]=r)}return e}run(t,e){return e&&(t._req=e.req,t._res=e.reply),super.run(t)}func(t){}},Pi={...m};Fi.defineProperties(Fi,Pi);var Li=require("events-ex"),zi=class extends Ci{constructor(){super(...arguments),this._emitter=new Li.EventEmitter,this.description="Return event bus",this.result="event"}get emitter(){return this._emitter}func(){return this.emitter}},_i=new zi(bt),Di=require("secondary-cache"),Bi=require("secondary-cache"),Xi=Di.Cache;function Ji({key:t,value:e,options:n}={}){return void 0!==t?null===e?this.cache.del(t):void 0!==e?this.cache.set(t,e,n):this.cache.get(t):(n&&this.cache.setDefaultOptions(n),this.cache)}function Gi(t,e){let n=Ci.get(t);return n||(n=new Ci(t,{func:Ji,description:"get/set LRU cache or return the LRUCache object",params:{key:{name:"key",type:"string",description:"the key is undefined means change the default cache options"},value:{name:"value",type:"any",description:"the value to store, if value is null means remove the key"},options:{name:"options",type:"object|number",description:"the optional cache options:{capacity,expires,cleanInterval} or expires"}},result:"any"}),n.cache=new Di.Cache(e)),n}var Ui=Gi("lrucache"),Wi=class extends Ri{async fetch(t,e,n){return t||(t={}),e?.startsWith("$")&&(t.act=e,e="post"),await super.fetch(t,e,n)}async _func(t,e){return await this.fetch(e,t)}async func(t){const e=t.action;return e&&delete t.action,this._func(e,t)}assignMethods(t){if(Array.isArray(t))for(const e of t){const t=e.startsWith("$")?e.slice(1):e;this[t]||(this[t]=(t=>this._func.bind(this,t))(e))}}},Hi={methods:{type:"array",assign(t,e,n,r,i){i?.isExported||e.assignMethods(t)}}};Wi.defineProperties(Wi,Hi);var Zi=class extends Wi{async fetch(t,e){if(t||(t={}),e&&"res"===this.action){if("get"===e||"delete"===e){let n=t.id;return n||(0,y.throwError)("id is required"),"string"==typeof n&&(n=encodeURIComponent(n)),delete t.id,super.fetch(t,e,n)}"list"===e?e="get":e.startsWith("$")&&(t.act=e,e="post")}return await super.fetch(t,e)}},Ki=class extends Zi{constructor(){super(...arguments),this._sseListeners={},this._forwardEvents=new Set,this.description="subscribe server event",this.ebListener=async function(...t){const e=this.type;this.target.publish&&await this.target.publish({data:t,event:e})}}static setPubSubTransport(t){this._pubSubTransport=t}static get pubSubTransport(){if(!this._pubSubTransport)throw new Error("EventClient pubSubTransport not set");return this._pubSubTransport}get evtSource(){let t=this._stream;return t&&2!==t.readyState||(t=this.initEventStream(this._streamEvents)),t}get active(){return!!this._stream&&2!==this._stream.readyState}set active(t){t!==this.active&&(t?this.initEventStream(this._streamEvents):this._stream&&this.close())}initEventStream(t){const e="string"==typeof t?[t]:t;if(this._stream&&2!==this._stream.readyState){if(!this._streamEvents||e&&e.every(t=>this._streamEvents.includes(t)))return this._stream;this._stream.close()}const n=e?ki({event:e}):"",r=`${this.apiRoot}/${this.name}${n}`,i=this._stream=this.constructor.pubSubTransport.connect(r);return Object.entries(this._sseListeners).forEach(([t,e])=>{i.on(t,e)}),this._streamEvents=e,i}esListener(t,e,n){if(!this._forwardEvents.has(t)){const n=this.emitter;n&&t&&(Array.isArray(e)?n.emit(t,...e):n.emit(t,e))}}async subscribe(t){const e=await this.sub({event:t});"string"==typeof t&&(t=[t]);const n=this.evtSource;for(const e of t)if(!this._sseListeners[e]){const t=this._sseListeners[e]=(t,n)=>this.esListener(e,t,n);n.on(e,t)}return e}async unsubscribe(t){"string"==typeof t&&(t=[t]);const e=await this.unsub({event:t}),n=this.evtSource;for(const e of t){const t=this._sseListeners[e];t&&(delete this._sseListeners[e],n.off(e,t))}return e}forwardEvent(t){"string"==typeof t&&(t=[t]);for(const e of t)this._forwardEvents.has(e)||(this._forwardEvents.add(e),this.on&&this.on(e,this.ebListener))}unforwardEvent(t){"string"==typeof t&&(t=[t]);for(const e of t)this._forwardEvents.has(e)&&(this._forwardEvents.delete(e),this.off&&this.off(e,this.ebListener))}async init(t){if(this.active=!1,this.initEventStream(t),t)return await this.subscribe(t)}close(){const t=this._stream;if(t)return this._stream=void 0,t.close()}},Vi=new Ki(gt),Qi=require("util-ex"),Yi=class extends Fi{constructor(t,e={}){super(t,e),this.params={act:{type:"string"}};const n=this.methods=[];this.initRpcMethods(n)}get SpecialRpcMethodNames(){return this.constructor.SpecialRpcMethodNames}initRpcMethods(t=this.methods){const e=this.SpecialRpcMethodNames;if(Array.isArray(e))for(const n of e)"function"==typeof this[n]&&t.push(n);(0,Qi.getAllNames)(Object.getPrototypeOf(this)).filter(t=>t.startsWith("$")&&"function"==typeof this[t]).forEach(e=>{t.push(e);const n=e.slice(1);void 0===this[n]&&(this[n]=this[e])})}cast(t,e){let n=this.params[t];return n&&("string"!=typeof n&&(n=n.type),"number"===n&&(e=Number(e))),e}getMethodFromParams(t){const e=t?.act;return e}castParams(t){return t}func(t){const e=this.getMethodFromParams(t);if(e&&"function"==typeof this[e])return t=this.castParams(t),this[e](t);throw new y.NotFoundError(e,this.name)}};Yi.defineProperties(Yi,{methods:{type:"array"}});var ts=class extends Yi{constructor(t,e={}){super(t,e),this.action="res",this.params={id:{type:"string"},val:{type:"any"}}}static{this.SpecialRpcMethodNames=p}getMethodFromParams(t){let e=t?._req?.method?.toLowerCase();return"get"===e&&void 0===t.id&&(e="list"),"post"===e&&t.act&&(e=t.act),e}castParams(t){return void 0!==t.id&&(t.id=this.cast("id",t.id)),t}},es=_i.runSync(),ns=class t extends ts{constructor(){super(...arguments),this.description="subscribe server event",this.result="event",this.depends={[bt]:_i}}static setPubSubTransport(t){this._pubSubTransport=t}static get pubSubTransport(){return this._pubSubTransport||console.warn("EventServer pubSubTransport not set"),this._pubSubTransport}get pubSubTransport(){return this.constructor.pubSubTransport}static publish(t,e,n){return this.pubSubTransport?.publish(e,t,n)}static ebListener(t,...e){this.pubSubTransport?.publish(t,e)}static subscribe(t,e,n,r){return this.pubSubTransport?.subscribe(n,{...r,req:t,res:e})}static alreadyForward(t){const e=es.listeners(t);for(const t of e)if(t===this._boundEbListener)return!0}publishSSE(t,e){return this.constructor.publish(t,e)}subscribeSSE(t,e,n){return"string"==typeof n&&(n=[n]),this.constructor.subscribe(t,e,n)}forward(e){Array.isArray(e)||(e=[e]);const n=this.constructor;n._boundEbListener||(n._boundEbListener=function(...t){return n.ebListener(this.type,...t)});for(const r of e)t.alreadyForward(r)||es.on(r,n._boundEbListener)}unforward(t){"string"==typeof t&&(t=[t]);const e=this.constructor;if(e._boundEbListener)for(const n of t)es.off(n,e._boundEbListener)}list({_req:t,_res:e,event:n}){t&&e&&this.subscribeSSE(t,e,n)}$sub({event:t}){if(t)return this.forward(t),{event:t};(0,y.throwError)("event is required","sub",y.ErrorCode.InvalidArgument)}$unsub({event:t}){if(t)return this.unforward(t),{event:t};(0,y.throwError)("event is required","unsub",y.ErrorCode.InvalidArgument)}$publish({event:t,data:e}){if(t&&e){"string"==typeof t&&(t=[t]);for(const n of t)this.publishSSE(e,n);return{event:t}}(0,y.throwError)("event or data is required","pub",y.ErrorCode.InvalidArgument)}isStream(t){return"list"===this.getMethodFromParams(t)}},rs=new ns(gt);function is(){_i.register(),Ui.register()}var ss=class{setApiRoot(t){this.apiRoot=t}mount(t,e,n){if(e)this.setApiRoot(e);else if(!(e=this.apiRoot))throw new Error("apiRoot is required");return this.Tools=t,this.options=n,this._mount(t,e,n)}},os=class extends ss{constructor(t){if(!t)throw new Error("apiRoot is required for HttpClientTransport");super(),this.setApiRoot(t)}async _mount(t,e,n){return t.setTransport(this),t.loadFrom()}async loadApis(){return this.fetch("",void 0,"get",void 0,{headers:{"Content-Type":"application/json"}})}async fetch(t,e,n,r,i){i={...this.options,...i};const s=await this._fetch(t,e,n,r,i);if(e?.stream)return s;return await this.toObject(s,e)}},as=require("lodash-es"),cs=class extends ss{_mount(t,e,n){this.addDiscoveryHandler(e,()=>t),this.addRpcHandler(t,e,n)}start(t){return this.options&&(t=(0,as.defaultsDeep)(t,this.options)),this._start(t)}},us=c(require("http")),hs=require("url"),ls=require("lodash-es"),fs=class extends cs{constructor(t){super(),this.discoveryHandlerInfo=null,this.rpcHandlerInfo=null,this.server=t?us.default.createServer(t,this.requestListener.bind(this)):us.default.createServer(this.requestListener.bind(this))}async requestListener(t,e){const{url:n,method:r}=t;if(!n)return e.statusCode=400,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"Bad Request"}));if(this.discoveryHandlerInfo&&"GET"===r&&n===this.discoveryHandlerInfo.prefix)try{const t=this.discoveryHandlerInfo.handler();e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(t)),console.log(`[HttpServerTransport] Handled GET ${n} for discovery`)}catch(t){e.statusCode=500,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:t.message||"Internal Server Error"}))}else this.rpcHandlerInfo&&n.startsWith(this.rpcHandlerInfo.prefix)?await this.handleRpcRequest(t,e):(e.statusCode=404,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:"Not Found"})))}addDiscoveryHandler(t,e){this.discoveryHandlerInfo={prefix:t,handler:e},console.log(`[HttpServerTransport] Mapped GET ${t} for discovery`)}addRpcHandler(t,e,n){e.endsWith("/")||(e+="/"),this.rpcHandlerInfo={prefix:e,serverTools:t,options:n},console.log(`[HttpServerTransport] Mapped RPC calls for prefix ${e}`)}async handleRpcRequest(t,e){if(!this.rpcHandlerInfo||!t.url)return e.statusCode=500,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"RPC handler not configured"}));const{serverTools:n,prefix:r}=this.rpcHandlerInfo,i=t.url.split("?")[0].substring(r.length),[s,o]=i.split("/"),a=n.get(s);if(!a)return e.statusCode=404,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:`${s} Not Found`,data:{what:s}}));let c;const u=t.method;try{if("GET"===u||"DELETE"===u){const e=new hs.URL(t.url,`http://${t.headers.host}`).searchParams.get("p");c=e?JSON.parse(e):{}}else{const e=await this.getRequestBody(t);c=e?JSON.parse(e):{}}c._req=t,c._res=e,void 0!==o&&(c.id=o);let n=await a.run(c);a.isStream(c)?n&&"function"==typeof n.pipe?n.pipe(e):e.writableEnded||e.end():(e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(n)))}catch(t){if(console.error("Error during RPC execution:",t),e.headersSent)return;e.setHeader("Content-Type","application/json"),t.code&&"number"==typeof t.code?(e.statusCode=t.code,t.stack&&(t.stack=void 0),e.end(JSON.stringify(t))):(e.statusCode=500,e.end(JSON.stringify({error:t.message||"Internal Server Error"})))}}getRequestBody(t){return new Promise((e,n)=>{let r="";t.on("data",t=>{r+=t.toString()}),t.on("end",()=>{e(r)}),t.on("error",t=>{n(t)})})}async _start(t){const{port:e,host:n="0.0.0.0"}=(0,ls.defaultsDeep)(t,{port:3e3});return new Promise((t,r)=>{this.server.on("error",t=>{console.error("[HttpServerTransport] Server error:",t),r(t)}),this.server.listen(e,n,()=>{const e=this.server.address(),n="string"==typeof e?e:`${e?.address}:${e?.port}`;console.log(`[HttpServerTransport] Server listening on ${n}`),t()})})}async stop(){return new Promise((t,e)=>{if(!this.server.listening)return t();this.server.close(n=>{if(n)return e(n);t()})})}getRaw(){return this.server}},ds=class extends os{async loadApis(){const t=await fetch(this.apiRoot,{headers:{"Content-Type":"application/json"}});if(!t.ok)throw new Error(`Failed to load tools from ${this.apiRoot}: ${t.statusText}`);return await t.json()}async _fetch(t,e,n,r,i){const s=["post","put","patch"];let o;n||(n=this.Tools.action||"post"),"res"===n&&(n="get"),i.headers&&i.headers["Content-Type"]||!s.includes(n)||(i.headers={"Content-Type":"application/json",...i.headers}),e?.stream&&!i.headers.Connection&&(i.headers.Connection="keep-alive"),r?("string"!=typeof r&&(r=JSON.stringify(r)),t&&(r=t+"/"+r)):r=t,i.method=n.toUpperCase(),"get"===n||"delete"===n?o=r+ki(e):(i.body=JSON.stringify(e),o=r),i.headers&&!s.includes(n)&&delete i.headers["Content-Type"];const a=await fetch(`${this.apiRoot}/${o}`,i);if(!a.ok){throw await this.errorFrom(t,a)}return a}async errorFrom(t,e){let n,r=e.status,i=e.statusText;if(e.body){const r=await e.text();try{const e=JSON.parse(r);e&&(e.error&&(i=e.error),e.name&&(t=e.name),e.data&&(n=e.data,n.name=t,n.what&&(n.msg=i,i=n.what)),e.message&&(i=i+":"+e.message))}catch(t){console.warn("🚀 ~ parse error body to json:",t)}}return(0,y.createError)(i,t,r)}async toObject(t,e){return await t.json()}},ps=class{constructor(){this.name="sse",this.protocol="sse",this.channel=new kt}mount(){}subscribe(t,e){const{req:n,res:r,clientId:i}=e??{};if(!n||!r)throw new Error("SSE subscribe requires options.req and options.res");const s=this.channel.subscribe(n,r,t,i),o={id:`${Date.now()}-${Math.random().toString(36).slice(2)}`,clientId:s.clientId,protocol:"sse",send:(t,e)=>{r.write(`event: ${t}\n`),r.write(`data: ${JSON.stringify(e)}\n\n`)},close:()=>r.end?.(),raw:r};return this.onConn?.(o),n.on("close",()=>this.onDis?.(o)),s}publish(t,e,n){this.channel.publish(e,t,n)}onConnection(t){this.onConn=t}onDisconnect(t){this.onDis=t}},ms=class{connect(t,e){const n=e?`?${new URLSearchParams(e).toString()}`:"",r=new EventSource(`${t}${n}`),i=new Map,s=(t,e)=>{const n=n=>{const r=n.data,i=r?"string"==typeof r?JSON.parse(r):r:void 0;e(i,{...n,event:t})};let s=i.get(t);s||(s=new Map,i.set(t,s)),s.set(e,n),r.addEventListener(t,n)},o=(t,e)=>{const n=i.get(t),s=n?.get(e);s&&(r.removeEventListener(t,s),n.delete(e))};return{protocol:"sse",get readyState(){return r.readyState},on:s,off:o,addEventListener:s,removeEventListener:o,close:()=>r.close()}}disconnect(t){return t.close()}};
1
+ "use strict";var t,e=Object.create,n=Object.defineProperty,r=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,s=Object.getPrototypeOf,o=Object.prototype.hasOwnProperty,a=(t,e,s,a)=>{if(e&&"object"==typeof e||"function"==typeof e)for(let c of i(e))o.call(t,c)||c===s||n(t,c,{get:()=>e[c],enumerable:!(a=r(e,c))||a.enumerable});return t},c=(t,r,i)=>(i=null!=t?e(s(t)):{},a(!r&&t&&t.__esModule?i:n(i,"default",{value:t,enumerable:!0}),t)),u={};((t,e)=>{for(var r in e)n(t,r,{get:e[r],enumerable:!0})})(u,{AIArgProcessor:()=>Ee,AIChatRoles:()=>$,AIMessageTypes:()=>A,AIStream:()=>se,AITextGenerationFinishReasons:()=>k,AbortError:()=>y.AbortError,AbortErrorCode:()=>y.AbortErrorCode,ActionNames:()=>p,AlreadyExistsError:()=>y.AlreadyExistsError,AlreadyExistsErrorCode:()=>y.AlreadyExistsErrorCode,ArrayMergeWay:()=>gi,ArrayMergeWaySymbol:()=>bi,AsyncFeatureBits:()=>Hn,AsyncFeatures:()=>Zn,BaseError:()=>y.BaseError,BinarySemaphore:()=>Fn,CancelableAbility:()=>Vn,ChoiceArgProcessor:()=>Se,ClientEventPrefix:()=>os,ClientToolFuncSchema:()=>Fi,ClientToolTransport:()=>ls,ClientTools:()=>Pi,CommonError:()=>y.CommonError,ConfigFile:()=>mn.ConfigFile,DEFAULT_CONFIG_NAME:()=>Ur,DefaultAsyncSemaphoreCapacity:()=>jn,DefaultDateFormat:()=>g,EnvPromptTemplate:()=>I.EnvStringTemplate,ErrorCode:()=>y.ErrorCode,EventBusName:()=>gt,EventClient:()=>Yi,EventEmitter:()=>vt.EventEmitter,EventName:()=>bt,EventServer:()=>as,EventStates:()=>vt.states,EventToolFunc:()=>Di,FStringPromptTemplate:()=>I.FStringTemplate,FewShotPromptTemplate:()=>N,FilenameReservedRegex:()=>ce.FilenameReservedRegex,FuncMetaSymbol:()=>qi,GolangPromptTemplate:()=>I.GolangStringTemplate,HashAlgorithm:()=>Rt,HttpClientToolTransport:()=>vs,HttpServerToolTransport:()=>ws,IntSet:()=>Cn,InternalErrorCode:()=>y.InternalErrorCode,LLM_TOKENIZER_NAMES:()=>$r,LLM_TOKENIZER_NAMES_MAP:()=>xr,LRUCache:()=>Ji.LRUCache,NotFoundError:()=>y.NotFoundError,NotFoundErrorCode:()=>y.NotFoundErrorCode,NotImplementationError:()=>y.NotImplementationError,NotImplementedErrorCode:()=>y.NotImplementedErrorCode,ObjectArgsToArgsInfo:()=>ve,PASSING_SCORE:()=>d,PromptExampleSelector:()=>M,PromptTemplate:()=>I.StringTemplate,RStreamErrCode:()=>Vt,RateLimit:()=>_n,ReadableStreamError:()=>Yt,RemoteToolFuncSchema:()=>m,ResClientTools:()=>Vi,ResServerTools:()=>is,ResponseRStreamErrCode:()=>Qt,RpcMethodsClientTool:()=>Zi,RpcMethodsClientToolSchema:()=>Ki,RpcMethodsServerTool:()=>ns,RpcMethodsServerToolSchema:()=>rs,SHUTDOWN_SIGNALS:()=>ri,SSEChannel:()=>Zt,SSEChannelAlreadyClosedErrCode:()=>Ht,SecondaryCache:()=>Ui,Semaphore:()=>Ln,ServerToolFuncSchema:()=>_i,ServerToolTransport:()=>ds,ServerTools:()=>Li,SignalGate:()=>Bn,SseClientPubSubTransport:()=>gs,SseServerPubSubTransport:()=>bs,StrangeHumanName:()=>x,TaskAbortController:()=>Kn,TemplateArgProcessor:()=>Te,ToolAsyncCancelableBit:()=>Gn,ToolAsyncMultiTaskBit:()=>Un,ToolAsyncPriorityBit:()=>Wn,ToolFunc:()=>Ii,ToolFuncSchema:()=>Oi,ToolTransport:()=>hs,WindowsReservedNameRegex:()=>ce.WindowsReservedNameRegex,YamlTypeBaseObject:()=>zr,_lrucache:()=>Gi,addDate:()=>v.add,assignDirs:()=>fr,backendEventable:()=>St,base32768:()=>Xt,beforeShutdown:()=>ui,calcPerplexity:()=>mi,calcPerplexitySimple:()=>yi,canonicalize:()=>Dt.canonicalize,completeSentences:()=>V,concatText:()=>Y,countLLMTokens:()=>Or,countRegexMatches:()=>tr,createAbilityInjector:()=>l.createAbilityInjector,createCallbacksTransformer:()=>ae,createEmptyReadableStream:()=>ee,createEndWithRepetitionDetector:()=>We,createError:()=>y.createError,createEventStreamTransformer:()=>re,createHfValueFunc:()=>I.createHfValueFunc,createLRUCache:()=>Wi,createYamlObjectTag:()=>Dr,dateToText:()=>E,decodeCharset:()=>nn,defaultTemplateFormat:()=>I.defaultTemplateFormat,defaultsWithConcat:()=>Si,detectCharset:()=>un,encodeLLMTokens:()=>Ir,ensureQuoted:()=>$e,event:()=>Bi,eventClient:()=>ts,eventServer:()=>cs,eventable:()=>vt.eventable,expandConfig:()=>Wr,expandEnv:()=>I.expandEnv,expandObjEnv:()=>I.expandObjEnv,expandPath:()=>Vr,expandPathInObject:()=>Yr,expandPaths:()=>Qr,extNameLevel:()=>ce.extNameLevel,fileIsExists:()=>Qe,filterValidFnScope:()=>Je,findIndexNonEmptyFrom:()=>ct,findPort:()=>sr,formatISO:()=>v.formatISO,formatTextWithSpace:()=>qr,funcGetMeta:()=>Ri,funcWithMeta:()=>Ni,genUrlParamsStr:()=>Ai,getAllEnumKeys:()=>le,getConfigFileNames:()=>yn,getConfigs:()=>wn,getEnvVairables:()=>I.getEnvVairables,getFileMetaInfo:()=>an,getHashAlgoBySize:()=>cn,getKeysPath:()=>Ue,getLLMTokenizer:()=>Cr,getMultiLevelExtname:()=>ce.getMultiLevelExtname,getPackageDir:()=>cr,getRealFilepath:()=>sn,getResponseErrorReadableStream:()=>te,getXDGConfigs:()=>Kr,hasDirectoryIn:()=>lr,hash:()=>Ut,hashFile:()=>on,hashObject:()=>Gt,hashStream:()=>Jt,initShutdown:()=>hi,isLangUsingSpaces:()=>at,isListItemString:()=>rt,isModelNameMatched:()=>he,isPunctuationChar:()=>st,isQuoted:()=>ke,isRegExp:()=>wr,isSameString:()=>Br,isSectionString:()=>et,isSentenceEnding:()=>tt,isSepLineString:()=>it,isStrWrapped:()=>Ae,isSubdirectory:()=>hr,isTitleString:()=>nt,isValidFilename:()=>ce.isValidFilename,isValidFilepath:()=>ce.isValidFilepath,isWebStream:()=>Kt,joinSplitWords:()=>Ei,jsonFilterToWhere:()=>En,jsonToMarkdownStr:()=>xn,loadAIConfig:()=>Zr,loadConfig:()=>Hr,loadConfigFile:()=>Gr,loadFileFromPaths:()=>Ye,loadTextFromPaths:()=>en,lrucache:()=>Hi,makeToolFuncCancelable:()=>Yn,matchUrlProtocol:()=>kn,memoize:()=>rr,mergeArray:()=>Ti,messagesToText:()=>C,mimeType:()=>pn.mimeType,nanoid:()=>Tt.nanoid,normalizePath:()=>mr,paramsSizeToScaleStr:()=>An,parseCommand:()=>Re,parseDateFormat:()=>w.parse,parseISO:()=>v.parseISO,parseJsJson:()=>ze,parseJsJsonSimpleSync:()=>De,parseObjectArgInfo:()=>qe,parseObjectArgumentInfos:()=>ge,parseObjectArguments:()=>ye,parseObjectArgumentsAsArgInfos:()=>Ne,parseYaml:()=>mn.parseYaml,pruneSubdirectories:()=>dr,pruneSubdirectoriesInPlace:()=>pr,quoteStr:()=>xe,readFilenamesRecursiveSync:()=>rn,readTextFileChunks:()=>Pr,readTextFileChunksEx:()=>Fr,readableFromAsyncIterable:()=>oe,registerCoreTools:()=>us,registerYamlTag:()=>mn.registerYamlTag,removeMarkdownBold:()=>ut,removeMarkdownBoldAndItalic:()=>lt,removeMarkdownItalic:()=>ht,replaceWithPlaceholder:()=>Me,restoreFromPlacehoders:()=>Pe,sanitizeFilename:()=>ce.sanitizeFilename,sanitizeFilepath:()=>ce.sanitizeFilepath,saveConfigFile:()=>vn,scaleStrToParamsSize:()=>$n,shutdown:()=>ci,simplifyObjectArguments:()=>be,sleep:()=>pt,sortedValues:()=>q,splitChunks:()=>Lr,splitParagraph:()=>ft,splitSentence:()=>K,splitWords:()=>ki,stringifyYaml:()=>mn.stringifyYaml,stripConsoleColor:()=>vr,textToDate:()=>T,throwError:()=>y.throwError,toDate:()=>v.toDate,toDateTime:()=>S,toRegExp:()=>f.toRegExp,trimStartOfStreamHelper:()=>ie,truncTo:()=>dt,truncateByToken:()=>jr,truncateToTokenLimit:()=>Nr,truncateToTokenLimitEx:()=>Rr,uuid:()=>xt,uuidNIL:()=>At.NIL,uuidParse:()=>At.parse,uuidStringify:()=>At.stringify,uuidValidate:()=>At.validate,uuidVersion:()=>At.version,uuidv1:()=>At.v1,uuidv4:()=>At.v4,uuidv5:()=>At.v5,uuidv6:()=>At.v6,uuidv7:()=>At.v7,wait:()=>mt,wrapEventEmitter:()=>vt.wrapEventEmitter,xxhash:()=>_t,xxhash32:()=>Ft,xxhash64:()=>Lt,xxhashAsStr:()=>zt,yieldExec:()=>yt}),module.exports=(t=u,a(n({},"__esModule",{value:!0}),t));var h=(()=>"undefined"==typeof document?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.src||new URL("main.js",document.baseURI).href)(),l=require("custom-ability"),f=require("util-ex"),d=.618,p=["get","post","put","delete","patch","list","res"],m={action:{type:"string",assign:(t,e,n,r,i)=>t||"post"},fetchOptions:{type:"object"},allowExportFunc:{type:"boolean"}},y=require("@isdk/common-error"),w=require("date-fns"),v=require("date-fns"),b="MMMM d, y 'at' h:m:s b 'GMT'x";function g(t){return t&&(b=t),b}function S(t){let e;try{"string"==typeof t?e=(0,w.parseISO)(t):"number"==typeof t?e=new Date(t):t instanceof Date&&(e=t)}catch(t){console.error(t)}return e}function T(t,e=b){return(0,w.parse)(t,e,new Date)}function E(t,e=b){return(0,w.format)(t,e)}var k=["stop","length","content_filter","tool_calls","function_call","abort","error","other",null],A=["human","ai","generic","system","tool"],$=["user","assistant","system","tool","tool_calls"],x="陌生人";function C(t){let e="";for(const n of t)if(n.content){e+=n.role.toLowerCase()+":";let t=n.createdAt;if(t){const n=S(t);n&&(e+=" ["+E(n)+"]")}e+=" "+n.content+"\n"}return e}var I=require("@isdk/template-engines"),O=require("@isdk/template-engines");function q(t){return Object.keys(t).sort().map(e=>t[e])}var N=class extends O.StringTemplate{static from(t){return new this(t)}constructor(t){super(t)}_initialize(t){t&&(t.suffix&&(this.suffix=t.suffix),t.exampleSeparator&&(this.exampleSeparator=t.exampleSeparator),t.prefix&&(this.prefix=t.prefix),t.examplePrompt&&(this.examplePrompt=t.examplePrompt instanceof O.StringTemplate?t.examplePrompt:O.StringTemplate.from(t.examplePrompt)),t.examples&&(this.examples=t.examples)),this.prefix||(this.prefix=""),this.exampleSeparator||(this.exampleSeparator="\n\n"),this.suffix||(this.suffix="")}async _format(t){const e=[];for await(const t of this.examples)if(this.examplePrompt){const n=await this.examplePrompt.format(t);e.push(n)}else if("string"==typeof t)e.push(t);else if(t){const n=q(t);n.length>0&&e.push(...n)}const n=[this.prefix,...e,this.suffix].join(this.exampleSeparator),r=this.templateFormat;return await O.StringTemplate.format({template:n,data:t,templateFormat:r})}toJSON(t=this){const e=super.toJSON(t);return t.suffix&&(e.suffix=t.suffix),t.exampleSeparator&&(e.exampleSeparator=t.exampleSeparator),t.prefix&&(e.prefix=t.prefix),t.examplePrompt&&(e.examplePrompt=t.examplePrompt),t.examples&&(e.examples=t.examples),e}};function R(t){return(e=t)&&"function"==typeof e[Symbol.iterator]?async function*(t){const e=t[Symbol.iterator]();let n;try{for(;;){n=!1;const t=e.next();if(n=!0,t.done)return n=!1,await t.value;yield await t.value}}finally{n&&await(e.return?.().value)}}(t):t;var e}O.StringTemplate.register(N,{name:"fewshot",aliases:["few_shot"]});var j=!1;(async function(){let t=!1,e=!1;try{for await(const e of function*(){try{yield Promise.reject()}finally{t=!0}}())throw new Error("impossible")}catch{e=!0}return e&&t})().then(t=>{j=t});var M=class{constructor(t,e){this.initialize(t,e)}initialize(t,e){const n=e?.maxLength;var r;n>0&&(this.maxLength=n),void 0!==e?.threshold&&(!0===e.threshold?this.threshold=.5:!1!==e.threshold&&(this.threshold=e.threshold)),this.examples=(r=t,j?r:R(r))}selectExample(t,e){if(void 0===e||e<=this.threshold)return t}async*selectExamples(t=this.examples){let e=this.maxLength||1/0;for await(const n of t){const t="number"==typeof this.threshold?Math.random():void 0;if(this.selectExample(n,t)){if(--e<0)break;yield n}}}async*[Symbol.asyncIterator](){yield*this.selectExamples()}},P=require("@isdk/detect-text-language"),F="@",L=/(\S.+?[.!?])(?=\s+|$)|(\S.+?)(?=[\n]|$)/g,_=/([A-Z][a-z]{1,2}\.)\s(\w)/g,z=/(\.[a-zA-Z]\.)\s(\w)/g,D=new RegExp("([A-Z][a-z]{1,2}\\.)"+F+"(\\w)","g"),B=new RegExp("(\\.[a-zA-Z]\\.)"+F+"(\\w)","g"),X=/(```)([\s\S]*?)(```)/g,J=">>>CODE_BLOCK<<<",U=/([*_`]{1,3})(\S.*?\S)\1/,G=">>> INLINE_BLOCK ",W=/>>> INLINE_BLOCK (\d+) <<</,H=1e4;function Z(t,e,n){const r="$1"+e+"$2";let i=t;for(let t=0;t<n.length;t++)i=i.replace(n[t],r);return i}function K(t,{best:e=!0,completeSentence:n,isMarkdown:r,ignoreEmptyLine:i}={}){const s=[],o=[];let a,c=0;for(;c++<H&&(a=X.exec(t));){const e=a[0];s.push(e),t=t.replace(e,"\n"+J+(s.length-1)+"\n")}for(c=0;c++<H&&(a=U.exec(t));){const e=a[0];o.push(e),t=t.replace(e,G+(o.length-1)+" <<<")}if(r){const e=t.split("\n");for(let t=0;t<e.length;t++){const n=e[t];nt(n,{isMarkdown:r,nextLine:e[t+1]})&&(s.push(n),e[t]=J+(s.length-1))}t=e.join("\n")}const u=(t=(t=(t=(t=(t=t.replace(/([。!??])\1+/g,"$1")).replace(/([。!??])([^”’])/g,"$1\n$2")).replace(/(\.{6})([^”’])/g,"$1\n$2")).replace(/(…{2})([^”’])/g,"$1\n$2")).replace(/([。!??][”’])([^,。!??])/g,"$1\n$2")).split("\n");let h=[];for(let t=0;t<u.length;t++){let n=u[t].trimEnd();if(!n){!r&&i||h.push("");continue}if(n.startsWith(J)){h.push(s[Number(n.slice(J.length))]);continue}if(r&&nt(n,{isMarkdown:r,nextLine:u[t+1]})){h.push(n);continue}if(!e){h.push(n);continue}let a=Z(n,F,[_,z]),c=Array.from(a.matchAll(L)),l=[];if(c.length)for(let t=0;t<c.length;t++)l.push(Z(c[t][0]," ",[D,B]));else l.push(n);h.push(...l.map(t=>ot(o,t)))}return n&&(h=V(h,{isMarkdown:r,ignoreEmptyLine:i})),h}function V(t,{isMarkdown:e,ignoreEmptyLine:n}={}){const r=[];let i=0,s="";for(n=!e&&n;i<t.length;){let o=t[i];if(o){let a;if(n){const n=ct(t,i+1);a=et(t[n],{isMarkdown:e,nextLine:-1===n?"":t[n+1]})}else a=et(t[i+1],{isMarkdown:e,nextLine:t[i+2]});Q(o,{isMarkdown:e,nextLine:t[i+1]})||""===t[i+1]||a?(s&&(o=Y(s,o),s=""),r.push(o)):(s&&(o=Y(s,o)),s=o)}else n||r[r.length-1]&&r.push(o);i++}return s&&r.push(s),r}function Q(t,e){return tt(t)||et(t,e)}function Y(t,e){const n=t+" "+e,r=(0,P.detectTextLanguage)(n,{isoCode:!0});return r&&!at(r)?(st(t)&&(t+=" "),e=t+e):e=t.endsWith("-")?(t=t.slice(0,-1))+e:n,e}function tt(t){if(!t)return!1;return/(([.。!!??]\s*['"”’]?)|```)\s*$/.test(t)}function et(t,e){let n=nt(t,e);return n||(n=rt(t)),n||(n=it(t)),n}function nt(t,e){if(!t)return null;let n=/^\s*第?\s*[壹贰叁肆伍陆柒捌玖拾一二三四五六七八九十百千萬万\d]+\s*([章節节编回部篇卷幕场場辑集段册冊期片題]|片段|段落|篇[章目]|小[节節]|(子)?部分|卷[册冊]|[单單]元|章[节節回]|[.、])[ \t]*(?<title>.*)(?=\n|$)/.exec(t);if(n||(n=/^\s*(Chapter|Book|Article|Part|Paragraph|Subsection|Subpart|Volume|Episode|Issue|Unit|Section|Segment|Act|Scene)\s*\d+.*(?=\n|$)/i.exec(t)),!n&&e?.isMarkdown){n=/^[ \t]{0,3}(#+)\s+(?<title>\S.*)$/.exec(t);const r=/^[ \t]{0,3}([-=]+)(?=\n|$)/;!n&&e.nextLine&&!r.test(t)&&/^[ \t]{0,3}\S/.test(t)&&r.test(e.nextLine)&&(n=/^\s*(?<title>.*)(?=\n|$)/.exec(t))}return n}function rt(t){return/^\s*([*+-]|\d+[.、])\s*(?<item>.*)(?=\n|$)/.exec(t)}function it(t){return/^[-=_]{3,}$/.exec(t)}function st(t){return/[。!??,、;;::'""“”‘’~~《》<>〈〉【】(){}【】\[\]\(\)…·]$/.test(t)}function ot(t,e){let n,r=0;for(;r++<H&&(n=W.exec(e));){const r=Number(n[1]);e=e.replace(n[0],t[r])}return e}function at(t){return!["zh","ja","th","lo","ta","ko"].includes(t)}function ct(t,e=0){for(let n=e;n<t.length;n++){const e=t[n];if(null!=e&&""!==e)return n}return-1}function ut(t,e){const n=/(?!\\)([*_])\1(?![ \t]|\1)(.+?)(?<!\\)\1{2}/;let r;for(;(r=n.exec(t))&&(t=t.slice(0,r.index)+r[2]+t.slice(r.index+r[0].length),!e););return t}function ht(t,e){const n=/(?!\\)([*_])(?![ \t]|\1)(.+?)(?<!\\)\1/;let r;for(;(r=n.exec(t))&&(t=t.slice(0,r.index)+r[2]+t.slice(r.index+r[0].length),!e););return t}function lt(t,e){return t=ht(t=ut(t,e),e)}function ft(t,e){const n=[],r=[],i=t.split("\n");for(let t=0;t<i.length;t++){let s=i[t];const o=0===s.trim().length;o||nt(s,{...e,nextLine:i[t+1]})?(r.length&&n.push([...r]),r.length=0,o||r.push(s)):r.push(s)}return r.length&&n.push([...r]),n}function dt(t,e=2,n=.5){const r=10**e;return Math.trunc((t+Number.EPSILON+n/r)*r)/r}async function pt(t){return new Promise(e=>setTimeout(e,t))}var mt=pt;async function yt(){return new Promise(t=>{setImmediate(t)})}var wt=require("custom-ability"),vt=require("events-ex"),bt="event",gt="event-bus";var St=(0,wt.createAbilityInjector)(function(t,e){const n=e?.eventBusName||gt;return class{static get emitter(){if(!this._emitter){const t=this.get(n)?.emitter;t&&(this._emitter=t,this.prototype._events=t._events)}return this._emitter}get emitter(){return this.constructor._emitter}on(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.on(e,n)}once(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.once(e,n)}off(e,n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.off(e,n)}emit(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return"error"===e?this.emitError.apply(this,n):r.emit.call(this,e,this.name,...n)}emitError(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.emit.call(this,"error",e,this.name,...n)}async emitAsync(e,...n){const r=t.emitter;if(!r)throw new TypeError("EventBackend required");return r.emitAsync.call(this,e,this.name,...n)}}},!0),Tt=require("nanoid"),Et=require("uuid"),kt=c(require("base32768")),At=require("uuid"),$t={1:Et.v1,4:Et.v4,5:Et.v5,6:Et.v6,7:Et.v7};function xt(t,e){!0===t&&(e=!0),"number"==typeof t&&$t[t]||(t=1);const n=$t[t];return e?kt.encode(n(null,new Uint8Array(16))):n()}var Ct=c(require("xxhashjs")),It=c(require("base32768")),Ot=require("json-canonicalize"),qt=require("hash-wasm"),Nt=588213,Rt=(t=>(t[t.md5=1]="md5",t[t.sha1=2]="sha1",t[t.ripemd=3]="ripemd",t[t.sha256=8]="sha256",t[t.sha384=9]="sha384",t[t.sha512=10]="sha512",t[t.sha224=11]="sha224",t[t.xxhash=111]="xxhash",t[t.xxhash64=111]="xxhash64",t[t.xxhash32=112]="xxhash32",t[t.xxhash128=113]="xxhash128",t))(Rt||{}),jt={1:qt.createMD5,2:qt.createSHA1,8:qt.createSHA256,10:qt.createSHA512,11:qt.createSHA224,3:qt.createRIPEMD160,112:qt.createXXHash32,111:qt.createXXHash64,113:qt.createXXHash128},{h32:Mt,h64:Pt}=Ct.default;function Ft(t,e=16){return"object"==typeof t&&(t=(0,Ot.canonicalize)(t)),Mt(t.normalize(),Nt).toString(e)}function Lt(t,e=16){return"object"==typeof t&&(t=(0,Ot.canonicalize)(t)),Pt(t.normalize(),Nt).toString(e)}function _t(t,e=111,n=Nt){let r;return t.buffer&&(t=t.buffer),112!==e?(r=Pt(t,n),r=new Uint16Array([r._a00,r._a16,r._a32,r._a48]),r=new Uint8Array(r.buffer)):(r=Mt(t,n),r=new Uint16Array([r._low,r._high]),r=new Uint8Array(r.buffer)),r}function zt(t,e=111,n=Nt){return It.encode(_t(t,e,n))}var Dt=require("json-canonicalize"),Bt=c(require("base32768")),Xt=Bt;async function Jt(t,{hashAlgo:e=111,seed:n=Nt,outputType:r="string"}={}){const i=await jt[e](n);i.init();const s=t.getReader();for(;;){const{done:t,value:e}=await s.read();if(t)break;i.update(e)}return"string"!==r?i.digest(r):Bt.encode(i.digest("binary"))}async function Ut(t,{hashAlgo:e=111,seed:n=Nt,outputType:r="string"}={}){const i=await jt[e](n);i.init(),i.update(t);return"string"!==r?i.digest(r):Bt.encode(i.digest("binary"))}async function Gt(t,e){return Ut(t=(0,Dt.canonicalize)(t),e)}function Wt(t,e){return!t||t.some(t=>t instanceof RegExp?t.test(e):t===e)}var Ht=498,Zt=class{get active(){return this._active}set active(t){t!==this._active&&(t?(this.pingTimer&&(clearInterval(this.pingTimer),this.pingTimer=void 0),this.options.pingInterval>0&&(this.pingTimer=setInterval(()=>this.publish(),this.options.pingInterval))):(this.clients.size&&this.clearClients(),this.pingTimer&&(clearInterval(this.pingTimer),this.pingTimer=void 0)),this._active=t)}constructor(t){this.options=Object.assign({},{pingInterval:3e3,maxStreamDuration:3e4,clientRetryInterval:1e3,startId:1,historySize:100,rewind:0,cors:!1},t),this.nextID=this.options.startId,this.clients=new Map,this.messages=[],this.active=!0}publish(t,e,n){let r,i;this.active||(0,y.throwError)("Channel closed","SSEChannel",Ht);let s=e;if(t||e)i=this.nextID++,"object"==typeof t&&(t.event?(s=t.event,void 0!==t.data&&(t=JSON.stringify(t.data))):t=JSON.stringify(t)),t&&"string"!=typeof t&&(t=""+t),t=t?t.split(/[\r\n]+/).map(t=>"data: "+t).join("\n"):"",r="id: "+i+"\n"+(e?"event: "+e+"\n":"")+(t||"data: ")+"\n\n",this.messages.push({id:i,_eventName:s,output:r});else{if(!this.clients.size)return;r="data: \n\n"}if(n?.clientId){(Array.isArray(n.clientId)?n.clientId:[n.clientId]).forEach(t=>{const e=this.clients.get(t);e&&e.res.write(r)})}else this.clients.forEach(t=>{s&&!Wt(t.events,s)||t.res.write(r)});for(;this.messages.length>this.options.historySize;)this.messages.shift();return i}subscribe(t,e){this.active||(0,y.throwError)("Channel closed","SSEChannel",Ht),(e instanceof RegExp||"string"==typeof e)&&(e=[e]);const n=this.clients.get(t);if(n){n.events||(n.events=[]);for(const t of e)n.events.some(e=>e.toString()===t.toString())||n.events.push(t);return!0}return!1}unsubscribe(t,e){this.active||(0,y.throwError)("Channel closed","SSEChannel",Ht),(e instanceof RegExp||"string"==typeof e)&&(e=[e]);const n=this.clients.get(t);return!!n&&(n.events&&(n.events=n.events.filter(t=>!e.some(e=>e.toString()===t.toString()))),!0)}getClient(t){return this.clients.get(t)}connect(t,e,n,r){this.active||(0,y.throwError)("Channel closed","SSEChannel",Ht);const i=xt();if(this.clients.has(i)){const t=this.clients.get(i);t&&this.disconnect(t)}(n instanceof RegExp||"string"==typeof n)&&(n=[n]);const s={req:t,res:e,events:n,clientId:i},o=this.options.maxStreamDuration;let a="max-age=0, stale-while-revalidate=0, stale-if-error=0, no-transform";o>0&&(a+=", s-maxage="+(Math.floor(o/1e3)-1));const c={"Content-Type":"text/event-stream","Cache-Control":a,Connection:"keep-alive"};this.options.cors&&(c["Access-Control-Allow-Origin"]="*"),s.req.socket.setNoDelay(!0),s.res.writeHead(200,c);let u="retry: "+this.options.clientRetryInterval+"\n\n";const h=Number.parseInt(t.headers["last-event-id"],10),l=Number.isNaN(h)?this.options.rewind:this.nextID-1-h;return l&&this.messages.filter(t=>Wt(s.events,t.eventName)).slice(0-l).forEach(t=>{u+=t.output}),s.res.write(u),this.clients.set(s.clientId,s),this.publish({clientId:i},"welcome",{clientId:i}),o>0&&setTimeout(()=>{s.res.writableEnded||this.disconnect(s)},o),s.res.on("close",()=>this.disconnect(s)),s}disconnect(t){t.res.end(),this.clients.delete(t.clientId)}clearClients(){this.clients.forEach(t=>t.res.end()),this.clients.clear()}listClients(){const t={};return this.clients.forEach(e=>{const n=e.req.socket.remoteAddress??"";n in t||(t[n]=0),t[n]++}),t}getSubscriberCount(){return this.clients.size}};function Kt(t){return t instanceof ReadableStream||t instanceof WritableStream}var Vt=600,Qt=601,Yt=class extends y.BaseError{constructor(t,e=Vt){super(t,500)}};function te(t){if(t){const e=t.getReader();return new ReadableStream({async start(t){const{done:n,value:r}=await e.read();if(!n){const e=(new TextDecoder).decode(r);t.error(new Yt(`Response error: ${e}`,Qt))}}})}return new ReadableStream({start(t){t.error(new Yt("Response error: No response body",Qt))}})}function ee(){return new ReadableStream({start(t){t.close()}})}var ne=require("eventsource-parser");function re(t){const e=new TextDecoder;let n;return new TransformStream({async start(e){n=(0,ne.createParser)({onEvent:n=>{if("data"in n&&"[DONE]"===n.data||"done"===n.event)e.terminate();else if("data"in n){const r=t?t(n.data,{event:n.event}):n.data;r&&e.enqueue(r)}}})},transform(t){n.feed(e.decode(t))}})}function ie(){let t=!0;return e=>(t&&(e=e.trimStart())&&(t=!1),e)}function se(t,e){if(!t.ok)return te(t.body);let n=t.body||new ReadableStream({start(t){t.close()}});return n instanceof ReadableStream||(n=ReadableStream.from(n)),n.pipeThrough(re(e))}function oe(t){let e=t[Symbol.asyncIterator]();return new ReadableStream({async pull(t){const{done:n,value:r}=await e.next();n?t.close():t.enqueue(r)},async cancel(t){await(e.return?.(t))}})}function ae(t){const e=t||{};return new TransformStream({async start(t){const n=t.error;if(t.error=r=>{n.call(t,r),e.onError&&e.onError(r)},e.onStart)try{await e.onStart(t)}catch(e){t.error(e)}},async transform(t,n){try{let r;e.onTransform&&(r=await e.onTransform(t,n)),r||(r=t),n.enqueue(r)}catch(t){n.error(t)}},async flush(t){if(e.onFinal)try{await e.onFinal(t)}catch(e){return t.error(e)}t.terminate()}})}var ce=require("@isdk/util"),ue=require("util-ex");function he(t,e){if("string"!=typeof t)throw new y.CommonError("modelName must be a string","isModelNameMatched",y.ErrorCode.InvalidArgument);switch(typeof e){case"string":if((0,ue.isRegExpStr)(e)){const n=(e=(0,ue.toRegExp)(e)).exec(t);if(n)return n}else if(t.toLowerCase()===e.toLowerCase())return e;break;case"object":if(Array.isArray(e)){for(const n of e)if("string"==typeof n){if((0,ue.isRegExpStr)(n)){const r=(e=(0,ue.toRegExp)(n)).exec(t);if(r)return r}else if(t.toLowerCase()===n.toLowerCase())return n}else if(n instanceof RegExp){const e=n.exec(t);if(e)return e}else if("function"==typeof n){const e=n.call(this,t);if(e)return e}}else if(e instanceof RegExp){const n=e.exec(t);if(n)return n}break;case"function":const n=e.call(this,t);if(n)return n}}function le(t){return Object.keys(t).filter(t=>Number.isNaN(Number(t)))}var fe=require("lodash-es"),de=require("util-ex"),pe=require("lodash-es"),me=require("util-ex");async function ye(t,e,n){return ge(Ne(t,e,n),e,n)}function we(t){for(let e=1;e<t.length;e++)if(t[e]<=t[e-1])return!1;return!0}function ve(t){if(t&&!Array.isArray(t)&&"object"==typeof t){const e=Object.entries(t),n=Object.keys(t),r=n.filter(t=>!isNaN(parseInt(t)));if(1===e.length)void 0!==t[0]&&(t=[t[0]]);else if(n.every(t=>!isNaN(parseInt(t)))&&we(n.map(t=>parseInt(t))))t=Object.values(t);else if("0"===r[0]&&we(r.map(t=>parseInt(t)))){const n=e.filter(([t,e])=>isNaN(parseInt(t)));t=e.filter(([t,e])=>!isNaN(parseInt(t))).map(([t,e])=>e);let r=0;const i=[];for(;r<n.length&&n[r][1]===t[r];)i.push(r),r++;for(;i.length;)n.splice(i.pop(),1);t={args:t,kvArgs:Object.fromEntries(n)}}else t={args:[],kvArgs:t}}return Array.isArray(t)&&(t={args:t}),t}function be(t){if(t&&!Array.isArray(t)&&"object"==typeof t){const e=Object.entries(t),n=Object.keys(t);1===e.length&&void 0!==t[0]?t=t[0]:n.every(t=>!isNaN(parseInt(t)))?t=n.sort((t,e)=>parseInt(t)-parseInt(e)).map(e=>t[e]):2===e.length&&"0"===e[0][0]&&e[0][1]===e[1][1]&&(t=t[0])}return t}async function ge(t,e,n){if(t.length){const r=await Promise.all(t.map((t,r)=>qe(t,r,e,n))),i=n?.returnArrayOnly;let s;if(r?.length){s=De(`{${r.map(t=>t).join(",")}}`,e)}return s&&!i&&(s=be(s)),s}}function Se(t,e,n,r){const[i,s]=t;if(!i&&"|"===s[0])return"choice: {"+function(t,e,n){const r=Ne(t,e,{...n,delimiter:":"}),i={},s=r.map(([t,e],n)=>{if(t){const t=e.indexOf(":"),n=e.slice(0,t).trim();if(i[n])throw new Error("Only one "+n+" is allowed");return i[n]=!0,e}{if("|"===e[0]){if(i.items)throw new Error("Only one items is allowed");return i.items=!0,"items:["+function(t,e='"'){return t.map(t=>$e(t,e))}(e.split("|").filter(Boolean))+"]"}const t=parseInt(e.trim());if(!isNaN(t)){if(i.maxPick)throw new Error("Only one maxPick is allowed");return i.maxPick=!0,"maxPick:"+t}if("random"===e||"ai"===e)return i.type=!0,'type:"'+e+'"';if(ke(e)){if(i.separator)throw new Error("Only one separator is allowed");return i.separator=!0,"separator:"+e}}});return s}(s,n,r)+"}"}async function Te([t,e],n,r,i){let s,o;if(r||(r={}),t){const t=e.split(":");s=t[0].trim(),o=t[1].trim()}else o=e,s=n+"";const a={template:o,data:{...(0,pe.omitBy)(r,(t,e)=>!e||"_"===e[0]||"function"==typeof t),...i?.templateData}};i?.templateFormat&&(a.templateFormat=i.templateFormat);const c=await I.StringTemplate.formatIf(a);if(c)return o=ke(c)?c:JSON.stringify(c),s+":"+o}async function Ee(t,e,n,r){let i=Se(t,0,n,r);return i||(i=await Te(t,e,n,r)),i}function ke(t){const e=t[0];return('"'===e||"'"===e)&&t[t.length-1]===e}function Ae(t,e=['""',"''","{}"]){return e.some(e=>t[0]===e[0]&&t[t.length-1]===e[1])}function $e(t,e='"'){return ke(t)?t:e+t+e}function xe(t){return'"'+t.replace(/(?<!\\)"(?!\\)/g,'\\"')+'"'}var Ce=["true","false","null","undefined","NaN","Infinity"];async function Ie(t,e,n){const r=(0,me.newFunction)("async expression",[],`return ${t};`,Je(e));let i;try{i=await r.call(this)}catch(t){if(n||!(t instanceof ReferenceError))throw t}switch(typeof i){case"number":case"boolean":case"undefined":return i;case"function":return r.toString();default:return JSON.stringify(i)}}async function Oe(t,e,n){let r=t;if(["true","false"].includes(t.toLowerCase()))r=r.toLowerCase();else if(!(i=t,Ae(i)||!Number.isNaN(parseFloat(i))||Ce.includes(i)||_e(i)||e&&void 0!==(0,pe.get)(e,t)||_e(t)))try{r=n?.skipExpression?xe(t):await Ie.call(this,t,e,n?.preserveUnresolvedName)}catch(e){r=xe(t)}var i;return r}async function qe(t,e,n,r){const[i,s]=t,o=r?.argProcessor,a=r?.ignoreIndexNamed;if("function"==typeof o){const i=await o(t,e,n,r);if(i)return i}if(i){const t=s.indexOf(":");return s.slice(0,t).trim()+":"+await Oe(s.slice(t+1).trim(),n,r)}{const t=s.trim();if(n&&void 0!==(0,pe.get)(n,t)){return(a?"":e+":"+t+",")+'"'+t+'":'+t}return e+":"+await Oe(s.trim(),n,r)}}function Ne(t,e,n){const r=n?.delimiter??",",i=n?.assigner??"=";let s=[],o=!1,a="",c="",u=!1,h="";for(let e=0;e<t.length;e++){const n=t[e];if(n!==r||o||h)if("\\"===n)c+=n,e++,c+=t[e];else if("("!==n&&"["!==n||o)if(h&&n===h)h="",c+=n;else if("{"!==n||o)'"'===n||"'"===n?(o&&n===a?o=!1:o||(o=!0,a=n),c+=n):n!==i||o||u||!/^[\p{L}\p{N}_ ]+$/u.test(c)?c+=n:(c+=":",u=!0);else{let r,i=e,s=!1,o="",a=-1;for(;i<t.length&&("}"!==(r=t[i])||s||a>0);)"\\"===r?i++:"{"!==r||s?"}"!==r||s?'"'!==r&&"'"!==r||(s&&n===o?s=!1:s||(s=!0,o=n)):a--:a++,i++;i<t.length&&(c+=t.substring(e,i+1),e=i)}else h="("===n?")":"]",c+=n;else c=c.trim(),c.endsWith(":")&&(c+="undefined"),s.push([u,c]),c="",u=!1}return c&&(c=c.trim(),c.endsWith(":")&&(c+="undefined"),s.push([u,c])),s}async function Re(t,e,n){const r=t.match(/^([^(]+)(?:\((.*)\))?$/);if(!r){if(n?.raiseError)throw new Error("Invalid command format");return}const[,i,s]=r;let o;return s&&(o=await ye(s,e,n)),{command:i.trim(),args:o}}var je="__PlacEhoLdeR_";function Me(t,e){let n=e?.startChar?Array.isArray(e.startChar)?e.startChar:[e.startChar]:['"',"'"],r=e?.endChar?Array.isArray(e.endChar)?e.endChar:[e.endChar]:n;if(n.length!==r.length)throw new Error("start and end characters must have the same length");const i=e?.placeholder??je,s=n.every((t,e)=>t===r[e]),o=e?.placehoders??[];if(s){n=n.map(t=>"\\"+t);const e=new RegExp(`(?<!\\\\)(${n.join("|")}).*?(?<!\\\\)\\1`);let r;for(;null!==(r=e.exec(t));){const e=`${i}${o.length}`;t=t.replace(r[0],e),o.push(r[0])}}else{n=n.map(t=>"\\"+t),r=r.map(t=>"\\"+t);for(let e=0;e<n.length;e++){const s=new RegExp(`(?<!\\\\)${n[e]}.*?(?<!\\\\)${r[e]}`);let a;for(;null!==(a=s.exec(t));){const e=`${i}${o.length}`;t=t.replace(a[0],e),o.push(a[0])}}}return[t,o]}function Pe(t,e,n){const r=n?.placeholder??je;return e.reduce((t,e,n)=>t.replace(new RegExp(r+n,"g"),e),t)}var Fe="[a-zA-Z_$][a-zA-Z_\\d$]*",Le=new RegExp(`^\\s*(\\(\\s*\\)|${Fe}|\\(${`${Fe}\\s*(,\\s*${Fe})*`}\\))\\s*=>`);function _e(t){return Le.test(t)}async function ze(t,e){if(e&&(e=Je(e)),e&&(t=t.trim()).startsWith("{")&&t.endsWith("}")){return await ye(t.slice(1,-1),e,{assigner:":",ignoreIndexNamed:!0})}return De(t,e)}function De(t,e){if(e&&(e=Je(e)),e){const n=Object.keys(e);if(n.length){const r=Object.values(e);let i=0;for(;i++<100;)try{return(0,de.newFunction)("expression",n,`return ${t}`)(...r)}catch(t){if(!(t instanceof ReferenceError))throw t;{const e=/(.+)\s+is not defined/.exec(t.message);if(!e)throw t;n.push(e[1]),r.push(void 0)}}}}return(0,de.newFunction)("expression",[],`return ${t}`)()}var Be=/^[a-zA-Z_$][0-9a-zA-Z_$.]*$/,Xe=t=>Be.test(t);function Je(t){if(t){const e=Object.keys(t),n=e.length,r=e.filter(e=>Xe(e)&&null!==t[e]);if(n===r.length)return t;if(r.length)return t=(0,fe.pick)(t,r)}}function Ue(t){return t?Ge(t,[],{dot:""}):[]}function Ge(t,e,{dot:n=".",visited:r=new Set}={}){return r.has(t)?[e.join("")]:Array.isArray(t)?(r.add(t),t.flatMap((t,n)=>Ge(t,[...e,`[${n}]`],{dot:".",visited:r}))):(i=t)&&i.constructor===Object?(r.add(t),Object.entries(t).flatMap(([t,i])=>Ge(i,[...e,n+t],{dot:".",visited:r}))):[e.join("")];var i}function We(t){if(t<2)throw new y.CommonError("repetitionThreshold must be greater than 1","createEndWithRepetitionDetector",y.ErrorCode.InvalidArgument);const e=new RegExp(`([\\S\\s]+)(\\1{${t-1},})$`);return function(t){return e.exec(t)}}var He=c(require("path")),Ze=c(require("fs")),Ke=c(require("mime-type/with-db")),Ve=c(require("jschardet"));function Qe(t){const e=Ze.statSync(t,{throwIfNoEntry:!1});return e?.isFile()}function Ye(t,e,n,r){const i=r?.signal,s=r?.exclude;let o;if(He.default.isAbsolute(t)?o=Qe(t)?t:tn(He.default.basename(t),[He.default.dirname(t)],{extNames:n,exclude:s,signal:i}):(e||(e=["."]),o=tn(t,e,{extNames:n,exclude:s,signal:i})),!o)throw new y.NotFoundError(t,"loadFileFromPaths");{const t=o;o=Ze.readFileSync(o),r&&(r.filepath=t)}return o}function tn(t,e,{extNames:n,signal:r,exclude:i=[]}){let s;const o=n?n.map(e=>(0,ce.getMultiLevelExtname)(t,(0,ce.extNameLevel)(e))):void 0;"string"==typeof i&&(i=[i]);for(const a of e){if(r?.aborted)throw r.reason;const e=He.default.resolve(a,t);if(o)for(let t=0;t<o.length;t++){const r=e+(o[t]!==n[t]?n[t]:"");if(!i.includes(r)&&Qe(r)){s=r;break}}else if(!i.includes(e)&&Qe(e)){s=e;break}}return s}function en(t,e,n,r,i){let s;"string"==typeof r?(s=r,r=void 0):s=r?.encoding;return nn(Ye(t,e,n,r),s)}function nn(t,e){void 0===e&&(e=un(t)??"utf8");return new TextDecoder(e).decode(t)}function rn(t,e){const n=[],r="string"==typeof t?[{dir:t,level:0}]:[...t.map(t=>({dir:t,level:0}))],i=new Set,s=e?.signal,o=e?.isFileMatched,a=e?.level,c=e?.resolveSymlinks??!0;let u=0;for(;r.length>0;){if(s?.aborted)throw s.reason;const t=r.pop(),e=c?sn(t.dir):t.dir,h=He.default.resolve(e);if(i.has(h))continue;i.add(h);const l=Ze.statSync(e,{throwIfNoEntry:!1});if(l?.isDirectory()){u=t.level+1;const i=Ze.readdirSync(e,{withFileTypes:!0});for(let t=0;t<i.length;t++){let s=i[t],h=He.default.join(e,s.name);const l=h;if(s.isSymbolicLink()){const t=He.default.dirname(h);if(h=Ze.readlinkSync(h),h=He.default.resolve(t,h),s=Ze.statSync(h,{throwIfNoEntry:!1}),!s)continue}if(s.isDirectory())(!a||u<a)&&(o&&!o(h,s)||r.push({dir:h,level:u}));else if(s.isFile()&&(!o||o(h,s))){const t=c?h:l;n.includes(t)||n.push(t)}}}}return n}function sn(t){const e=Ze.lstatSync(t,{throwIfNoEntry:!1});return e?.isSymbolicLink()&&(t=Ze.readlinkSync(t)),t}async function on(t,e){return Jt(ReadableStream.from(Ze.createReadStream(t)),e)}async function an(t){const e=He.default.basename(t);t=He.default.resolve(t);const n=await Ze.promises.stat(t),r=n.mtime,i=n.ctime,s=n.size,o=cn(s),a=await on(t,{hashAlgo:o}),c=Ke.default.lookup(t);return{name:e,mtime:r,ctime:i,size:s,hash:Rt[o]+":"+a,mimeType:c,id:"file://"+t}}function cn(t){let e=111;return t<=2048?e=112:t<=1048576?e=111:t<=10485760?e=113:t>10485760&&(e=10),e}function un(t,e){return Ve.default.detect(t,e).encoding}var hn=require("fs"),ln=c(require("path")),fn=require("@isdk/util"),dn=require("yaml-types"),pn=require("mime-type/with-db"),mn=require("@isdk/util");function yn(t,e){const n=[],r=e?.after,i=e?.exclude?"string"==typeof e.exclude?[e.exclude]:e.exclude:void 0,s=e?.extensions?"string"==typeof e.extensions?[e.extensions]:e.extensions.map(t=>t.startsWith(".")?t:"."+t):[".yml",".yaml",".json"];return(0,fn.traverseFolderSync)(t,(t,e)=>{if(i?.includes(t)||!e.isFile())return;const o=ln.default.extname(t),a=(0,hn.statSync)(t);if(s.includes(o)){if(r?.hasOwnProperty(t)&&a.mtimeMs<=r[t])return;n.push(t)}}),n}function wn(t,e){return yn(t,e).map(t=>fn.ConfigFile.loadSync(t)).filter(t=>void 0!==t)}function vn(t,e,n=1){return fn.ConfigFile.saveSync(t,e,{extLevel:n})}function bn(t){t instanceof Date&&(t=t.toISOString());return function(t,e){return t?`'${e}'`:String(e)}("string"==typeof t,t)}function gn(t,e){return t.map(t=>En(t,e)).join(" AND ")}function Sn(t,e){return t.map(t=>En(t,e)).join(" OR ")}function Tn(t,e){const n=[];return Object.keys(e).forEach(r=>{const i=e[r];switch(r){case"$lt":case"<":n.push(`${t} < ${bn(i)}`);break;case"<=":case"$lte":n.push(`${t} <= ${bn(i)}`);break;case"$gt":case">":n.push(`${t} > ${bn(i)}`);break;case"$gte":case">=":n.push(`${t} >= ${bn(i)}`);break;case"$ne":case"!=":n.push(`${t} != ${bn(i)}`);break;case"=":case"$eq":n.push(`${t} = ${bn(i)}`);break;case"$in":n.push(`${t} IN (${i.map(t=>bn(t)).join(", ")})`);break;case"$nin":n.push(`${t} NOT IN (${i.map(t=>bn(t)).join(", ")})`);break;case"$regex":n.push(`${t} REGEXP '${i.source}'`);break;case"$like":n.push(`${t} LIKE '${i}'`);break;case"$nlike":n.push(`${t} NOT LIKE '${i}'`);break;case"$glob":n.push(`${t} GLOB '${i}'`);break;case"$nglob":n.push(`${t} NOT GLOB '${i}'`);break;default:throw new Error(`Unsupported condition operator: ${r}`)}}),n.join(" AND ")}function En(t,e){const n=[];if("function"!=typeof e&&(e=t=>t),Array.isArray(t))n.push(gn(t,e));else for(const[r,i]of Object.entries(t))if("$and"===r)n.push(`(${gn(t[r],e)})`);else if("$or"===r)n.push(`(${Sn(t[r],e)})`);else{const t=typeof i;if(null==i)n.push(`${e(r)} IS NULL`);else if(i instanceof Date)n.push(`${e(r)}='${i.toISOString()}'`);else if("object"!==t||Array.isArray(i))if("string"===t)n.push(`${e(r)}='${i}'`);else{if("number"!==t&&"boolean"!==t)throw new Error(`Unsupported value type for key ${r}`);n.push(`${e(r)}=${i}`)}else n.push(Tn(e(r),i))}return n.length>1?n.join(" AND "):n[0]}function kn(t){const e=t.indexOf("://");if(e>0)return t.substring(0,e)}function An(t,e=0){let n,r=t*10**e;return t>=1e12?(r=Math.round(r/1e12),n="T"):t>=1e9?(r=Math.round(r/1e9),n="B"):t>=1e6?(r=Math.round(r/1e6),n="M"):t>=1e3?(r=Math.round(r/1e3),n="K"):(r=Math.round(r),n=""),r/=10**e,r.toFixed(e)+n}function $n(t){const e=t.match(/^\s*[+]?(\d+(?:[.]\d+)?)\s*([TBMK])?\s*$/i);if(!e)throw new y.CommonError("Invalid formatted parameter size string.","scaleToSize",y.ErrorCode.InvalidArgument);const n=parseFloat(e[1]),r=e[2]?.toLowerCase();switch(r){case"t":return 1e12*n;case"b":return 1e9*n;case"m":return 1e6*n;case"k":return 1e3*n;default:return n}}function xn(t,e){const n=e?.level||0,r=e?.visiting||new Set,i=e?.objectTag||"*",s=e?.arrayTag||"-",o=!0===e?.title?"name":e?.title;let a=[];const c=" ".repeat(2*n);if(null!=t)switch(typeof t){case"object":r.has(t)?a=["[Circular]"]:(r.add(t),a=Array.isArray(t)?t.map(e=>s+u(e,t)):Object.entries(t).map(([e,n])=>i+" `"+e+"`:"+u(n,t)));break;case"string":return t;default:return JSON.stringify(t)}else a=["null"];return a.length?c+a.join("\n"+c):"";function u(t,e){const i=null!=t&&"object"==typeof t;let s="";return o&&"string"==typeof o&&i&&t[o]&&"string"==typeof t[o]&&(s=" "+t[o],delete t[o]),(i?s+"\n":" ")+xn(t,{level:n+1,visiting:r,parent:e})}}(0,fn.registerYamlTag)(dn.regexp);var Cn=class t{constructor(t=0){this.bitField=t}static has(t,e){return!!(t&1<<e)}static add(t,e){return t|1<<e}static delete(t,e){return t&~(1<<e)}add(t){return this.bitField|=1<<t,this}delete(t){return this.bitField&=~(1<<t),this}has(e){return t.has(this.bitField,e)}clear(){return this.bitField=0,this}valueOf(){return this.bitField}toString(){return this.bitField.toString()}toJSON(){return this.bitField}},In=require("util-ex"),On=require("events-ex");function qn(t=0){return e=Math.min(Math.max(16,t),1073741824),e>>>=0,e-=1,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,1+(e|=e>>16);var e}var Nn=class extends Array{constructor(t,e){Array.isArray(t)?(super(...t),this._length=t.length,t=void 0):(super(),this._length=0),this._capacity=qn(t),this._front=0,this._disableAutoResize=e}push(t){let e=this._length;this.checkCapacity(e+1);const n=this._front+e&this._capacity-1;return this[n]=t,++e<=this._capacity&&(this._length=e),n}unshift(t){let e=this._length;this.checkCapacity(++e);const n=this._capacity,r=(this._front-1&n-1^n)-n;return this[r]=t,this._front=r,e<=this._capacity&&(this._length=e),r}pop(t){let e=this._length;if(0===e)return;let n=this._front+e-1&this._capacity-1,r=this[n];for(;--e>0&&t&&null==r;)n--,r=this[n];return this[n]=void 0,this._length=e,r}shift(t){let e=this._length;if(0===e)return;let n=this._front,r=this[n];for(;--e>0&&t&&null==r;)n=n+1&this._capacity-1,r=this[n];return this[n]=void 0,this._front=n+1&this._capacity-1,this._length=e,r}get size(){return this._length}get(t){let e;if(t===(0|t)){const n=this._length;t<0&&(t+=n),t>=0&&t<n&&(e=this[this._front+t&this._capacity-1])}return e}peekBack(){const t=this._length;if(0===t)return;return this[this._front+t-1&this._capacity-1]}peekFront(){if(0!==this._length)return this[this._front]}clear(){const t=this._length,e=this._front,n=this._capacity;for(let r=0;r<t;++r)this[e+r&n-1]=void 0;this._length=0,this._front=0}isEmpty(){return 0===this._length}removeAt(t){const e=this._length;if(t<0||t>=e)return;const n=this._front,r=this._capacity-1,i=n+t&r,s=this[i];if(t<e/2)this.copyWithin(n+1&r,n,n+t&r),this[n]=void 0,this._front=n+1&r;else{this.copyWithin(i,i+1&r,n+e&r);this[n+e-1&r]=void 0}return this._length=e-1,s}checkCapacity(t){this._capacity<t&&!this._disableAutoResize&&this.resizeTo(qn(1.5*this._capacity+16))}resizeTo(t){const e=this._capacity;this._capacity=t;const n=this._front,r=this._length;if(n+r>e){!function(t,e,n,r,i){for(let s=0;s<i;++s)n[s+r]=t[s+e],t[s+e]=void 0}(this,0,this,e,n+r&e-1)}}},Rn=require("@isdk/common-error"),jn=32;function Mn(t){return"function"==typeof t}function Pn(){return"1"}var Fn=class{constructor(t={}){const{initFn:e=Pn,pauseFn:n,resumeFn:r,capacity:i=jn}=t;if(Mn(n)!==Mn(r))throw new Error("pauseFn and resumeFn must be both set for pausing");this.waiting=new Nn(i),this.emitter=new On.EventEmitter,this.useDefaultTokens=e===Pn,this.pauseFn=n,this.resumeFn=r,this.initTokenFn=e,this.paused=!1,this._activeCount=0,this.initFree(t),this.init(t)}initFree(t){this.free=this.initTokenFn()}onReleased(t){const e=t?.token,n=this.waiting.shift(!0);n?this._dispatchTask(n,t):(this.resumeFn&&this.paused&&(this.paused=!1,this.resumeFn()),this.unlock(e))}init(t){this.emitter.on("release",t=>{this.onReleased(t)})}_newReleaser(t){let e=!1;const n=()=>{e||(e=!0,this.release(t))};return t&&Object.assign(n,t),n}_dispatchTask(t,e){const{resolve:n}=t;n(this._newReleaser(e))}lock(t){let e=this.free;if(e)return this.free=void 0,e}unlock(t){this.free=this.useDefaultTokens?"1":t??this.initTokenFn()}tryAcquire(t){return this.lock(t)}async acquire(t){this._activeCount++;const e=t?.signal,n=t=>{this.pauseFn&&!this.paused&&(this.paused=!0,this.pauseFn());const n=this.waiting.push(t),r=t.reject;return e&&e.addEventListener("abort",()=>{this.waiting[n]=void 0;const t=e.reason instanceof Error?e.reason:new Rn.AbortError(e.reason||"aborted");e.alreadyRejected=!0,r(t)}),n};let r=this.tryAcquire(t);const i=r&&(0,In.isAsync)(r),s=e=>new Promise((r,i)=>{const s={...t,resolve:r,reject:i,token:e};void 0===e?n(s):this._dispatchTask(s,{...t,token:e})});return i?r.then(t=>s(t)):s(r)}release(t){this._activeCount--,this.emitter.emit("release",t)}drain(){const t=[this.acquire()];return Promise.all(t)}abort(t){let e;for(;e=this.waiting.shift(!0);)e.reject(new Rn.AbortError(t))}get activeCount(){return this._activeCount}get pendingCount(){return this.waiting.size}},Ln=class extends Fn{constructor(t,e){if("number"==typeof t)(e=e||{}).maxConcurrency=t;else{if("number"!=typeof(e=t).maxConcurrency)throw new Error("maxConcurrency must be set");t=e.maxConcurrency}super(e),this.maxConcurrency=e.maxConcurrency,e.isReadyFn&&(this.isReady=e.isReadyFn)}initFree(t){const e=t.maxConcurrency=Math.max(1,t.maxConcurrency);this.free=new Nn(e);for(let t=0;t<e;t++)this.free.push(this.initTokenFn())}tryAcquire(t){let e=this.isReady;if(e&&(0,In.isAsync)(e)){return e instanceof Promise||(e=e()),e.then(e=>{if(e)return this.lock(t)})}if(!e||e())return this.lock(t)}unlock(t){this.free.push(this.useDefaultTokens?"1":t??this.initTokenFn())}lock(t){return this.free.pop()}drain(){const t=new Array(this.maxConcurrency);for(let e=0;e<this.maxConcurrency;e++)t[e]=this.acquire();return Promise.all(t)}};function _n(t,{timeUnit:e=1e3,uniformDistribution:n=!1}={}){const r=new Ln(n?1:t),i=n?e/t:e;return async function(){await r.acquire(),setTimeout(()=>r.release(),i)}}var zn,Dn=require("@isdk/common-error"),Bn=class{constructor(){this._isSignaled=!1,this.waitQueue=[]}get signaled(){return this._isSignaled}signal(t){if(this._isSignaled)return;this._isSignaled=!0,this._signalValue=t;const e=this.waitQueue.slice();for(this.waitQueue.length=0;e.length>0;){const t=e.shift();t?.resolve(this._signalValue)}}reset(){this._isSignaled=!1,this._signalValue=void 0,this.waitQueue.length=0}abort(t){if(this.waitQueue.length){const e=this.waitQueue.slice();this.waitQueue.length=0;const n=new Dn.AbortError(t);for(;e.length>0;){const{reject:t}=e.shift();t(n)}}}async wait(){return new Promise((t,e)=>{this._isSignaled?t(this._signalValue):this.waitQueue.push({resolve:t,reject:e})})}},Xn=require("custom-ability"),Jn=require("util-ex"),Un=0,Gn=1,Wn=2,Hn=(t=>(t[t.MultiTask=Un]="MultiTask",t[t.Cancelable=Gn]="Cancelable",t[t.Priority=Wn]="Priority",t))(Hn||{}),Zn=((zn=Zn||{})[zn.MultiTask=1<<Un]="MultiTask",zn[zn.Cancelable=1<<Gn]="Cancelable",zn[zn.Priority=1<<Wn]="Priority",zn),Kn=class extends AbortController{constructor(t){super(),(0,Jn.defineProperty)(this,"parent",t)}abort(t,e){this.signal.aborted||("string"==typeof t&&(t=new y.AbortError(t)),t&&e&&"object"==typeof t&&Object.assign(t.data,e),super.abort(t))}throwRejected(t){const e=this.signal;if(e.aborted){if(void 0===t&&(t=e.alreadyRejected),t)return!0;throw e.reason instanceof Error?e.reason:new y.AbortError(e.reason||"aborted")}}},Vn=class{get maxTaskConcurrency(){return this._maxTaskConcurrency}get semaphore(){return this.getSemaphore()}getSemaphore(t=this._isReadyFn){let e=this._maxTaskConcurrency,n=this.__task_semaphore;return e>0&&!n&&(t&&(t=t.bind(this)),n=this.__task_semaphore=new Ln(e-1,{isReadyFn:t})),n}static hasAsyncFeature(t){const e=this.prototype;let n=e.asyncFeatures;return e._asyncFeatures&&(n|=e._asyncFeatures),Cn.has(n,t)}hasAsyncFeature(t){let e=this.asyncFeatures;return this._asyncFeatures&&(e|=this._asyncFeatures),Cn.has(e,t)}isAborted(t){const e=this.hasAsyncFeature(Un);let n=this.__task_aborter;if(n&&e){if(null==t)throw new y.CommonError("Missing taskId",this.name+".isAborted",y.ErrorCode.InvalidArgument);n=n[t]}return!n||n.signal.aborted}getRunningTask(t){const e=this.hasAsyncFeature(Un);let n=this.__task_aborter;if(n&&e){if(null==t)throw new y.CommonError("Missing taskId",this.name+".getRunningTask",y.ErrorCode.InvalidArgument);n=n[t]}return n?.signal.aborted&&(e?this.__task_aborter[t]=void 0:this.__task_aborter=void 0,n=void 0),n}getRunningTaskCount(){let t;if(this.hasAsyncFeature(Un)){const e=this.__task_aborter;t=e&&Object.entries(e).filter(([t,n])=>{if(!n?.signal.aborted)return!0;e[t]=void 0}).length}else{const e=this.__task_aborter;t=e?.signal.aborted?0:1}return t}_generateAsyncTaskId(t,e){if(e||(e=this.__task_aborter),null==t&&(t=0,e))for(;e[t];)t++;return t}$generateAsyncTaskId(t,e){const n=this.super,r=this.self||this;return t=n?n.call(r,t):this._generateAsyncTaskId(t,e)}createAborter(t,e,n=!0){const r=this.hasAsyncFeature(Un);if(!r&&n&&this.getRunningTask())throw new y.CommonError("The task is running",this.name,y.ErrorCode.TooManyRequests);const i=t?.aborter||new Kn(this);if(!(i instanceof Kn)){if(!(i instanceof AbortController))throw new y.CommonError("aborter should be an AbortController",this.name,y.ErrorCode.InvalidArgument);Object.setPrototypeOf(i,new Kn(this))}if(r){null==this.__task_aborter&&(this.__task_aborter={});const t=this.__task_aborter;null==e&&(e=this.generateAsyncTaskId(e,t)),i.id=e,t[e]=i}else this.__task_aborter=i;const s=[...Qn(t?.signal),...Qn(t?.signals)];s.length&&function(t,e){if(!e.length)return;const n=[],r=()=>{for(const t of n)try{t()}catch{}n.length=0},i=e.find(t=>t.aborted);if(i){const e=i.reason;try{t.abort(e||"aborted")}catch{}return}for(const r of e){const e=()=>{const e=r.reason;try{t.abort(e||"aborted")}catch(t){console.log(t)}};r.addEventListener("abort",e,{once:!0}),n.push(()=>r.removeEventListener("abort",e))}const s=()=>r();t.signal.addEventListener("abort",s,{once:!0}),n.push(()=>t.signal.removeEventListener("abort",s))}(i,s);const o=t?.timeout;return o>0&&(i.timeoutId=setTimeout(()=>{i.timeoutId=void 0,this.abort("timeout",{timeout:o})},o)),i.signal.addEventListener("abort",()=>{const t=i.timeoutId;t&&(i.timeoutId=void 0,clearTimeout(t));const e=i.signal;try{this.emit&&this.emit("aborting",e.reason,e.reason?.data)}finally{try{i.streamController?.error?.(e.reason)}catch{}}}),i}$cleanMultiTaskAborter(t,e){const n=this.super,r=this.self||this;n?n.call(r,t,e):r._cleanMultiTaskAborter(t,e)}cleanTaskAborter(t){if(this.hasAsyncFeature(Un)){const e=this.__task_aborter;this.cleanMultiTaskAborter(t.id,e)}else this.__task_aborter=void 0}_cleanMultiTaskAborter(t,e){"number"==typeof t?e[t]=void 0:delete e[t]}createTaskPromise(t,e,n){const r=this.createAborter(e,n?.taskId,n?.raiseError);void 0===e&&(e={}),"object"==typeof e&&(e.aborter=r);let i=t(e,r).then(t=>{if(t&&t instanceof ReadableStream){const e=()=>{this.cleanTaskAborter(r)},n=ae({onStart:t=>{(0,Jn.defineProperty)(r,"streamController",t)},onFinal:e,onError:e,onTransform:(t,e)=>(t&&"object"==typeof t&&(t.taskId=r.id),t)});t=t.pipeThrough(n)}else this.cleanTaskAborter(r);return t}).catch(t=>{throw this.cleanTaskAborter(r),t}).finally(()=>{r.timeoutId&&(clearTimeout(r.timeoutId),r.timeoutId=void 0)});return i.task=r,i}runAsyncCancelableTask(t={},e,n){let r=this.createTaskPromise(e,t,n);const i=this.getSemaphore(n?.isReadyFn);if(i){const t=r,e=t.task;r=i.acquire({signal:e.signal}).then(()=>t).finally(()=>{i.release()}),r.task=e}return r}abort(t,e){let n=this.__task_aborter;if(n){const r=n;if(this.hasAsyncFeature(Un)){const t=e?.taskId;if(null==t)throw new y.CommonError("Missing data.taskId",this.name+".abort",y.ErrorCode.InvalidArgument);n=n[t],this.cleanMultiTaskAborter(t,r)}else this.__task_aborter=void 0;n&&!n.signal.aborted&&n.abort(t,e)}}};function Qn(t){return t?Array.isArray(t)?t.filter(Boolean):[t]:[]}Vn.prototype.generateAsyncTaskId=function(t,e){return this._generateAsyncTaskId(t,e)},Vn.prototype.cleanMultiTaskAborter=function(t,e){return this._cleanMultiTaskAborter(t,e)};var Yn=(0,Xn.createAbilityInjector)(Vn,"abort",{afterInjection:function(t,e){let n=t.prototype._asyncFeatures||0;n|=Zn.Cancelable,e&&(e.asyncFeatures&&(n|=e.asyncFeatures),e.maxTaskConcurrency>0&&(t.prototype._maxTaskConcurrency=e.maxTaskConcurrency),e.isReadyFn&&"function"==typeof e.isReadyFn&&(t.prototype._isReadyFn=e.isReadyFn)),t.prototype._asyncFeatures=n}});function tr(t,e){const n=e.global?e:new RegExp(e.source,`${e.flags}g`);let r,i=0;for(;null!==(r=n.exec(t));)i++;return i}var er=c(require("memoizee")),nr=require("json-canonicalize");function rr(t,e){var n;void 0!==e?.promise||!function(t){return"function"==typeof t&&"AsyncFunction"===t.constructor.name}(t)&&(!(n=t)||"object"!=typeof n&&"function"!=typeof n||"function"!=typeof n.then)||(e={promise:!0,...e}),void 0===e?.length&&(e={length:!1,...e});const r=e?.normalizer;return(0,er.default)(t,{...e,normalizer:t=>{if(r){const e=r(t);if("string"===e)return e;e&&(t=e)}return zt((0,nr.canonicalize)(t))}})}var ir=c(require("net"));async function sr(t,e=10){return new Promise((n,r)=>{void 0===t?t=0:("string"==typeof t&&(t=parseInt(t)),t>=0||(t=0));const i=ir.default.createServer();i.on("error",n=>{"EADDRINUSE"===n.code&&(t++,--e>0)?i.listen(t):r(n)}),i.on("listening",async()=>{const t=i.address().port;i.close(e=>{e?r(e):n(t)})}),i.listen(t)})}var or=c(require("path")),ar=require("package-directory");function cr(t){const e=(0,ar.packageDirectorySync)({cwd:t});if(e)return e;const n=t.split(or.default.sep);let r=n.lastIndexOf("dist");if(r>0)return n.slice(0,r).join(or.default.sep);if(r=n.lastIndexOf("src"),r>0)return n.slice(0,r).join(or.default.sep);throw new Error("can not find package directory")}var ur=c(require("path"));function hr(t,e){try{const n=ur.default.relative(ur.default.resolve(t),ur.default.resolve(e));return!n.startsWith("..")&&!ur.default.isAbsolute(n)}catch{return!1}}function lr(t,e){return e?.some(e=>hr(e,t))}function fr(t,e){for(const n of e)lr(n,t)||t.push(n);return t}function dr(t){const e=t.slice();return pr(e),e}function pr(t){const e=t.length;if(e<=1)return;const n=new Map,r=[];for(let i=0;i<e;i++){const e=mr(t[i]);n.has(e)||(r.push(e),n.set(e,i))}const i=[...r].sort(),s=new Set;for(let t=0;t<i.length;t++){const e=i[t];let n=!1;for(const t of s)if(hr(t,e)){n=!0;break}n||s.add(e)}let o=0;for(let n=0;n<e;n++)s.has(r[n])&&(o!==n&&(t[o]=t[n]),o++);t.length=o}function mr(t){let e=ur.default.normalize(t);return e=e.split(/[/\\]/).join(ur.default.posix.sep),e.length>1&&e.endsWith("/")&&(e=e.slice(0,-1)),e}var yr=require("util-ex");function wr(t){return(0,yr.isRegExpStr)(t)||(0,yr.isRegExp)(t)}function vr(t){return t.replace(/\x1B[[(?);]{0,2}(;?\d)*./g,"")}var br=c(require("path")),gr=require("url"),Sr=require("@huggingface/transformers"),Tr=(0,gr.fileURLToPath)(h),Er=br.default.dirname(Tr),kr=br.default.join(cr(Er),".cache"),Ar=new Map,$r={"deepseek-ai/DeepSeek-V2-Lite-Chat":"deepseek2","Qwen/Qwen2.5-0.5B":"Qwen2.5","Xenova/gpt-4":"gpt-4 / gpt-3.5-turbo / text-embedding-ada-002","Xenova/text-davinci-003":"text-davinci-003 / text-davinci-002","Xenova/gpt-3":"gpt-3","Xenova/grok-1-tokenizer":"Grok-1","Xenova/claude-tokenizer":"Claude","Xenova/mistral-tokenizer-v3":"Mistral v3","Xenova/mistral-tokenizer-v1":"Mistral v1","Xenova/gemma-tokenizer":"Gemma","Xenova/gemma2-tokenizer":"Gemma2","Xenova/llama3-tokenizer-new":"Llama 3","unsloth/Llama-3.2-1B-Instruct":"Llama 3.2","Xenova/llama-tokenizer":"LLaMA / Llama 2","Xenova/c4ai-command-r-v01-tokenizer":"Cohere Command-R","Xenova/t5-small":"T5","Xenova/bert-base-cased":"bert-base-cased"},xr={deepseek2:"deepseek-ai/DeepSeek-V2-Lite-Chat","qwen2.5":"Qwen/Qwen2.5-0.5B","gpt-4":"Xenova/gpt-4","gpt-3.5-turbo":"Xenova/gpt-4","text-embedding-ada-002":"Xenova/gpt-4","text-davinci-003":"Xenova/text-davinci-003","text-davinci-002":"Xenova/text-davinci-003","gpt-3":"Xenova/gpt-3","grok-1":"Xenova/grok-1-tokenizer",claude:"Xenova/claude-tokenizer",mistral:"Xenova/mistral-tokenizer-v3",mistral3:"Xenova/mistral-tokenizer-v3",mistral1:"Xenova/mistral-tokenizer-v1",gemma:"Xenova/gemma-tokenizer",gemma2:"Xenova/gemma2-tokenizer",llama3:"Xenova/llama3-tokenizer-new",llama2:"Xenova/llama-tokenizer",llama:"Xenova/llama-tokenizer","llama3.2":"unsloth/Llama-3.2-1B-Instruct","cohere-command-r":"Xenova/c4ai-command-r-v01-tokenizer",t5:"Xenova/t5-small","bert-cased":"Xenova/bert-base-cased"};async function Cr(t){let e=Ar.get(t);return e||(e=Sr.AutoTokenizer.from_pretrained(t,{cache_dir:kr}),Ar.set(t,e)),e}async function Ir(t,e="qwen2.5"){xr[e]&&(e=xr[e]);return(await Cr(e)).encode(t)}async function Or(t,e="qwen2.5"){return(await Ir(t,e)).length}function qr(t,e){const n=e?.capitalize??!0;let r=e?.delimiter??/[_-]/g;r instanceof RegExp&&(r.flags.includes("g")||(r=new RegExp(r.source,r.flags+"g")));let i=(t=t.replace(r," ")).split(" ").map(t=>t.trim()).filter(Boolean);return n&&(i=i.map(t=>t.charAt(0).toUpperCase()+t.slice(1))),t=i.join(" ")}async function Nr(t,e){let n,r=1984,i=!0,s=!1,o=!0,a=Or,c=!0;if(e&&(n=e.modelId,e.size>=0&&(r=e.size),void 0!==e.corrected&&(i=e.corrected),void 0!==e.completeSentence&&(s=e.completeSentence),void 0!==e.truncLastSection&&(o=e.truncLastSection),"function"==typeof e.countLLMTokens&&(a=e.countLLMTokens),void 0!==e.bySentence&&(c=e.bySentence)),!c)throw new y.NotImplementationError("truncateToTokenLimit only implemented by sentence","truncateToTokenLimit");if(r>0){let c=await a(t,n);const u=e?.sentences??K(t,e);if(c>r)for(c=await a(u.join("\n"),n);c>r&&u.length;){const e=u.pop();if(e){if(c-=await a(e+"\n",n),s||i)t=u.join("\n");else{const n=t.lastIndexOf(e);if(-1===n)throw new y.CommonError(`Can not find sentence: ${e}`,"truncateContentToTokenLimit");t=t.slice(0,n)}if(c<=1)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");if(c<=r&&o){const e=u[u.length-1];if(e&&et(e)){if(c-await a(e,n)>9){const n=t.lastIndexOf(e);if(-1===n)throw new y.CommonError(`Can not find sentence: ${e}`,"truncateContentToTokenLimit");t=t.slice(0,n).trimEnd()}}}}else c--}else t=u.join("\n")}if(!t)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");return t}async function Rr(t,e){let n,r=1984,i=!0,s=Or,o=!0;if(e&&(n=e.modelId,e.size>=0&&(r=e.size),void 0!==e.truncLastSection&&(i=e.truncLastSection),"function"==typeof e.countLLMTokens&&(s=e.countLLMTokens),void 0!==e.bySentence&&(o=e.bySentence)),!o)throw new y.NotImplementationError("truncateToTokenLimit only implemented by sentence","truncateToTokenLimit");if(r>0){const e=(t=t.slice()).join("\n");let o=await s(e,n);if(o>r)for(;o>r&&t.length;){const e=t.pop();if(e){if(o-=await s(e,n),o<=1)throw new y.CommonError(`Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");if(o<=r&&i){const e=t[t.length-1];if(e&&et(e)){o-await s(e,n)>9&&t.pop()}}}}}if(!t.length)throw new y.CommonError(`Empty. Can not truncate content to fit within the token limit: ${r}`,"truncateContentToTokenLimit");return t}async function jr(t,e){let n,r=1984,i=Or;if(e&&(n=e.modelId,"function"==typeof e.countLLMTokens&&(e.size>=0&&(r=e.size),i=e.countLLMTokens)),r>0){await i(t,n)}}var Mr=c(require("fs"));async function*Pr(t,e){const n=(e={...e,completeSentence:!1,corrected:!1}).size??1984,r=e.modelId,i=e.metaInfo?.size??(await Mr.default.promises.stat(t)).size;let s=Math.trunc(i/2);if(s<=n){let i=nn(await Mr.default.promises.readFile(t));if(s=await Or(i,r),s<=n)yield i;else do{const t=await Nr(i,{...e,modelId:r,size:n});yield t,i=i.slice(t.length)}while(i)}else{const i=ReadableStream.from(Mr.default.createReadStream(t)).getReader();let s="";for(;;){const{done:t,value:o}=await i.read();if(t)break;s+=nn(o);const a=K(s,e);let c=a.pop();if(c){const t=s.lastIndexOf(c);c=s.slice(t),s=s.slice(0,t)}if(s.length>=n){const t=await Nr(s,{...e,modelId:r,size:n,sentences:a});s=s.slice(t.length),yield t}for(;s.length>n;){const t=K(s,e),i=await Nr(s,{...e,modelId:r,size:n,sentences:t});s=s.slice(i.length),yield i}void 0!==c&&(s+=c)}for(;s;){const t=K(s,e),i=await Nr(s,{...e,modelId:r,size:n,sentences:t});s=s.slice(i.length),yield i}}}async function*Fr(t,e){const n=e?.size??1984,r=e?.modelId,i=e?.metaInfo?.size??(await Mr.default.promises.stat(t)).size;let s=Math.trunc(i/2);if(s<=n){let i=nn(await Mr.default.promises.readFile(t));if(s=await Or(i,r),s<=n)yield K(i,e);else{let t=K(i,e);do{const i=await Rr(t,{...e,modelId:r,size:n});yield i,t=t.slice(i.length)}while(t.length)}}else{const i=ReadableStream.from(Mr.default.createReadStream(t)).getReader();let s="";const o=e?.completeSentence,a=e?.corrected,c=!o&&!a;let u;for(;;){const{done:t,value:o}=await i.read();if(t)break;s+=nn(o),u=K(s,e);let a=u.pop();if(s.length>=n){const t=await Rr(u,{...e,modelId:r,size:n});s=c?s.slice(t.length):u.join("\n"),u=u.slice(t.length),s=u.join("\n"),yield t}for(;s.length>n;){const t=await Rr(u,{...e,modelId:r,size:n});u=u.slice(t.length),s=u.join("\n"),yield t}a&&u.push(a)}if(u)for(;u.length;){const t=await Rr(u,{...e,modelId:r,size:n});u=u.slice(t.length),yield t}}}async function Lr(t,e){const n=e?.size??1984,r=e?.modelId;let i=K(t,e);const s=[];if(await Or(t,r)<=n)s.push(i);else do{const t=await Rr(i,{...e,modelId:r,size:n});s.push(t),i=i.slice(t.length)}while(i.length);return s}var _r=require("yaml"),zr=class{constructor(t){t&&Object.assign(this,t)}};function Dr(t,e){class n extends _r.YAMLMap{constructor(){super(...arguments),this.tag=t}toJSON(t,n){n={...n,mapAsMap:!1};const r=super.toJSON(t,n);return new e(r)}}return{tag:t,collection:"map",nodeClass:n,identify:t=>t instanceof e}}function Br(t,e){let n=t.length===e.length;if(n){const r=_t(t),i=_t(e);n=r.every((t,e)=>t===i[e])}return n}var Xr=require("lodash-es"),Jr=c(require("path")),Ur=".ai";function Gr(t,e=["."]){if(Jr.default.isAbsolute(t))return mn.ConfigFile.loadSync(t);const n=e.map(e=>mn.ConfigFile.loadSync(Jr.default.resolve(e,t))).filter(Boolean);return(0,Xr.defaultsDeep)({},...n.reverse())}function Wr(t,e){const n={...process.env,...e};return n.HOME||(n.HOME=process.env.USERPROFILE),(0,I.expandObjEnv)(t,{processEnv:n,parsed:n})}function Hr(t,e){let n=mn.ConfigFile.loadSync(Jr.default.resolve(e.configDir,t));n||(n={configDirs:["$XDG_BIN_HOME",e.configDir,"$HOME"],brainDir:Jr.default.join(e.dataDir,"brain"),agentDirs:[Jr.default.join(e.dataDir,"agent")],promptDirs:[Jr.default.join(e.dataDir,"prompt")],chatsDir:Jr.default.join(e.dataDir,"log","chats"),inputsDir:Jr.default.join(e.dataDir,"log","inputs")});const r=Kr(e);for(const[t,e]of Object.entries(r))n[t]=e;Wr(n,n);const i=n.configDirs;n.AI_CONFIG_BASENAME&&(t=n.AI_CONFIG_BASENAME);const s=Wr(Gr(t,i),n);return(0,Xr.defaultsDeep)(s,(0,Xr.omit)(n,Object.keys(r))),Yr(s),s}function Zr(t){return Hr(Ur,t)}function Kr(t){return{XDG_CONFIG_HOME:t.configDir,XDG_DATA_HOME:t.dataDir,XDG_CACHE_HOME:t.cacheDir,XDG_BIN_HOME:Jr.default.dirname(t.options.root)}}function Vr(t,e){t.startsWith("~")&&(t="$HOME"+t.slice(1));return Wr(t,e)}function Qr(t,e){return t.map(t=>Vr(t,e))}function Yr(t,e=["configDirs","brainDir","agentDirs","promptDirs","chatsDir","inputsDir"],n){for(const r of e){const e=(0,Xr.get)(t,r);if(!e)continue;let i;Array.isArray(e)&&e.length?i=Qr(e,n):"string"==typeof e&&(i=Vr(e,n)),i&&(0,Xr.set)(t,r,i)}}var{exit:ti}=process,ei=!1,ni=!1,ri=["SIGINT","SIGTERM","exit"],ii=3e5,si=[],oi=(t,e)=>t.forEach(t=>process.once(t,e)),ai=t=>()=>{setTimeout(()=>(console.warn(`Could not close resources gracefully after ${t}ms: forcing shutdown`),ti(1)),t).unref()};async function ci(t="shutdown",e=0){if(!ei){ei=!0,"number"==typeof t&&(e=t,t="shutdown");for(const e of si)try{await e(t)}catch(t){console.warn(`A shutdown handler failed before completing with: ${t.message||t}`)}return ti(e)}console.warn(`Shutdown already in progress, ignoring [${t}] signal`)}function ui(t){if(ni||hi(),!si.some(e=>e===t))return si.push(t),t}function hi(){ni||(ni=!0,process.exit=t=>{ei||ci(void 0,t).then()},oi(ri,ai(ii)),oi(ri,ci))}var li=["<BOS>","<EOS>","<PAD>","<UNK>"],fi=".,!?;?!",di=[" ","\n","\t","▁"," "],pi=["the","a","an","的","是","在"];function mi(t,e){const n=e?.exclude?function(t){const e=new Set;if(t.controlSymbols&&li.forEach(t=>e.add(t)),t.punctuation)for(let t=0;t<fi.length;t++)e.add(fi[t]);return t.stopWords&&pi.forEach(t=>e.add(t)),t.whitespace&&di.forEach(t=>e.add(t)),Array.isArray(t.tokens)&&t.tokens.forEach(t=>e.add(t)),[...e]}(e.exclude):void 0;return n&&n.length&&(t=t.filter(t=>!n.includes(t.token.trim()))),yi(t)}function yi(t){if(!Array.isArray(t)||0===t.length)return;const e=t.reduce((t,e)=>t+e.probability,0);return Math.exp(-e/t.length)}var wi=require("lodash-es"),vi=/^\s*@inheritMerge\s*(?:[(]\s*(?<arg>\.start|\.end|false)[)])?/,bi=Symbol("MergeWay"),gi={replace:0,start:1,end:2};function Si(t,...e){return(0,wi.mergeWith)(t,...e,(t,e)=>Array.isArray(t)&&Array.isArray(e)?Ti(t,e):void 0!==t&&"object"!=typeof t?t:void 0)}function Ti(t,e){let n=t[bi];return void 0===n&&(t=function(t){const e=t[0];let n=".start";if("string"==typeof e){const r=vi.exec(e);r&&(r.groups?.arg&&(n=r.groups?.arg),t=t.slice(1))}else e&&"object"==typeof e&&e.hasOwnProperty("@inheritMerge")&&(n=e["@inheritMerge"]||n,t=t.slice(1));n&&(n=n.toLowerCase());let r=gi.start;"false"===n||"no"===n||"not"===n?r=gi.replace:".end"===n&&(r=gi.end);return Object.defineProperty(t,bi,{value:r,enumerable:!1}),t}(t),n=t[bi]),t=n===gi.replace?e:n===gi.end?t.concat(e):e.concat(t),Object.defineProperty(t,bi,{value:n,enumerable:!1}),t}function Ei(t,e=" "){return ki(t).join(e)}function ki(t){return t.split(/(?<=[a-z])(?=[A-Z])|(?<=\d)(?=[A-Za-z])|(?<=[A-Z])(?=[A-Z][a-z])|[\s_]+/g).filter(t=>t.length>0)}function Ai(t,e){if(void 0!==t){const n=JSON.stringify(t);if("{}"!==n&&"[]"!==n&&'""'!==n){const t="p="+encodeURIComponent(n);return e?t:"?"+t}}return""}var $i=require("lodash-es"),xi=require("property-manager"),Ci=require("util-ex"),Ii=class t extends xi.AdvancePropertyManager{static{this.items={}}static{this.aliases={}}static get(t){let e=this.items[t];return!e&&(t=this.aliases[t])&&(e=this.items[t]),e}static list(){return this.items}static getByTag(t){let e;for(const n in this.list()){const r=this.get(n);let i=r.tags;if("string"==typeof i){if(i===t){e=r;break}}else if(Array.isArray(i)&&i.indexOf(t)>=0){e=r;break}}return e}static getAllByTag(t){let e=[];for(const n in this.list()){const r=this.get(n);let i=r.tags;"string"==typeof i?i===t&&e.push(r):Array.isArray(i)&&i.indexOf(t)>=0&&e.push(r)}return e}static hasAsyncFeature(t){const e=this.prototype;let n=e.asyncFeatures??0;return e._asyncFeatures&&(n|=e._asyncFeatures),Cn.has(n,t)}static run(t,e){const n=this.get(t);if(n)return n.run(e);throw new y.NotFoundError(`${t} to run`,this.name)}static runSync(t,e){const n=this.get(t);if(n)return n.runSync(e);throw new y.NotFoundError(`${t} to run`,this.name)}static getFunc(t){const e=this.get(t);return e?.getFunc()}static runWithPos(t,...e){const n=this.get(t);if(n)return n.runWithPos(...e);throw new y.NotFoundError(`${t} to run`,this.name)}static runWithPosSync(t,...e){const n=this.get(t);if(n)return n.runWithPosSync(...e);throw new y.NotFoundError(`${t} to run`,this.name)}static getFuncWithPos(t){const e=this.get(t);return e?.getFuncWithPos()}static register(e,n={}){switch(typeof e){case"string":n.name=e;break;case"function":n.func=e;break;case"object":n=e}e=n.name;let r=!!this.get(e);if(r)r=!1;else{if(!(n instanceof t))return r=new this(n),r.register();if(this.items[e]=n,n.alias){const t=n.alias;if("string"==typeof t)this.aliases[t]&&(0,y.throwError)(`Alias ${t} already exists for ${e}`),this.aliases[t]=e;else if(Array.isArray(t))for(const n of t)this.aliases[n]&&(0,y.throwError)(`Alias ${n} already exists for ${e}`),this.aliases[n]=e}r=n}return r}static unregister(t){const e=this.get(t);if(e&&(delete this.items[t],e.alias)){const t=e.alias;if("string"==typeof t)delete this.aliases[t];else if(Array.isArray(t))for(const e of t)delete this.aliases[e]}return e}constructor(t,e={}){switch(super(),typeof t){case"string":e.name=t;break;case"function":e.func=t;break;case"object":e=t}this.name=t=e.name,e.scope&&(this.scope=e.scope),"function"==typeof e.setup&&e.setup.call(this,e),this.initialize(e)}register(){const e=this.constructor,n=this.depends;if(n){const e=Object.keys(n);for(const r of e){const e=n[r];e instanceof t&&e.register()}}return e.register(this)}unregister(){return this.constructor.unregister(this.name)}arr2ObjParams(t){if(this.params&&(t.length>1||Array.isArray(t[0])||t[0]&&"object"!=typeof t[0])){const e={},n=Object.keys(this.params);let r=Math.min(n.length,t.length);for(let i=0;i<r;i++)e[n[i]]=t[i];t=[e]}return t}obj2ArrParams(t){const e=[];if(t&&this.params&&Array.isArray(this.params)){const n=Object.keys(t);let r=Math.min(n.length,this.params.length);for(let i=0;i<r;i++)e.push(t[n[i]])}return e}runSync(t){const e=this.params&&Array.isArray(this.params);if(Array.isArray(t)){if(e)return this.func(...t);(0,y.throwError)("the function is not support array params, the params must be object!",this.name)}return e?(t=this.obj2ArrParams(t),console.warn('Warning:Use runWithPos() instead of run() for the "'+this.name+'" is function with position params'),this.func(...t)):this.func(t)}run(t){return this.runSync(t)}runAs(t,e){return this.runAsSync(t,e)}runAsSync(t,e){return this.constructor.runSync(t,e)}getFunc(t){return t?this.constructor.getFunc(t):this.runSync.bind(this)}runWithPosSync(...t){return this.params&&!Array.isArray(this.params)&&(t=this.arr2ObjParams(t)),this.func(...t)}runWithPosAsSync(t,...e){return this.constructor.runWithPosSync(t,...e)}runWithPos(...t){return this.runWithPosSync(...t)}runWithPosAs(t,...e){return this.runWithPosAsSync(t,...e)}getFuncWithPos(t){return t?this.constructor.getFuncWithPos(t):this.runWithPosSync.bind(this)}hasAsyncFeature(t){let e=this.asyncFeatures??0;return this._asyncFeatures&&(e|=this._asyncFeatures),Cn.has(e,t)}isStream(t){let e=this.stream;if(e){const n=this.params;n?.stream&&(e=t?.stream)}return e}},Oi={name:{type:"string"},description:{type:"string"},title:{type:"string"},func:{type:"function",assign(t,e,n,r,i){let s=t;const o=typeof t;return i.isExported?s="function"===o?t.toString():t:t&&("string"!==o&&(t=t.toString()),s=(0,Ci._createFunction)(t,e.scope)),s}},params:{type:"object"},result:{type:"any"},setup:{type:"function"},depends:{type:"object",exported:!1},tags:{type:["array","string"]},isApi:{type:"boolean"},stream:{type:"boolean"},asyncFeatures:{type:"number"},alias:{type:["array","string"]}};Ii.defineProperties(Ii,Oi);var qi=Symbol("meta");function Ni(t,e,n=!0){if(e&&"object"==typeof e){if("function"==typeof t)return e=n?(0,$i.assign)({},t[qi],e):(0,$i.defaultsDeep)({},t[qi],e),t[qi]=e,t;if(t instanceof Ii)return t.assign(e)}}function Ri(t){return"function"==typeof t?t[qi]:t instanceof Ii?t.toObject():void 0}var ji=require("lodash-es"),Mi="A client transport has not been set. Use ClientTools.setTransport() or transport.mount(ClientTools) first.",Pi=class t extends Ii{static get apiRoot(){return this._transport||(0,y.throwError)(Mi,"ClientTools"),this._transport.apiRoot}static setTransport(t){if(t){this._transport=t;const e=this.constructor;t.Tools!==e&&(t.Tools=e)}}static get transport(){return this._transport}static async loadFrom(t){return t||(this._transport||(0,y.throwError)(Mi,"ClientTools"),t=await this._transport.loadApis()),t&&this.loadFromSync(t),t}static loadFromSync(e){for(const n in e){const r=this.get(n),i=e[n];r?r instanceof t?r.assign(i):(0,y.throwError)(`${n} already registered as ${r.constructor.name}`,"ClientTools"):this.register(i)}}static async fetch(t,e,...n){const r=this.get(t);if(r&&r.fetch)return r.fetch(e,...n)}get apiRoot(){return this.constructor.apiRoot}async fetch(t,e,n,r){const i=this.constructor;if(i._transport)return r=(0,ji.defaultsDeep)(r,this.fetchOptions),i._transport.fetch(this.name,t,e,n,r);(0,y.throwError)(Mi,"ClientTools")}async func(t){return await this.fetch(t)}},Fi={...m};Pi.defineProperties(Pi,Fi);var Li=class t extends Ii{static get apiRoot(){return this._apiRoot}static setApiRoot(t){this._apiRoot=t}static toJSON(){const e={};for(const n in this.items){let r=this.items[n];(r instanceof t||r.isApi)&&(r.allowExportFunc||(r=r.toJSON(),delete r.func),e[n]=r)}return e}run(t,e){return e&&(t._req=e.req,t._res=e.reply),super.run(t)}func(t){}},_i={...m};Li.defineProperties(Li,_i);var zi=require("events-ex"),Di=class extends Ii{constructor(){super(...arguments),this._emitter=new zi.EventEmitter,this.description="Return event bus",this.result="event"}get emitter(){return this._emitter}func(){return this.emitter}},Bi=new Di(gt),Xi=require("secondary-cache"),Ji=require("secondary-cache"),Ui=Xi.Cache;function Gi({key:t,value:e,options:n}={}){return void 0!==t?null===e?this.cache.del(t):void 0!==e?this.cache.set(t,e,n):this.cache.get(t):(n&&this.cache.setDefaultOptions(n),this.cache)}function Wi(t,e){let n=Ii.get(t);return n||(n=new Ii(t,{func:Gi,description:"get/set LRU cache or return the LRUCache object",params:{key:{name:"key",type:"string",description:"the key is undefined means change the default cache options"},value:{name:"value",type:"any",description:"the value to store, if value is null means remove the key"},options:{name:"options",type:"object|number",description:"the optional cache options:{capacity,expires,cleanInterval} or expires"}},result:"any"}),n.cache=new Xi.Cache(e)),n}var Hi=Wi("lrucache"),Zi=class extends Pi{async fetch(t,e,n,r){return t||(t={}),e?.startsWith("$")&&(t.act=e,e="post"),await super.fetch(t,e,n,r)}async _func(t,e,n){return await this.fetch(e,t,null,n)}async func(t){const e=t.action;return e&&delete t.action,this._func(e,t)}assignMethods(t){if(Array.isArray(t))for(const e of t){const t=e.startsWith("$")?e.slice(1):e;this[t]||(this[t]=(t=>this._func.bind(this,t))(e))}}},Ki={methods:{type:"array",assign(t,e,n,r,i){i?.isExported||e.assignMethods(t)}}};Zi.defineProperties(Zi,Ki);var Vi=class extends Zi{async fetch(t,e,...n){if(t||(t={}),e&&"res"===this.action){if("get"===e||"delete"===e){let n=t.id;return n||(0,y.throwError)("id is required"),"string"==typeof n&&(n=encodeURIComponent(n)),delete t.id,super.fetch(t,e,n)}"list"===e?e="get":e.startsWith("$")&&(t.act=e,e="post")}return await super.fetch(t,e,...n)}},Qi=require("lodash-es"),Yi=class extends Vi{constructor(){super(...arguments),this._sseListeners={},this._forwardEvents=new Set,this.description="subscribe server event",this.ebListener=async function(...t){const e=t[0];let n=t[1];const r=this.type;("string"!=typeof e||n&&"object"!=typeof n||t.length>2)&&(n=t,e&&e===this.target.name&&(n=t.slice(1))),this.target.publish&&await this.target.publish({data:n,event:r})}}static setPubSubTransport(t){t?.setApiRoot&&this.apiRoot&&t.setApiRoot(this.apiRoot),this._pubSubTransport=t}static get pubSubTransport(){if(!this._pubSubTransport)throw new Error("EventClient pubSubTransport not set");return this._pubSubTransport}get clientId(){return this._stream?.clientId}async getEvtSource(){let t=this._stream;return t&&2!==t.readyState||(t=await this.initEventStream(this._streamEvents)),t}get active(){return!!this._stream&&2!==this._stream.readyState}async setActive(t){t!==this.active&&(t?await this.initEventStream(this._streamEvents):this._stream&&this.close())}async initEventStream(t){const e="string"==typeof t?[t]:t;if(this._stream&&2!==this._stream.readyState){if(!this._streamEvents||e&&e.every(t=>this._streamEvents.includes(t)))return this._stream;this._stream.close()}const n=e?{event:e}:void 0,r=this._stream=await this.constructor.pubSubTransport.connect(this.name,n);return r.clientId&&(this.fetchOptions=(0,Qi.defaultsDeep)({clientId:r.clientId},this.fetchOptions)),Object.entries(this._sseListeners).forEach(([t,e])=>{r.on(t,e)}),this._streamEvents=e,r}esListener(t,e,n){if(!this._forwardEvents.has(t)){const n=this.emitter;n&&t&&(Array.isArray(e)?n.emit(t,...e):n.emit(t,e))}}async subscribe(t){this.active||await this.initEventStream(t);const e=await this.sub({event:t});"string"==typeof t&&(t=[t]);const n=await this.getEvtSource();for(const e of t)if(!this._sseListeners[e]){const t=this._sseListeners[e]=(t,n)=>this.esListener(e,t,n);n.on(e,t)}return e}async unsubscribe(t){"string"==typeof t&&(t=[t]);const e=await this.unsub({event:t}),n=await this.getEvtSource();for(const e of t){const t=this._sseListeners[e];t&&(delete this._sseListeners[e],n.off(e,t))}return e}forwardEvent(t){"string"==typeof t&&(t=[t]);for(const e of t)this._forwardEvents.has(e)||(this._forwardEvents.add(e),this.on&&this.on(e,this.ebListener))}unforwardEvent(t){"string"==typeof t&&(t=[t]);for(const e of t)this._forwardEvents.has(e)&&(this._forwardEvents.delete(e),this.off&&this.off(e,this.ebListener))}async init(t){if(this.setActive(!1),await this.initEventStream(t),t)return await this.subscribe(t)}close(){const t=this._stream;if(t)return this._stream=void 0,t.close()}},ts=new Yi(bt),es=require("util-ex"),ns=class extends Li{constructor(t,e={}){super(t,e),this.params={act:{type:"string"}};const n=this.methods=[];this.initRpcMethods(n)}get SpecialRpcMethodNames(){return this.constructor.SpecialRpcMethodNames}initRpcMethods(t=this.methods){const e=this.SpecialRpcMethodNames;if(Array.isArray(e))for(const n of e)"function"==typeof this[n]&&t.push(n);(0,es.getAllNames)(Object.getPrototypeOf(this)).filter(t=>t.startsWith("$")&&"function"==typeof this[t]).forEach(e=>{t.push(e);const n=e.slice(1);void 0===this[n]&&(this[n]=this[e])})}cast(t,e){let n=this.params[t];return n&&("string"!=typeof n&&(n=n.type),"number"===n&&(e=Number(e))),e}getMethodFromParams(t){const e=t?.act;return e}castParams(t){return t}func(t){const e=this.getMethodFromParams(t);if(e&&"function"==typeof this[e])return t=this.castParams(t),this[e](t);throw new y.NotFoundError(e,this.name)}},rs={methods:{type:"array"}};ns.defineProperties(ns,rs);var is=class extends ns{constructor(t,e={}){super(t,e),this.action="res",this.params={id:{type:"string"},val:{type:"any"}}}static{this.SpecialRpcMethodNames=p}getMethodFromParams(t){let e=t?._req?.method?.toLowerCase();return"get"===e&&void 0===t.id?e="list":t.act&&(e=t.act),e}castParams(t){return void 0!==t.id&&(t.id=this.cast("id",t.id)),t}},ss=Bi.runSync(),os="client:",as=class t extends is{constructor(){super(...arguments),this.description="subscribe server event",this.result="event",this.depends={[gt]:Bi}}static{this.autoInjectToLocalBus=!1}static setPubSubTransport(t){this._pubSubTransport=t}static get pubSubTransport(){return this._pubSubTransport||console.warn("EventServer pubSubTransport not set"),this._pubSubTransport}get pubSubTransport(){return this.constructor.pubSubTransport}static publish(t,e,n){return this.pubSubTransport?.publish(t,e,n)}static ebListener(t,...e){this.pubSubTransport?.publish(t,e)}static alreadyForward(t){const e=ss.listeners(t);for(const t of e)if(t===this._boundEbListener)return!0}publishServerEvent(t,e){return this.constructor.publish(t,e)}forward(e){Array.isArray(e)||(e=[e]);const n=this.constructor;n._boundEbListener||(n._boundEbListener=function(...t){return n.ebListener(this.type,...t)});for(const r of e)t.alreadyForward(r)||ss.on(r,n._boundEbListener)}unforward(t){"string"==typeof t&&(t=[t]);const e=this.constructor;if(e._boundEbListener)for(const n of t)ss.off(n,e._boundEbListener)}list({_req:t,_res:e,event:n}){if(this.pubSubTransport)return this.pubSubTransport.connect({req:t,res:e,events:n});(0,y.throwError)("PubSub transport not available","list",y.ErrorCode.NotImplemented)}$sub({event:t,_req:e}){if(this.pubSubTransport||(0,y.throwError)("PubSub transport not available","sub",y.ErrorCode.NotImplemented),t){this.forward(t);const n=e&&this.pubSubTransport.getSessionFromReq?.(e);return n?(this.pubSubTransport.subscribe(n,Array.isArray(t)?t:[t]),{forward:!0,subscribed:!0,event:t,clientId:n.clientId}):(this.pubSubTransport.getSessionFromReq?console.warn("$sub: No session found for request"):e?console.warn(`$sub: The ${this.pubSubTransport.name} Transport does not support dynamic subscription`):console.warn("$sub: missing _req"),{forward:!0,event:t})}(0,y.throwError)("event is required","sub",y.ErrorCode.InvalidArgument)}$unsub({event:t,_req:e}){if(this.pubSubTransport||(0,y.throwError)("PubSub transport not available","unsub",y.ErrorCode.NotImplemented),t){this.unforward(t);const n=e&&this.pubSubTransport.getSessionFromReq?.(e);return n?(this.pubSubTransport.unsubscribe(n,Array.isArray(t)?t:[t]),{forward:!1,subscribed:!1,event:t,clientId:n.clientId}):(this.pubSubTransport.getSessionFromReq?console.warn("$unsub: No session found for request"):e?console.warn(`$unsub: The ${this.pubSubTransport.name} Transport does not support dynamic subscription`):console.warn("$sub: missing _req"),{forward:!1,event:t})}(0,y.throwError)("event is required","unsub",y.ErrorCode.InvalidArgument)}$publish({event:t,data:e,_req:n}){if(t&&e){const r=n&&this.pubSubTransport?.getSessionFromReq?.(n),i=r?.clientId,s=this.constructor;"string"==typeof t&&(t=[t]);for(const n of t)s.autoInjectToLocalBus&&ss.emit(os+n,e,{event:n,sender:r}),this.publishServerEvent(n,e);return{event:t,senderId:i}}(0,y.throwError)("event or data is required","pub",y.ErrorCode.InvalidArgument)}isStream(t){return"list"===this.getMethodFromParams(t)}},cs=new as(bt);function us(){Bi.register(),Hi.register()}var hs=class{setApiRoot(t){this.apiRoot=t}mount(t,e,n){if(e)this.setApiRoot(e);else if(!(e=this.apiRoot))throw new Error("apiRoot is required");return this.Tools=t,this.options=n,this._mount(t,e,n)}},ls=class extends hs{constructor(t){if(!t)throw new Error("apiRoot is required for HttpClientTransport");super(),this.setApiRoot(t)}async _mount(t,e,n){return t.setTransport(this),t.loadFrom()}async loadApis(){return this.fetch("",void 0,"get",void 0,{headers:{"Content-Type":"application/json"}})}async fetch(t,e,n,r,i){i={...this.options,...i};const s=await this._fetch(t,e,n,r,i);if(e?.stream)return s;return await this.toObject(s,e)}},fs=require("lodash-es"),ds=class extends hs{_mount(t,e,n){this.addDiscoveryHandler(e,()=>t),this.addRpcHandler(t,e,n)}start(t){return this.options&&(t=(0,fs.defaultsDeep)(t,this.options)),this._start(t)}},ps=c(require("http")),ms=require("url"),ys=require("lodash-es"),ws=class extends ds{constructor(t){super(),this.discoveryHandlerInfo=null,this.server=t?ps.default.createServer(t,this.requestListener.bind(this)):ps.default.createServer(this.requestListener.bind(this))}async requestListener(t,e){const{url:n,method:r}=t;if(!n)return e.statusCode=400,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"Bad Request"}));if(this.discoveryHandlerInfo&&"GET"===r&&n===this.discoveryHandlerInfo.prefix)try{const t=this.discoveryHandlerInfo.handler();e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(t)),console.log(`[HttpServerTransport] Handled GET ${n} for discovery`)}catch(t){e.statusCode=500,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:t.message||"Internal Server Error"}))}else this.apiRoot&&n.startsWith(this.apiRoot)?await this.handleRpcRequest(t,e):(e.statusCode=404,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:"Not Found"})))}addDiscoveryHandler(t,e){this.discoveryHandlerInfo={prefix:t,handler:e},console.log(`[HttpServerTransport] Mapped GET ${t} for discovery`)}addRpcHandler(t,e,n){e.endsWith("/")||(e+="/"),this.apiRoot=e,console.log(`[HttpServerTransport] Mapped RPC calls for prefix ${e}`)}async handleRpcRequest(t,e){const n=this.Tools;if(!n||!t.url)return e.statusCode=500,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"RPC handler not configured"}));const r=this.apiRoot,i=t.url.split("?")[0].substring(r.length),[s,o]=i.split("/").map(t=>void 0===t?t:decodeURIComponent(t)),a=n.get(s);if(!a)return e.statusCode=404,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:`${s} Not Found`,data:{what:s}}));let c;const u=t.method;try{if("GET"===u||"DELETE"===u){const e=new ms.URL(t.url,`http://${t.headers.host}`).searchParams.get("p");c=e?JSON.parse(e):{}}else{const e=await this.getRequestBody(t);c=e?JSON.parse(e):{}}c._req=t,c._res=e,void 0!==o&&(c.id=o);let n=await a.run(c);a.isStream(c)?n&&"function"==typeof n.pipe?n.pipe(e):e.writableEnded:(e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(n)))}catch(t){if(console.error("Error during RPC execution:",t),e.headersSent)return;e.setHeader("Content-Type","application/json"),t.code&&"number"==typeof t.code?(e.statusCode=t.code,t.stack&&(t.stack=void 0),e.end(JSON.stringify(t))):(e.statusCode=500,e.end(JSON.stringify({error:t.message||"Internal Server Error"})))}}getRequestBody(t){return new Promise((e,n)=>{let r="";t.on("data",t=>{r+=t.toString()}),t.on("end",()=>{e(r)}),t.on("error",t=>{n(t)})})}async _start(t){const{port:e,host:n="0.0.0.0"}=(0,ys.defaultsDeep)(t,{port:3e3});return new Promise((t,r)=>{this.server.on("error",t=>{console.error("[HttpServerTransport] Server error:",t),r(t)}),this.server.listen(e,n,()=>{const e=this.server.address(),n="string"==typeof e?e:`${e?.address}:${e?.port}`;console.log(`[HttpServerTransport] Server listening on ${n}`),t()})})}async stop(t){return new Promise((e,n)=>{if(!this.server||!this.server.listening)return e();t&&this.server.closeAllConnections(),this.server.close(t=>{if(t)return n(t);e()})})}getRaw(){return this.server}},vs=class extends ls{async loadApis(){const t=await fetch(this.apiRoot,{headers:{"Content-Type":"application/json"}});if(!t.ok)throw new Error(`Failed to load tools from ${this.apiRoot}: ${t.statusText}`);return await t.json()}async _fetch(t,e,n,r,i){const s=["post","put","patch"];let o;n||(n=this.Tools.action||"post"),"res"===n&&(n="get"),i.headers&&i.headers["Content-Type"]||!s.includes(n)||(i.headers={"Content-Type":"application/json",...i.headers}),i?.clientId&&(i.headers||(i.headers={}),i.headers["x-client-id"]=i.clientId,delete i.clientId),e?.stream&&!i.headers.Connection&&(i.headers.Connection="keep-alive"),r?("string"!=typeof r&&(r=JSON.stringify(r)),t&&(r=t+"/"+r)):r=t,i.method=n.toUpperCase(),"get"===n||"delete"===n?o=r+Ai(e):(i.body=JSON.stringify(e),o=r),i.headers&&!s.includes(n)&&delete i.headers["Content-Type"];const a=await fetch(`${this.apiRoot}/${o}`,i);if(!a.ok){throw await this.errorFrom(t,a)}return a}async errorFrom(t,e){let n,r=e.status,i=e.statusText;if(e.body){const r=await e.text();try{const e=JSON.parse(r);e&&(e.error&&(i=e.error),e.name&&(t=e.name),e.data&&(n=e.data,n.name=t,n.what&&(n.msg=i,i=n.what)),e.message&&(i=i+":"+e.message))}catch(t){console.warn("🚀 ~ parse error body to json:",t)}}return(0,y.createError)(i,t,r)}async toObject(t,e){return await t.json()}},bs=class{constructor(){this.name="sse",this.protocol="sse",this.channel=new Zt,this.sessions=new Map}connect(t){const{req:e,res:n,clientId:r,events:i}=t??{};if(!e||!n)throw new Error("SSE connect requires options.req and options.res");const s=this.channel.connect(e,n,i,r),o={id:s.clientId,clientId:s.clientId,protocol:"sse",send:(t,e)=>{this.channel.publish(e,t,{clientId:s.clientId})},close:()=>this.channel.disconnect(s),raw:n};return this.sessions.set(s.clientId,o),this.onConn?.(o),e.on("close",()=>{this.sessions.delete(s.clientId),this.onDis?.(o)}),o}getSessionFromReq(t){const e=t.headers["x-client-id"];if(e){return this.sessions.get(e)}}subscribe(t,e){t.clientId&&this.channel.subscribe(t.clientId,e)}unsubscribe(t,e){t.clientId&&this.channel.unsubscribe(t.clientId,e)}publish(t,e,n){this.channel.publish(e,t,n)}onConnection(t){this.onConn=t}onDisconnect(t){this.onDis=t}},gs=class{constructor(){this.apiRoot=""}setApiRoot(t){this.apiRoot=t}async connect(t,e){if(!this.apiRoot&&!t.startsWith("http"))throw new Error("SseClientPubSubTransport requires apiRoot to be set or a full URL to be provided.");const n={...e};let r=t.startsWith("http")?t:`${this.apiRoot}/${t}`;if(n){const t=Ai(n,!0);t&&(r+=(r.includes("?")?"&":"?")+t)}const i=new EventSource(r),s=new Promise(t=>{const e=n=>{i.removeEventListener("welcome",e);const r=n.data,s=r?"string"==typeof r?JSON.parse(r):r:void 0;t(s)};i.addEventListener("welcome",e)}),o=(await s).clientId,a=new Map,c=(t,e)=>{const n=n=>{const r=n.data,i=r?"string"==typeof r?JSON.parse(r):r:void 0;e(i,{...n,event:t})};let r=a.get(t);r||(r=new Map,a.set(t,r)),r.set(e,n),i.addEventListener(t,n)},u=(t,e)=>{const n=a.get(t),r=n?.get(e);r&&(i.removeEventListener(t,r),n.delete(e))};return{clientId:o,protocol:"sse",get readyState(){return i.readyState},on:c,off:u,addEventListener:c,removeEventListener:u,close:()=>i.close()}}disconnect(t){return t.close()}};
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- import{AIArgProcessor as t,AIChatRoles as e,AIMessageTypes as r,AIStream as s,AITextGenerationFinishReasons as o,AbortError as n,AbortErrorCode as i,ActionNames as a,AlreadyExistsError as c,AlreadyExistsErrorCode as p,ArrayMergeWay as h,ArrayMergeWaySymbol as l,AsyncFeatureBits as u,AsyncFeatures as d,BaseError as f,BinarySemaphore as v,CancelableAbility as y,ChoiceArgProcessor as m,ClientToolFuncSchema as S,ClientTools as w,CommonError as T,ConfigFile as N,DEFAULT_CONFIG_NAME as E,DefaultAsyncSemaphoreCapacity as $,DefaultDateFormat as O,EnvStringTemplate as C,ErrorCode as J,EventBusName as g,EventClient as j,EventEmitter as R,EventName as P,EventServer as x,EventToolFunc as q,FStringTemplate as H,FewShotPromptTemplate as b,FilenameReservedRegex as G,FuncMetaSymbol as I,GolangStringTemplate as L,HashAlgorithm as D,IntSet as F,InternalErrorCode as M,LLM_TOKENIZER_NAMES as _,LLM_TOKENIZER_NAMES_MAP as k,LRUCache as A,NIL as B,NotFoundError as V,NotFoundErrorCode as Q,NotImplementationError as U,NotImplementedErrorCode as z,ObjectArgsToArgsInfo as K,PASSING_SCORE as W,PromptExampleSelector as X,RStreamErrCode as Y,RateLimit as Z,ReadableStreamError as tt,RemoteToolFuncSchema as et,ResClientTools as rt,ResServerTools as st,ResponseRStreamErrCode as ot,SHUTDOWN_SIGNALS as nt,SSEChannel as it,SSEChannelAlreadyClosedErrCode as at,SecondaryCache as ct,Semaphore as pt,ServerToolFuncSchema as ht,ServerTools as lt,SignalGate as ut,StrangeHumanName as dt,StringTemplate as ft,TaskAbortController as vt,TemplateArgProcessor as yt,ToolAsyncCancelableBit as mt,ToolAsyncMultiTaskBit as St,ToolAsyncPriorityBit as wt,ToolFunc as Tt,ToolFuncSchema as Nt,WindowsReservedNameRegex as Et,YamlTypeBaseObject as $t,_lrucache as Ot,add as Ct,assignDirs as Jt,backendEventable as gt,base32768 as jt,beforeShutdown as Rt,calcPerplexity as Pt,calcPerplexitySimple as xt,canonicalize as qt,completeSentences as Ht,concatText as bt,countLLMTokens as Gt,countRegexMatches as It,createAbilityInjector as Lt,createCallbacksTransformer as Dt,createEmptyReadableStream as Ft,createEndWithRepetitionDetector as Mt,createError as _t,createEventStreamTransformer as kt,createHfValueFunc as At,createLRUCache as Bt,createYamlObjectTag as Vt,dateToText as Qt,decodeCharset as Ut,defaultTemplateFormat as zt,defaultsWithConcat as Kt,detectCharset as Wt,encodeLLMTokens as Xt,ensureQuoted as Yt,event as Zt,eventClient as te,eventServer as ee,eventable as re,expandConfig as se,expandEnv as oe,expandObjEnv as ne,expandPath as ie,expandPathInObject as ae,expandPaths as ce,extNameLevel as pe,fileIsExists as he,filterValidFnScope as le,findIndexNonEmptyFrom as ue,formatISO as de,formatTextWithSpace as fe,funcGetMeta as ve,funcWithMeta as ye,genUrlParamsStr as me,getAllEnumKeys as Se,getConfigFileNames as we,getConfigs as Te,getEnvVairables as Ne,getFileMetaInfo as Ee,getHashAlgoBySize as $e,getKeysPath as Oe,getLLMTokenizer as Ce,getMultiLevelExtname as Je,getPackageDir as ge,getRealFilepath as je,getResponseErrorReadableStream as Re,getXDGConfigs as Pe,hasDirectoryIn as xe,hash as qe,hashFile as He,hashObject as be,hashStream as Ge,initShutdown as Ie,isLangUsingSpaces as Le,isListItemString as De,isModelNameMatched as Fe,isPunctuationChar as Me,isQuoted as _e,isRegExp as ke,isSameString as Ae,isSectionString as Be,isSentenceEnding as Ve,isSepLineString as Qe,isStrWrapped as Ue,isSubdirectory as ze,isTitleString as Ke,isValidFilename as We,isValidFilepath as Xe,isWebStream as Ye,joinSplitWords as Ze,jsonFilterToWhere as tr,jsonToMarkdownStr as er,loadAIConfig as rr,loadConfig as sr,loadConfigFile as or,loadFileFromPaths as nr,loadTextFromPaths as ir,lrucache as ar,makeToolFuncCancelable as cr,matchUrlProtocol as pr,memoize as hr,mergeArray as lr,messagesToText as ur,mimeType as dr,normalizePath as fr,paramsSizeToScaleStr as vr,parse as yr,parseCommand as mr,parseDateFormat as Sr,parseISO as wr,parseJsJson as Tr,parseJsJsonSimpleSync as Nr,parseObjectArgInfo as Er,parseObjectArgumentInfos as $r,parseObjectArguments as Or,parseObjectArgumentsAsArgInfos as Cr,parseYaml as Jr,pruneSubdirectories as gr,pruneSubdirectoriesInPlace as jr,quoteStr as Rr,readFilenamesRecursiveSync as Pr,readTextFileChunks as xr,readTextFileChunksEx as qr,readableFromAsyncIterable as Hr,registerCoreTools as br,registerYamlTag as Gr,removeMarkdownBold as Ir,removeMarkdownBoldAndItalic as Lr,removeMarkdownItalic as Dr,replaceWithPlaceholder as Fr,restoreFromPlacehoders as Mr,sanitizeFilename as _r,sanitizeFilepath as kr,saveConfigFile as Ar,scaleStrToParamsSize as Br,shutdown as Vr,simplifyObjectArguments as Qr,sleep as Ur,sortedValues as zr,splitChunks as Kr,splitParagraph as Wr,splitSentence as Xr,splitWords as Yr,states as Zr,stringify as ts,stringifyYaml as es,stripConsoleColor as rs,textToDate as ss,throwError as os,toDate as ns,toDateTime as is,toRegExp as as,trimStartOfStreamHelper as cs,truncTo as ps,truncateByToken as hs,truncateToTokenLimit as ls,truncateToTokenLimitEx as us,uuid as ds,v1 as fs,v4 as vs,v5 as ys,validate as ms,version as Ss,wait as ws,wrapEventEmitter as Ts,xxhash as Ns,xxhash32 as Es,xxhash64 as $s,xxhashAsStr as Os,yieldExec as Cs}from"./chunk-LNTIQQNN.mjs";import{findPort as Js}from"./chunk-VIG2GB47.mjs";var gs=class{setApiRoot(t){this.apiRoot=t}mount(t,e,r){if(e)this.setApiRoot(e);else if(!(e=this.apiRoot))throw new Error("apiRoot is required");return this.Tools=t,this.options=r,this._mount(t,e,r)}},js=class extends gs{constructor(t){if(!t)throw new Error("apiRoot is required for HttpClientTransport");super(),this.setApiRoot(t)}async _mount(t,e,r){return t.setTransport(this),t.loadFrom()}async loadApis(){return this.fetch("",void 0,"get",void 0,{headers:{"Content-Type":"application/json"}})}async fetch(t,e,r,s,o){o={...this.options,...o};const n=await this._fetch(t,e,r,s,o);if(e?.stream)return n;return await this.toObject(n,e)}};import{defaultsDeep as Rs}from"lodash-es";var Ps=class extends gs{_mount(t,e,r){this.addDiscoveryHandler(e,()=>t),this.addRpcHandler(t,e,r)}start(t){return this.options&&(t=Rs(t,this.options)),this._start(t)}};import xs from"http";import{URL as qs}from"url";import{defaultsDeep as Hs}from"lodash-es";var bs=class extends Ps{constructor(t){super(),this.discoveryHandlerInfo=null,this.rpcHandlerInfo=null,this.server=t?xs.createServer(t,this.requestListener.bind(this)):xs.createServer(this.requestListener.bind(this))}async requestListener(t,e){const{url:r,method:s}=t;if(!r)return e.statusCode=400,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"Bad Request"}));if(this.discoveryHandlerInfo&&"GET"===s&&r===this.discoveryHandlerInfo.prefix)try{const t=this.discoveryHandlerInfo.handler();e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(t)),console.log(`[HttpServerTransport] Handled GET ${r} for discovery`)}catch(t){e.statusCode=500,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:t.message||"Internal Server Error"}))}else this.rpcHandlerInfo&&r.startsWith(this.rpcHandlerInfo.prefix)?await this.handleRpcRequest(t,e):(e.statusCode=404,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:"Not Found"})))}addDiscoveryHandler(t,e){this.discoveryHandlerInfo={prefix:t,handler:e},console.log(`[HttpServerTransport] Mapped GET ${t} for discovery`)}addRpcHandler(t,e,r){e.endsWith("/")||(e+="/"),this.rpcHandlerInfo={prefix:e,serverTools:t,options:r},console.log(`[HttpServerTransport] Mapped RPC calls for prefix ${e}`)}async handleRpcRequest(t,e){if(!this.rpcHandlerInfo||!t.url)return e.statusCode=500,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"RPC handler not configured"}));const{serverTools:r,prefix:s}=this.rpcHandlerInfo,o=t.url.split("?")[0].substring(s.length),[n,i]=o.split("/"),a=r.get(n);if(!a)return e.statusCode=404,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:`${n} Not Found`,data:{what:n}}));let c;const p=t.method;try{if("GET"===p||"DELETE"===p){const e=new qs(t.url,`http://${t.headers.host}`).searchParams.get("p");c=e?JSON.parse(e):{}}else{const e=await this.getRequestBody(t);c=e?JSON.parse(e):{}}c._req=t,c._res=e,void 0!==i&&(c.id=i);let r=await a.run(c);a.isStream(c)?r&&"function"==typeof r.pipe?r.pipe(e):e.writableEnded||e.end():(e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(r)))}catch(t){if(console.error("Error during RPC execution:",t),e.headersSent)return;e.setHeader("Content-Type","application/json"),t.code&&"number"==typeof t.code?(e.statusCode=t.code,t.stack&&(t.stack=void 0),e.end(JSON.stringify(t))):(e.statusCode=500,e.end(JSON.stringify({error:t.message||"Internal Server Error"})))}}getRequestBody(t){return new Promise((e,r)=>{let s="";t.on("data",t=>{s+=t.toString()}),t.on("end",()=>{e(s)}),t.on("error",t=>{r(t)})})}async _start(t){const{port:e,host:r="0.0.0.0"}=Hs(t,{port:3e3});return new Promise((t,s)=>{this.server.on("error",t=>{console.error("[HttpServerTransport] Server error:",t),s(t)}),this.server.listen(e,r,()=>{const e=this.server.address(),r="string"==typeof e?e:`${e?.address}:${e?.port}`;console.log(`[HttpServerTransport] Server listening on ${r}`),t()})})}async stop(){return new Promise((t,e)=>{if(!this.server.listening)return t();this.server.close(r=>{if(r)return e(r);t()})})}getRaw(){return this.server}},Gs=class extends js{async loadApis(){const t=await fetch(this.apiRoot,{headers:{"Content-Type":"application/json"}});if(!t.ok)throw new Error(`Failed to load tools from ${this.apiRoot}: ${t.statusText}`);return await t.json()}async _fetch(t,e,r,s,o){const n=["post","put","patch"];let i;r||(r=this.Tools.action||"post"),"res"===r&&(r="get"),o.headers&&o.headers["Content-Type"]||!n.includes(r)||(o.headers={"Content-Type":"application/json",...o.headers}),e?.stream&&!o.headers.Connection&&(o.headers.Connection="keep-alive"),s?("string"!=typeof s&&(s=JSON.stringify(s)),t&&(s=t+"/"+s)):s=t,o.method=r.toUpperCase(),"get"===r||"delete"===r?i=s+me(e):(o.body=JSON.stringify(e),i=s),o.headers&&!n.includes(r)&&delete o.headers["Content-Type"];const a=await fetch(`${this.apiRoot}/${i}`,o);if(!a.ok){throw await this.errorFrom(t,a)}return a}async errorFrom(t,e){let r,s=e.status,o=e.statusText;if(e.body){const s=await e.text();try{const e=JSON.parse(s);e&&(e.error&&(o=e.error),e.name&&(t=e.name),e.data&&(r=e.data,r.name=t,r.what&&(r.msg=o,o=r.what)),e.message&&(o=o+":"+e.message))}catch(t){console.warn("🚀 ~ parse error body to json:",t)}}return _t(o,t,s)}async toObject(t,e){return await t.json()}},Is=class{constructor(){this.name="sse",this.protocol="sse",this.channel=new it}mount(){}subscribe(t,e){const{req:r,res:s,clientId:o}=e??{};if(!r||!s)throw new Error("SSE subscribe requires options.req and options.res");const n=this.channel.subscribe(r,s,t,o),i={id:`${Date.now()}-${Math.random().toString(36).slice(2)}`,clientId:n.clientId,protocol:"sse",send:(t,e)=>{s.write(`event: ${t}\n`),s.write(`data: ${JSON.stringify(e)}\n\n`)},close:()=>s.end?.(),raw:s};return this.onConn?.(i),r.on("close",()=>this.onDis?.(i)),n}publish(t,e,r){this.channel.publish(e,t,r)}onConnection(t){this.onConn=t}onDisconnect(t){this.onDis=t}},Ls=class{connect(t,e){const r=e?`?${new URLSearchParams(e).toString()}`:"",s=new EventSource(`${t}${r}`),o=new Map,n=(t,e)=>{const r=r=>{const s=r.data,o=s?"string"==typeof s?JSON.parse(s):s:void 0;e(o,{...r,event:t})};let n=o.get(t);n||(n=new Map,o.set(t,n)),n.set(e,r),s.addEventListener(t,r)},i=(t,e)=>{const r=o.get(t),n=r?.get(e);n&&(s.removeEventListener(t,n),r.delete(e))};return{protocol:"sse",get readyState(){return s.readyState},on:n,off:i,addEventListener:n,removeEventListener:i,close:()=>s.close()}}disconnect(t){return t.close()}};export{t as AIArgProcessor,e as AIChatRoles,r as AIMessageTypes,s as AIStream,o as AITextGenerationFinishReasons,n as AbortError,i as AbortErrorCode,a as ActionNames,c as AlreadyExistsError,p as AlreadyExistsErrorCode,h as ArrayMergeWay,l as ArrayMergeWaySymbol,u as AsyncFeatureBits,d as AsyncFeatures,f as BaseError,v as BinarySemaphore,y as CancelableAbility,m as ChoiceArgProcessor,S as ClientToolFuncSchema,js as ClientToolTransport,w as ClientTools,T as CommonError,N as ConfigFile,E as DEFAULT_CONFIG_NAME,$ as DefaultAsyncSemaphoreCapacity,O as DefaultDateFormat,C as EnvPromptTemplate,J as ErrorCode,g as EventBusName,j as EventClient,R as EventEmitter,P as EventName,x as EventServer,Zr as EventStates,q as EventToolFunc,H as FStringPromptTemplate,b as FewShotPromptTemplate,G as FilenameReservedRegex,I as FuncMetaSymbol,L as GolangPromptTemplate,D as HashAlgorithm,Gs as HttpClientToolTransport,bs as HttpServerToolTransport,F as IntSet,M as InternalErrorCode,_ as LLM_TOKENIZER_NAMES,k as LLM_TOKENIZER_NAMES_MAP,A as LRUCache,V as NotFoundError,Q as NotFoundErrorCode,U as NotImplementationError,z as NotImplementedErrorCode,K as ObjectArgsToArgsInfo,W as PASSING_SCORE,X as PromptExampleSelector,ft as PromptTemplate,Y as RStreamErrCode,Z as RateLimit,tt as ReadableStreamError,et as RemoteToolFuncSchema,rt as ResClientTools,st as ResServerTools,ot as ResponseRStreamErrCode,nt as SHUTDOWN_SIGNALS,it as SSEChannel,at as SSEChannelAlreadyClosedErrCode,ct as SecondaryCache,pt as Semaphore,ht as ServerToolFuncSchema,Ps as ServerToolTransport,lt as ServerTools,ut as SignalGate,Ls as SseClientPubSubTransport,Is as SseServerPubSubTransport,dt as StrangeHumanName,vt as TaskAbortController,yt as TemplateArgProcessor,mt as ToolAsyncCancelableBit,St as ToolAsyncMultiTaskBit,wt as ToolAsyncPriorityBit,Tt as ToolFunc,Nt as ToolFuncSchema,gs as ToolTransport,Et as WindowsReservedNameRegex,$t as YamlTypeBaseObject,Ot as _lrucache,Ct as addDate,Jt as assignDirs,gt as backendEventable,jt as base32768,Rt as beforeShutdown,Pt as calcPerplexity,xt as calcPerplexitySimple,qt as canonicalize,Ht as completeSentences,bt as concatText,Gt as countLLMTokens,It as countRegexMatches,Lt as createAbilityInjector,Dt as createCallbacksTransformer,Ft as createEmptyReadableStream,Mt as createEndWithRepetitionDetector,_t as createError,kt as createEventStreamTransformer,At as createHfValueFunc,Bt as createLRUCache,Vt as createYamlObjectTag,Qt as dateToText,Ut as decodeCharset,zt as defaultTemplateFormat,Kt as defaultsWithConcat,Wt as detectCharset,Xt as encodeLLMTokens,Yt as ensureQuoted,Zt as event,te as eventClient,ee as eventServer,re as eventable,se as expandConfig,oe as expandEnv,ne as expandObjEnv,ie as expandPath,ae as expandPathInObject,ce as expandPaths,pe as extNameLevel,he as fileIsExists,le as filterValidFnScope,ue as findIndexNonEmptyFrom,Js as findPort,de as formatISO,fe as formatTextWithSpace,ve as funcGetMeta,ye as funcWithMeta,me as genUrlParamsStr,Se as getAllEnumKeys,we as getConfigFileNames,Te as getConfigs,Ne as getEnvVairables,Ee as getFileMetaInfo,$e as getHashAlgoBySize,Oe as getKeysPath,Ce as getLLMTokenizer,Je as getMultiLevelExtname,ge as getPackageDir,je as getRealFilepath,Re as getResponseErrorReadableStream,Pe as getXDGConfigs,xe as hasDirectoryIn,qe as hash,He as hashFile,be as hashObject,Ge as hashStream,Ie as initShutdown,Le as isLangUsingSpaces,De as isListItemString,Fe as isModelNameMatched,Me as isPunctuationChar,_e as isQuoted,ke as isRegExp,Ae as isSameString,Be as isSectionString,Ve as isSentenceEnding,Qe as isSepLineString,Ue as isStrWrapped,ze as isSubdirectory,Ke as isTitleString,We as isValidFilename,Xe as isValidFilepath,Ye as isWebStream,Ze as joinSplitWords,tr as jsonFilterToWhere,er as jsonToMarkdownStr,rr as loadAIConfig,sr as loadConfig,or as loadConfigFile,nr as loadFileFromPaths,ir as loadTextFromPaths,ar as lrucache,cr as makeToolFuncCancelable,pr as matchUrlProtocol,hr as memoize,lr as mergeArray,ur as messagesToText,dr as mimeType,fr as normalizePath,vr as paramsSizeToScaleStr,mr as parseCommand,Sr as parseDateFormat,wr as parseISO,Tr as parseJsJson,Nr as parseJsJsonSimpleSync,Er as parseObjectArgInfo,$r as parseObjectArgumentInfos,Or as parseObjectArguments,Cr as parseObjectArgumentsAsArgInfos,Jr as parseYaml,gr as pruneSubdirectories,jr as pruneSubdirectoriesInPlace,Rr as quoteStr,Pr as readFilenamesRecursiveSync,xr as readTextFileChunks,qr as readTextFileChunksEx,Hr as readableFromAsyncIterable,br as registerCoreTools,Gr as registerYamlTag,Ir as removeMarkdownBold,Lr as removeMarkdownBoldAndItalic,Dr as removeMarkdownItalic,Fr as replaceWithPlaceholder,Mr as restoreFromPlacehoders,_r as sanitizeFilename,kr as sanitizeFilepath,Ar as saveConfigFile,Br as scaleStrToParamsSize,Vr as shutdown,Qr as simplifyObjectArguments,Ur as sleep,zr as sortedValues,Kr as splitChunks,Wr as splitParagraph,Xr as splitSentence,Yr as splitWords,es as stringifyYaml,rs as stripConsoleColor,ss as textToDate,os as throwError,ns as toDate,is as toDateTime,as as toRegExp,cs as trimStartOfStreamHelper,ps as truncTo,hs as truncateByToken,ls as truncateToTokenLimit,us as truncateToTokenLimitEx,ds as uuid,B as uuidNIL,yr as uuidParse,ts as uuidStringify,ms as uuidValidate,Ss as uuidVersion,fs as uuidv1,vs as uuidv4,ys as uuidv5,ws as wait,Ts as wrapEventEmitter,Ns as xxhash,Es as xxhash32,$s as xxhash64,Os as xxhashAsStr,Cs as yieldExec};
1
+ import{AIArgProcessor as t,AIChatRoles as e,AIMessageTypes as s,AIStream as r,AITextGenerationFinishReasons as o,AbortError as n,AbortErrorCode as i,ActionNames as a,AlreadyExistsError as c,AlreadyExistsErrorCode as p,ArrayMergeWay as h,ArrayMergeWaySymbol as l,AsyncFeatureBits as u,AsyncFeatures as d,BaseError as f,BinarySemaphore as v,CancelableAbility as y,ChoiceArgProcessor as m,ClientEventPrefix as w,ClientToolFuncSchema as S,ClientTools as T,CommonError as E,ConfigFile as N,DEFAULT_CONFIG_NAME as C,DefaultAsyncSemaphoreCapacity as O,DefaultDateFormat as g,EnvStringTemplate as R,ErrorCode as J,EventBusName as j,EventClient as P,EventEmitter as $,EventName as b,EventServer as q,EventToolFunc as H,FStringTemplate as I,FewShotPromptTemplate as x,FilenameReservedRegex as F,FuncMetaSymbol as G,GolangStringTemplate as L,HashAlgorithm as D,IntSet as M,InternalErrorCode as A,LLM_TOKENIZER_NAMES as _,LLM_TOKENIZER_NAMES_MAP as k,LRUCache as B,NIL as V,NotFoundError as U,NotFoundErrorCode as K,NotImplementationError as Y,NotImplementedErrorCode as Z,ObjectArgsToArgsInfo as z,PASSING_SCORE as Q,PromptExampleSelector as W,RStreamErrCode as X,RateLimit as tt,ReadableStreamError as et,RemoteToolFuncSchema as st,ResClientTools as rt,ResServerTools as ot,ResponseRStreamErrCode as nt,RpcMethodsClientTool as it,RpcMethodsClientToolSchema as at,RpcMethodsServerTool as ct,RpcMethodsServerToolSchema as pt,SHUTDOWN_SIGNALS as ht,SSEChannel as lt,SSEChannelAlreadyClosedErrCode as ut,SecondaryCache as dt,Semaphore as ft,ServerToolFuncSchema as vt,ServerTools as yt,SignalGate as mt,StrangeHumanName as wt,StringTemplate as St,TaskAbortController as Tt,TemplateArgProcessor as Et,ToolAsyncCancelableBit as Nt,ToolAsyncMultiTaskBit as Ct,ToolAsyncPriorityBit as Ot,ToolFunc as gt,ToolFuncSchema as Rt,WindowsReservedNameRegex as Jt,YamlTypeBaseObject as jt,_lrucache as Pt,add as $t,assignDirs as bt,backendEventable as qt,base32768 as Ht,beforeShutdown as It,calcPerplexity as xt,calcPerplexitySimple as Ft,canonicalize as Gt,completeSentences as Lt,concatText as Dt,countLLMTokens as Mt,countRegexMatches as At,createAbilityInjector as _t,createCallbacksTransformer as kt,createEmptyReadableStream as Bt,createEndWithRepetitionDetector as Vt,createError as Ut,createEventStreamTransformer as Kt,createHfValueFunc as Yt,createLRUCache as Zt,createYamlObjectTag as zt,dateToText as Qt,decodeCharset as Wt,defaultTemplateFormat as Xt,defaultsWithConcat as te,detectCharset as ee,encodeLLMTokens as se,ensureQuoted as re,event as oe,eventClient as ne,eventServer as ie,eventable as ae,expandConfig as ce,expandEnv as pe,expandObjEnv as he,expandPath as le,expandPathInObject as ue,expandPaths as de,extNameLevel as fe,fileIsExists as ve,filterValidFnScope as ye,findIndexNonEmptyFrom as me,formatISO as we,formatTextWithSpace as Se,funcGetMeta as Te,funcWithMeta as Ee,genUrlParamsStr as Ne,getAllEnumKeys as Ce,getConfigFileNames as Oe,getConfigs as ge,getEnvVairables as Re,getFileMetaInfo as Je,getHashAlgoBySize as je,getKeysPath as Pe,getLLMTokenizer as $e,getMultiLevelExtname as be,getPackageDir as qe,getRealFilepath as He,getResponseErrorReadableStream as Ie,getXDGConfigs as xe,hasDirectoryIn as Fe,hash as Ge,hashFile as Le,hashObject as De,hashStream as Me,initShutdown as Ae,isLangUsingSpaces as _e,isListItemString as ke,isModelNameMatched as Be,isPunctuationChar as Ve,isQuoted as Ue,isRegExp as Ke,isSameString as Ye,isSectionString as Ze,isSentenceEnding as ze,isSepLineString as Qe,isStrWrapped as We,isSubdirectory as Xe,isTitleString as ts,isValidFilename as es,isValidFilepath as ss,isWebStream as rs,joinSplitWords as os,jsonFilterToWhere as ns,jsonToMarkdownStr as is,loadAIConfig as as,loadConfig as cs,loadConfigFile as ps,loadFileFromPaths as hs,loadTextFromPaths as ls,lrucache as us,makeToolFuncCancelable as ds,matchUrlProtocol as fs,memoize as vs,mergeArray as ys,messagesToText as ms,mimeType as ws,nanoid as Ss,normalizePath as Ts,paramsSizeToScaleStr as Es,parse as Ns,parseCommand as Cs,parseDateFormat as Os,parseISO as gs,parseJsJson as Rs,parseJsJsonSimpleSync as Js,parseObjectArgInfo as js,parseObjectArgumentInfos as Ps,parseObjectArguments as $s,parseObjectArgumentsAsArgInfos as bs,parseYaml as qs,pruneSubdirectories as Hs,pruneSubdirectoriesInPlace as Is,quoteStr as xs,readFilenamesRecursiveSync as Fs,readTextFileChunks as Gs,readTextFileChunksEx as Ls,readableFromAsyncIterable as Ds,registerCoreTools as Ms,registerYamlTag as As,removeMarkdownBold as _s,removeMarkdownBoldAndItalic as ks,removeMarkdownItalic as Bs,replaceWithPlaceholder as Vs,restoreFromPlacehoders as Us,sanitizeFilename as Ks,sanitizeFilepath as Ys,saveConfigFile as Zs,scaleStrToParamsSize as zs,shutdown as Qs,simplifyObjectArguments as Ws,sleep as Xs,sortedValues as tr,splitChunks as er,splitParagraph as sr,splitSentence as rr,splitWords as or,states as nr,stringify as ir,stringifyYaml as ar,stripConsoleColor as cr,textToDate as pr,throwError as hr,toDate as lr,toDateTime as ur,toRegExp as dr,trimStartOfStreamHelper as fr,truncTo as vr,truncateByToken as yr,truncateToTokenLimit as mr,truncateToTokenLimitEx as wr,uuid as Sr,v1 as Tr,v4 as Er,v5 as Nr,v6 as Cr,v7 as Or,validate as gr,version as Rr,wait as Jr,wrapEventEmitter as jr,xxhash as Pr,xxhash32 as $r,xxhash64 as br,xxhashAsStr as qr,yieldExec as Hr}from"./chunk-4FKBOPZI.mjs";import{findPort as Ir}from"./chunk-TGTHY57V.mjs";var xr=class{setApiRoot(t){this.apiRoot=t}mount(t,e,s){if(e)this.setApiRoot(e);else if(!(e=this.apiRoot))throw new Error("apiRoot is required");return this.Tools=t,this.options=s,this._mount(t,e,s)}},Fr=class extends xr{constructor(t){if(!t)throw new Error("apiRoot is required for HttpClientTransport");super(),this.setApiRoot(t)}async _mount(t,e,s){return t.setTransport(this),t.loadFrom()}async loadApis(){return this.fetch("",void 0,"get",void 0,{headers:{"Content-Type":"application/json"}})}async fetch(t,e,s,r,o){o={...this.options,...o};const n=await this._fetch(t,e,s,r,o);if(e?.stream)return n;return await this.toObject(n,e)}};import{defaultsDeep as Gr}from"lodash-es";var Lr=class extends xr{_mount(t,e,s){this.addDiscoveryHandler(e,()=>t),this.addRpcHandler(t,e,s)}start(t){return this.options&&(t=Gr(t,this.options)),this._start(t)}};import Dr from"http";import{URL as Mr}from"url";import{defaultsDeep as Ar}from"lodash-es";var _r=class extends Lr{constructor(t){super(),this.discoveryHandlerInfo=null,this.server=t?Dr.createServer(t,this.requestListener.bind(this)):Dr.createServer(this.requestListener.bind(this))}async requestListener(t,e){const{url:s,method:r}=t;if(!s)return e.statusCode=400,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"Bad Request"}));if(this.discoveryHandlerInfo&&"GET"===r&&s===this.discoveryHandlerInfo.prefix)try{const t=this.discoveryHandlerInfo.handler();e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(t)),console.log(`[HttpServerTransport] Handled GET ${s} for discovery`)}catch(t){e.statusCode=500,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:t.message||"Internal Server Error"}))}else this.apiRoot&&s.startsWith(this.apiRoot)?await this.handleRpcRequest(t,e):(e.statusCode=404,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({error:"Not Found"})))}addDiscoveryHandler(t,e){this.discoveryHandlerInfo={prefix:t,handler:e},console.log(`[HttpServerTransport] Mapped GET ${t} for discovery`)}addRpcHandler(t,e,s){e.endsWith("/")||(e+="/"),this.apiRoot=e,console.log(`[HttpServerTransport] Mapped RPC calls for prefix ${e}`)}async handleRpcRequest(t,e){const s=this.Tools;if(!s||!t.url)return e.statusCode=500,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:"RPC handler not configured"}));const r=this.apiRoot,o=t.url.split("?")[0].substring(r.length),[n,i]=o.split("/").map(t=>void 0===t?t:decodeURIComponent(t)),a=s.get(n);if(!a)return e.statusCode=404,e.setHeader("Content-Type","application/json"),void e.end(JSON.stringify({error:`${n} Not Found`,data:{what:n}}));let c;const p=t.method;try{if("GET"===p||"DELETE"===p){const e=new Mr(t.url,`http://${t.headers.host}`).searchParams.get("p");c=e?JSON.parse(e):{}}else{const e=await this.getRequestBody(t);c=e?JSON.parse(e):{}}c._req=t,c._res=e,void 0!==i&&(c.id=i);let s=await a.run(c);a.isStream(c)?s&&"function"==typeof s.pipe?s.pipe(e):e.writableEnded:(e.setHeader("Content-Type","application/json"),e.statusCode=200,e.end(JSON.stringify(s)))}catch(t){if(console.error("Error during RPC execution:",t),e.headersSent)return;e.setHeader("Content-Type","application/json"),t.code&&"number"==typeof t.code?(e.statusCode=t.code,t.stack&&(t.stack=void 0),e.end(JSON.stringify(t))):(e.statusCode=500,e.end(JSON.stringify({error:t.message||"Internal Server Error"})))}}getRequestBody(t){return new Promise((e,s)=>{let r="";t.on("data",t=>{r+=t.toString()}),t.on("end",()=>{e(r)}),t.on("error",t=>{s(t)})})}async _start(t){const{port:e,host:s="0.0.0.0"}=Ar(t,{port:3e3});return new Promise((t,r)=>{this.server.on("error",t=>{console.error("[HttpServerTransport] Server error:",t),r(t)}),this.server.listen(e,s,()=>{const e=this.server.address(),s="string"==typeof e?e:`${e?.address}:${e?.port}`;console.log(`[HttpServerTransport] Server listening on ${s}`),t()})})}async stop(t){return new Promise((e,s)=>{if(!this.server||!this.server.listening)return e();t&&this.server.closeAllConnections(),this.server.close(t=>{if(t)return s(t);e()})})}getRaw(){return this.server}},kr=class extends Fr{async loadApis(){const t=await fetch(this.apiRoot,{headers:{"Content-Type":"application/json"}});if(!t.ok)throw new Error(`Failed to load tools from ${this.apiRoot}: ${t.statusText}`);return await t.json()}async _fetch(t,e,s,r,o){const n=["post","put","patch"];let i;s||(s=this.Tools.action||"post"),"res"===s&&(s="get"),o.headers&&o.headers["Content-Type"]||!n.includes(s)||(o.headers={"Content-Type":"application/json",...o.headers}),o?.clientId&&(o.headers||(o.headers={}),o.headers["x-client-id"]=o.clientId,delete o.clientId),e?.stream&&!o.headers.Connection&&(o.headers.Connection="keep-alive"),r?("string"!=typeof r&&(r=JSON.stringify(r)),t&&(r=t+"/"+r)):r=t,o.method=s.toUpperCase(),"get"===s||"delete"===s?i=r+Ne(e):(o.body=JSON.stringify(e),i=r),o.headers&&!n.includes(s)&&delete o.headers["Content-Type"];const a=await fetch(`${this.apiRoot}/${i}`,o);if(!a.ok){throw await this.errorFrom(t,a)}return a}async errorFrom(t,e){let s,r=e.status,o=e.statusText;if(e.body){const r=await e.text();try{const e=JSON.parse(r);e&&(e.error&&(o=e.error),e.name&&(t=e.name),e.data&&(s=e.data,s.name=t,s.what&&(s.msg=o,o=s.what)),e.message&&(o=o+":"+e.message))}catch(t){console.warn("🚀 ~ parse error body to json:",t)}}return Ut(o,t,r)}async toObject(t,e){return await t.json()}},Br=class{constructor(){this.name="sse",this.protocol="sse",this.channel=new lt,this.sessions=new Map}connect(t){const{req:e,res:s,clientId:r,events:o}=t??{};if(!e||!s)throw new Error("SSE connect requires options.req and options.res");const n=this.channel.connect(e,s,o,r),i={id:n.clientId,clientId:n.clientId,protocol:"sse",send:(t,e)=>{this.channel.publish(e,t,{clientId:n.clientId})},close:()=>this.channel.disconnect(n),raw:s};return this.sessions.set(n.clientId,i),this.onConn?.(i),e.on("close",()=>{this.sessions.delete(n.clientId),this.onDis?.(i)}),i}getSessionFromReq(t){const e=t.headers["x-client-id"];if(e){return this.sessions.get(e)}}subscribe(t,e){t.clientId&&this.channel.subscribe(t.clientId,e)}unsubscribe(t,e){t.clientId&&this.channel.unsubscribe(t.clientId,e)}publish(t,e,s){this.channel.publish(e,t,s)}onConnection(t){this.onConn=t}onDisconnect(t){this.onDis=t}},Vr=class{constructor(){this.apiRoot=""}setApiRoot(t){this.apiRoot=t}async connect(t,e){if(!this.apiRoot&&!t.startsWith("http"))throw new Error("SseClientPubSubTransport requires apiRoot to be set or a full URL to be provided.");const s={...e};let r=t.startsWith("http")?t:`${this.apiRoot}/${t}`;if(s){const t=Ne(s,!0);t&&(r+=(r.includes("?")?"&":"?")+t)}const o=new EventSource(r),n=new Promise(t=>{const e=s=>{o.removeEventListener("welcome",e);const r=s.data,n=r?"string"==typeof r?JSON.parse(r):r:void 0;t(n)};o.addEventListener("welcome",e)}),i=(await n).clientId,a=new Map,c=(t,e)=>{const s=s=>{const r=s.data,o=r?"string"==typeof r?JSON.parse(r):r:void 0;e(o,{...s,event:t})};let r=a.get(t);r||(r=new Map,a.set(t,r)),r.set(e,s),o.addEventListener(t,s)},p=(t,e)=>{const s=a.get(t),r=s?.get(e);r&&(o.removeEventListener(t,r),s.delete(e))};return{clientId:i,protocol:"sse",get readyState(){return o.readyState},on:c,off:p,addEventListener:c,removeEventListener:p,close:()=>o.close()}}disconnect(t){return t.close()}};export{t as AIArgProcessor,e as AIChatRoles,s as AIMessageTypes,r as AIStream,o as AITextGenerationFinishReasons,n as AbortError,i as AbortErrorCode,a as ActionNames,c as AlreadyExistsError,p as AlreadyExistsErrorCode,h as ArrayMergeWay,l as ArrayMergeWaySymbol,u as AsyncFeatureBits,d as AsyncFeatures,f as BaseError,v as BinarySemaphore,y as CancelableAbility,m as ChoiceArgProcessor,w as ClientEventPrefix,S as ClientToolFuncSchema,Fr as ClientToolTransport,T as ClientTools,E as CommonError,N as ConfigFile,C as DEFAULT_CONFIG_NAME,O as DefaultAsyncSemaphoreCapacity,g as DefaultDateFormat,R as EnvPromptTemplate,J as ErrorCode,j as EventBusName,P as EventClient,$ as EventEmitter,b as EventName,q as EventServer,nr as EventStates,H as EventToolFunc,I as FStringPromptTemplate,x as FewShotPromptTemplate,F as FilenameReservedRegex,G as FuncMetaSymbol,L as GolangPromptTemplate,D as HashAlgorithm,kr as HttpClientToolTransport,_r as HttpServerToolTransport,M as IntSet,A as InternalErrorCode,_ as LLM_TOKENIZER_NAMES,k as LLM_TOKENIZER_NAMES_MAP,B as LRUCache,U as NotFoundError,K as NotFoundErrorCode,Y as NotImplementationError,Z as NotImplementedErrorCode,z as ObjectArgsToArgsInfo,Q as PASSING_SCORE,W as PromptExampleSelector,St as PromptTemplate,X as RStreamErrCode,tt as RateLimit,et as ReadableStreamError,st as RemoteToolFuncSchema,rt as ResClientTools,ot as ResServerTools,nt as ResponseRStreamErrCode,it as RpcMethodsClientTool,at as RpcMethodsClientToolSchema,ct as RpcMethodsServerTool,pt as RpcMethodsServerToolSchema,ht as SHUTDOWN_SIGNALS,lt as SSEChannel,ut as SSEChannelAlreadyClosedErrCode,dt as SecondaryCache,ft as Semaphore,vt as ServerToolFuncSchema,Lr as ServerToolTransport,yt as ServerTools,mt as SignalGate,Vr as SseClientPubSubTransport,Br as SseServerPubSubTransport,wt as StrangeHumanName,Tt as TaskAbortController,Et as TemplateArgProcessor,Nt as ToolAsyncCancelableBit,Ct as ToolAsyncMultiTaskBit,Ot as ToolAsyncPriorityBit,gt as ToolFunc,Rt as ToolFuncSchema,xr as ToolTransport,Jt as WindowsReservedNameRegex,jt as YamlTypeBaseObject,Pt as _lrucache,$t as addDate,bt as assignDirs,qt as backendEventable,Ht as base32768,It as beforeShutdown,xt as calcPerplexity,Ft as calcPerplexitySimple,Gt as canonicalize,Lt as completeSentences,Dt as concatText,Mt as countLLMTokens,At as countRegexMatches,_t as createAbilityInjector,kt as createCallbacksTransformer,Bt as createEmptyReadableStream,Vt as createEndWithRepetitionDetector,Ut as createError,Kt as createEventStreamTransformer,Yt as createHfValueFunc,Zt as createLRUCache,zt as createYamlObjectTag,Qt as dateToText,Wt as decodeCharset,Xt as defaultTemplateFormat,te as defaultsWithConcat,ee as detectCharset,se as encodeLLMTokens,re as ensureQuoted,oe as event,ne as eventClient,ie as eventServer,ae as eventable,ce as expandConfig,pe as expandEnv,he as expandObjEnv,le as expandPath,ue as expandPathInObject,de as expandPaths,fe as extNameLevel,ve as fileIsExists,ye as filterValidFnScope,me as findIndexNonEmptyFrom,Ir as findPort,we as formatISO,Se as formatTextWithSpace,Te as funcGetMeta,Ee as funcWithMeta,Ne as genUrlParamsStr,Ce as getAllEnumKeys,Oe as getConfigFileNames,ge as getConfigs,Re as getEnvVairables,Je as getFileMetaInfo,je as getHashAlgoBySize,Pe as getKeysPath,$e as getLLMTokenizer,be as getMultiLevelExtname,qe as getPackageDir,He as getRealFilepath,Ie as getResponseErrorReadableStream,xe as getXDGConfigs,Fe as hasDirectoryIn,Ge as hash,Le as hashFile,De as hashObject,Me as hashStream,Ae as initShutdown,_e as isLangUsingSpaces,ke as isListItemString,Be as isModelNameMatched,Ve as isPunctuationChar,Ue as isQuoted,Ke as isRegExp,Ye as isSameString,Ze as isSectionString,ze as isSentenceEnding,Qe as isSepLineString,We as isStrWrapped,Xe as isSubdirectory,ts as isTitleString,es as isValidFilename,ss as isValidFilepath,rs as isWebStream,os as joinSplitWords,ns as jsonFilterToWhere,is as jsonToMarkdownStr,as as loadAIConfig,cs as loadConfig,ps as loadConfigFile,hs as loadFileFromPaths,ls as loadTextFromPaths,us as lrucache,ds as makeToolFuncCancelable,fs as matchUrlProtocol,vs as memoize,ys as mergeArray,ms as messagesToText,ws as mimeType,Ss as nanoid,Ts as normalizePath,Es as paramsSizeToScaleStr,Cs as parseCommand,Os as parseDateFormat,gs as parseISO,Rs as parseJsJson,Js as parseJsJsonSimpleSync,js as parseObjectArgInfo,Ps as parseObjectArgumentInfos,$s as parseObjectArguments,bs as parseObjectArgumentsAsArgInfos,qs as parseYaml,Hs as pruneSubdirectories,Is as pruneSubdirectoriesInPlace,xs as quoteStr,Fs as readFilenamesRecursiveSync,Gs as readTextFileChunks,Ls as readTextFileChunksEx,Ds as readableFromAsyncIterable,Ms as registerCoreTools,As as registerYamlTag,_s as removeMarkdownBold,ks as removeMarkdownBoldAndItalic,Bs as removeMarkdownItalic,Vs as replaceWithPlaceholder,Us as restoreFromPlacehoders,Ks as sanitizeFilename,Ys as sanitizeFilepath,Zs as saveConfigFile,zs as scaleStrToParamsSize,Qs as shutdown,Ws as simplifyObjectArguments,Xs as sleep,tr as sortedValues,er as splitChunks,sr as splitParagraph,rr as splitSentence,or as splitWords,ar as stringifyYaml,cr as stripConsoleColor,pr as textToDate,hr as throwError,lr as toDate,ur as toDateTime,dr as toRegExp,fr as trimStartOfStreamHelper,vr as truncTo,yr as truncateByToken,mr as truncateToTokenLimit,wr as truncateToTokenLimitEx,Sr as uuid,V as uuidNIL,Ns as uuidParse,ir as uuidStringify,gr as uuidValidate,Rr as uuidVersion,Tr as uuidv1,Er as uuidv4,Nr as uuidv5,Cr as uuidv6,Or as uuidv7,Jr as wait,jr as wrapEventEmitter,Pr as xxhash,$r as xxhash32,br as xxhash64,qr as xxhashAsStr,Hr as yieldExec};
package/dist/test/util.js CHANGED
@@ -1 +1 @@
1
- "use strict";var e,r=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,u=Object.getOwnPropertyNames,o=Object.getPrototypeOf,c=Object.prototype.hasOwnProperty,i=(e,r,o,i)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let f of u(r))c.call(e,f)||f===o||t(e,f,{get:()=>r[f],enumerable:!(i=n(r,f))||i.enumerable});return e},f={};function a(e,r){expect(e.length).toBeGreaterThanOrEqual(r.length);for(let t=0;t<r.length;t++)if(e[t]!==r[t])return!1;return!0}((e,r)=>{for(var n in r)t(e,n,{get:r[n],enumerable:!0})})(f,{compareStr:()=>a,findPort:()=>s,rmFile:()=>m}),module.exports=(e=f,i(t({},"__esModule",{value:!0}),e));var l=((e,n,u)=>(u=null!=e?r(o(e)):{},i(!n&&e&&e.__esModule?u:t(u,"default",{value:e,enumerable:!0}),e)))(require("net"));async function s(e,r=10){return new Promise((t,n)=>{void 0===e?e=0:("string"==typeof e&&(e=parseInt(e)),e>=0||(e=0));const u=l.default.createServer();u.on("error",t=>{"EADDRINUSE"===t.code&&(e++,--r>0)?u.listen(e):n(t)}),u.on("listening",async()=>{const e=u.address().port;u.close(),t(e)}),u.listen(e)})}var b=require("fs");function m(e){(0,b.existsSync)(e)&&(0,b.rmSync)(e,{recursive:!0}),(0,b.existsSync)(e+".temp")&&(0,b.rmSync)(e+".temp",{recursive:!0})}
1
+ "use strict";var e,r=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,u=Object.getOwnPropertyNames,o=Object.getPrototypeOf,c=Object.prototype.hasOwnProperty,i=(e,r,o,i)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let f of u(r))c.call(e,f)||f===o||t(e,f,{get:()=>r[f],enumerable:!(i=n(r,f))||i.enumerable});return e},f={};function a(e,r){expect(e.length).toBeGreaterThanOrEqual(r.length);for(let t=0;t<r.length;t++)if(e[t]!==r[t])return!1;return!0}((e,r)=>{for(var n in r)t(e,n,{get:r[n],enumerable:!0})})(f,{compareStr:()=>a,findPort:()=>s,rmFile:()=>m}),module.exports=(e=f,i(t({},"__esModule",{value:!0}),e));var l=((e,n,u)=>(u=null!=e?r(o(e)):{},i(!n&&e&&e.__esModule?u:t(u,"default",{value:e,enumerable:!0}),e)))(require("net"));async function s(e,r=10){return new Promise((t,n)=>{void 0===e?e=0:("string"==typeof e&&(e=parseInt(e)),e>=0||(e=0));const u=l.default.createServer();u.on("error",t=>{"EADDRINUSE"===t.code&&(e++,--r>0)?u.listen(e):n(t)}),u.on("listening",async()=>{const e=u.address().port;u.close(r=>{r?n(r):t(e)})}),u.listen(e)})}var b=require("fs");function m(e){(0,b.existsSync)(e)&&(0,b.rmSync)(e,{recursive:!0}),(0,b.existsSync)(e+".temp")&&(0,b.rmSync)(e+".temp",{recursive:!0})}
@@ -1 +1 @@
1
- import{findPort as r}from"../chunk-VIG2GB47.mjs";function e(r,e){expect(r.length).toBeGreaterThanOrEqual(e.length);for(let t=0;t<e.length;t++)if(r[t]!==e[t])return!1;return!0}import{existsSync as t,rmSync as o}from"fs";function f(r){t(r)&&o(r,{recursive:!0}),t(r+".temp")&&o(r+".temp",{recursive:!0})}export{e as compareStr,r as findPort,f as rmFile};
1
+ import{findPort as r}from"../chunk-TGTHY57V.mjs";function e(r,e){expect(r.length).toBeGreaterThanOrEqual(e.length);for(let t=0;t<e.length;t++)if(r[t]!==e[t])return!1;return!0}import{existsSync as t,rmSync as o}from"fs";function f(r){t(r)&&o(r,{recursive:!0}),t(r+".temp")&&o(r+".temp",{recursive:!0})}export{e as compareStr,r as findPort,f as rmFile};
@@ -1,8 +1,8 @@
1
- [**@isdk/ai-tool**](../../README.md)
1
+ [**@isdk/ai-tool**](../../../README.md)
2
2
 
3
3
  ***
4
4
 
5
- [@isdk/ai-tool](../../globals.md) / EventStates
5
+ [@isdk/ai-tool](../../../globals.md) / EventStates
6
6
 
7
7
  # EventStates
8
8
 
@@ -1,8 +1,8 @@
1
- [**@isdk/ai-tool**](../../../README.md)
1
+ [**@isdk/ai-tool**](../../../../README.md)
2
2
 
3
3
  ***
4
4
 
5
- [@isdk/ai-tool](../../../globals.md) / [EventStates](../README.md) / ABORT
5
+ [@isdk/ai-tool](../../../../globals.md) / [EventStates](../README.md) / ABORT
6
6
 
7
7
  # Variable: ABORT
8
8
 
@@ -1,8 +1,8 @@
1
- [**@isdk/ai-tool**](../../../README.md)
1
+ [**@isdk/ai-tool**](../../../../README.md)
2
2
 
3
3
  ***
4
4
 
5
- [@isdk/ai-tool](../../../globals.md) / [EventStates](../README.md) / CONTINUE
5
+ [@isdk/ai-tool](../../../../globals.md) / [EventStates](../README.md) / CONTINUE
6
6
 
7
7
  # Variable: CONTINUE
8
8