@botpress/cli 0.0.14 → 0.0.17
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.
- package/dist/api-client.js +1 -0
- package/dist/api-client.js.map +7 -0
- package/dist/code-generation/action.js +1 -0
- package/dist/code-generation/action.js.map +7 -0
- package/dist/code-generation/channel.js +1 -0
- package/dist/code-generation/channel.js.map +7 -0
- package/dist/code-generation/configuration.js +1 -0
- package/dist/code-generation/configuration.js.map +7 -0
- package/dist/code-generation/const.js +1 -0
- package/dist/code-generation/const.js.map +7 -0
- package/dist/code-generation/event.js +1 -0
- package/dist/code-generation/event.js.map +7 -0
- package/dist/code-generation/index.js +1 -0
- package/dist/code-generation/index.js.map +7 -0
- package/dist/code-generation/integration-impl.js +1 -0
- package/dist/code-generation/integration-impl.js.map +7 -0
- package/dist/code-generation/integration-instance.js +1 -0
- package/dist/code-generation/integration-instance.js.map +7 -0
- package/dist/code-generation/integration-secret.js +1 -0
- package/dist/code-generation/integration-secret.js.map +7 -0
- package/dist/code-generation/message.js +1 -0
- package/dist/code-generation/message.js.map +7 -0
- package/dist/code-generation/module.js +1 -0
- package/dist/code-generation/module.js.map +7 -0
- package/dist/code-generation/typings.js +1 -0
- package/dist/code-generation/typings.js.map +7 -0
- package/dist/command-definitions.js +1 -0
- package/dist/command-definitions.js.map +7 -0
- package/dist/command-implementations/add-command.js +1 -0
- package/dist/command-implementations/add-command.js.map +7 -0
- package/dist/command-implementations/base-command.js +8 -1
- package/dist/command-implementations/base-command.js.map +7 -0
- package/dist/command-implementations/bot-commands.js +1 -0
- package/dist/command-implementations/bot-commands.js.map +7 -0
- package/dist/command-implementations/build-command.js +1 -0
- package/dist/command-implementations/build-command.js.map +7 -0
- package/dist/command-implementations/bundle-command.js +1 -0
- package/dist/command-implementations/bundle-command.js.map +7 -0
- package/dist/command-implementations/deploy-command.js +21 -3
- package/dist/command-implementations/deploy-command.js.map +7 -0
- package/dist/command-implementations/dev-command.js +1 -0
- package/dist/command-implementations/dev-command.js.map +7 -0
- package/dist/command-implementations/gen-command.js +1 -0
- package/dist/command-implementations/gen-command.js.map +7 -0
- package/dist/command-implementations/global-command.js +1 -0
- package/dist/command-implementations/global-command.js.map +7 -0
- package/dist/command-implementations/index.js +1 -0
- package/dist/command-implementations/index.js.map +7 -0
- package/dist/command-implementations/init-command.js +1 -0
- package/dist/command-implementations/init-command.js.map +7 -0
- package/dist/command-implementations/integration-commands.js +1 -0
- package/dist/command-implementations/integration-commands.js.map +7 -0
- package/dist/command-implementations/login-command.js +1 -0
- package/dist/command-implementations/login-command.js.map +7 -0
- package/dist/command-implementations/logout-command.js +1 -0
- package/dist/command-implementations/logout-command.js.map +7 -0
- package/dist/command-implementations/project-command.js +1 -0
- package/dist/command-implementations/project-command.js.map +7 -0
- package/dist/command-implementations/serve-command.js +1 -0
- package/dist/command-implementations/serve-command.js.map +7 -0
- package/dist/command-tree.js +1 -0
- package/dist/command-tree.js.map +7 -0
- package/dist/config.js +1 -0
- package/dist/config.js.map +7 -0
- package/dist/consts.js +1 -0
- package/dist/consts.js.map +7 -0
- package/dist/errors.js +27 -1
- package/dist/errors.js.map +7 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +7 -0
- package/dist/init.js +1 -0
- package/dist/init.js.map +7 -0
- package/dist/integration-ref.js +1 -0
- package/dist/integration-ref.js.map +7 -0
- package/dist/logger/base-logger.js +1 -0
- package/dist/logger/base-logger.js.map +7 -0
- package/dist/logger/index.js +1 -0
- package/dist/logger/index.js.map +7 -0
- package/dist/register-yargs.js +1 -0
- package/dist/register-yargs.js.map +7 -0
- package/dist/typings.js +1 -0
- package/dist/typings.js.map +7 -0
- package/dist/utils/cache-utils.js +1 -0
- package/dist/utils/cache-utils.js.map +7 -0
- package/dist/utils/case-utils.js +1 -0
- package/dist/utils/case-utils.js.map +7 -0
- package/dist/utils/esbuild-utils.js +1 -0
- package/dist/utils/esbuild-utils.js.map +7 -0
- package/dist/utils/event-emitter.js +1 -0
- package/dist/utils/event-emitter.js.map +7 -0
- package/dist/utils/file-watcher.js +1 -0
- package/dist/utils/file-watcher.js.map +7 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +7 -0
- package/dist/utils/path-utils.js +1 -0
- package/dist/utils/path-utils.js.map +7 -0
- package/dist/utils/prompt-utils.js +1 -0
- package/dist/utils/prompt-utils.js.map +7 -0
- package/dist/utils/require-utils.js +1 -0
- package/dist/utils/require-utils.js.map +7 -0
- package/dist/worker/child-entrypoint.js +1 -0
- package/dist/worker/child-entrypoint.js.map +7 -0
- package/dist/worker/child-wrapper.js +1 -0
- package/dist/worker/child-wrapper.js.map +7 -0
- package/dist/worker/config.js +1 -0
- package/dist/worker/config.js.map +7 -0
- package/dist/worker/index.js +1 -0
- package/dist/worker/index.js.map +7 -0
- package/dist/worker/is-child.js +1 -0
- package/dist/worker/is-child.js.map +7 -0
- package/dist/worker/worker-state.js +1 -0
- package/dist/worker/worker-state.js.map +7 -0
- package/dist/worker/worker.js +1 -0
- package/dist/worker/worker.js.map +7 -0
- package/package.json +13 -13
- package/templates/echo-bot/package.json +1 -2
- package/templates/empty-integration/integration.definition.ts +2 -2
- package/templates/empty-integration/package.json +1 -2
- package/build.ts +0 -12
- package/dist/app/api-utils.js +0 -112
- package/dist/app/base.js +0 -71
- package/dist/app/cache.js +0 -95
- package/dist/app/errors.js +0 -156
- package/dist/app/file-paths.js +0 -79
- package/dist/app/generator/action.js +0 -76
- package/dist/app/generator/channel.js +0 -51
- package/dist/app/generator/configuration.js +0 -40
- package/dist/app/generator/const.js +0 -31
- package/dist/app/generator/event.js +0 -47
- package/dist/app/generator/index.js +0 -83
- package/dist/app/generator/integration-impl.js +0 -147
- package/dist/app/generator/integration-instance.js +0 -85
- package/dist/app/generator/message.js +0 -47
- package/dist/app/generator/module.js +0 -115
- package/dist/app/generator/strings.js +0 -38
- package/dist/app/generator/typings.js +0 -16
- package/dist/app/index.js +0 -82
- package/dist/app/integration-ref.js +0 -61
- package/dist/app/project.js +0 -486
- package/dist/app/typings.js +0 -16
- package/dist/app/user.js +0 -237
- package/dist/esbuild-utils.js +0 -89
- package/dist/event-emitter.js +0 -62
- package/dist/path-utils.js +0 -72
- package/dist/require-utils.js +0 -49
- package/dist/update-notif.js +0 -47
- package/dist/utils/string-utils.js +0 -68
- package/dist/watcher.js +0 -68
- package/templates/echo-bot/.botpress/project.cache.json +0 -1
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/utils/path-utils.ts"],
|
|
4
|
+
"sourcesContent": ["import _ from 'lodash'\nimport pathlib from 'path'\n\nexport type AbsolutePath = `/${string}` | `C:\\\\${string}`\n\nexport const cwd = (): AbsolutePath => process.cwd() as AbsolutePath\nexport const isAbsolute = (path: string): path is AbsolutePath => pathlib.isAbsolute(path)\nexport const isPath = (path: string) => isAbsolute(path) || path.startsWith('.')\nexport const join = (abs: AbsolutePath, ...paths: string[]): AbsolutePath => {\n const joined = pathlib.join(abs, ...paths)\n return pathlib.normalize(joined) as AbsolutePath\n}\n\nexport const rmExtension = (filename: string) => filename.replace(/\\.[^/.]+$/, '')\n\nexport const toUnix = (path: string) => path.split(pathlib.sep).join(pathlib.posix.sep)\n\nexport const absoluteFrom = (rootdir: AbsolutePath, target: string): AbsolutePath => {\n if (isAbsolute(target)) {\n return target\n }\n return pathlib.join(rootdir, target) as AbsolutePath\n}\n\nexport const relativeFrom = (rootdir: AbsolutePath, target: string) => {\n let absPath: string\n\n if (isAbsolute(target)) {\n absPath = target\n } else {\n absPath = pathlib.resolve(pathlib.join(rootdir, target))\n }\n\n return pathlib.relative(rootdir, absPath)\n}\n\nexport class PathStore<P extends string> {\n public constructor(public readonly abs: Record<P, AbsolutePath>) {}\n public rel(from: Extract<P, `${string}Dir`>) {\n return _.mapValues(this.abs, (to) => relativeFrom(this.abs[from], to))\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAc;AACd,kBAAoB;AAIb,MAAM,MAAM,MAAoB,QAAQ,IAAI;AAC5C,MAAM,aAAa,CAAC,SAAuC,YAAAA,QAAQ,WAAW,IAAI;AAClF,MAAM,SAAS,CAAC,SAAiB,WAAW,IAAI,KAAK,KAAK,WAAW,GAAG;AACxE,MAAM,OAAO,CAAC,QAAsB,UAAkC;AAC3E,QAAM,SAAS,YAAAA,QAAQ,KAAK,KAAK,GAAG,KAAK;AACzC,SAAO,YAAAA,QAAQ,UAAU,MAAM;AACjC;AAEO,MAAM,cAAc,CAAC,aAAqB,SAAS,QAAQ,aAAa,EAAE;AAE1E,MAAM,SAAS,CAAC,SAAiB,KAAK,MAAM,YAAAA,QAAQ,GAAG,EAAE,KAAK,YAAAA,QAAQ,MAAM,GAAG;AAE/E,MAAM,eAAe,CAAC,SAAuB,WAAiC;AACnF,MAAI,WAAW,MAAM,GAAG;AACtB,WAAO;AAAA,EACT;AACA,SAAO,YAAAA,QAAQ,KAAK,SAAS,MAAM;AACrC;AAEO,MAAM,eAAe,CAAC,SAAuB,WAAmB;AACrE,MAAI;AAEJ,MAAI,WAAW,MAAM,GAAG;AACtB,cAAU;AAAA,EACZ,OAAO;AACL,cAAU,YAAAA,QAAQ,QAAQ,YAAAA,QAAQ,KAAK,SAAS,MAAM,CAAC;AAAA,EACzD;AAEA,SAAO,YAAAA,QAAQ,SAAS,SAAS,OAAO;AAC1C;AAEO,MAAM,UAA4B;AAAA,EAChC,YAA4B,KAA8B;AAA9B;AAAA,EAA+B;AAAA,EAC3D,IAAI,MAAkC;AAC3C,WAAO,cAAAC,QAAE,UAAU,KAAK,KAAK,CAAC,OAAO,aAAa,KAAK,IAAI,OAAO,EAAE,CAAC;AAAA,EACvE;AACF;",
|
|
6
|
+
"names": ["pathlib", "_"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/utils/prompt-utils.ts"],
|
|
4
|
+
"sourcesContent": ["import prompts from 'prompts'\nimport type { Logger } from '../logger'\n\nexport type CLIPromptsProps = {\n confirm: boolean\n}\n\nexport type CLIPromptsChoice<V extends string> = {\n title: string\n value: V\n}\n\nexport class CLIPrompt {\n constructor(private _props: CLIPromptsProps, private _logger: Logger) {}\n\n public async confirm(message: string): Promise<boolean> {\n if (this._props.confirm) {\n this._logger.debug(`Confirming automatically: ${message}`)\n return true\n }\n\n const { confirm } = await this._prompts({\n type: 'confirm',\n name: 'confirm',\n message,\n initial: false,\n })\n\n if (!confirm) {\n return false\n }\n return true\n }\n\n public async password(message: string, opts?: { initial?: string }): Promise<string | undefined> {\n const { prompted } = await this._prompts({\n type: 'password',\n name: 'prompted',\n message,\n initial: opts?.initial,\n })\n\n return prompted ? prompted : undefined\n }\n\n public async select<V extends string>(\n message: string,\n opts?: { initial?: CLIPromptsChoice<V>; choices: CLIPromptsChoice<V>[] }\n ): Promise<V | undefined> {\n const { prompted } = await this._prompts({\n type: 'autocomplete',\n name: 'prompted',\n message,\n initial: opts?.initial?.value,\n choices: opts?.choices,\n })\n return prompted ? prompted : undefined\n }\n\n public async text(message: string, opts?: { initial?: string }): Promise<string | undefined> {\n const { prompted } = await this._prompts({\n type: 'text',\n name: 'prompted',\n message,\n initial: opts?.initial,\n })\n\n return prompted ? prompted : undefined\n }\n\n private _prompts = (...args: Parameters<typeof prompts>): ReturnType<typeof prompts> => {\n this._logger.cleanup()\n return prompts(...args)\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAAoB;AAYb,MAAM,UAAU;AAAA,EACrB,YAAoB,QAAiC,SAAiB;AAAlD;AAAiC;AAAA,EAAkB;AAAA,EAEvE,MAAa,QAAQ,SAAmC;AACtD,QAAI,KAAK,OAAO,SAAS;AACvB,WAAK,QAAQ,MAAM,6BAA6B,SAAS;AACzD,aAAO;AAAA,IACT;AAEA,UAAM,EAAE,QAAQ,IAAI,MAAM,KAAK,SAAS;AAAA,MACtC,MAAM;AAAA,MACN,MAAM;AAAA,MACN;AAAA,MACA,SAAS;AAAA,IACX,CAAC;AAED,QAAI,CAAC,SAAS;AACZ,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT;AAAA,EAEA,MAAa,SAAS,SAAiB,MAA0D;AAC/F,UAAM,EAAE,SAAS,IAAI,MAAM,KAAK,SAAS;AAAA,MACvC,MAAM;AAAA,MACN,MAAM;AAAA,MACN;AAAA,MACA,SAAS,MAAM;AAAA,IACjB,CAAC;AAED,WAAO,WAAW,WAAW;AAAA,EAC/B;AAAA,EAEA,MAAa,OACX,SACA,MACwB;AACxB,UAAM,EAAE,SAAS,IAAI,MAAM,KAAK,SAAS;AAAA,MACvC,MAAM;AAAA,MACN,MAAM;AAAA,MACN;AAAA,MACA,SAAS,MAAM,SAAS;AAAA,MACxB,SAAS,MAAM;AAAA,IACjB,CAAC;AACD,WAAO,WAAW,WAAW;AAAA,EAC/B;AAAA,EAEA,MAAa,KAAK,SAAiB,MAA0D;AAC3F,UAAM,EAAE,SAAS,IAAI,MAAM,KAAK,SAAS;AAAA,MACvC,MAAM;AAAA,MACN,MAAM;AAAA,MACN;AAAA,MACA,SAAS,MAAM;AAAA,IACjB,CAAC;AAED,WAAO,WAAW,WAAW;AAAA,EAC/B;AAAA,EAEQ,WAAW,IAAI,SAAiE;AACtF,SAAK,QAAQ,QAAQ;AACrB,eAAO,eAAAA,SAAQ,GAAG,IAAI;AAAA,EACxB;AACF;",
|
|
6
|
+
"names": ["prompts"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/utils/require-utils.ts"],
|
|
4
|
+
"sourcesContent": ["import Module from 'module'\nimport pathlib from 'path'\n\nexport const requireJsFile = <T>(path: string): T => {\n return require(path)\n}\n\nexport const requireJsCode = <T>(code: string): T => {\n const filedir = 'tmp'\n const filename = `${Date.now()}.js`\n\n const fileid = pathlib.join(filedir, filename)\n\n const m = new Module(fileid)\n m.filename = filename\n // @ts-ignore\n m._compile(code, filename)\n return m.exports\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAmB;AACnB,kBAAoB;AAEb,MAAM,gBAAgB,CAAI,SAAoB;AACnD,SAAO,QAAQ,IAAI;AACrB;AAEO,MAAM,gBAAgB,CAAI,SAAoB;AACnD,QAAM,UAAU;AAChB,QAAM,WAAW,GAAG,KAAK,IAAI;AAE7B,QAAM,SAAS,YAAAA,QAAQ,KAAK,SAAS,QAAQ;AAE7C,QAAM,IAAI,IAAI,cAAAC,QAAO,MAAM;AAC3B,IAAE,WAAW;AAEb,IAAE,SAAS,MAAM,QAAQ;AACzB,SAAO,EAAE;AACX;",
|
|
6
|
+
"names": ["pathlib", "Module"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/child-entrypoint.ts"],
|
|
4
|
+
"sourcesContent": ["import * as utils from '../utils'\nimport { CONFIG_ENV_KEY, configSchema } from './config'\nimport { ChildProcessProps, processProps } from './is-child'\n\nexport const ENTRY_POINT = __filename\n\nconst childProcessEntrypoint = async (_props: ChildProcessProps) => {\n const rawConfig = process.env[CONFIG_ENV_KEY]\n if (!rawConfig) {\n throw new Error(`Config variable ${CONFIG_ENV_KEY} was not set`)\n }\n const config = configSchema.parse(JSON.parse(rawConfig))\n\n if (config.type === 'code') {\n utils.require.requireJsCode(config.code)\n }\n if (config.type === 'file') {\n utils.require.requireJsFile(config.file)\n }\n}\n\nif (processProps.type === 'child') {\n // here we are in the child process\n void childProcessEntrypoint(processProps)\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAAuB;AACvB,oBAA6C;AAC7C,sBAAgD;AAEzC,MAAM,cAAc;AAE3B,MAAM,yBAAyB,OAAO,WAA8B;AAClE,QAAM,YAAY,QAAQ,IAAI;AAC9B,MAAI,CAAC,WAAW;AACd,UAAM,IAAI,MAAM,mBAAmB,0CAA4B;AAAA,EACjE;AACA,QAAM,SAAS,2BAAa,MAAM,KAAK,MAAM,SAAS,CAAC;AAEvD,MAAI,OAAO,SAAS,QAAQ;AAC1B,UAAM,QAAQ,cAAc,OAAO,IAAI;AAAA,EACzC;AACA,MAAI,OAAO,SAAS,QAAQ;AAC1B,UAAM,QAAQ,cAAc,OAAO,IAAI;AAAA,EACzC;AACF;AAEA,IAAI,6BAAa,SAAS,SAAS;AAEjC,OAAK,uBAAuB,4BAAY;AAC1C;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/child-wrapper.ts"],
|
|
4
|
+
"sourcesContent": ["import * as childProcess from 'child_process'\nimport type { Logger } from '../logger'\nimport { ENTRY_POINT } from './child-entrypoint'\nimport { CONFIG_ENV_KEY, Config } from './config'\nimport { CHILD_ENV_KEY, CHILD_ENV_VALUE, isChildProcess } from './is-child'\n\nexport type ChildOutput = {\n exitCode: number | null\n signal: NodeJS.Signals | null\n}\n\nconst listenForChildSpawn = (child: childProcess.ChildProcess, logger: Logger) =>\n new Promise<void>((resolve, reject) => {\n child.on('spawn', () => {\n logger.debug(`Child process spawned with pid ${child.pid}`)\n resolve()\n })\n child.on('error', (err: Error) => {\n /**\n * The 'error' event is emitted whenever:\n * - The process could not be spawned.\n * - The child process was aborted via the signal option.\n */\n logger.debug(`Child process error: ${err.message}`)\n reject(err)\n })\n })\n\nconst listenForChildExit = (child: childProcess.ChildProcess, logger: Logger) =>\n new Promise<ChildOutput>((resolve, reject) => {\n child.on('disconnect', () => {\n logger.debug('Child process disconnected')\n })\n child.on('close', (exitCode: number | null, signal: NodeJS.Signals | null) => {\n /**\n * this event usually fires after exit unless stdio streams are shared across multiple processes.\n * see https://stackoverflow.com/questions/37522010/difference-between-childprocess-close-exit-events\n */\n logger.debug(`Child process closed with code ${exitCode} and signal ${signal}`)\n })\n child.on('exit', (exitCode: number | null, signal: NodeJS.Signals | null) => {\n logger.debug(`Child process exited with code ${exitCode} and signal ${signal}`)\n resolve({ exitCode, signal })\n })\n child.on('error', (err: Error) => {\n /**\n * The 'error' event is emitted whenever:\n * - The process could not be killed.\n * - The child process was aborted via the signal option.\n */\n logger.debug(`Child process error: ${err.message}`)\n reject(err)\n })\n child.on('message', (message) => {\n logger.debug(`Child process message: ${message}`)\n })\n })\n\n/**\n * Wrapper above child_process.ChildProcess to simplify usage\n */\nexport class ChildProcessWrapper {\n public static async spawn(config: Config, logger: Logger): Promise<ChildProcessWrapper> {\n if (isChildProcess) {\n throw new Error('Cannot spawn child process from child process')\n }\n\n const child = childProcess.fork(ENTRY_POINT, [], {\n stdio: 'inherit',\n env: {\n [CHILD_ENV_KEY]: CHILD_ENV_VALUE,\n [CONFIG_ENV_KEY]: JSON.stringify(config),\n ...config.env,\n },\n })\n\n const childSpawnPromise = listenForChildSpawn(child, logger)\n const childExitPromise = listenForChildExit(child, logger)\n\n const instance = new ChildProcessWrapper(child, childExitPromise)\n\n childExitPromise.finally(() => {\n instance._exited = true\n })\n\n await childSpawnPromise\n\n return instance\n }\n\n private _exited = false\n private constructor(private _child: childProcess.ChildProcess, private _exitPromise: Promise<ChildOutput>) {}\n\n public async kill(): Promise<ChildOutput> {\n if (this._exited) {\n throw new Error('Child process already exited and cannot be killed')\n }\n this._child.kill()\n const res = await this._exitPromise\n return res\n }\n\n public async listen(): Promise<ChildOutput> {\n if (this._exited) {\n throw new Error('Child process already exited and cannot be listened on')\n }\n const res = await this._exitPromise\n return res\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA8B;AAE9B,8BAA4B;AAC5B,oBAAuC;AACvC,sBAA+D;AAO/D,MAAM,sBAAsB,CAAC,OAAkC,WAC7D,IAAI,QAAc,CAAC,SAAS,WAAW;AACrC,QAAM,GAAG,SAAS,MAAM;AACtB,WAAO,MAAM,kCAAkC,MAAM,KAAK;AAC1D,YAAQ;AAAA,EACV,CAAC;AACD,QAAM,GAAG,SAAS,CAAC,QAAe;AAMhC,WAAO,MAAM,wBAAwB,IAAI,SAAS;AAClD,WAAO,GAAG;AAAA,EACZ,CAAC;AACH,CAAC;AAEH,MAAM,qBAAqB,CAAC,OAAkC,WAC5D,IAAI,QAAqB,CAAC,SAAS,WAAW;AAC5C,QAAM,GAAG,cAAc,MAAM;AAC3B,WAAO,MAAM,4BAA4B;AAAA,EAC3C,CAAC;AACD,QAAM,GAAG,SAAS,CAAC,UAAyB,WAAkC;AAK5E,WAAO,MAAM,kCAAkC,uBAAuB,QAAQ;AAAA,EAChF,CAAC;AACD,QAAM,GAAG,QAAQ,CAAC,UAAyB,WAAkC;AAC3E,WAAO,MAAM,kCAAkC,uBAAuB,QAAQ;AAC9E,YAAQ,EAAE,UAAU,OAAO,CAAC;AAAA,EAC9B,CAAC;AACD,QAAM,GAAG,SAAS,CAAC,QAAe;AAMhC,WAAO,MAAM,wBAAwB,IAAI,SAAS;AAClD,WAAO,GAAG;AAAA,EACZ,CAAC;AACD,QAAM,GAAG,WAAW,CAAC,YAAY;AAC/B,WAAO,MAAM,0BAA0B,SAAS;AAAA,EAClD,CAAC;AACH,CAAC;AAKI,MAAM,oBAAoB;AAAA,EA8BvB,YAAoB,QAA2C,cAAoC;AAA/E;AAA2C;AAAA,EAAqC;AAAA,EA7B5G,aAAoB,MAAM,QAAgB,QAA8C;AACtF,QAAI,gCAAgB;AAClB,YAAM,IAAI,MAAM,+CAA+C;AAAA,IACjE;AAEA,UAAM,QAAQ,aAAa,KAAK,qCAAa,CAAC,GAAG;AAAA,MAC/C,OAAO;AAAA,MACP,KAAK;AAAA,QACH,CAAC,gCAAgB;AAAA,QACjB,CAAC,+BAAiB,KAAK,UAAU,MAAM;AAAA,QACvC,GAAG,OAAO;AAAA,MACZ;AAAA,IACF,CAAC;AAED,UAAM,oBAAoB,oBAAoB,OAAO,MAAM;AAC3D,UAAM,mBAAmB,mBAAmB,OAAO,MAAM;AAEzD,UAAM,WAAW,IAAI,oBAAoB,OAAO,gBAAgB;AAEhE,qBAAiB,QAAQ,MAAM;AAC7B,eAAS,UAAU;AAAA,IACrB,CAAC;AAED,UAAM;AAEN,WAAO;AAAA,EACT;AAAA,EAEQ,UAAU;AAAA,EAGlB,MAAa,OAA6B;AACxC,QAAI,KAAK,SAAS;AAChB,YAAM,IAAI,MAAM,mDAAmD;AAAA,IACrE;AACA,SAAK,OAAO,KAAK;AACjB,UAAM,MAAM,MAAM,KAAK;AACvB,WAAO;AAAA,EACT;AAAA,EAEA,MAAa,SAA+B;AAC1C,QAAI,KAAK,SAAS;AAChB,YAAM,IAAI,MAAM,wDAAwD;AAAA,IAC1E;AACA,UAAM,MAAM,MAAM,KAAK;AACvB,WAAO;AAAA,EACT;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
package/dist/worker/config.js
CHANGED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/config.ts"],
|
|
4
|
+
"sourcesContent": ["import zod from 'zod'\n\nexport const CONFIG_ENV_KEY = 'CHILD_PROCESS_CONFIGURATION'\n\nexport type Config = zod.infer<typeof configSchema>\nexport const configSchema = zod.union([\n zod.object({\n type: zod.literal('code'),\n code: zod.string(),\n env: zod.record(zod.string(), zod.string()).optional(),\n }),\n zod.object({\n type: zod.literal('file'),\n file: zod.string(),\n env: zod.record(zod.string(), zod.string()).optional(),\n }),\n])\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAAgB;AAET,MAAM,iBAAiB;AAGvB,MAAM,eAAe,WAAAA,QAAI,MAAM;AAAA,EACpC,WAAAA,QAAI,OAAO;AAAA,IACT,MAAM,WAAAA,QAAI,QAAQ,MAAM;AAAA,IACxB,MAAM,WAAAA,QAAI,OAAO;AAAA,IACjB,KAAK,WAAAA,QAAI,OAAO,WAAAA,QAAI,OAAO,GAAG,WAAAA,QAAI,OAAO,CAAC,EAAE,SAAS;AAAA,EACvD,CAAC;AAAA,EACD,WAAAA,QAAI,OAAO;AAAA,IACT,MAAM,WAAAA,QAAI,QAAQ,MAAM;AAAA,IACxB,MAAM,WAAAA,QAAI,OAAO;AAAA,IACjB,KAAK,WAAAA,QAAI,OAAO,WAAAA,QAAI,OAAO,GAAG,WAAAA,QAAI,OAAO,CAAC,EAAE,SAAS;AAAA,EACvD,CAAC;AACH,CAAC;",
|
|
6
|
+
"names": ["zod"]
|
|
7
|
+
}
|
package/dist/worker/index.js
CHANGED
package/dist/worker/is-child.js
CHANGED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/is-child.ts"],
|
|
4
|
+
"sourcesContent": ["export const CHILD_ENV_KEY = 'IS_CHILD'\nexport const CHILD_ENV_VALUE = 'true'\n\nexport type MainProcessProps = {\n type: 'main'\n pid: number\n}\nexport type ChildProcessProps = {\n type: 'child'\n sendMessage: (message: string) => void\n pid: number\n}\n\nexport type ProcessProps = MainProcessProps | ChildProcessProps\n\nconst getProcessProps = (): ProcessProps => {\n const type = process.env[CHILD_ENV_KEY] === CHILD_ENV_VALUE ? 'child' : 'main'\n if (type === 'main') {\n return {\n type,\n pid: process.pid,\n }\n }\n\n if (!process.send) {\n throw new Error(`Please do not use variable ${CHILD_ENV_KEY} manually`)\n }\n\n return {\n type,\n sendMessage: process.send,\n pid: process.pid,\n }\n}\n\nexport const processProps = getProcessProps()\nexport const isChildProcess = processProps.type === 'child'\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,MAAM,gBAAgB;AACtB,MAAM,kBAAkB;AAc/B,MAAM,kBAAkB,MAAoB;AAC1C,QAAM,OAAO,QAAQ,IAAI,mBAAmB,kBAAkB,UAAU;AACxE,MAAI,SAAS,QAAQ;AACnB,WAAO;AAAA,MACL;AAAA,MACA,KAAK,QAAQ;AAAA,IACf;AAAA,EACF;AAEA,MAAI,CAAC,QAAQ,MAAM;AACjB,UAAM,IAAI,MAAM,8BAA8B,wBAAwB;AAAA,EACxE;AAEA,SAAO;AAAA,IACL;AAAA,IACA,aAAa,QAAQ;AAAA,IACrB,KAAK,QAAQ;AAAA,EACf;AACF;AAEO,MAAM,eAAe,gBAAgB;AACrC,MAAM,iBAAiB,aAAa,SAAS;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/worker-state.ts"],
|
|
4
|
+
"sourcesContent": ["import type { ChildProcessWrapper } from './child-wrapper'\n\nexport type WorkerStatus = WorkerState['status']\nexport type WorkerState =\n | { status: 'errored'; thrown: unknown } // only occurs if the event error is emitted https://nodejs.org/api/child_process.html#event-error\n | { status: 'dead'; murdered: boolean }\n | { status: 'killing' }\n | { status: 'reloading' }\n | {\n status: 'live'\n child: ChildProcessWrapper\n }\n\nexport type StateOf<S extends WorkerStatus> = Extract<WorkerState, { status: S }>\nexport type WorkerStateHandler<S extends WorkerStatus> = (state: StateOf<S>) => void\n\nexport class WorkerStateObserver {\n private _state: WorkerState\n private _handlers: {\n [K in WorkerStatus]: WorkerStateHandler<K>[]\n } = {\n dead: [],\n reloading: [],\n live: [],\n killing: [],\n errored: [],\n }\n\n public constructor(initialState: WorkerState) {\n this._state = initialState\n }\n\n public waitFor<S extends WorkerStatus>(status: S): Promise<void> {\n return new Promise<void>((resolve) => {\n const cb = () => {\n this.off(status, cb)\n resolve()\n }\n this.on(status, cb)\n })\n }\n\n public on<S extends WorkerStatus>(status: S, handler: WorkerStateHandler<S>) {\n this._handlers[status].push(handler)\n if (this._state.status === status) {\n handler(this._state as StateOf<S>)\n }\n }\n\n public off<S extends WorkerStatus>(status: S, handler: WorkerStateHandler<S>) {\n const index = this._handlers[status].indexOf(handler)\n this._handlers[status].splice(index, 1)\n }\n\n public get() {\n return this._state\n }\n\n public set(newState: WorkerState) {\n this._state = newState\n const { status } = newState\n for (const handler of this._handlers[status]) {\n const fn = handler as WorkerStateHandler<typeof status>\n fn(newState)\n }\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBO,MAAM,oBAAoB;AAAA,EACvB;AAAA,EACA,YAEJ;AAAA,IACF,MAAM,CAAC;AAAA,IACP,WAAW,CAAC;AAAA,IACZ,MAAM,CAAC;AAAA,IACP,SAAS,CAAC;AAAA,IACV,SAAS,CAAC;AAAA,EACZ;AAAA,EAEO,YAAY,cAA2B;AAC5C,SAAK,SAAS;AAAA,EAChB;AAAA,EAEO,QAAgC,QAA0B;AAC/D,WAAO,IAAI,QAAc,CAAC,YAAY;AACpC,YAAM,KAAK,MAAM;AACf,aAAK,IAAI,QAAQ,EAAE;AACnB,gBAAQ;AAAA,MACV;AACA,WAAK,GAAG,QAAQ,EAAE;AAAA,IACpB,CAAC;AAAA,EACH;AAAA,EAEO,GAA2B,QAAW,SAAgC;AAC3E,SAAK,UAAU,QAAQ,KAAK,OAAO;AACnC,QAAI,KAAK,OAAO,WAAW,QAAQ;AACjC,cAAQ,KAAK,MAAoB;AAAA,IACnC;AAAA,EACF;AAAA,EAEO,IAA4B,QAAW,SAAgC;AAC5E,UAAM,QAAQ,KAAK,UAAU,QAAQ,QAAQ,OAAO;AACpD,SAAK,UAAU,QAAQ,OAAO,OAAO,CAAC;AAAA,EACxC;AAAA,EAEO,MAAM;AACX,WAAO,KAAK;AAAA,EACd;AAAA,EAEO,IAAI,UAAuB;AAChC,SAAK,SAAS;AACd,UAAM,EAAE,OAAO,IAAI;AACnB,eAAW,WAAW,KAAK,UAAU,SAAS;AAC5C,YAAM,KAAK;AACX,SAAG,QAAQ;AAAA,IACb;AAAA,EACF;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
package/dist/worker/worker.js
CHANGED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/worker/worker.ts"],
|
|
4
|
+
"sourcesContent": ["import type { Logger } from '../logger'\nimport { ChildProcessWrapper } from './child-wrapper'\nimport type { Config } from './config'\nimport { WorkerStateObserver } from './worker-state'\n\nexport type WorkerProps = {\n hangOnExit?: boolean\n}\n\nexport class Worker {\n public static async spawn(config: Config, logger: Logger, props?: Partial<WorkerProps>): Promise<Worker> {\n const instance = new Worker(config, logger, props)\n await instance.reload()\n return instance\n }\n\n private _state = new WorkerStateObserver({ status: 'dead', murdered: false })\n\n private constructor(private _config: Config, private _logger: Logger, private _props: Partial<WorkerProps> = {}) {}\n\n /**\n * Used to determine if the worker can be killed\n */\n public get running() {\n return this._state.get().status === 'live'\n }\n\n public kill = () => {\n const state = this._state.get()\n if (state.status !== 'live') {\n throw new Error('Cannot kill a child process that is not alive')\n }\n\n this._state.set({ status: 'killing' })\n return state.child.kill()\n }\n\n public reload = async () => {\n if (this._state.get().status === 'reloading') {\n this._logger.debug('Already reloading')\n return\n }\n\n const previousState = this._state.get()\n this._state.set({ status: 'reloading' })\n\n if (previousState.status === 'live') {\n await previousState.child.kill()\n }\n\n const child = await ChildProcessWrapper.spawn(this._config, this._logger)\n this._state.set({ status: 'live', child })\n\n void child\n .listen()\n .catch((thrown) => {\n this._state.set({ status: 'errored', thrown })\n })\n .then(() => {\n const { status } = this._state.get()\n if (status === 'reloading') {\n return\n }\n this._state.set({ status: 'dead', murdered: status === 'killing' })\n })\n }\n\n public wait = () =>\n new Promise<void>((resolve, reject) => {\n this._state.on('dead', (state) => {\n if (state.murdered || !this._props.hangOnExit) {\n resolve()\n return\n }\n\n this._logger.debug('Child process died of natural causes...')\n })\n\n this._state.on('errored', (state) => {\n reject(state.thrown)\n })\n })\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,2BAAoC;AAEpC,0BAAoC;AAM7B,MAAM,OAAO;AAAA,EASV,YAAoB,SAAyB,SAAyB,SAA+B,CAAC,GAAG;AAArF;AAAyB;AAAyB;AAAA,EAAoC;AAAA,EARlH,aAAoB,MAAM,QAAgB,QAAgB,OAA+C;AACvG,UAAM,WAAW,IAAI,OAAO,QAAQ,QAAQ,KAAK;AACjD,UAAM,SAAS,OAAO;AACtB,WAAO;AAAA,EACT;AAAA,EAEQ,SAAS,IAAI,wCAAoB,EAAE,QAAQ,QAAQ,UAAU,MAAM,CAAC;AAAA,EAO5E,IAAW,UAAU;AACnB,WAAO,KAAK,OAAO,IAAI,EAAE,WAAW;AAAA,EACtC;AAAA,EAEO,OAAO,MAAM;AAClB,UAAM,QAAQ,KAAK,OAAO,IAAI;AAC9B,QAAI,MAAM,WAAW,QAAQ;AAC3B,YAAM,IAAI,MAAM,+CAA+C;AAAA,IACjE;AAEA,SAAK,OAAO,IAAI,EAAE,QAAQ,UAAU,CAAC;AACrC,WAAO,MAAM,MAAM,KAAK;AAAA,EAC1B;AAAA,EAEO,SAAS,YAAY;AAC1B,QAAI,KAAK,OAAO,IAAI,EAAE,WAAW,aAAa;AAC5C,WAAK,QAAQ,MAAM,mBAAmB;AACtC;AAAA,IACF;AAEA,UAAM,gBAAgB,KAAK,OAAO,IAAI;AACtC,SAAK,OAAO,IAAI,EAAE,QAAQ,YAAY,CAAC;AAEvC,QAAI,cAAc,WAAW,QAAQ;AACnC,YAAM,cAAc,MAAM,KAAK;AAAA,IACjC;AAEA,UAAM,QAAQ,MAAM,yCAAoB,MAAM,KAAK,SAAS,KAAK,OAAO;AACxE,SAAK,OAAO,IAAI,EAAE,QAAQ,QAAQ,MAAM,CAAC;AAEzC,SAAK,MACF,OAAO,EACP,MAAM,CAAC,WAAW;AACjB,WAAK,OAAO,IAAI,EAAE,QAAQ,WAAW,OAAO,CAAC;AAAA,IAC/C,CAAC,EACA,KAAK,MAAM;AACV,YAAM,EAAE,OAAO,IAAI,KAAK,OAAO,IAAI;AACnC,UAAI,WAAW,aAAa;AAC1B;AAAA,MACF;AACA,WAAK,OAAO,IAAI,EAAE,QAAQ,QAAQ,UAAU,WAAW,UAAU,CAAC;AAAA,IACpE,CAAC;AAAA,EACL;AAAA,EAEO,OAAO,MACZ,IAAI,QAAc,CAAC,SAAS,WAAW;AACrC,SAAK,OAAO,GAAG,QAAQ,CAAC,UAAU;AAChC,UAAI,MAAM,YAAY,CAAC,KAAK,OAAO,YAAY;AAC7C,gBAAQ;AACR;AAAA,MACF;AAEA,WAAK,QAAQ,MAAM,yCAAyC;AAAA,IAC9D,CAAC;AAED,SAAK,OAAO,GAAG,WAAW,CAAC,UAAU;AACnC,aAAO,MAAM,MAAM;AAAA,IACrB,CAAC;AAAA,EACH,CAAC;AACL;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
package/package.json
CHANGED
|
@@ -1,16 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@botpress/cli",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.17",
|
|
4
4
|
"description": "Botpress CLI",
|
|
5
|
-
"scripts": {
|
|
6
|
-
"build": "pnpm run type-check && pnpm run bundle && pnpm run template:gen && pnpm run template:type-check",
|
|
7
|
-
"dev": "ts-node -T src/index.ts",
|
|
8
|
-
"start": "node dist/index.js",
|
|
9
|
-
"type-check": "tsc --noEmit",
|
|
10
|
-
"bundle": "ts-node -T build.ts",
|
|
11
|
-
"template:type-check": "pnpm -r --stream -F './**/templates/*' run type-check",
|
|
12
|
-
"template:gen": "pnpm -r --stream -F './**/templates/*' exec bp gen"
|
|
13
|
-
},
|
|
14
5
|
"keywords": [],
|
|
15
6
|
"author": "",
|
|
16
7
|
"license": "MIT",
|
|
@@ -19,7 +10,7 @@
|
|
|
19
10
|
},
|
|
20
11
|
"main": "dist/index.js",
|
|
21
12
|
"dependencies": {
|
|
22
|
-
"@botpress/client": "0.0.
|
|
13
|
+
"@botpress/client": "0.0.13",
|
|
23
14
|
"@bpinternal/yargs-extra": "^0.0.3",
|
|
24
15
|
"@parcel/watcher": "^2.1.0",
|
|
25
16
|
"@types/lodash": "^4.14.191",
|
|
@@ -45,7 +36,7 @@
|
|
|
45
36
|
"zod-to-json-schema": "^3.20.1"
|
|
46
37
|
},
|
|
47
38
|
"devDependencies": {
|
|
48
|
-
"@botpress/sdk": "0.0.
|
|
39
|
+
"@botpress/sdk": "0.0.13",
|
|
49
40
|
"@types/bluebird": "^3.5.38",
|
|
50
41
|
"@types/prompts": "^2.0.14",
|
|
51
42
|
"@types/semver": "^7.3.11",
|
|
@@ -55,5 +46,14 @@
|
|
|
55
46
|
},
|
|
56
47
|
"engines": {
|
|
57
48
|
"node": ">=18"
|
|
49
|
+
},
|
|
50
|
+
"scripts": {
|
|
51
|
+
"build": "pnpm run type-check && pnpm run bundle && pnpm run template:gen && pnpm run template:type-check",
|
|
52
|
+
"dev": "ts-node -T src/index.ts",
|
|
53
|
+
"start": "node dist/index.js",
|
|
54
|
+
"type-check": "tsc --noEmit",
|
|
55
|
+
"bundle": "ts-node -T build.ts",
|
|
56
|
+
"template:type-check": "pnpm -r --stream -F './**/templates/*' run type-check",
|
|
57
|
+
"template:gen": "pnpm -r --stream -F './**/templates/*' exec bp gen"
|
|
58
58
|
}
|
|
59
|
-
}
|
|
59
|
+
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "echo-bot",
|
|
3
|
-
"version": "0.1.0",
|
|
4
3
|
"scripts": {
|
|
5
4
|
"type-check": "tsc --noEmit"
|
|
6
5
|
},
|
|
@@ -10,7 +9,7 @@
|
|
|
10
9
|
"license": "MIT",
|
|
11
10
|
"dependencies": {
|
|
12
11
|
"@botpress/client": "0.0.11",
|
|
13
|
-
"@botpress/sdk": "0.0.
|
|
12
|
+
"@botpress/sdk": "0.0.11",
|
|
14
13
|
"zod": "^3.20.6"
|
|
15
14
|
},
|
|
16
15
|
"devDependencies": {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { IntegrationDefinition, messages } from '@botpress/sdk'
|
|
2
|
-
import {
|
|
2
|
+
import { name } from './package.json'
|
|
3
3
|
|
|
4
4
|
export default new IntegrationDefinition({
|
|
5
5
|
name,
|
|
6
|
-
version,
|
|
6
|
+
version: '0.0.1',
|
|
7
7
|
public: false,
|
|
8
8
|
channels: {
|
|
9
9
|
channel: {
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "empty-integration",
|
|
3
|
-
"version": "0.1.0",
|
|
4
3
|
"scripts": {
|
|
5
4
|
"type-check": "tsc --noEmit"
|
|
6
5
|
},
|
|
@@ -10,7 +9,7 @@
|
|
|
10
9
|
"license": "MIT",
|
|
11
10
|
"dependencies": {
|
|
12
11
|
"@botpress/client": "0.0.11",
|
|
13
|
-
"@botpress/sdk": "0.0.
|
|
12
|
+
"@botpress/sdk": "0.0.11",
|
|
14
13
|
"zod": "^3.20.6"
|
|
15
14
|
},
|
|
16
15
|
"devDependencies": {
|
package/build.ts
DELETED
package/dist/app/api-utils.js
DELETED
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
25
|
-
var api_utils_exports = {};
|
|
26
|
-
__export(api_utils_exports, {
|
|
27
|
-
ApiUtils: () => ApiUtils
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(api_utils_exports);
|
|
30
|
-
var import_client = require("@botpress/client");
|
|
31
|
-
var import_lodash = __toESM(require("lodash"));
|
|
32
|
-
var errors = __toESM(require("./errors"));
|
|
33
|
-
var import_integration_ref = require("./integration-ref");
|
|
34
|
-
class ApiUtils {
|
|
35
|
-
constructor(props, _logger) {
|
|
36
|
-
this._logger = _logger;
|
|
37
|
-
const { host, token, workspaceId } = props;
|
|
38
|
-
this.client = new import_client.Client({ host, token, workspaceId });
|
|
39
|
-
this.host = host;
|
|
40
|
-
this.token = token;
|
|
41
|
-
this.workspaceId = workspaceId;
|
|
42
|
-
}
|
|
43
|
-
client;
|
|
44
|
-
host;
|
|
45
|
-
token;
|
|
46
|
-
workspaceId;
|
|
47
|
-
async findIntegration(ref) {
|
|
48
|
-
const formatted = (0, import_integration_ref.formatIntegrationRef)(ref);
|
|
49
|
-
const privateIntegration = await this.findPrivateIntegration(ref);
|
|
50
|
-
if (privateIntegration) {
|
|
51
|
-
this._logger.debug(`Found integration "${formatted}" in workspace`);
|
|
52
|
-
return privateIntegration;
|
|
53
|
-
}
|
|
54
|
-
const publicIntegration = await this.findPublicIntegration(ref);
|
|
55
|
-
if (publicIntegration) {
|
|
56
|
-
this._logger.debug(`Found integration "${formatted}" in hub`);
|
|
57
|
-
return publicIntegration;
|
|
58
|
-
}
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
async findPrivateIntegration(ref) {
|
|
62
|
-
if (ref.type === "id") {
|
|
63
|
-
return this.validateStatus(() => this.client.getIntegration(ref).then((r) => r.integration), [404, 500]);
|
|
64
|
-
}
|
|
65
|
-
return this.validateStatus(() => this.client.getIntegrationByName(ref).then((r) => r.integration), [404, 500]);
|
|
66
|
-
}
|
|
67
|
-
async findPublicIntegration(ref) {
|
|
68
|
-
if (ref.type === "id") {
|
|
69
|
-
return this.validateStatus(() => this.client.getPublicIntegrationById(ref).then((r) => r.integration), [404, 500]);
|
|
70
|
-
}
|
|
71
|
-
return this.validateStatus(() => this.client.getPublicIntegration(ref).then((r) => r.integration), [404, 500]);
|
|
72
|
-
}
|
|
73
|
-
async testLogin() {
|
|
74
|
-
try {
|
|
75
|
-
await this.client.listBots({});
|
|
76
|
-
} catch (thrown) {
|
|
77
|
-
throw errors.BotpressCLIError.wrap(thrown, "Authentication failed. Please check your credentials");
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
async listAllPages(lister, map) {
|
|
81
|
-
let nextToken;
|
|
82
|
-
const all = [];
|
|
83
|
-
do {
|
|
84
|
-
const { meta, ...r } = await lister({ nextToken });
|
|
85
|
-
all.push(r);
|
|
86
|
-
nextToken = meta.nextToken;
|
|
87
|
-
} while (nextToken);
|
|
88
|
-
if (!map) {
|
|
89
|
-
return all;
|
|
90
|
-
}
|
|
91
|
-
const mapped = all.flatMap((r) => map(r));
|
|
92
|
-
return mapped;
|
|
93
|
-
}
|
|
94
|
-
async validateStatus(fn, allowedStatuses) {
|
|
95
|
-
try {
|
|
96
|
-
const v = await fn();
|
|
97
|
-
return v;
|
|
98
|
-
} catch (thrown) {
|
|
99
|
-
const err = errors.BotpressCLIError.map(thrown);
|
|
100
|
-
const allowedStatusesArray = import_lodash.default.isArray(allowedStatuses) ? allowedStatuses : [allowedStatuses];
|
|
101
|
-
const isAllowed = err instanceof errors.HTTPError && err.status && allowedStatusesArray.includes(err.status);
|
|
102
|
-
if (isAllowed) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
throw err;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
110
|
-
0 && (module.exports = {
|
|
111
|
-
ApiUtils
|
|
112
|
-
});
|
package/dist/app/base.js
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
25
|
-
var base_exports = {};
|
|
26
|
-
__export(base_exports, {
|
|
27
|
-
BaseCommands: () => BaseCommands
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(base_exports);
|
|
30
|
-
var import_prompts = __toESM(require("prompts"));
|
|
31
|
-
var import_api_utils = require("./api-utils");
|
|
32
|
-
var errors = __toESM(require("./errors"));
|
|
33
|
-
class BaseCommands {
|
|
34
|
-
constructor(_props, _userCache, _logger) {
|
|
35
|
-
this._props = _props;
|
|
36
|
-
this._userCache = _userCache;
|
|
37
|
-
this._logger = _logger;
|
|
38
|
-
}
|
|
39
|
-
teardown() {
|
|
40
|
-
this._logger.cleanup();
|
|
41
|
-
}
|
|
42
|
-
async _ensureLoginAndCreateClient(argv) {
|
|
43
|
-
const token = await this._userCache.get("token");
|
|
44
|
-
const workspaceId = argv.workspaceId ?? await this._userCache.get("workspaceId");
|
|
45
|
-
const host = argv.host ?? await this._userCache.get("host");
|
|
46
|
-
if (!(token && workspaceId && host)) {
|
|
47
|
-
throw new errors.NotLoggedInError();
|
|
48
|
-
}
|
|
49
|
-
return new import_api_utils.ApiUtils({ host, token, workspaceId }, this._logger);
|
|
50
|
-
}
|
|
51
|
-
async _confirm(message) {
|
|
52
|
-
if (this._props.confirm) {
|
|
53
|
-
this._logger.debug(`Confirming automatically: ${message}`);
|
|
54
|
-
return true;
|
|
55
|
-
}
|
|
56
|
-
const { confirm } = await (0, import_prompts.default)({
|
|
57
|
-
type: "confirm",
|
|
58
|
-
name: "confirm",
|
|
59
|
-
message,
|
|
60
|
-
initial: false
|
|
61
|
-
});
|
|
62
|
-
if (!confirm) {
|
|
63
|
-
return false;
|
|
64
|
-
}
|
|
65
|
-
return true;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
69
|
-
0 && (module.exports = {
|
|
70
|
-
BaseCommands
|
|
71
|
-
});
|
package/dist/app/cache.js
DELETED
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
25
|
-
var cache_exports = {};
|
|
26
|
-
__export(cache_exports, {
|
|
27
|
-
FSConfigCache: () => FSConfigCache
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(cache_exports);
|
|
30
|
-
var import_fs = __toESM(require("fs"));
|
|
31
|
-
var import_path = __toESM(require("path"));
|
|
32
|
-
class FSConfigCache {
|
|
33
|
-
constructor(_filepath) {
|
|
34
|
-
this._filepath = _filepath;
|
|
35
|
-
}
|
|
36
|
-
static async loadFrom(filepath) {
|
|
37
|
-
const dirname = import_path.default.dirname(filepath);
|
|
38
|
-
if (!import_fs.default.existsSync(dirname)) {
|
|
39
|
-
await import_fs.default.promises.mkdir(dirname, { recursive: true });
|
|
40
|
-
}
|
|
41
|
-
if (!import_fs.default.existsSync(filepath)) {
|
|
42
|
-
await this._writeJSON(filepath, {});
|
|
43
|
-
}
|
|
44
|
-
return new FSConfigCache(filepath);
|
|
45
|
-
}
|
|
46
|
-
static _writeJSON = (filepath, data) => {
|
|
47
|
-
const fileContent = JSON.stringify(data, null, 2);
|
|
48
|
-
return import_fs.default.promises.writeFile(filepath, fileContent);
|
|
49
|
-
};
|
|
50
|
-
static _readJSON = async (filepath) => {
|
|
51
|
-
const fileContent = await import_fs.default.promises.readFile(filepath, "utf8");
|
|
52
|
-
return JSON.parse(fileContent);
|
|
53
|
-
};
|
|
54
|
-
async sync(key, value, prompt) {
|
|
55
|
-
if (value) {
|
|
56
|
-
await this.set(key, value);
|
|
57
|
-
return value;
|
|
58
|
-
}
|
|
59
|
-
const data = await this.get(key);
|
|
60
|
-
const newValue = await prompt(data);
|
|
61
|
-
await this.set(key, newValue);
|
|
62
|
-
return newValue;
|
|
63
|
-
}
|
|
64
|
-
async has(key) {
|
|
65
|
-
const data = await FSConfigCache._readJSON(this._filepath);
|
|
66
|
-
return data[key] !== void 0;
|
|
67
|
-
}
|
|
68
|
-
async get(key) {
|
|
69
|
-
const data = await FSConfigCache._readJSON(this._filepath);
|
|
70
|
-
return data[key];
|
|
71
|
-
}
|
|
72
|
-
async set(key, value) {
|
|
73
|
-
const data = await FSConfigCache._readJSON(this._filepath);
|
|
74
|
-
data[key] = value;
|
|
75
|
-
return FSConfigCache._writeJSON(this._filepath, data);
|
|
76
|
-
}
|
|
77
|
-
async rm(key) {
|
|
78
|
-
const data = await FSConfigCache._readJSON(this._filepath);
|
|
79
|
-
delete data[key];
|
|
80
|
-
return FSConfigCache._writeJSON(this._filepath, data);
|
|
81
|
-
}
|
|
82
|
-
async clear() {
|
|
83
|
-
return FSConfigCache._writeJSON(this._filepath, {});
|
|
84
|
-
}
|
|
85
|
-
async nuke() {
|
|
86
|
-
if (!import_fs.default.existsSync(this._filepath)) {
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
import_fs.default.unlinkSync(this._filepath);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
93
|
-
0 && (module.exports = {
|
|
94
|
-
FSConfigCache
|
|
95
|
-
});
|