UNPKG

msbot

Version:

MSBot command line tool for manipulating Microsoft Bot Framework .bot files

101 lines 4.21 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); /** * Copyright(c) Microsoft Corporation.All rights reserved. * Licensed under the MIT License. */ // tslint:disable:no-console // tslint:disable:no-object-literal-type-assertion const botframework_config_1 = require("botframework-config"); const chalk = require("chalk"); const program = require("commander"); const fs = require("fs-extra"); const stdioAsync_1 = require("./stdioAsync"); const utils_1 = require("./utils"); program.Command.prototype.unknownOption = (flag) => { console.error(chalk.default.redBright(`Unknown arguments: ${flag}`)); showErrorHelp(); }; program .name('msbot update qna') .description('update the bot to a QnA knowledgebase (--id or --kbId is required)') .option('--id <id>', 'service id') .option('-n, --name <name>', 'name for the QNA knowledgebase') .option('-k, --kbId <kbId>', 'QnA Knowledgebase Id ') .option('--subscriptionKey <subscriptionKey>', 'Azure Cognitive Service subscriptionKey/accessKey for calling the QnA management API (from azure portal)') .option('--endpointKey <endpointKey>', 'endpointKey for calling the QnA service (from https://qnamaker.ai portal or qnamaker list endpointkeys command)') .option('--hostname <url>', 'url for private QnA service (example: https://myqna.azurewebsites.net)') .option('-b, --bot <path>', 'path to bot file. If omitted, local folder will look for a .bot file') .option('--input <jsonfile>', 'path to arguments in JSON format { id:\'\',name:\'\', ... }') .option('--secret <secret>', 'bot file secret password for encrypting service secrets') .option('--stdin', 'arguments are passed in as JSON object via stdin') .option('--prefix', 'Append [msbot] prefix to all messages') .action((cmd, actions) => undefined); const command = program.parse(process.argv); const args = {}; Object.assign(args, command); if (args.stdin) { //force verbosity output if args are passed via stdin process.env.PREFIX = 'prefix'; } if (process.argv.length < 3) { program.help(); } else { if (!args.bot) { botframework_config_1.BotConfiguration.loadBotFromFolder(process.cwd(), args.secret) .then(processArgs) .catch((reason) => { console.error(chalk.default.redBright(reason.toString().split('\n')[0])); showErrorHelp(); }); } else { botframework_config_1.BotConfiguration.load(args.bot, args.secret) .then(processArgs) .catch((reason) => { console.error(chalk.default.redBright(reason.toString().split('\n')[0])); showErrorHelp(); }); } } async function processArgs(config) { if (args.stdin) { Object.assign(args, JSON.parse(await utils_1.getStdin())); } else if (args.input != null) { Object.assign(args, await fs.readJSON(args.input)); } if (!args.id && !args.kbId) { throw new Error('requires --id or --kbId'); } for (const service of config.services) { if (service.type === botframework_config_1.ServiceTypes.QnA) { const qnaService = service; if (qnaService.id === args.id || qnaService.kbId === args.kbId) { if (args.hasOwnProperty('name')) qnaService.name = args.name; if (args.kbId) qnaService.kbId = args.kbId; if (args.subscriptionKey) qnaService.subscriptionKey = args.subscriptionKey; if (args.endpointKey) qnaService.endpointKey = args.endpointKey; if (args.hostname) qnaService.hostname = args.hostname; await config.save(args.secret); await stdioAsync_1.stdoutAsync(JSON.stringify(qnaService, null, 2)); return config; } } } throw new Error(`QnaMaker Service ${args.kbId} was not found in the bot file`); } function showErrorHelp() { program.outputHelp((str) => { console.error(str); return ''; }); process.exit(1); } //# sourceMappingURL=msbot-update-qna.js.map