From 4ccaba9442c908483aa30560968f475e10e5bc85 Mon Sep 17 00:00:00 2001 From: Paul Paterson Date: Fri, 13 Dec 2024 17:27:09 -0500 Subject: [PATCH] implement query info toggling in shell --- src/commands/shell.mjs | 22 +++++++++++++++++----- src/lib/command-helpers.mjs | 10 +++++++++- 2 files changed, 26 insertions(+), 6 deletions(-) diff --git a/src/commands/shell.mjs b/src/commands/shell.mjs index b24688dd..2f338414 100644 --- a/src/commands/shell.mjs +++ b/src/commands/shell.mjs @@ -7,6 +7,7 @@ import * as esprima from "esprima"; import { container } from "../cli.mjs"; import { + QUERY_INFO_CHOICES, resolveFormat, validateDatabaseOrSecret, yargsWithCommonConfigurableQueryOptions, @@ -66,6 +67,8 @@ async function shellCommand(argv) { shell.on("exit", resolve); }); + shell.context.include = argv.include; + [ { cmd: "clear", @@ -114,13 +117,21 @@ async function shellCommand(argv) { }, }, { - cmd: "toggleSummary", - help: "Enable or disable the summary field of the API response. Disabled by default. If enabled, outputs the summary field of the API response.", + cmd: "toggleInfo", + help: "Enable or disable the query info fields of the API response. Disabled by default. If enabled, outputs the included fields of the API response.", action: () => { - shell.context.summary = !shell.context.summary; + shell.context.include = + shell.context.include.length === 0 + ? // if we are toggling on and no include was provided, turn everything on + argv.include.length === 0 + ? QUERY_INFO_CHOICES + : argv.include + : []; + logger.stderr( - `Summary in shell: ${shell.context.summary ? "on" : "off"}`, + `Query info in shell: ${shell.context.include.length === 0 ? "off" : shell.context.include.join(", ")}`, ); + shell.prompt(); }, }, @@ -149,7 +160,8 @@ async function buildCustomEval(argv) { if (cmd.trim() === "") return cb(); // These are options used for querying and formatting the response - const { apiVersion, color, include } = argv; + const { apiVersion, color } = argv; + const include = getArgvOrCtx("include", argv, ctx); const performanceHints = getArgvOrCtx("performanceHints", argv, ctx); // Using --json output takes precedence over --format diff --git a/src/lib/command-helpers.mjs b/src/lib/command-helpers.mjs index 438c1fe2..ddbc02fb 100644 --- a/src/lib/command-helpers.mjs +++ b/src/lib/command-helpers.mjs @@ -79,6 +79,14 @@ const COMMON_QUERY_OPTIONS = { }, }; +export const QUERY_INFO_CHOICES = [ + "txnTs", + "schemaVersion", + "summary", + "queryTags", + "stats", +]; + // used for queries customers can configure const COMMON_CONFIGURABLE_QUERY_OPTIONS = { ...COMMON_QUERY_OPTIONS, @@ -123,7 +131,7 @@ const COMMON_CONFIGURABLE_QUERY_OPTIONS = { }, include: { type: "array", - choices: ["all", "txnTs", "schemaVersion", "summary", "queryTags", "stats"], + choices: ["all", ...QUERY_INFO_CHOICES], default: [], describe: "Select additional query information to include in the output", },