@transcend-io/cli 8.0.2 → 8.0.4

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 (200) hide show
  1. package/dist/bin/bash-complete.cjs +1 -1
  2. package/dist/bin/bash-complete.cjs.map +1 -1
  3. package/dist/bin/cli.cjs +1 -1
  4. package/dist/bin/cli.cjs.map +1 -1
  5. package/dist/bin/deprecated-command.cjs +2 -2
  6. package/dist/bin/deprecated-command.cjs.map +1 -1
  7. package/dist/{chunk-YKZKPWDF.cjs → chunk-2P2C7ZL3.cjs} +2 -2
  8. package/dist/{chunk-YKZKPWDF.cjs.map → chunk-2P2C7ZL3.cjs.map} +1 -1
  9. package/dist/{chunk-XARKMCNP.cjs → chunk-4ZN6PNJE.cjs} +4 -4
  10. package/dist/{chunk-XARKMCNP.cjs.map → chunk-4ZN6PNJE.cjs.map} +1 -1
  11. package/dist/{chunk-3PX3HVEO.cjs → chunk-6VG44TPZ.cjs} +2 -2
  12. package/dist/{chunk-3PX3HVEO.cjs.map → chunk-6VG44TPZ.cjs.map} +1 -1
  13. package/dist/{chunk-BPX6MSMC.cjs → chunk-6Z44RBJE.cjs} +2 -2
  14. package/dist/{chunk-BPX6MSMC.cjs.map → chunk-6Z44RBJE.cjs.map} +1 -1
  15. package/dist/chunk-GVWWTQ2S.cjs +3 -0
  16. package/dist/chunk-GVWWTQ2S.cjs.map +1 -0
  17. package/dist/chunk-HJBQCKCR.cjs +12 -0
  18. package/dist/chunk-HJBQCKCR.cjs.map +1 -0
  19. package/dist/chunk-LQHB5EIW.cjs +2 -0
  20. package/dist/chunk-LQHB5EIW.cjs.map +1 -0
  21. package/dist/{chunk-FNBADTTI.cjs → chunk-OBNZ7JBG.cjs} +19 -19
  22. package/dist/chunk-OBNZ7JBG.cjs.map +1 -0
  23. package/dist/chunk-QG4ECDFE.cjs +15 -0
  24. package/dist/chunk-QG4ECDFE.cjs.map +1 -0
  25. package/dist/{chunk-YP2PMUM5.cjs → chunk-XJAEXXYU.cjs} +2 -2
  26. package/dist/{chunk-YP2PMUM5.cjs.map → chunk-XJAEXXYU.cjs.map} +1 -1
  27. package/dist/{chunk-W3S3ULXN.cjs → chunk-YREFLYHM.cjs} +2 -2
  28. package/dist/{chunk-W3S3ULXN.cjs.map → chunk-YREFLYHM.cjs.map} +1 -1
  29. package/dist/chunk-ZBKJMC7C.cjs +2920 -0
  30. package/dist/chunk-ZBKJMC7C.cjs.map +1 -0
  31. package/dist/impl-35XLHL4O.cjs +2 -0
  32. package/dist/impl-35XLHL4O.cjs.map +1 -0
  33. package/dist/impl-3IUL3P3V.cjs +2 -0
  34. package/dist/impl-3IUL3P3V.cjs.map +1 -0
  35. package/dist/impl-3WG6YKYX.cjs +2 -0
  36. package/dist/impl-3WG6YKYX.cjs.map +1 -0
  37. package/dist/{impl-WWQBCKZV.cjs → impl-426AX523.cjs} +2 -2
  38. package/dist/impl-426AX523.cjs.map +1 -0
  39. package/dist/{impl-7MIPQI3E.cjs → impl-5B6CLRP6.cjs} +2 -2
  40. package/dist/impl-5B6CLRP6.cjs.map +1 -0
  41. package/dist/impl-5IBWZCND.cjs +2 -0
  42. package/dist/impl-5IBWZCND.cjs.map +1 -0
  43. package/dist/impl-6GEUCO6I.cjs +2 -0
  44. package/dist/impl-6GEUCO6I.cjs.map +1 -0
  45. package/dist/impl-6HXNGVRH.cjs +2 -0
  46. package/dist/impl-6HXNGVRH.cjs.map +1 -0
  47. package/dist/impl-77KAZ4XH.cjs +6 -0
  48. package/dist/impl-77KAZ4XH.cjs.map +1 -0
  49. package/dist/impl-AIUN3M37.cjs +2 -0
  50. package/dist/impl-AIUN3M37.cjs.map +1 -0
  51. package/dist/impl-B5MBY4PI.cjs +2 -0
  52. package/dist/impl-B5MBY4PI.cjs.map +1 -0
  53. package/dist/impl-BYVUQ5PD.cjs +2 -0
  54. package/dist/impl-BYVUQ5PD.cjs.map +1 -0
  55. package/dist/impl-CQPYZDEP.cjs +2 -0
  56. package/dist/impl-CQPYZDEP.cjs.map +1 -0
  57. package/dist/impl-E6NFYH4V.cjs +2 -0
  58. package/dist/impl-E6NFYH4V.cjs.map +1 -0
  59. package/dist/impl-E7RIXWG5.cjs +2 -0
  60. package/dist/impl-E7RIXWG5.cjs.map +1 -0
  61. package/dist/{impl-OXCKKL3L.cjs → impl-EHBBW7RO.cjs} +2 -2
  62. package/dist/impl-EHBBW7RO.cjs.map +1 -0
  63. package/dist/impl-EPE2BP2D.cjs +2 -0
  64. package/dist/impl-EPE2BP2D.cjs.map +1 -0
  65. package/dist/impl-G7JOSWM6.cjs +12 -0
  66. package/dist/impl-G7JOSWM6.cjs.map +1 -0
  67. package/dist/impl-HOCQ2FU3.cjs +3 -0
  68. package/dist/impl-HOCQ2FU3.cjs.map +1 -0
  69. package/dist/impl-I7QN6JHE.cjs +2 -0
  70. package/dist/impl-I7QN6JHE.cjs.map +1 -0
  71. package/dist/impl-IHFTH6YX.cjs +2 -0
  72. package/dist/impl-IHFTH6YX.cjs.map +1 -0
  73. package/dist/impl-JZLYOI5F.cjs +2 -0
  74. package/dist/impl-JZLYOI5F.cjs.map +1 -0
  75. package/dist/impl-M6FW6NDT.cjs +2 -0
  76. package/dist/impl-M6FW6NDT.cjs.map +1 -0
  77. package/dist/impl-O5FXKTSS.cjs +2 -0
  78. package/dist/impl-O5FXKTSS.cjs.map +1 -0
  79. package/dist/{impl-TC6DE6BU.cjs → impl-OKNOTBT6.cjs} +5 -5
  80. package/dist/impl-OKNOTBT6.cjs.map +1 -0
  81. package/dist/impl-PB3CEDXP.cjs +2 -0
  82. package/dist/impl-PB3CEDXP.cjs.map +1 -0
  83. package/dist/impl-QHLD4E4E.cjs +2 -0
  84. package/dist/impl-QHLD4E4E.cjs.map +1 -0
  85. package/dist/impl-RO3RT7ZE.cjs +2 -0
  86. package/dist/impl-RO3RT7ZE.cjs.map +1 -0
  87. package/dist/impl-SDF36RUQ.cjs +2 -0
  88. package/dist/impl-SDF36RUQ.cjs.map +1 -0
  89. package/dist/{impl-DFDEITPV.cjs → impl-T4JNIPRU.cjs} +4 -4
  90. package/dist/impl-T4JNIPRU.cjs.map +1 -0
  91. package/dist/impl-UIQVAQFF.cjs +2 -0
  92. package/dist/impl-UIQVAQFF.cjs.map +1 -0
  93. package/dist/impl-V4AAI72P.cjs +2 -0
  94. package/dist/impl-V4AAI72P.cjs.map +1 -0
  95. package/dist/impl-VMZLIXUM.cjs +4 -0
  96. package/dist/impl-VMZLIXUM.cjs.map +1 -0
  97. package/dist/impl-VO6SR3UF.cjs +2 -0
  98. package/dist/impl-VO6SR3UF.cjs.map +1 -0
  99. package/dist/impl-WVOC3NBM.cjs +2 -0
  100. package/dist/impl-WVOC3NBM.cjs.map +1 -0
  101. package/dist/impl-YJ7MLTPD.cjs +2 -0
  102. package/dist/impl-YJ7MLTPD.cjs.map +1 -0
  103. package/dist/impl-YVUKRVNV.cjs +2 -0
  104. package/dist/impl-YVUKRVNV.cjs.map +1 -0
  105. package/dist/impl-ZGRHLCA3.cjs +6 -0
  106. package/dist/impl-ZGRHLCA3.cjs.map +1 -0
  107. package/dist/index.cjs +3 -3
  108. package/dist/index.cjs.map +1 -1
  109. package/dist/index.d.cts +92 -12
  110. package/package.json +1 -1
  111. package/dist/chunk-44J2TVZU.cjs +0 -15
  112. package/dist/chunk-44J2TVZU.cjs.map +0 -1
  113. package/dist/chunk-7UL54E7X.cjs +0 -2
  114. package/dist/chunk-7UL54E7X.cjs.map +0 -1
  115. package/dist/chunk-A4OQQVQT.cjs +0 -3
  116. package/dist/chunk-A4OQQVQT.cjs.map +0 -1
  117. package/dist/chunk-FNBADTTI.cjs.map +0 -1
  118. package/dist/chunk-N7QF44VW.cjs +0 -2
  119. package/dist/chunk-N7QF44VW.cjs.map +0 -1
  120. package/dist/chunk-PQTI6C4Q.cjs +0 -12
  121. package/dist/chunk-PQTI6C4Q.cjs.map +0 -1
  122. package/dist/chunk-TD7ADMVO.cjs +0 -2
  123. package/dist/chunk-TD7ADMVO.cjs.map +0 -1
  124. package/dist/chunk-UONUI4AB.cjs +0 -2920
  125. package/dist/chunk-UONUI4AB.cjs.map +0 -1
  126. package/dist/chunk-XPKFB4IL.cjs +0 -2
  127. package/dist/chunk-XPKFB4IL.cjs.map +0 -1
  128. package/dist/chunk-YMXQXAUZ.cjs +0 -2
  129. package/dist/chunk-YMXQXAUZ.cjs.map +0 -1
  130. package/dist/impl-2BXBJZII.cjs +0 -2
  131. package/dist/impl-2BXBJZII.cjs.map +0 -1
  132. package/dist/impl-2SHN3CZX.cjs +0 -2
  133. package/dist/impl-2SHN3CZX.cjs.map +0 -1
  134. package/dist/impl-334G4VTL.cjs +0 -2
  135. package/dist/impl-334G4VTL.cjs.map +0 -1
  136. package/dist/impl-37NGCBEQ.cjs +0 -2
  137. package/dist/impl-37NGCBEQ.cjs.map +0 -1
  138. package/dist/impl-5IS3UVQQ.cjs +0 -2
  139. package/dist/impl-5IS3UVQQ.cjs.map +0 -1
  140. package/dist/impl-5IZQDLG7.cjs +0 -2
  141. package/dist/impl-5IZQDLG7.cjs.map +0 -1
  142. package/dist/impl-7MIPQI3E.cjs.map +0 -1
  143. package/dist/impl-AJMAFFJG.cjs +0 -2
  144. package/dist/impl-AJMAFFJG.cjs.map +0 -1
  145. package/dist/impl-BL64FHKY.cjs +0 -2
  146. package/dist/impl-BL64FHKY.cjs.map +0 -1
  147. package/dist/impl-BXNGIHN2.cjs +0 -4
  148. package/dist/impl-BXNGIHN2.cjs.map +0 -1
  149. package/dist/impl-DDHHIRXW.cjs +0 -12
  150. package/dist/impl-DDHHIRXW.cjs.map +0 -1
  151. package/dist/impl-DFDEITPV.cjs.map +0 -1
  152. package/dist/impl-DZSW2V2J.cjs +0 -2
  153. package/dist/impl-DZSW2V2J.cjs.map +0 -1
  154. package/dist/impl-FC7ICRDM.cjs +0 -2
  155. package/dist/impl-FC7ICRDM.cjs.map +0 -1
  156. package/dist/impl-G2MAA4QD.cjs +0 -2
  157. package/dist/impl-G2MAA4QD.cjs.map +0 -1
  158. package/dist/impl-GIZXIRD5.cjs +0 -2
  159. package/dist/impl-GIZXIRD5.cjs.map +0 -1
  160. package/dist/impl-H3RZXUMP.cjs +0 -2
  161. package/dist/impl-H3RZXUMP.cjs.map +0 -1
  162. package/dist/impl-HG3PK5DG.cjs +0 -2
  163. package/dist/impl-HG3PK5DG.cjs.map +0 -1
  164. package/dist/impl-IAZCCRHG.cjs +0 -2
  165. package/dist/impl-IAZCCRHG.cjs.map +0 -1
  166. package/dist/impl-K3VBUCUB.cjs +0 -2
  167. package/dist/impl-K3VBUCUB.cjs.map +0 -1
  168. package/dist/impl-KMLDAWB5.cjs +0 -6
  169. package/dist/impl-KMLDAWB5.cjs.map +0 -1
  170. package/dist/impl-LDJGDZNJ.cjs +0 -2
  171. package/dist/impl-LDJGDZNJ.cjs.map +0 -1
  172. package/dist/impl-LLCE3XUF.cjs +0 -6
  173. package/dist/impl-LLCE3XUF.cjs.map +0 -1
  174. package/dist/impl-MVGWE3OY.cjs +0 -2
  175. package/dist/impl-MVGWE3OY.cjs.map +0 -1
  176. package/dist/impl-N56GZUUE.cjs +0 -2
  177. package/dist/impl-N56GZUUE.cjs.map +0 -1
  178. package/dist/impl-NRVKZ6QP.cjs +0 -2
  179. package/dist/impl-NRVKZ6QP.cjs.map +0 -1
  180. package/dist/impl-O7M62JQO.cjs +0 -2
  181. package/dist/impl-O7M62JQO.cjs.map +0 -1
  182. package/dist/impl-OXCKKL3L.cjs.map +0 -1
  183. package/dist/impl-OYQLTGBY.cjs +0 -2
  184. package/dist/impl-OYQLTGBY.cjs.map +0 -1
  185. package/dist/impl-PNDNQD25.cjs +0 -2
  186. package/dist/impl-PNDNQD25.cjs.map +0 -1
  187. package/dist/impl-Q2JAFPV5.cjs +0 -2
  188. package/dist/impl-Q2JAFPV5.cjs.map +0 -1
  189. package/dist/impl-Q6LOHZB6.cjs +0 -2
  190. package/dist/impl-Q6LOHZB6.cjs.map +0 -1
  191. package/dist/impl-QS77O4PW.cjs +0 -2
  192. package/dist/impl-QS77O4PW.cjs.map +0 -1
  193. package/dist/impl-TC6DE6BU.cjs.map +0 -1
  194. package/dist/impl-W6WGF5YD.cjs +0 -3
  195. package/dist/impl-W6WGF5YD.cjs.map +0 -1
  196. package/dist/impl-WHZWURMO.cjs +0 -2
  197. package/dist/impl-WHZWURMO.cjs.map +0 -1
  198. package/dist/impl-WWQBCKZV.cjs.map +0 -1
  199. package/dist/impl-XWRII7ET.cjs +0 -2
  200. package/dist/impl-XWRII7ET.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/cli/cli/dist/index.cjs","../src/lib/ai/TranscendPromptManager.ts","../src/lib/graphql/fetchLargeLanguageModels.ts","../src/lib/ai/getGitFilesThatChanged.ts"],"names":["PAGE_SIZE","fetchAllLargeLanguageModels","client","largeLanguageModels","offset","shouldContinue","nodes","makeGraphQLRequest","LARGE_LANGUAGE_MODELS","a","b","createRegexForTag","tagName","defineTranscendPrompts","prompts","jsonParseSafe","obj","TranscendPromptManager","handlebarsOptions","transcendUrl","DEFAULT_TRANSCEND_API","transcendApiKey","requireApproval","cacheDuration","defaultVariables","buildTranscendGraphQLClient","createHandlebarsWithHelpers","promptDefinitions","getValues","promptIds","id","x","promptTitles","title","agentNames","uniq_default","response","agents","fetchPromptsWithVariables","fetchAllAgents","keyBy_default","model","promptByTitle","promptById","acc","v","partial","apply","result","name","agent","remoteAgent","ts","thread","fetchAllPromptThreads","names","hasCache","missingCache","groupBy_default","cachedAgents","chunkedNames","chunk_default","remoteAgents","mapSeries","chunkedName","pageOfAgents","filterBy","fetchAllAgentFiles","largeLanguageModel","matching"],"mappings":"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","file":"/home/runner/work/cli/cli/dist/index.cjs","sourcesContent":[null,"/* eslint-disable max-lines */\nimport {\n Optionalize,\n Requirize,\n apply,\n decodeCodec,\n getValues,\n} from '@transcend-io/type-utils';\nimport type { Handlebars } from '@transcend-io/handlebars-utils';\nimport { Secret } from '@transcend-io/secret-value';\nimport * as t from 'io-ts';\nimport { DEFAULT_TRANSCEND_API } from '../../constants';\nimport {\n Agent,\n AgentFile,\n AgentFileFilterBy,\n ReportPromptRunInput,\n buildTranscendGraphQLClient,\n fetchAllAgentFiles,\n fetchAllAgents,\n reportPromptRun,\n} from '../graphql';\nimport {\n HandlebarsInput,\n createHandlebarsWithHelpers,\n} from '@transcend-io/handlebars-utils';\nimport {\n TranscendPromptTemplated,\n TranscendPromptsAndVariables,\n fetchPromptsWithVariables,\n} from '../graphql/fetchPrompts';\nimport { GraphQLClient } from 'graphql-request';\nimport {\n PromptStatus,\n ChatCompletionRole,\n PromptRunProductArea,\n QueueStatus,\n LargeLanguageModelClient,\n} from '@transcend-io/privacy-types';\nimport {\n LargeLanguageModel,\n fetchAllLargeLanguageModels,\n} from '../graphql/fetchLargeLanguageModels';\nimport { groupBy, keyBy, uniq, chunk } from 'lodash-es';\nimport { mapSeries } from 'bluebird';\nimport {\n PromptThread,\n fetchAllPromptThreads,\n} from '../graphql/fetchPromptThreads';\n\n/**\n * An LLM Prompt definition\n */\nexport type TranscendPrompt<\n TInputParams extends t.Any,\n TOutputCodec extends t.Any,\n> = (\n | {\n /** ID of the prompt */\n id: string;\n /** Title of the prompt */\n title?: string;\n }\n | {\n /** ID of the prompt */\n id?: string;\n /** Title of the prompt */\n title: string;\n }\n) & {\n /** The names of the agents that should be loaded along with the prompt */\n agentNames?: string[];\n /** Codec to validate runtime input shape */\n paramCodec: TInputParams;\n /** Codec to validate output response */\n outputCodec: TOutputCodec;\n /**\n * If the output that needs to be parsed is returned within a tag\n * e.g. <tag> or <json> - this is the name of the tag\n */\n extractFromTag?: string;\n};\n\nexport interface PromptRunResult {\n /** The ID of the prompt run created on Transcend */\n promptRunId: string;\n /** The URL of the prompt run on Transcend */\n promptRunUrl: string;\n}\n\n/**\n * Create a regex to extract data from a tag\n *\n * Input:\n * \"here is some data <tag>Data</tag>...\"\n *\n * @param tagName - Name of tag\n * @returns Data within the tag\n */\nexport function createRegexForTag(tagName: string): RegExp {\n return new RegExp(`<${tagName}>([\\\\s\\\\S]+?)<\\\\/${tagName}>`);\n}\n\n/**\n * Helper function to declare prompts\n *\n * @param prompts - Prompt config\n * @returns Prompts as identity function - but type enforced\n */\nexport function defineTranscendPrompts<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n>(prompts: TPrompts): TPrompts {\n return prompts;\n}\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptParamType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['paramCodec']>;\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptResponseType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n\n/**\n * Input for reporting a prompt run\n */\nexport interface ReportPromptRunOptions\n extends Optionalize<\n Omit<ReportPromptRunInput, 'status' | 'promptId' | 'largeLanguageModelId'>,\n 'name' | 'productArea'\n > {\n /** The large language model being run. Either the ID of the LLM or the client/name pairing */\n largeLanguageModel:\n | string\n | {\n /** Name of client */\n client: LargeLanguageModelClient;\n /** Name of the model */\n name: string;\n };\n}\n\nconst jsonParseSafe = (obj: string): unknown => {\n try {\n return JSON.parse(obj);\n } catch (e) {\n return obj;\n }\n};\n\n/**\n * A class that is capable of loading and insert variables into prompts from\n * Transcend's Prompt Manager\n */\nexport class TranscendPromptManager<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n> {\n /** Prompt definitions */\n public prompts: TPrompts;\n\n /** Options for configuring handlebars */\n public handlebarsOptions!: HandlebarsInput;\n\n /** Prompt name -> content map, populated by call to Transcend API */\n public promptContentMap?: { [k in TPromptNames]: TranscendPromptTemplated };\n\n /** The large language models that are registered to this organization for reporting */\n public largeLanguageModels: LargeLanguageModel[] = [];\n\n /** The agent definitions registered to this organization */\n private agentsByName: { [name in string]: Agent } = {};\n\n /** The agent definitions registered to this organization */\n private agentsByAgentId: { [id in string]: Agent } = {};\n\n /** The GraphQL client that can be used to call Transcend */\n public graphQLClient: GraphQLClient;\n\n /** The set of variables to expose in handlebars context specified at class initiation */\n public defaultVariables: { [k in string]: unknown };\n\n /**\n * The set of variables to expose in handlebars context,\n * merges defaults with calculated variables from the inventory\n */\n public variables: { [k in string]: unknown };\n\n /** Handlebars compiler */\n public handlebars: typeof Handlebars;\n\n /** The Transcend API key */\n public transcendApiKey: string | Secret<string>;\n\n /** API of Transcend to call */\n public transcendUrl: string;\n\n /** When true, throw an error if the prompt is not approved */\n public requireApproval: boolean;\n\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n public cacheDuration?: number;\n\n /**\n * The last time the metadata was fetched\n */\n public lastUpdatedAt?: Date;\n\n /**\n * Constructor\n *\n * @param options - Options\n */\n constructor({\n prompts,\n handlebarsOptions = {},\n transcendUrl = DEFAULT_TRANSCEND_API,\n transcendApiKey,\n requireApproval = true,\n cacheDuration,\n defaultVariables = {},\n }: {\n /** Prompt definitions to load */\n prompts: TPrompts;\n /** Options for configuring handlebars */\n handlebarsOptions?: HandlebarsInput;\n /** The Transcend API key */\n transcendApiKey: string | Secret<string>;\n /** API of Transcend to call */\n transcendUrl?: string;\n /** When true, throw an error if the prompt is not approved */\n requireApproval?: boolean;\n /** The set of variables to expose in handlebars context specified at class initiation */\n defaultVariables?: { [k in string]: unknown };\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n cacheDuration?: number;\n }) {\n this.prompts = prompts;\n this.transcendUrl = transcendUrl;\n this.transcendApiKey = transcendApiKey;\n this.variables = defaultVariables;\n this.defaultVariables = defaultVariables;\n this.graphQLClient = buildTranscendGraphQLClient(\n transcendUrl,\n typeof transcendApiKey === 'object'\n ? transcendApiKey.release()\n : transcendApiKey,\n );\n this.requireApproval = requireApproval;\n this.cacheDuration = cacheDuration;\n this.handlebarsOptions = handlebarsOptions;\n this.handlebars = createHandlebarsWithHelpers(handlebarsOptions);\n }\n\n /**\n * Fetch prompt metadata from Transcend and cache to the class definition\n *\n * @returns A function that can be used to call the prompt\n */\n async fetchPromptsAndMetadata(): Promise<TranscendPromptsAndVariables> {\n // Determine what to fetch\n const promptDefinitions = getValues(this.prompts) as TranscendPrompt<\n t.Any,\n t.Any\n >[];\n const promptIds = promptDefinitions\n .map(({ id }) => id)\n .filter((x): x is string => !!x);\n const promptTitles = promptDefinitions\n .map(({ title }) => title)\n .filter((x): x is string => !!x);\n const agentNames = uniq(\n promptDefinitions.map(({ agentNames }) => agentNames || []).flat(),\n );\n\n // Fetch prompts and data\n const [response, largeLanguageModels, agents] = await Promise.all([\n fetchPromptsWithVariables(this.graphQLClient, {\n promptIds,\n promptTitles,\n }),\n fetchAllLargeLanguageModels(this.graphQLClient),\n fetchAllAgents(this.graphQLClient, { names: agentNames }),\n ]);\n this.agentsByName = keyBy(agents, 'name');\n this.agentsByAgentId = keyBy(agents, 'agentId');\n this.largeLanguageModels = largeLanguageModels.filter(\n (model) => model.isTranscendHosted === false,\n );\n\n // Lookup prompts by id/title\n const promptByTitle = keyBy(response.prompts, 'title');\n const promptById = keyBy(response.prompts, 'id');\n\n // Update variables\n this.variables = {\n ...response.calculatedVariables.reduce(\n (acc, v) =>\n Object.assign(acc, {\n [v.name]: v.data ? JSON.parse(v.data) : v.data,\n }),\n {},\n ),\n ...this.defaultVariables,\n };\n\n // Update partials\n this.handlebars = createHandlebarsWithHelpers({\n ...this.handlebarsOptions,\n templates: [\n ...(this.handlebarsOptions.templates || []),\n ...response.promptPartials.map((partial) => ({\n name: partial.slug,\n content: partial.content,\n })),\n ],\n });\n\n // Create mapping from prompt to content\n this.promptContentMap = apply(this.prompts, ({ id, title }) => {\n const result = id\n ? promptById[id]\n : title\n ? promptByTitle[title]\n : undefined;\n if (!result) {\n throw new Error(\n `Failed to find prompt with title: \"${title}\" and id: \"${id}\"`,\n );\n }\n return result;\n });\n\n // For cache\n this.lastUpdatedAt = new Date();\n\n return response;\n }\n\n /**\n * Get an agent definition by name\n *\n * @param name - Name of the agent to grab\n * @returns Large language model configuration\n */\n async getAgentByName(name: string): Promise<Agent | undefined> {\n const agent = this.agentsByName[name];\n if (agent) {\n return agent;\n }\n const [remoteAgent] = await fetchAllAgents(this.graphQLClient, {\n names: [name],\n });\n if (!remoteAgent) {\n return undefined;\n }\n this.agentsByName[remoteAgent.name] = remoteAgent;\n this.agentsByAgentId[remoteAgent.agentId] = remoteAgent;\n return remoteAgent;\n }\n\n /**\n * Get a prompt thread by ts\n *\n * @param ts - the slack message timestamp to look up thread for\n * @returns Large language model configuration\n */\n async getPromptThreadBySlackTs(\n ts: string,\n ): Promise<PromptThread | undefined> {\n const [thread] = await fetchAllPromptThreads(this.graphQLClient, {\n slackMessageTs: [ts],\n });\n return thread;\n }\n\n /**\n * Get a list of agent definitions by name.\n * Pulls from cache and may return less agents\n * than requested if some are not found\n *\n * @param names - Names of agents to fetch\n * @returns The agents that were found matching the names\n */\n async getAgentsByName(names: string[]): Promise<Agent[]> {\n if (names.length < 1) {\n throw new Error('Expected at least one name to be provided');\n }\n const { hasCache = [], missingCache = [] } = groupBy(names, (name) =>\n this.agentsByName[name] ? 'hasCache' : 'missingCache',\n );\n const cachedAgents = hasCache.map((name) => this.agentsByName[name]);\n if (missingCache.length === 0) {\n return cachedAgents;\n }\n const chunkedNames = chunk(missingCache, 50);\n const remoteAgents: Agent[] = [];\n await mapSeries(chunkedNames, async (chunkedName) => {\n const pageOfAgents = await fetchAllAgents(this.graphQLClient, {\n names: chunkedName,\n });\n pageOfAgents.forEach((agent) => {\n this.agentsByName[agent.name] = agent;\n this.agentsByAgentId[agent.agentId] = agent;\n });\n remoteAgents.push(...pageOfAgents);\n });\n return [...cachedAgents, ...remoteAgents];\n }\n\n /**\n * Fetch metadata on agent files\n *\n * @param filterBy - Filter by parameters\n * @returns The files found matching the filter\n */\n getAgentFiles(filterBy: AgentFileFilterBy): Promise<AgentFile[]> {\n return fetchAllAgentFiles(this.graphQLClient, filterBy);\n }\n\n /**\n * Look up the large language model to report on\n *\n * @param largeLanguageModel - Input\n * @returns Large language model configuration\n */\n getLargeLanguageModel(\n largeLanguageModel: ReportPromptRunOptions['largeLanguageModel'],\n ): LargeLanguageModel {\n const matching = this.largeLanguageModels.find((model) =>\n typeof largeLanguageModel === 'string'\n ? model.id === largeLanguageModel\n : model.name === largeLanguageModel.name &&\n model.client === largeLanguageModel.client,\n );\n if (!matching) {\n throw new Error(\n `Failed to find model matching: ${\n typeof largeLanguageModel === 'string'\n ? largeLanguageModel\n : JSON.stringify(largeLanguageModel)\n }`,\n );\n }\n return matching;\n }\n\n /**\n * Get a prompt definition by name\n *\n * @param promptName - Prompt to compile\n * @returns Parsed content\n */\n async getPromptDefinition<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n ): Promise<TranscendPromptTemplated> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n // Lookup prompt\n const { promptContentMap } = this;\n if (!promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n const promptTemplate = promptContentMap[promptName];\n if (!promptTemplate) {\n throw new Error(\n `Expected this.promptContentMap[${promptName}] to be defined`,\n );\n }\n return promptTemplate;\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to compile\n * @param params - Runtime parameters\n * @returns Parsed content\n */\n async compilePrompt<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n params: t.TypeOf<TPrompts[TPromptName]['paramCodec']>,\n ): Promise<string> {\n // Grab the prompt\n const promptTemplate = await this.getPromptDefinition(promptName);\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure prompt is approved\n if (\n this.requireApproval &&\n promptTemplate.status !== PromptStatus.Approved\n ) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because its in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // If prompt is rejected, throw error\n if (promptTemplate.status === PromptStatus.Rejected) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because it's in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // Validate params\n decodeCodec(promptInput.paramCodec, params);\n\n // Compile prompt and template\n return this.handlebars.compile(promptTemplate.content)({\n // template in currentDate by default\n currentDate: new Date().toISOString(),\n ...this.variables,\n ...params,\n });\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to parse\n * @param response - AI response as string\n * @returns Parsed content\n */\n parseAiResponse<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n response: string,\n ): t.TypeOf<TPrompts[TPromptName]['outputCodec']> {\n // Look up prompt info\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Extract from tag if needed\n const extracted = promptInput.extractFromTag\n ? (createRegexForTag(promptInput.extractFromTag).exec(response) ||\n [])[1] || response\n : response;\n\n // Parse via codec\n return decodeCodec(\n promptInput.outputCodec,\n jsonParseSafe(extracted),\n false,\n );\n }\n\n /**\n * Parse the AI response and report back to Transcend\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportAndParsePromptRun<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n { largeLanguageModel, ...options }: ReportPromptRunOptions,\n ): Promise<\n PromptRunResult & {\n /** Resulting prompt run */\n result: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n }\n > {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n if (\n options.promptRunMessages[options.promptRunMessages.length - 1].role !==\n ChatCompletionRole.Assistant\n ) {\n throw new Error(\n `promptRunMessages[${\n options.promptRunMessages.length - 1\n }].role is expected to be = ${ChatCompletionRole.Assistant}`,\n );\n }\n const response =\n options.promptRunMessages[options.promptRunMessages.length - 1].content;\n\n let parsed: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n try {\n // Parse the response\n parsed = this.parseAiResponse(promptName, response);\n } catch (err) {\n await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n error: err.message,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n throw err;\n }\n\n // report successful run\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Resolved,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n result: parsed,\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n\n /**\n * Report an error for a particular prompt\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportPromptRunError<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n {\n largeLanguageModel,\n ...options\n }: Requirize<ReportPromptRunOptions, 'error'>,\n ): Promise<PromptRunResult> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n}\n/* eslint-enable max-lines */\n","import { GraphQLClient } from 'graphql-request';\nimport { LargeLanguageModelClient } from '@transcend-io/privacy-types';\nimport { LARGE_LANGUAGE_MODELS } from './gqls';\nimport { makeGraphQLRequest } from './makeGraphQLRequest';\n\nexport interface LargeLanguageModel {\n /** ID of prompts */\n id: string;\n /** The name of the large language model. */\n name: string;\n /** The content of the prompt template. */\n client: LargeLanguageModelClient;\n /** Whether hosted by Transcend or not */\n isTranscendHosted: boolean;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all LargeLanguageModels in the organization\n *\n * @param client - GraphQL client\n * @returns All LargeLanguageModels in the organization\n */\nexport async function fetchAllLargeLanguageModels(\n client: GraphQLClient,\n): Promise<LargeLanguageModel[]> {\n const largeLanguageModels: LargeLanguageModel[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n largeLanguageModels: { nodes },\n } = await makeGraphQLRequest<{\n /** LargeLanguageModels */\n largeLanguageModels: {\n /** List */\n nodes: LargeLanguageModel[];\n };\n }>(client, LARGE_LANGUAGE_MODELS, {\n first: PAGE_SIZE,\n offset,\n });\n largeLanguageModels.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return largeLanguageModels.sort((a, b) => a.name.localeCompare(b.name));\n}\n","import { difference } from 'lodash-es';\nimport fastGlob from 'fast-glob';\nimport { execSync } from 'child_process';\n\n/**\n * Function thats gets the git files that have changed\n * and returns the code\n *\n * @param options - Options\n * @returns Changes files and diffs\n */\nexport function getGitFilesThatChanged({\n baseBranch,\n rootDirectory,\n githubRepo,\n excludedGlob = [],\n fileBlockList = [],\n}: {\n /** Base branch */\n baseBranch: string;\n /** Github repo name */\n githubRepo: string;\n /** Root directory */\n rootDirectory: string;\n /** A glob that excludes files */\n excludedGlob?: string[];\n /** Block list of files to not process */\n fileBlockList?: string[];\n}): {\n /** The list of files that changed */\n changedFiles: string[];\n /** Github repo name */\n repoName: string;\n /** Current commit */\n commit: string;\n /** File diffs */\n fileDiffs: { [k in string]: string };\n} {\n // Pull base branch\n execSync(`git fetch origin ${baseBranch}`);\n\n // Latest commit on base branch. If we are on the base branch, we take the prior commit\n const latestBasedCommit = execSync(\n `git ls-remote ${githubRepo} \"refs/heads/${baseBranch}\" | cut -f 1`,\n { encoding: 'utf-8' },\n ).split('\\n')[0];\n\n // This commit\n const latestThisCommit = execSync('git rev-parse HEAD', {\n encoding: 'utf-8',\n }).split('\\n')[0];\n\n // Ensure commits are present\n if (!latestBasedCommit || !latestThisCommit) {\n throw new Error('FAILED TO FIND COMMIT RANGE');\n }\n\n // Get the diff between the given branch and base branch\n const diff = execSync(\n `git fetch && git diff --name-only \"${\n baseBranch || latestBasedCommit\n }...${latestThisCommit}\" -- ${rootDirectory}`,\n { encoding: 'utf-8' },\n );\n\n // Filter out block list\n const changedFiles = difference(\n diff.split('\\n').filter((f) => f),\n fileBlockList,\n );\n\n // Filter out globs\n const filteredChanges =\n excludedGlob.length > 0\n ? fastGlob.sync(changedFiles, { ignore: excludedGlob })\n : changedFiles;\n\n // Get the contents of only the changed files\n const fileDiffs: { [k in string]: string } = {};\n filteredChanges.forEach((file) => {\n const contents = execSync(`git show ${latestThisCommit}:${file}`, {\n encoding: 'utf-8',\n });\n fileDiffs[file] = contents;\n });\n\n // Pull the github repo name\n const repoName = githubRepo.split('/').pop()!.split('.')[0];\n\n return {\n changedFiles,\n fileDiffs,\n repoName,\n commit: latestThisCommit,\n };\n}\n"]}
1
+ {"version":3,"sources":["/home/runner/work/cli/cli/dist/index.cjs","../src/lib/ai/TranscendPromptManager.ts","../src/lib/graphql/fetchLargeLanguageModels.ts","../src/lib/ai/getGitFilesThatChanged.ts"],"names":["PAGE_SIZE","fetchAllLargeLanguageModels","client","largeLanguageModels","offset","shouldContinue","nodes","makeGraphQLRequest","LARGE_LANGUAGE_MODELS","a","b","createRegexForTag","tagName","defineTranscendPrompts","prompts","jsonParseSafe","obj","TranscendPromptManager","handlebarsOptions","transcendUrl","DEFAULT_TRANSCEND_API","transcendApiKey","requireApproval","cacheDuration","defaultVariables","buildTranscendGraphQLClient","createHandlebarsWithHelpers","promptDefinitions","getValues","promptIds","id","x","promptTitles","title","agentNames","uniq_default","response","agents","fetchPromptsWithVariables","fetchAllAgents","keyBy_default","model","promptByTitle","promptById","acc","v","partial","apply","result","name","agent","remoteAgent","ts","thread","fetchAllPromptThreads","names","hasCache","missingCache","groupBy_default","cachedAgents","chunkedNames","chunk_default","remoteAgents","mapSeries","chunkedName","pageOfAgents","filterBy","fetchAllAgentFiles","largeLanguageModel","matching"],"mappings":"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","file":"/home/runner/work/cli/cli/dist/index.cjs","sourcesContent":[null,"/* eslint-disable max-lines */\nimport {\n Optionalize,\n Requirize,\n apply,\n decodeCodec,\n getValues,\n} from '@transcend-io/type-utils';\nimport type { Handlebars } from '@transcend-io/handlebars-utils';\nimport { Secret } from '@transcend-io/secret-value';\nimport * as t from 'io-ts';\nimport { DEFAULT_TRANSCEND_API } from '../../constants';\nimport {\n Agent,\n AgentFile,\n AgentFileFilterBy,\n ReportPromptRunInput,\n buildTranscendGraphQLClient,\n fetchAllAgentFiles,\n fetchAllAgents,\n reportPromptRun,\n} from '../graphql';\nimport {\n HandlebarsInput,\n createHandlebarsWithHelpers,\n} from '@transcend-io/handlebars-utils';\nimport {\n TranscendPromptTemplated,\n TranscendPromptsAndVariables,\n fetchPromptsWithVariables,\n} from '../graphql/fetchPrompts';\nimport { GraphQLClient } from 'graphql-request';\nimport {\n PromptStatus,\n ChatCompletionRole,\n PromptRunProductArea,\n QueueStatus,\n LargeLanguageModelClient,\n} from '@transcend-io/privacy-types';\nimport {\n LargeLanguageModel,\n fetchAllLargeLanguageModels,\n} from '../graphql/fetchLargeLanguageModels';\nimport { groupBy, keyBy, uniq, chunk } from 'lodash-es';\nimport { mapSeries } from 'bluebird';\nimport {\n PromptThread,\n fetchAllPromptThreads,\n} from '../graphql/fetchPromptThreads';\n\n/**\n * An LLM Prompt definition\n */\nexport type TranscendPrompt<\n TInputParams extends t.Any,\n TOutputCodec extends t.Any,\n> = (\n | {\n /** ID of the prompt */\n id: string;\n /** Title of the prompt */\n title?: string;\n }\n | {\n /** ID of the prompt */\n id?: string;\n /** Title of the prompt */\n title: string;\n }\n) & {\n /** The names of the agents that should be loaded along with the prompt */\n agentNames?: string[];\n /** Codec to validate runtime input shape */\n paramCodec: TInputParams;\n /** Codec to validate output response */\n outputCodec: TOutputCodec;\n /**\n * If the output that needs to be parsed is returned within a tag\n * e.g. <tag> or <json> - this is the name of the tag\n */\n extractFromTag?: string;\n};\n\nexport interface PromptRunResult {\n /** The ID of the prompt run created on Transcend */\n promptRunId: string;\n /** The URL of the prompt run on Transcend */\n promptRunUrl: string;\n}\n\n/**\n * Create a regex to extract data from a tag\n *\n * Input:\n * \"here is some data <tag>Data</tag>...\"\n *\n * @param tagName - Name of tag\n * @returns Data within the tag\n */\nexport function createRegexForTag(tagName: string): RegExp {\n return new RegExp(`<${tagName}>([\\\\s\\\\S]+?)<\\\\/${tagName}>`);\n}\n\n/**\n * Helper function to declare prompts\n *\n * @param prompts - Prompt config\n * @returns Prompts as identity function - but type enforced\n */\nexport function defineTranscendPrompts<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n>(prompts: TPrompts): TPrompts {\n return prompts;\n}\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptParamType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['paramCodec']>;\n\n/**\n * Helper to get the type of the parameter for a given prompt\n */\nexport type GetPromptResponseType<\n TPromptName extends keyof TPrompts,\n TPrompts extends { [k in TPromptName]: TranscendPrompt<t.Any, t.Any> },\n> = t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n\n/**\n * Input for reporting a prompt run\n */\nexport interface ReportPromptRunOptions\n extends Optionalize<\n Omit<ReportPromptRunInput, 'status' | 'promptId' | 'largeLanguageModelId'>,\n 'name' | 'productArea'\n > {\n /** The large language model being run. Either the ID of the LLM or the client/name pairing */\n largeLanguageModel:\n | string\n | {\n /** Name of client */\n client: LargeLanguageModelClient;\n /** Name of the model */\n name: string;\n };\n}\n\nconst jsonParseSafe = (obj: string): unknown => {\n try {\n return JSON.parse(obj);\n } catch (e) {\n return obj;\n }\n};\n\n/**\n * A class that is capable of loading and insert variables into prompts from\n * Transcend's Prompt Manager\n */\nexport class TranscendPromptManager<\n TPromptNames extends string,\n TPrompts extends { [k in TPromptNames]: TranscendPrompt<t.Any, t.Any> },\n> {\n /** Prompt definitions */\n public prompts: TPrompts;\n\n /** Options for configuring handlebars */\n public handlebarsOptions!: HandlebarsInput;\n\n /** Prompt name -> content map, populated by call to Transcend API */\n public promptContentMap?: { [k in TPromptNames]: TranscendPromptTemplated };\n\n /** The large language models that are registered to this organization for reporting */\n public largeLanguageModels: LargeLanguageModel[] = [];\n\n /** The agent definitions registered to this organization */\n private agentsByName: { [name in string]: Agent } = {};\n\n /** The agent definitions registered to this organization */\n private agentsByAgentId: { [id in string]: Agent } = {};\n\n /** The GraphQL client that can be used to call Transcend */\n public graphQLClient: GraphQLClient;\n\n /** The set of variables to expose in handlebars context specified at class initiation */\n public defaultVariables: { [k in string]: unknown };\n\n /**\n * The set of variables to expose in handlebars context,\n * merges defaults with calculated variables from the inventory\n */\n public variables: { [k in string]: unknown };\n\n /** Handlebars compiler */\n public handlebars: typeof Handlebars;\n\n /** The Transcend API key */\n public transcendApiKey: string | Secret<string>;\n\n /** API of Transcend to call */\n public transcendUrl: string;\n\n /** When true, throw an error if the prompt is not approved */\n public requireApproval: boolean;\n\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n public cacheDuration?: number;\n\n /**\n * The last time the metadata was fetched\n */\n public lastUpdatedAt?: Date;\n\n /**\n * Constructor\n *\n * @param options - Options\n */\n constructor({\n prompts,\n handlebarsOptions = {},\n transcendUrl = DEFAULT_TRANSCEND_API,\n transcendApiKey,\n requireApproval = true,\n cacheDuration,\n defaultVariables = {},\n }: {\n /** Prompt definitions to load */\n prompts: TPrompts;\n /** Options for configuring handlebars */\n handlebarsOptions?: HandlebarsInput;\n /** The Transcend API key */\n transcendApiKey: string | Secret<string>;\n /** API of Transcend to call */\n transcendUrl?: string;\n /** When true, throw an error if the prompt is not approved */\n requireApproval?: boolean;\n /** The set of variables to expose in handlebars context specified at class initiation */\n defaultVariables?: { [k in string]: unknown };\n /**\n * The cache duration in ms for how long prompts and associated metadata should be cached\n * When undefined - prompts are cached indefinitely unless explicitly re-requested\n * When 0, prompts and metadata are fetched every time (not recommended)\n * Setting this to be an hour is a good rate that optimizes for performance and keeping up to date\n */\n cacheDuration?: number;\n }) {\n this.prompts = prompts;\n this.transcendUrl = transcendUrl;\n this.transcendApiKey = transcendApiKey;\n this.variables = defaultVariables;\n this.defaultVariables = defaultVariables;\n this.graphQLClient = buildTranscendGraphQLClient(\n transcendUrl,\n typeof transcendApiKey === 'object'\n ? transcendApiKey.release()\n : transcendApiKey,\n );\n this.requireApproval = requireApproval;\n this.cacheDuration = cacheDuration;\n this.handlebarsOptions = handlebarsOptions;\n this.handlebars = createHandlebarsWithHelpers(handlebarsOptions);\n }\n\n /**\n * Fetch prompt metadata from Transcend and cache to the class definition\n *\n * @returns A function that can be used to call the prompt\n */\n async fetchPromptsAndMetadata(): Promise<TranscendPromptsAndVariables> {\n // Determine what to fetch\n const promptDefinitions = getValues(this.prompts) as TranscendPrompt<\n t.Any,\n t.Any\n >[];\n const promptIds = promptDefinitions\n .map(({ id }) => id)\n .filter((x): x is string => !!x);\n const promptTitles = promptDefinitions\n .map(({ title }) => title)\n .filter((x): x is string => !!x);\n const agentNames = uniq(\n promptDefinitions.map(({ agentNames }) => agentNames || []).flat(),\n );\n\n // Fetch prompts and data\n const [response, largeLanguageModels, agents] = await Promise.all([\n fetchPromptsWithVariables(this.graphQLClient, {\n promptIds,\n promptTitles,\n }),\n fetchAllLargeLanguageModels(this.graphQLClient),\n fetchAllAgents(this.graphQLClient, { names: agentNames }),\n ]);\n this.agentsByName = keyBy(agents, 'name');\n this.agentsByAgentId = keyBy(agents, 'agentId');\n this.largeLanguageModels = largeLanguageModels.filter(\n (model) => model.isTranscendHosted === false,\n );\n\n // Lookup prompts by id/title\n const promptByTitle = keyBy(response.prompts, 'title');\n const promptById = keyBy(response.prompts, 'id');\n\n // Update variables\n this.variables = {\n ...response.calculatedVariables.reduce(\n (acc, v) =>\n Object.assign(acc, {\n [v.name]: v.data ? JSON.parse(v.data) : v.data,\n }),\n {},\n ),\n ...this.defaultVariables,\n };\n\n // Update partials\n this.handlebars = createHandlebarsWithHelpers({\n ...this.handlebarsOptions,\n templates: [\n ...(this.handlebarsOptions.templates || []),\n ...response.promptPartials.map((partial) => ({\n name: partial.slug,\n content: partial.content,\n })),\n ],\n });\n\n // Create mapping from prompt to content\n this.promptContentMap = apply(this.prompts, ({ id, title }) => {\n const result = id\n ? promptById[id]\n : title\n ? promptByTitle[title]\n : undefined;\n if (!result) {\n throw new Error(\n `Failed to find prompt with title: \"${title}\" and id: \"${id}\"`,\n );\n }\n return result;\n });\n\n // For cache\n this.lastUpdatedAt = new Date();\n\n return response;\n }\n\n /**\n * Get an agent definition by name\n *\n * @param name - Name of the agent to grab\n * @returns Large language model configuration\n */\n async getAgentByName(name: string): Promise<Agent | undefined> {\n const agent = this.agentsByName[name];\n if (agent) {\n return agent;\n }\n const [remoteAgent] = await fetchAllAgents(this.graphQLClient, {\n names: [name],\n });\n if (!remoteAgent) {\n return undefined;\n }\n this.agentsByName[remoteAgent.name] = remoteAgent;\n this.agentsByAgentId[remoteAgent.agentId] = remoteAgent;\n return remoteAgent;\n }\n\n /**\n * Get a prompt thread by ts\n *\n * @param ts - the slack message timestamp to look up thread for\n * @returns Large language model configuration\n */\n async getPromptThreadBySlackTs(\n ts: string,\n ): Promise<PromptThread | undefined> {\n const [thread] = await fetchAllPromptThreads(this.graphQLClient, {\n slackMessageTs: [ts],\n });\n return thread;\n }\n\n /**\n * Get a list of agent definitions by name.\n * Pulls from cache and may return less agents\n * than requested if some are not found\n *\n * @param names - Names of agents to fetch\n * @returns The agents that were found matching the names\n */\n async getAgentsByName(names: string[]): Promise<Agent[]> {\n if (names.length < 1) {\n throw new Error('Expected at least one name to be provided');\n }\n const { hasCache = [], missingCache = [] } = groupBy(names, (name) =>\n this.agentsByName[name] ? 'hasCache' : 'missingCache',\n );\n const cachedAgents = hasCache.map((name) => this.agentsByName[name]);\n if (missingCache.length === 0) {\n return cachedAgents;\n }\n const chunkedNames = chunk(missingCache, 50);\n const remoteAgents: Agent[] = [];\n await mapSeries(chunkedNames, async (chunkedName) => {\n const pageOfAgents = await fetchAllAgents(this.graphQLClient, {\n names: chunkedName,\n });\n pageOfAgents.forEach((agent) => {\n this.agentsByName[agent.name] = agent;\n this.agentsByAgentId[agent.agentId] = agent;\n });\n remoteAgents.push(...pageOfAgents);\n });\n return [...cachedAgents, ...remoteAgents];\n }\n\n /**\n * Fetch metadata on agent files\n *\n * @param filterBy - Filter by parameters\n * @returns The files found matching the filter\n */\n getAgentFiles(filterBy: AgentFileFilterBy): Promise<AgentFile[]> {\n return fetchAllAgentFiles(this.graphQLClient, filterBy);\n }\n\n /**\n * Look up the large language model to report on\n *\n * @param largeLanguageModel - Input\n * @returns Large language model configuration\n */\n getLargeLanguageModel(\n largeLanguageModel: ReportPromptRunOptions['largeLanguageModel'],\n ): LargeLanguageModel {\n const matching = this.largeLanguageModels.find((model) =>\n typeof largeLanguageModel === 'string'\n ? model.id === largeLanguageModel\n : model.name === largeLanguageModel.name &&\n model.client === largeLanguageModel.client,\n );\n if (!matching) {\n throw new Error(\n `Failed to find model matching: ${\n typeof largeLanguageModel === 'string'\n ? largeLanguageModel\n : JSON.stringify(largeLanguageModel)\n }`,\n );\n }\n return matching;\n }\n\n /**\n * Get a prompt definition by name\n *\n * @param promptName - Prompt to compile\n * @returns Parsed content\n */\n async getPromptDefinition<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n ): Promise<TranscendPromptTemplated> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n // Lookup prompt\n const { promptContentMap } = this;\n if (!promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n const promptTemplate = promptContentMap[promptName];\n if (!promptTemplate) {\n throw new Error(\n `Expected this.promptContentMap[${promptName}] to be defined`,\n );\n }\n return promptTemplate;\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to compile\n * @param params - Runtime parameters\n * @returns Parsed content\n */\n async compilePrompt<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n params: t.TypeOf<TPrompts[TPromptName]['paramCodec']>,\n ): Promise<string> {\n // Grab the prompt\n const promptTemplate = await this.getPromptDefinition(promptName);\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure prompt is approved\n if (\n this.requireApproval &&\n promptTemplate.status !== PromptStatus.Approved\n ) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because its in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // If prompt is rejected, throw error\n if (promptTemplate.status === PromptStatus.Rejected) {\n throw new Error(\n `Assessment \"${promptTemplate.title}\" cannot be used because it's in status: \"${promptTemplate.status}\"`,\n );\n }\n\n // Validate params\n decodeCodec(promptInput.paramCodec, params);\n\n // Compile prompt and template\n return this.handlebars.compile(promptTemplate.content)({\n // template in currentDate by default\n currentDate: new Date().toISOString(),\n ...this.variables,\n ...params,\n });\n }\n\n /**\n * Validate the shape of the response from AI\n *\n * @param promptName - Prompt to parse\n * @param response - AI response as string\n * @returns Parsed content\n */\n parseAiResponse<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n response: string,\n ): t.TypeOf<TPrompts[TPromptName]['outputCodec']> {\n // Look up prompt info\n const promptInput = this.prompts[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Extract from tag if needed\n const extracted = promptInput.extractFromTag\n ? (createRegexForTag(promptInput.extractFromTag).exec(response) ||\n [])[1] || response\n : response;\n\n // Parse via codec\n return decodeCodec(\n promptInput.outputCodec,\n jsonParseSafe(extracted),\n false,\n );\n }\n\n /**\n * Parse the AI response and report back to Transcend\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportAndParsePromptRun<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n { largeLanguageModel, ...options }: ReportPromptRunOptions,\n ): Promise<\n PromptRunResult & {\n /** Resulting prompt run */\n result: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n }\n > {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n if (\n options.promptRunMessages[options.promptRunMessages.length - 1].role !==\n ChatCompletionRole.Assistant\n ) {\n throw new Error(\n `promptRunMessages[${\n options.promptRunMessages.length - 1\n }].role is expected to be = ${ChatCompletionRole.Assistant}`,\n );\n }\n const response =\n options.promptRunMessages[options.promptRunMessages.length - 1].content;\n\n let parsed: t.TypeOf<TPrompts[TPromptName]['outputCodec']>;\n try {\n // Parse the response\n parsed = this.parseAiResponse(promptName, response);\n } catch (err) {\n await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n error: err.message,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n throw err;\n }\n\n // report successful run\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Resolved,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n result: parsed,\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n\n /**\n * Report an error for a particular prompt\n *\n * @param promptName - Prompt to parse\n * @param options - Options for reporting\n * @returns Parsed content\n */\n async reportPromptRunError<TPromptName extends TPromptNames>(\n promptName: TPromptName,\n {\n largeLanguageModel,\n ...options\n }: Requirize<ReportPromptRunOptions, 'error'>,\n ): Promise<PromptRunResult> {\n // Determine if prompts need to be fetched\n if (\n // never been fetched\n !this.lastUpdatedAt ||\n // fetch every run\n this.cacheDuration === 0 ||\n // If cache duration met\n (this.cacheDuration &&\n Date.now() - this.lastUpdatedAt.getTime() > this.cacheDuration)\n ) {\n await this.fetchPromptsAndMetadata();\n }\n\n const name =\n options.name ||\n `@transcend-io/cli-prompt-run-${new Date().toISOString()}`;\n\n if (!this.promptContentMap) {\n throw new Error('Expected this.promptContentMap to be defined');\n }\n // Look up prompt info\n const promptInput = this.promptContentMap[promptName];\n if (!promptInput) {\n throw new Error(`Expected this.prompts[${promptName}] to be defined`);\n }\n\n // Ensure the first message in `promptRunMessages` is of type=system\n if (options.promptRunMessages.length === 0) {\n throw new Error('promptRunMessages is expected to have length > 0');\n }\n if (options.promptRunMessages[0].role !== ChatCompletionRole.System) {\n throw new Error(\n `promptRunMessages[0].role is expected to be = ${ChatCompletionRole.System}`,\n );\n }\n\n const promptRunId = await reportPromptRun(this.graphQLClient, {\n productArea: PromptRunProductArea.PromptManager,\n ...options,\n name,\n status: QueueStatus.Error,\n ...(typeof largeLanguageModel === 'string'\n ? { largeLanguageModelId: largeLanguageModel }\n : {\n largeLanguageModelName: largeLanguageModel.name,\n largeLanguageModelClient: largeLanguageModel.client,\n }),\n promptId: promptInput.id,\n promptRunMessages: options.promptRunMessages.map((message, ind) => ({\n ...message,\n ...(ind === 0 ? { template: promptInput.content } : {}),\n })),\n });\n\n return {\n promptRunId,\n promptRunUrl: `https://app.transcend.io/prompts/runs/${promptRunId}`,\n };\n }\n}\n/* eslint-enable max-lines */\n","import { GraphQLClient } from 'graphql-request';\nimport { LargeLanguageModelClient } from '@transcend-io/privacy-types';\nimport { LARGE_LANGUAGE_MODELS } from './gqls';\nimport { makeGraphQLRequest } from './makeGraphQLRequest';\n\nexport interface LargeLanguageModel {\n /** ID of prompts */\n id: string;\n /** The name of the large language model. */\n name: string;\n /** The content of the prompt template. */\n client: LargeLanguageModelClient;\n /** Whether hosted by Transcend or not */\n isTranscendHosted: boolean;\n}\n\nconst PAGE_SIZE = 20;\n\n/**\n * Fetch all LargeLanguageModels in the organization\n *\n * @param client - GraphQL client\n * @returns All LargeLanguageModels in the organization\n */\nexport async function fetchAllLargeLanguageModels(\n client: GraphQLClient,\n): Promise<LargeLanguageModel[]> {\n const largeLanguageModels: LargeLanguageModel[] = [];\n let offset = 0;\n\n // Whether to continue looping\n let shouldContinue = false;\n do {\n const {\n largeLanguageModels: { nodes },\n } = await makeGraphQLRequest<{\n /** LargeLanguageModels */\n largeLanguageModels: {\n /** List */\n nodes: LargeLanguageModel[];\n };\n }>(client, LARGE_LANGUAGE_MODELS, {\n first: PAGE_SIZE,\n offset,\n });\n largeLanguageModels.push(...nodes);\n offset += PAGE_SIZE;\n shouldContinue = nodes.length === PAGE_SIZE;\n } while (shouldContinue);\n\n return largeLanguageModels.sort((a, b) => a.name.localeCompare(b.name));\n}\n","import { difference } from 'lodash-es';\nimport fastGlob from 'fast-glob';\nimport { execSync } from 'child_process';\n\n/**\n * Function thats gets the git files that have changed\n * and returns the code\n *\n * @param options - Options\n * @returns Changes files and diffs\n */\nexport function getGitFilesThatChanged({\n baseBranch,\n rootDirectory,\n githubRepo,\n excludedGlob = [],\n fileBlockList = [],\n}: {\n /** Base branch */\n baseBranch: string;\n /** Github repo name */\n githubRepo: string;\n /** Root directory */\n rootDirectory: string;\n /** A glob that excludes files */\n excludedGlob?: string[];\n /** Block list of files to not process */\n fileBlockList?: string[];\n}): {\n /** The list of files that changed */\n changedFiles: string[];\n /** Github repo name */\n repoName: string;\n /** Current commit */\n commit: string;\n /** File diffs */\n fileDiffs: { [k in string]: string };\n} {\n // Pull base branch\n execSync(`git fetch origin ${baseBranch}`);\n\n // Latest commit on base branch. If we are on the base branch, we take the prior commit\n const latestBasedCommit = execSync(\n `git ls-remote ${githubRepo} \"refs/heads/${baseBranch}\" | cut -f 1`,\n { encoding: 'utf-8' },\n ).split('\\n')[0];\n\n // This commit\n const latestThisCommit = execSync('git rev-parse HEAD', {\n encoding: 'utf-8',\n }).split('\\n')[0];\n\n // Ensure commits are present\n if (!latestBasedCommit || !latestThisCommit) {\n throw new Error('FAILED TO FIND COMMIT RANGE');\n }\n\n // Get the diff between the given branch and base branch\n const diff = execSync(\n `git fetch && git diff --name-only \"${\n baseBranch || latestBasedCommit\n }...${latestThisCommit}\" -- ${rootDirectory}`,\n { encoding: 'utf-8' },\n );\n\n // Filter out block list\n const changedFiles = difference(\n diff.split('\\n').filter((f) => f),\n fileBlockList,\n );\n\n // Filter out globs\n const filteredChanges =\n excludedGlob.length > 0\n ? fastGlob.sync(changedFiles, { ignore: excludedGlob })\n : changedFiles;\n\n // Get the contents of only the changed files\n const fileDiffs: { [k in string]: string } = {};\n filteredChanges.forEach((file) => {\n const contents = execSync(`git show ${latestThisCommit}:${file}`, {\n encoding: 'utf-8',\n });\n fileDiffs[file] = contents;\n });\n\n // Pull the github repo name\n const repoName = githubRepo.split('/').pop()!.split('.')[0];\n\n return {\n changedFiles,\n fileDiffs,\n repoName,\n commit: latestThisCommit,\n };\n}\n"]}
package/dist/index.d.cts CHANGED
@@ -124088,12 +124088,8 @@ declare const RequestIdentifier: t.TypeC<{
124088
124088
  type: t.KeyofC<{
124089
124089
  email: unknown;
124090
124090
  phone: unknown;
124091
- thriveTrmContactId: unknown;
124092
- customerIoId: unknown;
124093
- sprigVisitorId: unknown;
124094
- linkedInURL: unknown;
124095
- custom: unknown;
124096
124091
  coreIdentifier: unknown;
124092
+ custom: unknown;
124097
124093
  gaid: unknown;
124098
124094
  idfa: unknown;
124099
124095
  idfv: unknown;
@@ -124105,8 +124101,12 @@ declare const RequestIdentifier: t.TypeC<{
124105
124101
  stripeId: unknown;
124106
124102
  braintreeCustomerId: unknown;
124107
124103
  chargebeeId: unknown;
124104
+ thriveTrmContactId: unknown;
124108
124105
  talkableUUID: unknown;
124109
124106
  recurlyId: unknown;
124107
+ customerIoId: unknown;
124108
+ sprigVisitorId: unknown;
124109
+ linkedInURL: unknown;
124110
124110
  advertisingId: unknown;
124111
124111
  personaReferenceId: unknown;
124112
124112
  streamUserId: unknown;
@@ -124133,12 +124133,8 @@ declare const RequestIdentifiersResponse: t.TypeC<{
124133
124133
  type: t.KeyofC<{
124134
124134
  email: unknown;
124135
124135
  phone: unknown;
124136
- thriveTrmContactId: unknown;
124137
- customerIoId: unknown;
124138
- sprigVisitorId: unknown;
124139
- linkedInURL: unknown;
124140
- custom: unknown;
124141
124136
  coreIdentifier: unknown;
124137
+ custom: unknown;
124142
124138
  gaid: unknown;
124143
124139
  idfa: unknown;
124144
124140
  idfv: unknown;
@@ -124150,8 +124146,12 @@ declare const RequestIdentifiersResponse: t.TypeC<{
124150
124146
  stripeId: unknown;
124151
124147
  braintreeCustomerId: unknown;
124152
124148
  chargebeeId: unknown;
124149
+ thriveTrmContactId: unknown;
124153
124150
  talkableUUID: unknown;
124154
124151
  recurlyId: unknown;
124152
+ customerIoId: unknown;
124153
+ sprigVisitorId: unknown;
124154
+ linkedInURL: unknown;
124155
124155
  advertisingId: unknown;
124156
124156
  personaReferenceId: unknown;
124157
124157
  streamUserId: unknown;
@@ -143850,7 +143850,7 @@ declare function removeUnverifiedRequestIdentifiers({ requestActions, identifier
143850
143850
  }): Promise<number>;
143851
143851
 
143852
143852
  var description = "A command line interface for programmatic operations across Transcend.";
143853
- var version = "8.0.2";
143853
+ var version = "8.0.4";
143854
143854
 
143855
143855
  /**
143856
143856
  * The name of the main binary for the CLI
@@ -143887,6 +143887,13 @@ declare const SCOPES_BY_TITLE: Record<string, ScopeDefinition & {
143887
143887
  name: ScopeName;
143888
143888
  }>;
143889
143889
  declare const SCOPE_TITLES: string[];
143890
+ /**
143891
+ * HTTP statuses that should be retried *in place* without splitting.
143892
+ * 429: Rate-limited
143893
+ * 502: Upstream/edge gateway error
143894
+ * 329: Reserved for custom infra (kept defensively)
143895
+ */
143896
+ declare const RETRYABLE_BATCH_STATUSES: Set<429 | 502 | 329>;
143890
143897
 
143891
143898
  /**
143892
143899
  * Update the consent manager to latest version
@@ -144241,6 +144248,79 @@ declare function parseVariablesFromString(variables: string): {
144241
144248
  [k in string]: string;
144242
144249
  };
144243
144250
 
144251
+ /**
144252
+ * Extract an HTTP status code from a thrown error (got compatible).
144253
+ *
144254
+ * @param err - Unknown error thrown by network call
144255
+ * @returns HTTP status code, if present
144256
+ */
144257
+ declare function getErrorStatus(err: unknown): number | undefined;
144258
+
144259
+ /**
144260
+ * Extract a human-readable error message from a thrown error.
144261
+ *
144262
+ * Tries to parse JSON bodies that follow common REST/GraphQL error patterns:
144263
+ * { error: { message: string } }
144264
+ * { errors: [{ message: string }, ...] }
144265
+ *
144266
+ * Falls back to `err.message` or 'Unknown error'.
144267
+ *
144268
+ * @param err - Unknown error thrown by network call
144269
+ * @returns A concise error string safe to log/show
144270
+ */
144271
+ declare function extractErrorMessage(err: unknown): string;
144272
+
144273
+ /**
144274
+ * Sleep in a promise
144275
+ *
144276
+ * @param sleepTime - The time to sleep in milliseconds.
144277
+ * @returns Resolves promise
144278
+ */
144279
+ declare function sleepPromise(sleepTime: number): Promise<number>;
144280
+
144281
+ /**
144282
+ * Split an array roughly in half. Stable for even/odd lengths.
144283
+ *
144284
+ * @param entries - Items to split
144285
+ * @returns A tuple [left, right] halves
144286
+ */
144287
+ declare function splitInHalf<T>(entries: T[]): [T[], T[]];
144288
+
144289
+ interface RetryPolicy {
144290
+ /** Maximum retry attempts (not counting the initial try) */
144291
+ maxAttempts: number;
144292
+ /** Fixed delay between attempts in milliseconds */
144293
+ delayMs: number;
144294
+ /**
144295
+ * Decide whether a given error should be retried.
144296
+ *
144297
+ * @param status - HTTP status code (if known)
144298
+ * @param message - Extracted error message (if known)
144299
+ */
144300
+ shouldRetry(status?: number, message?: string): boolean;
144301
+ }
144302
+ /**
144303
+ * Retry a single async operation according to the provided policy.
144304
+ * The operation is executed once initially, then up to `maxAttempts` retries.
144305
+ *
144306
+ * @param op - Operation to run
144307
+ * @param policy - Retry policy
144308
+ * @param onBackoff - Observer called before each retry (for logging/metrics)
144309
+ * @returns Result of the operation if it eventually succeeds
144310
+ * @throws The last error encountered if all retries fail
144311
+ */
144312
+ declare function retrySamePromise<T>(op: () => Promise<T>, policy: RetryPolicy, onBackoff: (note: string) => void): Promise<T>;
144313
+
144314
+ /**
144315
+ * Limits the number of records in the returned object to a maximum.
144316
+ * For entries beyond the max, sets their value to `true`.
144317
+ *
144318
+ * @param obj - Object
144319
+ * @param max - Maximum number of entries to retain original value.
144320
+ * @returns Object with keys mapped to their value or `true` if over the limit.
144321
+ */
144322
+ declare function limitRecords<T>(obj: Record<string, T>, max: number): Record<string, T | true>;
144323
+
144244
144324
  declare const CronIdentifier: t.TypeC<{
144245
144325
  /** The identifier value */
144246
144326
  identifier: t.StringC;
@@ -145007,4 +145087,4 @@ type EnrichPrivacyRequest = t.TypeOf<typeof EnrichPrivacyRequest>;
145007
145087
  */
145008
145088
  declare function enrichPrivacyRequest(sombra: Got, { id: rawId, ...rest }: EnrichPrivacyRequest, enricherId: string, index?: number): Promise<boolean>;
145009
145089
 
145010
- export { ACTIONS, ADD_MESSAGES_TO_PROMPT_RUN, ADD_SILO_DISCOVERY_RESULTS, ADMIN_DASH, ADMIN_DASH_DATAPOINTS, ADMIN_DASH_INTEGRATIONS, AGENTS, AGENT_FILES, AGENT_FUNCTIONS, type AIIntegrationC, API_KEYS, APPROVE_PRIVACY_REQUEST, ASSESSMENTS, ASSESSMENT_SECTION_FIELDS, ASSESSMENT_TEMPLATES, ASSUME_ROLE, ATTRIBUTES, ATTRIBUTE_KEYS_REQUESTS, ATTRIBUTE_VALUES, type Action, ActionInput, type ActionItem, ActionItemCollectionInput, ActionItemInput, type ActionItemRaw, type AddMessagesToPromptRunInput, type Agent, type AgentFile, type AgentFileFilterBy, AgentFileInput, type AgentFunction, AgentFunctionInput, AgentInput, type ApiKey, type ApiKeyGenerateError, ApiKeyInput, type Assessment, AssessmentAction, type AssessmentAnswer, type AssessmentAnswerOption, AssessmentAnswerOptionInput, type AssessmentComment, AssessmentDisplayLogicInput, type AssessmentGroup, AssessmentInput, AssessmentNestedRule, AssessmentNestedRuleInput, type AssessmentPreviousSubmission, type AssessmentQuestion, type AssessmentResource, AssessmentResourceInput, AssessmentRetentionScheduleInput, AssessmentRiskLogic, AssessmentRule, AssessmentRuleInput, type AssessmentSection, AssessmentSectionInput, AssessmentSectionQuestionInput, type AssessmentTemplate, AssessmentTemplateInput, AttestedExtraIdentifiers, type Attribute, AttributeInput, type AttributeKey, type AttributeNameMap, AttributePreview, type AttributeValue, AttributeValueInput, BLANK, BULK_APPLY, BULK_REQUEST_FILES, BUSINESS_ENTITIES, type BusinessEntity, BusinessEntityInput, CANCEL_PRIVACY_REQUEST, CAN_APPLY_IN_BULK, CATALOGS, CHANGE_REQUEST_DATA_SILO_STATUS, CODE_PACKAGES, CONSENT_MANAGER_ANALYTICS_DATA, CONSENT_PARTITIONS, COOKIES, CREATE_ACTION_ITEMS, CREATE_ACTION_ITEM_COLLECTION, CREATE_AGENT, CREATE_AGENT_FILE, CREATE_AGENT_FUNCTION, CREATE_API_KEY, CREATE_ATTRIBUTE, CREATE_ATTRIBUTE_VALUES, CREATE_BUSINESS_ENTITY, CREATE_CODE_PACKAGE, CREATE_CONSENT_EXPERIENCE, CREATE_CONSENT_MANAGER, CREATE_CONSENT_PARTITION, CREATE_DATA_FLOWS, CREATE_DATA_SILOS, CREATE_DATA_SUBJECT, CREATE_DATA_SUB_CATEGORY, CREATE_ENRICHER, CREATE_IDENTIFIER, CREATE_PROCESSING_ACTIVITY, CREATE_PROCESSING_PURPOSE_SUB_CATEGORY, CREATE_PROMPT, CREATE_PROMPT_GROUP, CREATE_PROMPT_PARTIAL, CREATE_REPOSITORY, CREATE_SOFTWARE_DEVELOPMENT_KIT, CREATE_TEAM, CREATE_TEMPLATE, CREATE_VENDOR, CachedFileState, CachedRequestState, type Catalog, CodePackageInput, CodePackageSdk, ColumnName, type ColumnNameMap, type ConsentExperience, ConsentManageExperienceInput, type ConsentManager, ConsentManagerInput, type ConsentManagerMetric, ConsentManagerMetricBin, ConsentManagerServiceMetadata, type ConsentManagerTheme, ConsentPreferenceResponse, ConsentPreferenceTopic, ConsentPreferenceTopicOptionValue, ConsentPurpose, type Cookie, CookieCsvInput, CookieInput, type CreatedApiKey, CronIdentifier, CronIdentifierPush, type CronIdentifierWithAction, type CsvFormattedIdentifier, DATAPOINT_EXPORT, DATA_FLOWS, DATA_POINTS, DATA_POINT_COUNT, DATA_SILOS, DATA_SILOS_ENRICHED, DATA_SILO_EXPORT, DATA_SUBJECTS, DATA_SUB_CATEGORIES, DEFAULT_TRANSCEND_API, DEFAULT_TRANSCEND_CONSENT_API, DEFAULT_TRANSCEND_PULL_RESOURCES, DELETE_API_KEY, DELETE_ATTRIBUTE_VALUE, DEPLOYED_PRIVACY_CENTER_URL, DEPLOY_CONSENT_MANAGER, DETERMINE_LOGIN_METHOD, DataCategoryGuessInput, DataCategoryInput, DataCategoryPreviewInput, DataCategoryRecommendationInput, type DataFlow, DataFlowCsvInput, DataFlowInput, type DataPointCsvPreview, type DataSilo, type DataSiloAttributeValue, type DataSiloCsvPreview, type DataSiloEnriched, DataSiloInput, type DataSubCategory, type DataSubject, DataSubjectInput, type DatapointFilterOptions, DatapointInput, ENABLED_PLUGINS, ENRICHERS, ENTRY_COUNT, EXPERIENCES, type EnabledRouteC, type EnabledRoutesC, EnrichPrivacyRequest, type Enricher, EnricherInput, type ExportedPrivacyRequest, type ExternalUser, FETCH_CONSENT_MANAGER, FETCH_CONSENT_MANAGER_ID, FETCH_CONSENT_MANAGER_THEME, FETCH_PRIVACY_CENTER_ID, FieldInput, GLOBAL_ACTION_ITEMS, GLOBAL_ACTION_ITEM_COLLECTIONS, type GetPromptParamType, type GetPromptResponseType, IDENTIFIERS, IDENTIFIER_BLOCK_LIST, IMPORT_ONE_TRUST_ASSESSMENT_FORMS, INITIALIZER, IP_ADDRESS_REGEX, IS_REQUIRED, type Identifier, IdentifierInput, type IdentifierNameMap, ImportOnetrustAssessmentsInput, type IndexedCatalogs, type Initializer, IntlMessage, IntlMessageInput, LARGE_LANGUAGE_MODELS, LOGIN, MESSAGES, type Message, NEW_IDENTIFIER_TYPES, NONE, NOTIFY_ADDITIONAL_TIME, ORGANIZATION, OneTrustFileFormat, OneTrustPullResource, OneTrustPullSource, OpenAIEnabledRoute, OpenAIEnabledRoutes, OpenAIIntegration, OpenAIRouteName, type OrganizationPreview, POLICIES, PREFERENCE_TOPICS, PRIVACY_CENTER, PROCESSING_ACTIVITIES, PROCESSING_PURPOSE_SUB_CATEGORIES, PROMPTS, PROMPTS_WITH_VARIABLES, PROMPT_GROUPS, PROMPT_PARTIALS, PROMPT_THREADS, PURPOSES, ParsedAttributeInput, PartitionInput, PathfinderPolicy, PathfinderPolicyName, PathfinderPolicyNameC, PathfinderPromptRunMetadata, type Plugin, type PluginResponse, type Policy, PolicyInput, type PreferenceTopic, type PrivacyCenter, PrivacyCenterInput, PrivacyRequest, PrivacyRequestInput, PrivacyRequestResponse, type PrivacyRequestWithIdentifiers, type ProcessingActivity, ProcessingActivityInput, ProcessingPurposeInput, ProcessingPurposePreviewInput, type ProcessingPurposeSubCategory, type Prompt, PromptAVendorEmailSettings, type PromptCalculatedVariable, type PromptGroup, PromptGroupInput, PromptInput, type PromptPartial, PromptPartialInput, type PromptRunResult, type PromptRuntimeVariable, type PromptThread, type Purpose, PurposeMap, type PurposeWithPreferences, REDUCED_REQUESTS_FOR_DATA_SILO_COUNT, REMOVE_REQUEST_IDENTIFIERS, REPORT_PROMPT_RUN, REPOSITORIES, REQUESTS, REQUEST_DATA_SILOS, REQUEST_ENRICHERS, REQUEST_FILES, REQUEST_IDENTIFIERS, RETRY_REQUEST_DATA_SILO, RETRY_REQUEST_ENRICHER, RegionInput, type ReportPromptRunInput, type ReportPromptRunOptions, RepositoryInput, type RequestDataSilo, type RequestEnricher, type RequestFile, type RequestFileCursor, RequestFileMetadata, RequestFileMetadataResponse, type RequestFileResponse, RequestIdentifier, type RequestIdentifierMetadata, RequestIdentifiersResponse, type RetentionSchedule, RiskAssignmentInput, type RiskCategory, type RiskFramework, type RiskLevel, RiskLogicInput, type RiskMatrix, type RiskMatrixColumn, type RiskMatrixRow, SCOPES_BY_TITLE, SCOPE_TITLES, SET_RESOURCE_ATTRIBUTES, SKIP_REQUEST_ENRICHER, SOFTWARE_DEVELOPMENT_KITS, SOMBRA_VERSION, SUB_DATA_POINTS, SUB_DATA_POINTS_COUNT, SUB_DATA_POINTS_WITH_GUESSES, SYNC_ATTRIBUTE_TYPES, SoftwareDevelopmentKitInput, StoredApiKey, type SubDataPoint, type SubDataPointCsvPreview, SuccessfulRequest, TEAMS, TEMPLATES, TOGGLE_CONSENT_PRECEDENCE, TOGGLE_DATA_SUBJECT, TOGGLE_TELEMETRY_PARTITION_STRATEGY, TOGGLE_UNKNOWN_COOKIE_POLICY, TOGGLE_UNKNOWN_REQUEST_POLICY, TR_PULL_RESOURCE_SCOPE_MAP, TR_PUSH_RESOURCE_SCOPE_MAP, TR_YML_RESOURCE_TO_FIELD_NAME, type Team, TeamInput, type Template, TemplateInput, TranscendInput, type TranscendPartition, type TranscendPrompt, TranscendPromptManager, type TranscendPromptPartialTemplated, type TranscendPromptTemplated, type TranscendPromptsAndVariables, type TranscendPullConfigurationInput, TranscendPullResource, UPDATE_ACTION, UPDATE_ACTION_ITEMS, UPDATE_ACTION_ITEM_COLLECTION, UPDATE_AGENTS, UPDATE_AGENT_FILES, UPDATE_AGENT_FUNCTIONS, UPDATE_ATTRIBUTE, UPDATE_ATTRIBUTE_VALUES, UPDATE_BUSINESS_ENTITIES, UPDATE_CODE_PACKAGES, UPDATE_CONSENT_EXPERIENCE, UPDATE_CONSENT_MANAGER_DOMAINS, UPDATE_CONSENT_MANAGER_PARTITION, UPDATE_CONSENT_MANAGER_THEME, UPDATE_CONSENT_MANAGER_TO_LATEST, UPDATE_CONSENT_MANAGER_VERSION, UPDATE_DATA_FLOWS, UPDATE_DATA_SILOS, UPDATE_DATA_SUBJECT, UPDATE_DATA_SUB_CATEGORIES, UPDATE_ENRICHER, UPDATE_IDENTIFIER, UPDATE_INTL_MESSAGES, UPDATE_LOAD_OPTIONS, UPDATE_OR_CREATE_COOKIES, UPDATE_OR_CREATE_DATA_POINT, UPDATE_POLICIES, UPDATE_PRIVACY_CENTER, UPDATE_PRIVACY_REQUEST, UPDATE_PROCESSING_ACTIVITIES, UPDATE_PROCESSING_PURPOSE_SUB_CATEGORIES, UPDATE_PROMPTS, UPDATE_PROMPT_GROUPS, UPDATE_PROMPT_PARTIALS, UPDATE_REPOSITORIES, UPDATE_SOFTWARE_DEVELOPMENT_KITS, UPDATE_TEAM, UPDATE_VENDORS, USERS, USP_STRING_REGEX, type User, type UserPreview, type UserRole, VARIABLE_PARAMETERS_NAME, VARIABLE_PARAMETERS_REGEXP, VENDORS, type Vendor, VendorInput, WebhookHeader, type XdiSyncGroups, addMessagesToPromptRun, appendCsvSync, approvePrivacyRequests, assumeRole, buildAIIntegrationType, buildEnabledRouteType, buildTranscendGraphQLClient, buildTranscendGraphQLClientGeneric, buildXdiSyncEndpoint, bulkRestartRequests, bulkRetryEnrichers, cancelPrivacyRequests, consentManagersToBusinessEntities, convertToDataSubjectAllowlist, convertToDataSubjectBlockList, createActionItemCollection, createActionItems, createAgent, createAgentFile, createAgentFunction, createApiKey, createBusinessEntity, createCodePackage, createConsentToken, createDataCategory, createDataFlows, createProcessingPurpose, createPrompt, createRegexForTag, createRepository, createSoftwareDevelopmentKit, createSombraGotInstance, createTranscendConsentGotInstance, createVendor, defineTranscendPrompts, deleteApiKey, deployConsentManager, description, domainToHost, downloadPrivacyRequestFiles, enrichPrivacyRequest, ensureAllDataSubjectsExist, extractClientError, fetchActiveSiloDiscoPlugin, fetchAllActionItems, fetchAllActions, fetchAllAgentFiles, fetchAllAgentFunctions, fetchAllAgents, fetchAllApiKeys, fetchAllAssessmentTemplates, fetchAllAssessments, fetchAllAttributeValues, fetchAllAttributes, fetchAllBusinessEntities, fetchAllCatalogs, fetchAllCookies, fetchAllDataCategories, fetchAllDataFlows, fetchAllDataPoints, fetchAllDataSilos, fetchAllDataSubjects, fetchAllEnrichers, fetchAllIdentifiers, fetchAllMessages, fetchAllPolicies, fetchAllPreferenceTopics, fetchAllPrivacyCenters, fetchAllProcessingActivities, fetchAllProcessingPurposes, fetchAllPromptGroups, fetchAllPromptPartials, fetchAllPromptThreads, fetchAllPrompts, fetchAllPurposes, fetchAllPurposesAndPreferences, fetchAllRequestAttributeKeys, fetchAllRequestEnrichers, fetchAllRequestIdentifierMetadata, fetchAllRequestIdentifiers, fetchAllRequests, fetchAllSubDataPoints, fetchAllTeams, fetchAllTemplates, fetchAllUsers, fetchAllVendors, fetchAndIndexCatalogs, fetchApiKeys, fetchConsentManager, fetchConsentManagerAnalyticsData, fetchConsentManagerExperiences, fetchConsentManagerId, fetchConsentManagerTheme, fetchConsentPreferences, fetchEnrichedDataSilos, fetchIdentifiersAndCreateMissing, fetchPartitions, fetchPrivacyCenterId, fetchPrivacyCenterUrl, fetchPromptsWithVariables, fetchRequestDataSilo, fetchRequestDataSiloActiveCount, fetchRequestDataSilos, fetchRequestFilesForRequest, filterNullishValuesFromObject, filterRows, fuzzyMatchColumns, fuzzySearch, generateCrossAccountApiKeys, getFileMetadataForPrivacyRequests, getGitFilesThatChanged, getUniqueValuesForColumn, inquirerAutoComplete, inquirerConfirmBoolean, inquirerConfirmText, listDirectories, listFiles, loginUser, makeGraphQLRequest, mapColumnsToAttributes, mapColumnsToIdentifiers, mapCsvColumnsToApi, mapCsvRowsToRequestInputs, mapEnumValues, mapRequestEnumValues, markCronIdentifierCompleted, markRequestDataSiloIdsCompleted, markSilentPrivacyRequests, mergeTranscendInputs, name, normalizeIdentifierValue, notifyPrivacyRequestsAdditionalTime, parseAssessmentDisplayLogic, parseAssessmentRiskLogic, parseAttributesFromString, parseFilePath, parseVariablesFromString, pullAllDatapoints, pullChunkedCustomSiloOutstandingIdentifiers, pullConsentManagerMetrics, pullCronPageOfIdentifiers, pullManualEnrichmentIdentifiersToCsv, pullPrivacyRequests, pullTranscendConfiguration, pullUnstructuredSubDataPointRecommendations, pushCronIdentifiersFromCsv, pushManualEnrichmentIdentifiersFromCsv, readCsv, readTranscendYaml, removeLinks, removeUnverifiedRequestIdentifiers, replaceVariablesInYaml, reportPromptRun, restartPrivacyRequest, retryRequestDataSilos, retryRequestEnricher, setResourceAttributes, skipPreflightJobs, skipRequestDataSilos, splitCsvToList, streamPrivacyRequestFiles, submitPrivacyRequest, syncAction, syncActionItemCollections, syncActionItems, syncAgentFiles, syncAgentFunctions, syncAgents, syncAttribute, syncBusinessEntities, syncCodePackages, syncConfigurationToTranscend, syncConsentManager, syncConsentManagerExperiences, syncCookies, syncDataCategories, syncDataFlows, syncDataSiloDependencies, syncDataSilos, syncDataSubject, syncEnricher, syncIdentifier, syncIntlMessages, syncPartitions, syncPolicies, syncPrivacyCenter, syncProcessingActivities, syncProcessingPurposes, syncPrompts, syncRepositories, syncSoftwareDevelopmentKits, syncTemplate, syncVendors, updateActionItem, updateActionItemCollection, updateAgentFiles, updateAgentFunctions, updateAgents, updateBusinessEntities, updateCodePackages, updateConsentManagerToLatest, updateConsentManagerVersionToLatest, updateDataCategories, updateDataFlows, updateIntlMessages, updateOrCreateCookies, updatePolicies, updateProcessingPurposes, updatePrompts, updateRepositories, updateSoftwareDevelopmentKits, updateVendors, uploadConsents, uploadCookiesFromCsv, uploadDataFlowsFromCsv, uploadPrivacyRequestsFromCsv, uploadSiloDiscoveryResults, validateTranscendAuth, version, writeCsv, writeCsvSync, writeLargeCsv, writeTranscendYaml };
145090
+ export { ACTIONS, ADD_MESSAGES_TO_PROMPT_RUN, ADD_SILO_DISCOVERY_RESULTS, ADMIN_DASH, ADMIN_DASH_DATAPOINTS, ADMIN_DASH_INTEGRATIONS, AGENTS, AGENT_FILES, AGENT_FUNCTIONS, type AIIntegrationC, API_KEYS, APPROVE_PRIVACY_REQUEST, ASSESSMENTS, ASSESSMENT_SECTION_FIELDS, ASSESSMENT_TEMPLATES, ASSUME_ROLE, ATTRIBUTES, ATTRIBUTE_KEYS_REQUESTS, ATTRIBUTE_VALUES, type Action, ActionInput, type ActionItem, ActionItemCollectionInput, ActionItemInput, type ActionItemRaw, type AddMessagesToPromptRunInput, type Agent, type AgentFile, type AgentFileFilterBy, AgentFileInput, type AgentFunction, AgentFunctionInput, AgentInput, type ApiKey, type ApiKeyGenerateError, ApiKeyInput, type Assessment, AssessmentAction, type AssessmentAnswer, type AssessmentAnswerOption, AssessmentAnswerOptionInput, type AssessmentComment, AssessmentDisplayLogicInput, type AssessmentGroup, AssessmentInput, AssessmentNestedRule, AssessmentNestedRuleInput, type AssessmentPreviousSubmission, type AssessmentQuestion, type AssessmentResource, AssessmentResourceInput, AssessmentRetentionScheduleInput, AssessmentRiskLogic, AssessmentRule, AssessmentRuleInput, type AssessmentSection, AssessmentSectionInput, AssessmentSectionQuestionInput, type AssessmentTemplate, AssessmentTemplateInput, AttestedExtraIdentifiers, type Attribute, AttributeInput, type AttributeKey, type AttributeNameMap, AttributePreview, type AttributeValue, AttributeValueInput, BLANK, BULK_APPLY, BULK_REQUEST_FILES, BUSINESS_ENTITIES, type BusinessEntity, BusinessEntityInput, CANCEL_PRIVACY_REQUEST, CAN_APPLY_IN_BULK, CATALOGS, CHANGE_REQUEST_DATA_SILO_STATUS, CODE_PACKAGES, CONSENT_MANAGER_ANALYTICS_DATA, CONSENT_PARTITIONS, COOKIES, CREATE_ACTION_ITEMS, CREATE_ACTION_ITEM_COLLECTION, CREATE_AGENT, CREATE_AGENT_FILE, CREATE_AGENT_FUNCTION, CREATE_API_KEY, CREATE_ATTRIBUTE, CREATE_ATTRIBUTE_VALUES, CREATE_BUSINESS_ENTITY, CREATE_CODE_PACKAGE, CREATE_CONSENT_EXPERIENCE, CREATE_CONSENT_MANAGER, CREATE_CONSENT_PARTITION, CREATE_DATA_FLOWS, CREATE_DATA_SILOS, CREATE_DATA_SUBJECT, CREATE_DATA_SUB_CATEGORY, CREATE_ENRICHER, CREATE_IDENTIFIER, CREATE_PROCESSING_ACTIVITY, CREATE_PROCESSING_PURPOSE_SUB_CATEGORY, CREATE_PROMPT, CREATE_PROMPT_GROUP, CREATE_PROMPT_PARTIAL, CREATE_REPOSITORY, CREATE_SOFTWARE_DEVELOPMENT_KIT, CREATE_TEAM, CREATE_TEMPLATE, CREATE_VENDOR, CachedFileState, CachedRequestState, type Catalog, CodePackageInput, CodePackageSdk, ColumnName, type ColumnNameMap, type ConsentExperience, ConsentManageExperienceInput, type ConsentManager, ConsentManagerInput, type ConsentManagerMetric, ConsentManagerMetricBin, ConsentManagerServiceMetadata, type ConsentManagerTheme, ConsentPreferenceResponse, ConsentPreferenceTopic, ConsentPreferenceTopicOptionValue, ConsentPurpose, type Cookie, CookieCsvInput, CookieInput, type CreatedApiKey, CronIdentifier, CronIdentifierPush, type CronIdentifierWithAction, type CsvFormattedIdentifier, DATAPOINT_EXPORT, DATA_FLOWS, DATA_POINTS, DATA_POINT_COUNT, DATA_SILOS, DATA_SILOS_ENRICHED, DATA_SILO_EXPORT, DATA_SUBJECTS, DATA_SUB_CATEGORIES, DEFAULT_TRANSCEND_API, DEFAULT_TRANSCEND_CONSENT_API, DEFAULT_TRANSCEND_PULL_RESOURCES, DELETE_API_KEY, DELETE_ATTRIBUTE_VALUE, DEPLOYED_PRIVACY_CENTER_URL, DEPLOY_CONSENT_MANAGER, DETERMINE_LOGIN_METHOD, DataCategoryGuessInput, DataCategoryInput, DataCategoryPreviewInput, DataCategoryRecommendationInput, type DataFlow, DataFlowCsvInput, DataFlowInput, type DataPointCsvPreview, type DataSilo, type DataSiloAttributeValue, type DataSiloCsvPreview, type DataSiloEnriched, DataSiloInput, type DataSubCategory, type DataSubject, DataSubjectInput, type DatapointFilterOptions, DatapointInput, ENABLED_PLUGINS, ENRICHERS, ENTRY_COUNT, EXPERIENCES, type EnabledRouteC, type EnabledRoutesC, EnrichPrivacyRequest, type Enricher, EnricherInput, type ExportedPrivacyRequest, type ExternalUser, FETCH_CONSENT_MANAGER, FETCH_CONSENT_MANAGER_ID, FETCH_CONSENT_MANAGER_THEME, FETCH_PRIVACY_CENTER_ID, FieldInput, GLOBAL_ACTION_ITEMS, GLOBAL_ACTION_ITEM_COLLECTIONS, type GetPromptParamType, type GetPromptResponseType, IDENTIFIERS, IDENTIFIER_BLOCK_LIST, IMPORT_ONE_TRUST_ASSESSMENT_FORMS, INITIALIZER, IP_ADDRESS_REGEX, IS_REQUIRED, type Identifier, IdentifierInput, type IdentifierNameMap, ImportOnetrustAssessmentsInput, type IndexedCatalogs, type Initializer, IntlMessage, IntlMessageInput, LARGE_LANGUAGE_MODELS, LOGIN, MESSAGES, type Message, NEW_IDENTIFIER_TYPES, NONE, NOTIFY_ADDITIONAL_TIME, ORGANIZATION, OneTrustFileFormat, OneTrustPullResource, OneTrustPullSource, OpenAIEnabledRoute, OpenAIEnabledRoutes, OpenAIIntegration, OpenAIRouteName, type OrganizationPreview, POLICIES, PREFERENCE_TOPICS, PRIVACY_CENTER, PROCESSING_ACTIVITIES, PROCESSING_PURPOSE_SUB_CATEGORIES, PROMPTS, PROMPTS_WITH_VARIABLES, PROMPT_GROUPS, PROMPT_PARTIALS, PROMPT_THREADS, PURPOSES, ParsedAttributeInput, PartitionInput, PathfinderPolicy, PathfinderPolicyName, PathfinderPolicyNameC, PathfinderPromptRunMetadata, type Plugin, type PluginResponse, type Policy, PolicyInput, type PreferenceTopic, type PrivacyCenter, PrivacyCenterInput, PrivacyRequest, PrivacyRequestInput, PrivacyRequestResponse, type PrivacyRequestWithIdentifiers, type ProcessingActivity, ProcessingActivityInput, ProcessingPurposeInput, ProcessingPurposePreviewInput, type ProcessingPurposeSubCategory, type Prompt, PromptAVendorEmailSettings, type PromptCalculatedVariable, type PromptGroup, PromptGroupInput, PromptInput, type PromptPartial, PromptPartialInput, type PromptRunResult, type PromptRuntimeVariable, type PromptThread, type Purpose, PurposeMap, type PurposeWithPreferences, REDUCED_REQUESTS_FOR_DATA_SILO_COUNT, REMOVE_REQUEST_IDENTIFIERS, REPORT_PROMPT_RUN, REPOSITORIES, REQUESTS, REQUEST_DATA_SILOS, REQUEST_ENRICHERS, REQUEST_FILES, REQUEST_IDENTIFIERS, RETRYABLE_BATCH_STATUSES, RETRY_REQUEST_DATA_SILO, RETRY_REQUEST_ENRICHER, RegionInput, type ReportPromptRunInput, type ReportPromptRunOptions, RepositoryInput, type RequestDataSilo, type RequestEnricher, type RequestFile, type RequestFileCursor, RequestFileMetadata, RequestFileMetadataResponse, type RequestFileResponse, RequestIdentifier, type RequestIdentifierMetadata, RequestIdentifiersResponse, type RetentionSchedule, type RetryPolicy, RiskAssignmentInput, type RiskCategory, type RiskFramework, type RiskLevel, RiskLogicInput, type RiskMatrix, type RiskMatrixColumn, type RiskMatrixRow, SCOPES_BY_TITLE, SCOPE_TITLES, SET_RESOURCE_ATTRIBUTES, SKIP_REQUEST_ENRICHER, SOFTWARE_DEVELOPMENT_KITS, SOMBRA_VERSION, SUB_DATA_POINTS, SUB_DATA_POINTS_COUNT, SUB_DATA_POINTS_WITH_GUESSES, SYNC_ATTRIBUTE_TYPES, SoftwareDevelopmentKitInput, StoredApiKey, type SubDataPoint, type SubDataPointCsvPreview, SuccessfulRequest, TEAMS, TEMPLATES, TOGGLE_CONSENT_PRECEDENCE, TOGGLE_DATA_SUBJECT, TOGGLE_TELEMETRY_PARTITION_STRATEGY, TOGGLE_UNKNOWN_COOKIE_POLICY, TOGGLE_UNKNOWN_REQUEST_POLICY, TR_PULL_RESOURCE_SCOPE_MAP, TR_PUSH_RESOURCE_SCOPE_MAP, TR_YML_RESOURCE_TO_FIELD_NAME, type Team, TeamInput, type Template, TemplateInput, TranscendInput, type TranscendPartition, type TranscendPrompt, TranscendPromptManager, type TranscendPromptPartialTemplated, type TranscendPromptTemplated, type TranscendPromptsAndVariables, type TranscendPullConfigurationInput, TranscendPullResource, UPDATE_ACTION, UPDATE_ACTION_ITEMS, UPDATE_ACTION_ITEM_COLLECTION, UPDATE_AGENTS, UPDATE_AGENT_FILES, UPDATE_AGENT_FUNCTIONS, UPDATE_ATTRIBUTE, UPDATE_ATTRIBUTE_VALUES, UPDATE_BUSINESS_ENTITIES, UPDATE_CODE_PACKAGES, UPDATE_CONSENT_EXPERIENCE, UPDATE_CONSENT_MANAGER_DOMAINS, UPDATE_CONSENT_MANAGER_PARTITION, UPDATE_CONSENT_MANAGER_THEME, UPDATE_CONSENT_MANAGER_TO_LATEST, UPDATE_CONSENT_MANAGER_VERSION, UPDATE_DATA_FLOWS, UPDATE_DATA_SILOS, UPDATE_DATA_SUBJECT, UPDATE_DATA_SUB_CATEGORIES, UPDATE_ENRICHER, UPDATE_IDENTIFIER, UPDATE_INTL_MESSAGES, UPDATE_LOAD_OPTIONS, UPDATE_OR_CREATE_COOKIES, UPDATE_OR_CREATE_DATA_POINT, UPDATE_POLICIES, UPDATE_PRIVACY_CENTER, UPDATE_PRIVACY_REQUEST, UPDATE_PROCESSING_ACTIVITIES, UPDATE_PROCESSING_PURPOSE_SUB_CATEGORIES, UPDATE_PROMPTS, UPDATE_PROMPT_GROUPS, UPDATE_PROMPT_PARTIALS, UPDATE_REPOSITORIES, UPDATE_SOFTWARE_DEVELOPMENT_KITS, UPDATE_TEAM, UPDATE_VENDORS, USERS, USP_STRING_REGEX, type User, type UserPreview, type UserRole, VARIABLE_PARAMETERS_NAME, VARIABLE_PARAMETERS_REGEXP, VENDORS, type Vendor, VendorInput, WebhookHeader, type XdiSyncGroups, addMessagesToPromptRun, appendCsvSync, approvePrivacyRequests, assumeRole, buildAIIntegrationType, buildEnabledRouteType, buildTranscendGraphQLClient, buildTranscendGraphQLClientGeneric, buildXdiSyncEndpoint, bulkRestartRequests, bulkRetryEnrichers, cancelPrivacyRequests, consentManagersToBusinessEntities, convertToDataSubjectAllowlist, convertToDataSubjectBlockList, createActionItemCollection, createActionItems, createAgent, createAgentFile, createAgentFunction, createApiKey, createBusinessEntity, createCodePackage, createConsentToken, createDataCategory, createDataFlows, createProcessingPurpose, createPrompt, createRegexForTag, createRepository, createSoftwareDevelopmentKit, createSombraGotInstance, createTranscendConsentGotInstance, createVendor, defineTranscendPrompts, deleteApiKey, deployConsentManager, description, domainToHost, downloadPrivacyRequestFiles, enrichPrivacyRequest, ensureAllDataSubjectsExist, extractClientError, extractErrorMessage, fetchActiveSiloDiscoPlugin, fetchAllActionItems, fetchAllActions, fetchAllAgentFiles, fetchAllAgentFunctions, fetchAllAgents, fetchAllApiKeys, fetchAllAssessmentTemplates, fetchAllAssessments, fetchAllAttributeValues, fetchAllAttributes, fetchAllBusinessEntities, fetchAllCatalogs, fetchAllCookies, fetchAllDataCategories, fetchAllDataFlows, fetchAllDataPoints, fetchAllDataSilos, fetchAllDataSubjects, fetchAllEnrichers, fetchAllIdentifiers, fetchAllMessages, fetchAllPolicies, fetchAllPreferenceTopics, fetchAllPrivacyCenters, fetchAllProcessingActivities, fetchAllProcessingPurposes, fetchAllPromptGroups, fetchAllPromptPartials, fetchAllPromptThreads, fetchAllPrompts, fetchAllPurposes, fetchAllPurposesAndPreferences, fetchAllRequestAttributeKeys, fetchAllRequestEnrichers, fetchAllRequestIdentifierMetadata, fetchAllRequestIdentifiers, fetchAllRequests, fetchAllSubDataPoints, fetchAllTeams, fetchAllTemplates, fetchAllUsers, fetchAllVendors, fetchAndIndexCatalogs, fetchApiKeys, fetchConsentManager, fetchConsentManagerAnalyticsData, fetchConsentManagerExperiences, fetchConsentManagerId, fetchConsentManagerTheme, fetchConsentPreferences, fetchEnrichedDataSilos, fetchIdentifiersAndCreateMissing, fetchPartitions, fetchPrivacyCenterId, fetchPrivacyCenterUrl, fetchPromptsWithVariables, fetchRequestDataSilo, fetchRequestDataSiloActiveCount, fetchRequestDataSilos, fetchRequestFilesForRequest, filterNullishValuesFromObject, filterRows, fuzzyMatchColumns, fuzzySearch, generateCrossAccountApiKeys, getErrorStatus, getFileMetadataForPrivacyRequests, getGitFilesThatChanged, getUniqueValuesForColumn, inquirerAutoComplete, inquirerConfirmBoolean, inquirerConfirmText, limitRecords, listDirectories, listFiles, loginUser, makeGraphQLRequest, mapColumnsToAttributes, mapColumnsToIdentifiers, mapCsvColumnsToApi, mapCsvRowsToRequestInputs, mapEnumValues, mapRequestEnumValues, markCronIdentifierCompleted, markRequestDataSiloIdsCompleted, markSilentPrivacyRequests, mergeTranscendInputs, name, normalizeIdentifierValue, notifyPrivacyRequestsAdditionalTime, parseAssessmentDisplayLogic, parseAssessmentRiskLogic, parseAttributesFromString, parseFilePath, parseVariablesFromString, pullAllDatapoints, pullChunkedCustomSiloOutstandingIdentifiers, pullConsentManagerMetrics, pullCronPageOfIdentifiers, pullManualEnrichmentIdentifiersToCsv, pullPrivacyRequests, pullTranscendConfiguration, pullUnstructuredSubDataPointRecommendations, pushCronIdentifiersFromCsv, pushManualEnrichmentIdentifiersFromCsv, readCsv, readTranscendYaml, removeLinks, removeUnverifiedRequestIdentifiers, replaceVariablesInYaml, reportPromptRun, restartPrivacyRequest, retryRequestDataSilos, retryRequestEnricher, retrySamePromise, setResourceAttributes, skipPreflightJobs, skipRequestDataSilos, sleepPromise, splitCsvToList, splitInHalf, streamPrivacyRequestFiles, submitPrivacyRequest, syncAction, syncActionItemCollections, syncActionItems, syncAgentFiles, syncAgentFunctions, syncAgents, syncAttribute, syncBusinessEntities, syncCodePackages, syncConfigurationToTranscend, syncConsentManager, syncConsentManagerExperiences, syncCookies, syncDataCategories, syncDataFlows, syncDataSiloDependencies, syncDataSilos, syncDataSubject, syncEnricher, syncIdentifier, syncIntlMessages, syncPartitions, syncPolicies, syncPrivacyCenter, syncProcessingActivities, syncProcessingPurposes, syncPrompts, syncRepositories, syncSoftwareDevelopmentKits, syncTemplate, syncVendors, updateActionItem, updateActionItemCollection, updateAgentFiles, updateAgentFunctions, updateAgents, updateBusinessEntities, updateCodePackages, updateConsentManagerToLatest, updateConsentManagerVersionToLatest, updateDataCategories, updateDataFlows, updateIntlMessages, updateOrCreateCookies, updatePolicies, updateProcessingPurposes, updatePrompts, updateRepositories, updateSoftwareDevelopmentKits, updateVendors, uploadConsents, uploadCookiesFromCsv, uploadDataFlowsFromCsv, uploadPrivacyRequestsFromCsv, uploadSiloDiscoveryResults, validateTranscendAuth, version, writeCsv, writeCsvSync, writeLargeCsv, writeTranscendYaml };
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "author": "Transcend Inc.",
3
3
  "name": "@transcend-io/cli",
4
4
  "description": "A command line interface for programmatic operations across Transcend.",
5
- "version": "8.0.2",
5
+ "version": "8.0.4",
6
6
  "homepage": "https://github.com/transcend-io/cli",
7
7
  "repository": {
8
8
  "type": "git",
@@ -1,15 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }function Zo(r,e,t){var o=-1,a=r.length;e<0&&(e=-e>a?0:a+e),t=t>a?a:t,t<0&&(t+=a),a=e>t?0:t-e>>>0,e>>>=0;for(var f=Array(a);++o<a;)f[o]=r[o+e];return f}var br=Zo;function $o(r,e){return r===e||r!==r&&e!==e}var H=$o;var Jo=typeof global=="object"&&global&&global.Object===Object&&global,yr=Jo;var Yo=typeof self=="object"&&self&&self.Object===Object&&self,Vo=yr||Yo||Function("return this")(),x=Vo;var Xo=x.Symbol,g=Xo;var Xr=Object.prototype,Qo=Xr.hasOwnProperty,ra=Xr.toString,mr=g?g.toStringTag:void 0;function ea(r){var e=Qo.call(r,mr),t=r[mr];try{r[mr]=void 0;var o=!0}catch (e2){}var a=ra.call(r);return o&&(e?r[mr]=t:delete r[mr]),a}var Qr=ea;var ta=Object.prototype,oa=ta.toString;function aa(r){return oa.call(r)}var re=aa;var fa="[object Null]",na="[object Undefined]",ee=g?g.toStringTag:void 0;function ia(r){return r==null?r===void 0?na:fa:ee&&ee in Object(r)?Qr(r):re(r)}var v=ia;function sa(r){var e=typeof r;return r!=null&&(e=="object"||e=="function")}var A=sa;var ua="[object AsyncFunction]",pa="[object Function]",ma="[object GeneratorFunction]",da="[object Proxy]";function la(r){if(!A(r))return!1;var e=v(r);return e==pa||e==ma||e==ua||e==da}var _r=la;var ca=9007199254740991;function xa(r){return typeof r=="number"&&r>-1&&r%1==0&&r<=ca}var k=xa;function ga(r){return r!=null&&k(r.length)&&!_r(r)}var w=ga;var ha=9007199254740991,ba=/^(?:0|[1-9]\d*)$/;function ya(r,e){var t=typeof r;return e=_nullishCoalesce(e, () => (ha)),!!e&&(t=="number"||t!="symbol"&&ba.test(r))&&r>-1&&r%1==0&&r<e}var K=ya;function _a(r,e,t){if(!A(t))return!1;var o=typeof e;return(o=="number"?w(t)&&K(e,t.length):o=="string"&&e in t)?H(t[e],r):!1}var dr=_a;var va=/\s/;function Aa(r){for(var e=r.length;e--&&va.test(r.charAt(e)););return e}var te=Aa;var Oa=/^\s+/;function wa(r){return r&&r.slice(0,te(r)+1).replace(Oa,"")}var oe=wa;function Ta(r){return r!=null&&typeof r=="object"}var b=Ta;var Sa="[object Symbol]";function Ca(r){return typeof r=="symbol"||b(r)&&v(r)==Sa}var O=Ca;var ae=NaN,ja=/^[-+]0x[0-9a-f]+$/i,Ia=/^0b[01]+$/i,Pa=/^0o[0-7]+$/i,Ea=parseInt;function Ra(r){if(typeof r=="number")return r;if(O(r))return ae;if(A(r)){var e=typeof r.valueOf=="function"?r.valueOf():r;r=A(e)?e+"":e}if(typeof r!="string")return r===0?r:+r;r=oe(r);var t=Ia.test(r);return t||Pa.test(r)?Ea(r.slice(2),t?2:8):ja.test(r)?ae:+r}var fe=Ra;var ne=1/0,Ma=17976931348623157e292;function La(r){if(!r)return r===0?r:0;if(r=fe(r),r===ne||r===-ne){var e=r<0?-1:1;return e*Ma}return r===r?r:0}var ie=La;function Na(r){var e=ie(r),t=e%1;return e===e?t?e-t:e:0}var se=Na;var Da=Math.ceil,Fa=Math.max;function Ba(r,e,t){(t?dr(r,e,t):e===void 0)?e=1:e=Fa(se(e),0);var o=r==null?0:r.length;if(!o||e<1)return[];for(var a=0,f=0,n=Array(Da(o/e));a<o;)n[f++]=br(r,a,a+=e);return n}var Ua=Ba;var qa=x["__core-js_shared__"],vr=qa;var ue=function(){var r=/[^.]+$/.exec(vr&&vr.keys&&vr.keys.IE_PROTO||"");return r?"Symbol(src)_1."+r:""}();function Wa(r){return!!ue&&ue in r}var pe=Wa;var Ga=Function.prototype,za=Ga.toString;function Ha(r){if(r!=null){try{return za.call(r)}catch (e3){}try{return r+""}catch (e4){}}return""}var S=Ha;var ka=/[\\^$.*+?()[\]{}|]/g,Ka=/^\[object .+?Constructor\]$/,Za=Function.prototype,$a=Object.prototype,Ja=Za.toString,Ya=$a.hasOwnProperty,Va=RegExp("^"+Ja.call(Ya).replace(ka,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function Xa(r){if(!A(r)||pe(r))return!1;var e=_r(r)?Va:Ka;return e.test(S(r))}var me=Xa;function Qa(r,e){return _optionalChain([r, 'optionalAccess', _2 => _2[e]])}var de=Qa;function rf(r,e){var t=de(r,e);return me(t)?t:void 0}var h=rf;var ef=h(Object,"create"),C=ef;function tf(){this.__data__=C?C(null):{},this.size=0}var le=tf;function of(r){var e=this.has(r)&&delete this.__data__[r];return this.size-=e?1:0,e}var ce=of;var af="__lodash_hash_undefined__",ff=Object.prototype,nf=ff.hasOwnProperty;function sf(r){var e=this.__data__;if(C){var t=e[r];return t===af?void 0:t}return nf.call(e,r)?e[r]:void 0}var xe=sf;var uf=Object.prototype,pf=uf.hasOwnProperty;function mf(r){var e=this.__data__;return C?e[r]!==void 0:pf.call(e,r)}var ge=mf;var df="__lodash_hash_undefined__";function lf(r,e){var t=this.__data__;return this.size+=this.has(r)?0:1,t[r]=C&&e===void 0?df:e,this}var he=lf;function Z(r){var e=-1,t=r==null?0:r.length;for(this.clear();++e<t;){var o=r[e];this.set(o[0],o[1])}}Z.prototype.clear=le;Z.prototype.delete=ce;Z.prototype.get=xe;Z.prototype.has=ge;Z.prototype.set=he;var qr=Z;function cf(){this.__data__=[],this.size=0}var be=cf;function xf(r,e){for(var t=r.length;t--;)if(H(r[t][0],e))return t;return-1}var I=xf;var gf=Array.prototype,hf=gf.splice;function bf(r){var e=this.__data__,t=I(e,r);if(t<0)return!1;var o=e.length-1;return t==o?e.pop():hf.call(e,t,1),--this.size,!0}var ye=bf;function yf(r){var e=this.__data__,t=I(e,r);return t<0?void 0:e[t][1]}var _e=yf;function _f(r){return I(this.__data__,r)>-1}var ve=_f;function vf(r,e){var t=this.__data__,o=I(t,r);return o<0?(++this.size,t.push([r,e])):t[o][1]=e,this}var Ae=vf;function $(r){var e=-1,t=r==null?0:r.length;for(this.clear();++e<t;){var o=r[e];this.set(o[0],o[1])}}$.prototype.clear=be;$.prototype.delete=ye;$.prototype.get=_e;$.prototype.has=ve;$.prototype.set=Ae;var P=$;var Af=h(x,"Map"),E=Af;function Of(){this.size=0,this.__data__={hash:new qr,map:new(E||P),string:new qr}}var Oe=Of;function wf(r){var e=typeof r;return e=="string"||e=="number"||e=="symbol"||e=="boolean"?r!=="__proto__":r===null}var we=wf;function Tf(r,e){var t=r.__data__;return we(e)?t[typeof e=="string"?"string":"hash"]:t.map}var R=Tf;function Sf(r){var e=R(this,r).delete(r);return this.size-=e?1:0,e}var Te=Sf;function Cf(r){return R(this,r).get(r)}var Se=Cf;function jf(r){return R(this,r).has(r)}var Ce=jf;function If(r,e){var t=R(this,r),o=t.size;return t.set(r,e),this.size+=t.size==o?0:1,this}var je=If;function J(r){var e=-1,t=r==null?0:r.length;for(this.clear();++e<t;){var o=r[e];this.set(o[0],o[1])}}J.prototype.clear=Oe;J.prototype.delete=Te;J.prototype.get=Se;J.prototype.has=Ce;J.prototype.set=je;var G=J;var Pf="__lodash_hash_undefined__";function Ef(r){return this.__data__.set(r,Pf),this}var Ie=Ef;function Rf(r){return this.__data__.has(r)}var Pe=Rf;function Ar(r){var e=-1,t=r==null?0:r.length;for(this.__data__=new G;++e<t;)this.add(r[e])}Ar.prototype.add=Ar.prototype.push=Ie;Ar.prototype.has=Pe;var Y=Ar;function Mf(r,e,t,o){for(var a=r.length,f=t+(o?1:-1);o?f--:++f<a;)if(e(r[f],f,r))return f;return-1}var Ee=Mf;function Lf(r){return r!==r}var Re=Lf;function Nf(r,e,t){for(var o=t-1,a=r.length;++o<a;)if(r[o]===e)return o;return-1}var Me=Nf;function Df(r,e,t){return e===e?Me(r,e,t):Ee(r,Re,t)}var Le=Df;function Ff(r,e){var t=r==null?0:r.length;return!!t&&Le(r,e,0)>-1}var Or=Ff;function Bf(r,e,t){for(var o=-1,a=r==null?0:r.length;++o<a;)if(t(e,r[o]))return!0;return!1}var wr=Bf;function Uf(r,e){for(var t=-1,o=r==null?0:r.length,a=Array(o);++t<o;)a[t]=e(r[t],t,r);return a}var M=Uf;function qf(r){return function(e){return r(e)}}var V=qf;function Wf(r,e){return r.has(e)}var X=Wf;var Gf=200;function zf(r,e,t,o){var a=-1,f=Or,n=!0,i=r.length,s=[],u=e.length;if(!i)return s;t&&(e=M(e,V(t))),o?(f=wr,n=!1):e.length>=Gf&&(f=X,n=!1,e=new Y(e));r:for(;++a<i;){var p=r[a],m=t==null?p:t(p);if(p=o||p!==0?p:0,n&&m===m){for(var d=u;d--;)if(e[d]===m)continue r;s.push(p)}else f(e,m,o)||s.push(p)}return s}var Ne=zf;function Hf(r,e){for(var t=-1,o=e.length,a=r.length;++t<o;)r[a+t]=e[t];return r}var Tr=Hf;var kf="[object Arguments]";function Kf(r){return b(r)&&v(r)==kf}var Wr=Kf;var De=Object.prototype,Zf=De.hasOwnProperty,$f=De.propertyIsEnumerable,Jf=Wr(function(){return arguments}())?Wr:function(r){return b(r)&&Zf.call(r,"callee")&&!$f.call(r,"callee")},Q=Jf;var Yf=Array.isArray,c=Yf;var Fe=g?g.isConcatSpreadable:void 0;function Vf(r){return c(r)||Q(r)||!!(Fe&&r&&r[Fe])}var Be=Vf;function Ue(r,e,t,o,a){var f=-1,n=r.length;for(t||(t=Be),a||(a=[]);++f<n;){var i=r[f];e>0&&t(i)?e>1?Ue(i,e-1,t,o,a):Tr(a,i):o||(a[a.length]=i)}return a}var L=Ue;function Xf(r){return r}var N=Xf;function Qf(r,e,t){switch(t.length){case 0:return r.call(e);case 1:return r.call(e,t[0]);case 2:return r.call(e,t[0],t[1]);case 3:return r.call(e,t[0],t[1],t[2])}return r.apply(e,t)}var qe=Qf;var We=Math.max;function rn(r,e,t){return e=We(e===void 0?r.length-1:e,0),function(){for(var o=arguments,a=-1,f=We(o.length-e,0),n=Array(f);++a<f;)n[a]=o[e+a];a=-1;for(var i=Array(e+1);++a<e;)i[a]=o[a];return i[e]=t(n),qe(r,this,i)}}var Ge=rn;function en(r){return function(){return r}}var ze=en;var tn=function(){try{var r=h(Object,"defineProperty");return r({},"",{}),r}catch (e5){}}(),rr=tn;var on=rr?function(r,e){return rr(r,"toString",{configurable:!0,enumerable:!1,value:ze(e),writable:!0})}:N,He=on;var an=800,fn=16,nn=Date.now;function sn(r){var e=0,t=0;return function(){var o=nn(),a=fn-(o-t);if(t=o,a>0){if(++e>=an)return arguments[0]}else e=0;return r.apply(void 0,arguments)}}var ke=sn;var un=ke(He),Ke=un;function pn(r,e){return Ke(Ge(r,e,N),r+"")}var er=pn;function mn(r){return b(r)&&w(r)}var lr=mn;var dn=er(function(r,e){return lr(r)?Ne(r,L(e,1,lr,!0)):[]}),ln= exports.c =dn;function cn(r,e,t){e=="__proto__"&&rr?rr(r,e,{configurable:!0,enumerable:!0,value:t,writable:!0}):r[e]=t}var tr=cn;function xn(r,e,t,o){for(var a=-1,f=r==null?0:r.length;++a<f;){var n=r[a];e(o,n,t(n),r)}return o}var Ze=xn;function gn(r){return function(e,t,o){for(var a=-1,f=Object(e),n=o(e),i=n.length;i--;){var s=n[r?i:++a];if(t(f[s],s,f)===!1)break}return e}}var $e=gn;var hn=$e(),Je=hn;function bn(r,e){for(var t=-1,o=Array(r);++t<r;)o[t]=e(t);return o}var Ye=bn;function yn(){return!1}var Ve=yn;var rt=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Xe=rt&&typeof module=="object"&&module&&!module.nodeType&&module,_n=Xe&&Xe.exports===rt,Qe=_n?x.Buffer:void 0,vn=Qe?Qe.isBuffer:void 0,An=vn||Ve,cr=An;var On="[object Arguments]",wn="[object Array]",Tn="[object Boolean]",Sn="[object Date]",Cn="[object Error]",jn="[object Function]",In="[object Map]",Pn="[object Number]",En="[object Object]",Rn="[object RegExp]",Mn="[object Set]",Ln="[object String]",Nn="[object WeakMap]",Dn="[object ArrayBuffer]",Fn="[object DataView]",Bn="[object Float32Array]",Un="[object Float64Array]",qn="[object Int8Array]",Wn="[object Int16Array]",Gn="[object Int32Array]",zn="[object Uint8Array]",Hn="[object Uint8ClampedArray]",kn="[object Uint16Array]",Kn="[object Uint32Array]",l={};l[Bn]=l[Un]=l[qn]=l[Wn]=l[Gn]=l[zn]=l[Hn]=l[kn]=l[Kn]=!0;l[On]=l[wn]=l[Dn]=l[Tn]=l[Fn]=l[Sn]=l[Cn]=l[jn]=l[In]=l[Pn]=l[En]=l[Rn]=l[Mn]=l[Ln]=l[Nn]=!1;function Zn(r){return b(r)&&k(r.length)&&!!l[v(r)]}var et=Zn;var tt=typeof exports=="object"&&exports&&!exports.nodeType&&exports,xr=tt&&typeof module=="object"&&module&&!module.nodeType&&module,$n=xr&&xr.exports===tt,Gr=$n&&yr.process,Jn=function(){try{var r=xr&&xr.require&&xr.require("util").types;return r||Gr&&Gr.binding&&Gr.binding("util")}catch (e6){}}(),zr=Jn;var ot=zr&&zr.isTypedArray,Yn=ot?V(ot):et,Sr=Yn;var Vn=Object.prototype,Xn=Vn.hasOwnProperty;function Qn(r,e){var t=c(r),o=!t&&Q(r),a=!t&&!o&&cr(r),f=!t&&!o&&!a&&Sr(r),n=t||o||a||f,i=n?Ye(r.length,String):[],s=i.length;for(var u in r)(e||Xn.call(r,u))&&!(n&&(u=="length"||a&&(u=="offset"||u=="parent")||f&&(u=="buffer"||u=="byteLength"||u=="byteOffset")||K(u,s)))&&i.push(u);return i}var at=Qn;var ri=Object.prototype;function ei(r){var e=r&&r.constructor,t=typeof e=="function"&&e.prototype||ri;return r===t}var ft=ei;function ti(r,e){return function(t){return r(e(t))}}var nt=ti;var oi=nt(Object.keys,Object),it=oi;var ai=Object.prototype,fi=ai.hasOwnProperty;function ni(r){if(!ft(r))return it(r);var e=[];for(var t in Object(r))fi.call(r,t)&&t!="constructor"&&e.push(t);return e}var st=ni;function ii(r){return w(r)?at(r):st(r)}var or=ii;function si(r,e){return r&&Je(r,e,or)}var Cr=si;function ui(r,e){return function(t,o){if(t==null)return t;if(!w(t))return r(t,o);for(var a=t.length,f=e?a:-1,n=Object(t);(e?f--:++f<a)&&o(n[f],f,n)!==!1;);return t}}var ut=ui;var pi=ut(Cr),jr=pi;function mi(r,e,t,o){return jr(r,function(a,f,n){e(o,a,t(a),n)}),o}var pt=mi;function di(){this.__data__=new P,this.size=0}var mt=di;function li(r){var e=this.__data__,t=e.delete(r);return this.size=e.size,t}var dt=li;function ci(r){return this.__data__.get(r)}var lt=ci;function xi(r){return this.__data__.has(r)}var ct=xi;var gi=200;function hi(r,e){var t=this.__data__;if(t instanceof P){var o=t.__data__;if(!E||o.length<gi-1)return o.push([r,e]),this.size=++t.size,this;t=this.__data__=new G(o)}return t.set(r,e),this.size=t.size,this}var xt=hi;function ar(r){var e=this.__data__=new P(r);this.size=e.size}ar.prototype.clear=mt;ar.prototype.delete=dt;ar.prototype.get=lt;ar.prototype.has=ct;ar.prototype.set=xt;var fr=ar;function bi(r,e){for(var t=-1,o=r==null?0:r.length;++t<o;)if(e(r[t],t,r))return!0;return!1}var gt=bi;var yi=1,_i=2;function vi(r,e,t,o,a,f){var n=t&yi,i=r.length,s=e.length;if(i!=s&&!(n&&s>i))return!1;var u=f.get(r),p=f.get(e);if(u&&p)return u==e&&p==r;var m=-1,d=!0,T=t&_i?new Y:void 0;for(f.set(r,e),f.set(e,r);++m<i;){var y=r[m],_=e[m];if(o)var j=n?o(_,y,m,e,r,f):o(y,_,m,r,e,f);if(j!==void 0){if(j)continue;d=!1;break}if(T){if(!gt(e,function(q,W){if(!X(T,W)&&(y===q||a(y,q,t,o,f)))return T.push(W)})){d=!1;break}}else if(!(y===_||a(y,_,t,o,f))){d=!1;break}}return f.delete(r),f.delete(e),d}var Ir=vi;var Ai=x.Uint8Array,Hr=Ai;function Oi(r){var e=-1,t=Array(r.size);return r.forEach(function(o,a){t[++e]=[a,o]}),t}var ht=Oi;function wi(r){var e=-1,t=Array(r.size);return r.forEach(function(o){t[++e]=o}),t}var nr=wi;var Ti=1,Si=2,Ci="[object Boolean]",ji="[object Date]",Ii="[object Error]",Pi="[object Map]",Ei="[object Number]",Ri="[object RegExp]",Mi="[object Set]",Li="[object String]",Ni="[object Symbol]",Di="[object ArrayBuffer]",Fi="[object DataView]",bt=g?g.prototype:void 0,kr=bt?bt.valueOf:void 0;function Bi(r,e,t,o,a,f,n){switch(t){case Fi:if(r.byteLength!=e.byteLength||r.byteOffset!=e.byteOffset)return!1;r=r.buffer,e=e.buffer;case Di:return!(r.byteLength!=e.byteLength||!f(new Hr(r),new Hr(e)));case Ci:case ji:case Ei:return H(+r,+e);case Ii:return r.name==e.name&&r.message==e.message;case Ri:case Li:return r==e+"";case Pi:var i=ht;case Mi:var s=o&Ti;if(i||(i=nr),r.size!=e.size&&!s)return!1;var u=n.get(r);if(u)return u==e;o|=Si,n.set(r,e);var p=Ir(i(r),i(e),o,a,f,n);return n.delete(r),p;case Ni:if(kr)return kr.call(r)==kr.call(e)}return!1}var yt=Bi;function Ui(r,e,t){var o=e(r);return c(r)?o:Tr(o,t(r))}var _t=Ui;function qi(r,e){for(var t=-1,o=r==null?0:r.length,a=0,f=[];++t<o;){var n=r[t];e(n,t,r)&&(f[a++]=n)}return f}var vt=qi;function Wi(){return[]}var At=Wi;var Gi=Object.prototype,zi=Gi.propertyIsEnumerable,Ot=Object.getOwnPropertySymbols,Hi=Ot?function(r){return r==null?[]:(r=Object(r),vt(Ot(r),function(e){return zi.call(r,e)}))}:At,wt=Hi;function ki(r){return _t(r,or,wt)}var Kr=ki;var Ki=1,Zi=Object.prototype,$i=Zi.hasOwnProperty;function Ji(r,e,t,o,a,f){var n=t&Ki,i=Kr(r),s=i.length,u=Kr(e),p=u.length;if(s!=p&&!n)return!1;for(var m=s;m--;){var d=i[m];if(!(n?d in e:$i.call(e,d)))return!1}var T=f.get(r),y=f.get(e);if(T&&y)return T==e&&y==r;var _=!0;f.set(r,e),f.set(e,r);for(var j=n;++m<s;){d=i[m];var q=r[d],W=e[d];if(o)var Vr=n?o(W,q,d,e,r,f):o(q,W,d,r,e,f);if(!(Vr===void 0?q===W||a(q,W,t,o,f):Vr)){_=!1;break}j||(j=d=="constructor")}if(_&&!j){var gr=r.constructor,hr=e.constructor;gr!=hr&&"constructor"in r&&"constructor"in e&&!(typeof gr=="function"&&gr instanceof gr&&typeof hr=="function"&&hr instanceof hr)&&(_=!1)}return f.delete(r),f.delete(e),_}var Tt=Ji;var Yi=h(x,"DataView"),Pr=Yi;var Vi=h(x,"Promise"),Er=Vi;var Xi=h(x,"Set"),D=Xi;var Qi=h(x,"WeakMap"),Rr=Qi;var St="[object Map]",rs="[object Object]",Ct="[object Promise]",jt="[object Set]",It="[object WeakMap]",Pt="[object DataView]",es=S(Pr),ts=S(E),os=S(Er),as=S(D),fs=S(Rr),z=v;(Pr&&z(new Pr(new ArrayBuffer(1)))!=Pt||E&&z(new E)!=St||Er&&z(Er.resolve())!=Ct||D&&z(new D)!=jt||Rr&&z(new Rr)!=It)&&(z=function(r){var e=v(r),t=e==rs?r.constructor:void 0,o=t?S(t):"";if(o)switch(o){case es:return Pt;case ts:return St;case os:return Ct;case as:return jt;case fs:return It}return e});var Zr=z;var ns=1,Et="[object Arguments]",Rt="[object Array]",Mr="[object Object]",is=Object.prototype,Mt=is.hasOwnProperty;function ss(r,e,t,o,a,f){var n=c(r),i=c(e),s=n?Rt:Zr(r),u=i?Rt:Zr(e);s=s==Et?Mr:s,u=u==Et?Mr:u;var p=s==Mr,m=u==Mr,d=s==u;if(d&&cr(r)){if(!cr(e))return!1;n=!0,p=!1}if(d&&!p)return f||(f=new fr),n||Sr(r)?Ir(r,e,t,o,a,f):yt(r,e,s,t,o,a,f);if(!(t&ns)){var T=p&&Mt.call(r,"__wrapped__"),y=m&&Mt.call(e,"__wrapped__");if(T||y){var _=T?r.value():r,j=y?e.value():e;return f||(f=new fr),a(_,j,t,o,f)}}return d?(f||(f=new fr),Tt(r,e,t,o,a,f)):!1}var Lt=ss;function Nt(r,e,t,o,a){return r===e?!0:r==null||e==null||!b(r)&&!b(e)?r!==r&&e!==e:Lt(r,e,t,o,Nt,a)}var Lr=Nt;var us=1,ps=2;function ms(r,e,t,o){var a=t.length,f=a,n=!o;if(r==null)return!f;for(r=Object(r);a--;){var i=t[a];if(n&&i[2]?i[1]!==r[i[0]]:!(i[0]in r))return!1}for(;++a<f;){i=t[a];var s=i[0],u=r[s],p=i[1];if(n&&i[2]){if(u===void 0&&!(s in r))return!1}else{var m=new fr;if(o)var d=o(u,p,s,r,e,m);if(!(d===void 0?Lr(p,u,us|ps,o,m):d))return!1}}return!0}var Dt=ms;function ds(r){return r===r&&!A(r)}var Nr=ds;function ls(r){for(var e=or(r),t=e.length;t--;){var o=e[t],a=r[o];e[t]=[o,a,Nr(a)]}return e}var Ft=ls;function cs(r,e){return function(t){return t==null?!1:t[r]===e&&(e!==void 0||r in Object(t))}}var Dr=cs;function xs(r){var e=Ft(r);return e.length==1&&e[0][2]?Dr(e[0][0],e[0][1]):function(t){return t===r||Dt(t,r,e)}}var Bt=xs;var gs=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,hs=/^\w*$/;function bs(r,e){if(c(r))return!1;var t=typeof r;return t=="number"||t=="symbol"||t=="boolean"||r==null||O(r)?!0:hs.test(r)||!gs.test(r)||e!=null&&r in Object(e)}var ir=bs;var ys="Expected a function";function $r(r,e){if(typeof r!="function"||e!=null&&typeof e!="function")throw new TypeError(ys);var t=function(){var o=arguments,a=e?e.apply(this,o):o[0],f=t.cache;if(f.has(a))return f.get(a);var n=r.apply(this,o);return t.cache=f.set(a,n)||f,n};return t.cache=new($r.Cache||G),t}$r.Cache=G;var Ut=$r;var _s=500;function vs(r){var e=Ut(r,function(o){return t.size===_s&&t.clear(),o}),t=e.cache;return e}var qt=vs;var As=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,Os=/\\(\\)?/g,ws=qt(function(r){var e=[];return r.charCodeAt(0)===46&&e.push(""),r.replace(As,function(t,o,a,f){e.push(a?f.replace(Os,"$1"):o||t)}),e}),Wt=ws;var Ts=1/0,Gt=g?g.prototype:void 0,zt=Gt?Gt.toString:void 0;function Ht(r){if(typeof r=="string")return r;if(c(r))return M(r,Ht)+"";if(O(r))return zt?zt.call(r):"";var e=r+"";return e=="0"&&1/r==-Ts?"-0":e}var kt=Ht;function Ss(r){return r==null?"":kt(r)}var F=Ss;function Cs(r,e){return c(r)?r:ir(r,e)?[r]:Wt(F(r))}var Fr=Cs;var js=1/0;function Is(r){if(typeof r=="string"||O(r))return r;var e=r+"";return e=="0"&&1/r==-js?"-0":e}var B=Is;function Ps(r,e){e=Fr(e,r);for(var t=0,o=e.length;r!=null&&t<o;)r=r[B(e[t++])];return t&&t==o?r:void 0}var sr=Ps;function Es(r,e,t){var o=r==null?void 0:sr(r,e);return o===void 0?t:o}var Kt=Es;function Rs(r,e){return r!=null&&e in Object(r)}var Zt=Rs;function Ms(r,e,t){e=Fr(e,r);for(var o=-1,a=e.length,f=!1;++o<a;){var n=B(e[o]);if(!(f=r!=null&&t(r,n)))break;r=r[n]}return f||++o!=a?f:(a=r==null?0:r.length,!!a&&k(a)&&K(n,a)&&(c(r)||Q(r)))}var $t=Ms;function Ls(r,e){return r!=null&&$t(r,e,Zt)}var Jt=Ls;var Ns=1,Ds=2;function Fs(r,e){return ir(r)&&Nr(e)?Dr(B(r),e):function(t){var o=Kt(t,r);return o===void 0&&o===e?Jt(t,r):Lr(e,o,Ns|Ds)}}var Yt=Fs;function Bs(r){return function(e){return _optionalChain([e, 'optionalAccess', _3 => _3[r]])}}var Vt=Bs;function Us(r){return function(e){return sr(e,r)}}var Xt=Us;function qs(r){return ir(r)?Vt(B(r)):Xt(r)}var Qt=qs;function Ws(r){return typeof r=="function"?r:r==null?N:typeof r=="object"?c(r)?Yt(r[0],r[1]):Bt(r):Qt(r)}var U=Ws;function Gs(r,e){return function(t,o){var a=c(t)?Ze:pt,f=e?e():{};return a(t,r,U(o,2),f)}}var Br=Gs;var zs=Object.prototype,Hs=zs.hasOwnProperty,ks=Br(function(r,e,t){Hs.call(r,t)?r[t].push(e):tr(r,t,[e])}),Ks= exports.d =ks;function Zs(){}var ro=Zs;var $s=1/0,Js=D&&1/nr(new D([,-0]))[1]==$s?function(r){return new D(r)}:ro,eo=Js;var Ys=200;function Vs(r,e,t){var o=-1,a=Or,f=r.length,n=!0,i=[],s=i;if(t)n=!1,a=wr;else if(f>=Ys){var u=e?null:eo(r);if(u)return nr(u);n=!1,a=X,s=new Y}else s=e?[]:i;r:for(;++o<f;){var p=r[o],m=e?e(p):p;if(p=t||p!==0?p:0,n&&m===m){for(var d=s.length;d--;)if(s[d]===m)continue r;e&&s.push(m),i.push(p)}else a(s,m,t)||(s!==i&&s.push(m),i.push(p))}return i}var ur=Vs;function Xs(r){return r&&r.length?ur(r):[]}var Qs=Xs;function ru(r){var e=r==null?0:r.length;return e?L(r,1):[]}var eu=ru;function tu(r,e,t){var o=r.length;return t=t===void 0?o:t,!e&&t>=o?r:br(r,e,t)}var to=tu;var ou="\\ud800-\\udfff",au="\\u0300-\\u036f",fu="\\ufe20-\\ufe2f",nu="\\u20d0-\\u20ff",iu=au+fu+nu,su="\\ufe0e\\ufe0f",uu="\\u200d",pu=RegExp("["+uu+ou+iu+su+"]");function mu(r){return pu.test(r)}var Ur=mu;function du(r){return r.split("")}var oo=du;var ao="\\ud800-\\udfff",lu="\\u0300-\\u036f",cu="\\ufe20-\\ufe2f",xu="\\u20d0-\\u20ff",gu=lu+cu+xu,hu="\\ufe0e\\ufe0f",bu="["+ao+"]",Jr="["+gu+"]",Yr="\\ud83c[\\udffb-\\udfff]",yu="(?:"+Jr+"|"+Yr+")",fo="[^"+ao+"]",no="(?:\\ud83c[\\udde6-\\uddff]){2}",io="[\\ud800-\\udbff][\\udc00-\\udfff]",_u="\\u200d",so=yu+"?",uo="["+hu+"]?",vu="(?:"+_u+"(?:"+[fo,no,io].join("|")+")"+uo+so+")*",Au=uo+so+vu,Ou="(?:"+[fo+Jr+"?",Jr,no,io,bu].join("|")+")",wu=RegExp(Yr+"(?="+Yr+")|"+Ou+Au,"g");function Tu(r){return r.match(wu)||[]}var po=Tu;function Su(r){return Ur(r)?po(r):oo(r)}var mo=Su;function Cu(r){return function(e){e=F(e);var t=Ur(e)?mo(e):void 0,o=t?t[0]:e.charAt(0),a=t?to(t,1).join(""):e.slice(1);return o[r]()+a}}var lo=Cu;var ju=lo("toUpperCase"),co=ju;function Iu(r,e,t,o){var a=-1,f=r==null?0:r.length;for(o&&f&&(t=r[++a]);++a<f;)t=e(t,r[a],a,r);return t}var xo=Iu;function Pu(r){return function(e){return _optionalChain([r, 'optionalAccess', _4 => _4[e]])}}var go=Pu;var Eu={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},Ru=go(Eu),ho=Ru;var Mu=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,Lu="\\u0300-\\u036f",Nu="\\ufe20-\\ufe2f",Du="\\u20d0-\\u20ff",Fu=Lu+Nu+Du,Bu="["+Fu+"]",Uu=RegExp(Bu,"g");function qu(r){return r=F(r),r&&r.replace(Mu,ho).replace(Uu,"")}var bo=qu;var Wu=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;function Gu(r){return r.match(Wu)||[]}var yo=Gu;var zu=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;function Hu(r){return zu.test(r)}var _o=Hu;var To="\\ud800-\\udfff",ku="\\u0300-\\u036f",Ku="\\ufe20-\\ufe2f",Zu="\\u20d0-\\u20ff",$u=ku+Ku+Zu,So="\\u2700-\\u27bf",Co="a-z\\xdf-\\xf6\\xf8-\\xff",Ju="\\xac\\xb1\\xd7\\xf7",Yu="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",Vu="\\u2000-\\u206f",Xu=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",jo="A-Z\\xc0-\\xd6\\xd8-\\xde",Qu="\\ufe0e\\ufe0f",Io=Ju+Yu+Vu+Xu,Po="['\u2019]",vo="["+Io+"]",rp="["+$u+"]",Eo="\\d+",ep="["+So+"]",Ro="["+Co+"]",Mo="[^"+To+Io+Eo+So+Co+jo+"]",tp="\\ud83c[\\udffb-\\udfff]",op="(?:"+rp+"|"+tp+")",ap="[^"+To+"]",Lo="(?:\\ud83c[\\udde6-\\uddff]){2}",No="[\\ud800-\\udbff][\\udc00-\\udfff]",pr="["+jo+"]",fp="\\u200d",Ao="(?:"+Ro+"|"+Mo+")",np="(?:"+pr+"|"+Mo+")",Oo="(?:"+Po+"(?:d|ll|m|re|s|t|ve))?",wo="(?:"+Po+"(?:D|LL|M|RE|S|T|VE))?",Do=op+"?",Fo="["+Qu+"]?",ip="(?:"+fp+"(?:"+[ap,Lo,No].join("|")+")"+Fo+Do+")*",sp="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",up="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",pp=Fo+Do+ip,mp="(?:"+[ep,Lo,No].join("|")+")"+pp,dp=RegExp([pr+"?"+Ro+"+"+Oo+"(?="+[vo,pr,"$"].join("|")+")",np+"+"+wo+"(?="+[vo,pr+Ao,"$"].join("|")+")",pr+"?"+Ao+"+"+Oo,pr+"+"+wo,up,sp,Eo,mp].join("|"),"g");function lp(r){return r.match(dp)||[]}var Bo=lp;function cp(r,e,t){return r=F(r),e=t?void 0:e,e===void 0?_o(r)?Bo(r):yo(r):r.match(e)||[]}var Uo=cp;var xp="['\u2019]",gp=RegExp(xp,"g");function hp(r){return function(e){return xo(Uo(bo(e).replace(gp,"")),r,"")}}var qo=hp;function bp(r,e){var t=-1,o=w(r)?Array(r.length):[];return jr(r,function(a,f,n){o[++t]=e(a,f,n)}),o}var Wo=bp;var yp=Br(function(r,e,t){tr(r,t,e)}),_p= exports.e =yp;function vp(r,e){var t={};return e=U(e,3),Cr(r,function(o,a,f){tr(t,a,e(o,a,f))}),t}var Ap=vp;function Op(r,e){var t=r.length;for(r.sort(e);t--;)r[t]=r[t].value;return r}var Go=Op;function wp(r,e){if(r!==e){var t=r!==void 0,o=r===null,a=r===r,f=O(r),n=e!==void 0,i=e===null,s=e===e,u=O(e);if(!i&&!u&&!f&&r>e||f&&n&&s&&!i&&!u||o&&n&&s||!t&&s||!a)return 1;if(!o&&!f&&!u&&r<e||u&&t&&a&&!o&&!f||i&&t&&a||!n&&a||!s)return-1}return 0}var zo=wp;function Tp(r,e,t){for(var o=-1,a=r.criteria,f=e.criteria,n=a.length,i=t.length;++o<n;){var s=zo(a[o],f[o]);if(s){if(o>=i)return s;var u=t[o];return s*(u=="desc"?-1:1)}}return r.index-e.index}var Ho=Tp;function Sp(r,e,t){e.length?e=M(e,function(f){return c(f)?function(n){return sr(n,f.length===1?f[0]:f)}:f}):e=[N];var o=-1;e=M(e,V(U));var a=Wo(r,function(f,n,i){var s=M(e,function(u){return u(f)});return{criteria:s,index:++o,value:f}});return Go(a,function(f,n){return Ho(f,n,t)})}var ko=Sp;var Cp=er(function(r,e){if(r==null)return[];var t=e.length;return t>1&&dr(r,e[0],e[1])?e=[]:t>2&&dr(e[0],e[1],e[2])&&(e=[e[0]]),ko(r,L(e,1),[])}),jp= exports.g =Cp;var Ip=qo(function(r,e,t){return r+(t?" ":"")+co(e)}),Pp= exports.h =Ip;var Ep=er(function(r){return ur(L(r,1,lr,!0))}),Rp= exports.i =Ep;function Mp(r,e){return r&&r.length?ur(r,U(e,2)):[]}var Lp=Mp;var Yb="A command line interface for programmatic operations across Transcend.",Vb= exports.m ="8.0.2";exports.a = eu; exports.b = Ua; exports.c = ln; exports.d = Ks; exports.e = _p; exports.f = Ap; exports.g = jp; exports.h = Pp; exports.i = Rp; exports.j = Qs; exports.k = Lp; exports.l = Yb; exports.m = Vb;
2
- /*! Bundled license information:
3
-
4
- lodash-es/lodash.js:
5
- (**
6
- * @license
7
- * Lodash (Custom Build) <https://lodash.com/>
8
- * Build: `lodash modularize exports="es" -o ./`
9
- * Copyright OpenJS Foundation and other contributors <https://openjsf.org/>
10
- * Released under MIT license <https://lodash.com/license>
11
- * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
12
- * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
13
- *)
14
- */
15
- //# sourceMappingURL=chunk-44J2TVZU.cjs.map