convex
Version:
Client for the Convex Cloud
162 lines (161 loc) • 7.29 kB
JavaScript
"use strict";
import { Command } from "@commander-js/extra-typings";
import { chalkStderr } from "chalk";
import { oneoffContext } from "../bundler/context.js";
import {
loadSelectedDeploymentCredentials
} from "./lib/api.js";
import { actionDescription } from "./lib/command.js";
import { ensureHasConvexDependency } from "./lib/utils/utils.js";
import {
deploymentEnvBackend,
envGet,
envList,
envRemove,
envSet
} from "./lib/env.js";
import { getDeploymentSelection } from "./lib/deploymentSelection.js";
import { withRunningBackend } from "./lib/localDeployment/run.js";
import { envDefault } from "./envDefault.js";
const envSetCmd = new Command("set").usage("[options] <name> <value>").argument("[name]", "The name of the environment variable to set.").argument(
"[value]",
"The value to set the variable to. Omit to set it interactively."
).summary("Set a variable").description(
[
"Set environment variables on your deployment.",
"",
"\u2022 `npx convex env set NAME 'value'`",
"\u2022 `npx convex env set NAME # omit a value to set one interactively`",
"\u2022 `npx convex env set NAME --from-file value.txt`",
"\u2022 `npx convex env set --from-file .env.defaults`",
"",
"When setting multiple values, it will refuse all changes if any variables are already set to different values by default. Pass --force to overwrite the provided values.",
"",
"To keep secrets out of your shell history, omit the value to pipe it in via stdin, for instance:",
"\u2022 `pbpaste | npx convex env set API_KEY` (macOS)",
"\u2022 `Get-Clipboard | npx convex env set API_KEY` (Windows PowerShell)",
"",
"To update many variables at once, save them with `npx convex env list > .env.convex`, edit the file, then reapply the changes with `npx convex env set --force < .env.convex`."
].join("\n")
).option(
"--from-file <file>",
"Read environment variables from a .env file. Without --force, fails if any existing variable has a different value."
).option(
"--force",
"When setting multiple variables, overwrite existing environment variable values instead of failing on mismatch."
).configureHelp({ showGlobalOptions: true }).allowExcessArguments(false).action(async (name, value, cmdOptions, cmd) => {
const options = cmd.optsWithGlobals();
const { ctx, deployment } = await selectEnvDeployment(options);
await ensureHasConvexDependency(ctx, "env set");
await withRunningBackend({
ctx,
deployment,
action: async () => {
const backend = deploymentEnvBackend(ctx, deployment);
const didAnything = await envSet(ctx, backend, name, value, cmdOptions);
if (didAnything === false) {
cmd.outputHelp({ error: true });
return await ctx.crash({
exitCode: 1,
errorType: "fatal",
printedMessage: "error: No environment variables specified to be set."
});
}
}
});
});
export async function selectEnvDeployment(options) {
const ctx = await oneoffContext(options);
const deploymentSelection = await getDeploymentSelection(ctx, options);
const {
adminKey,
url: deploymentUrl,
deploymentFields
} = await loadSelectedDeploymentCredentials(ctx, deploymentSelection, {
ensureLocalRunning: false
});
const deploymentNotice = deploymentFields !== null ? ` (on ${chalkStderr.bold(deploymentFields.deploymentType)} deployment ${chalkStderr.bold(deploymentFields.deploymentName)})` : "";
const result = {
ctx,
deployment: {
deploymentUrl,
adminKey,
deploymentNotice,
deploymentFields
}
};
return result;
}
const envGetCmd = new Command("get").argument("<name>", "The name of the environment variable to print.").summary("Print a variable's value").description("Print a variable's value: `npx convex env get NAME`").configureHelp({ showGlobalOptions: true }).allowExcessArguments(false).action(async (envVarName, _options, cmd) => {
const options = cmd.optsWithGlobals();
const { ctx, deployment } = await selectEnvDeployment(options);
await ensureHasConvexDependency(ctx, "env get");
await withRunningBackend({
ctx,
deployment,
action: async () => {
const backend = deploymentEnvBackend(ctx, deployment);
await envGet(ctx, backend, envVarName);
}
});
});
const envRemoveCmd = new Command("remove").alias("rm").alias("unset").argument("<name>", "The name of the environment variable to unset.").summary("Unset a variable").description(
"Unset a variable: `npx convex env remove NAME`\nIf the variable doesn't exist, the command doesn't do anything and succeeds."
).configureHelp({ showGlobalOptions: true }).allowExcessArguments(false).action(async (name, _options, cmd) => {
const options = cmd.optsWithGlobals();
const { ctx, deployment } = await selectEnvDeployment(options);
await ensureHasConvexDependency(ctx, "env remove");
await withRunningBackend({
ctx,
deployment,
action: async () => {
const backend = deploymentEnvBackend(ctx, deployment);
await envRemove(ctx, backend, name);
}
});
});
const envListCmd = new Command("list").summary("List all environment variables and their values").description(
[
"\u2022 List all variables and their values: `npx convex env list`",
"\u2022 List only variable names (no values): `npx convex env list --names-only`",
"\u2022 Save all variables to a file: `npx convex env list > .env.convex`",
"\u2022 Append to a file: `npx convex env list >> .env.convex`"
].join("\n")
).option(
"--names-only",
"List only the names of environment variables, without their values"
).configureHelp({ showGlobalOptions: true }).allowExcessArguments(false).action(async (cmdOptions, cmd) => {
const options = cmd.optsWithGlobals();
const { ctx, deployment } = await selectEnvDeployment(options);
await ensureHasConvexDependency(ctx, "env list");
await withRunningBackend({
ctx,
deployment,
action: async () => {
const backend = deploymentEnvBackend(ctx, deployment);
await envList(ctx, backend, {
namesOnly: cmdOptions.namesOnly ?? false
});
}
});
});
export const env = new Command("env").summary("Set and view environment variables").description(
[
"Set and view environment variables on your deployment",
"",
"\u2022 Set a variable: `npx convex env set NAME 'value'`",
"\u2022 Set interactively: `npx convex env set NAME`",
"\u2022 Set multiple from file: `npx convex env set --from-file .env`",
"\u2022 Unset a variable: `npx convex env remove NAME`",
"\u2022 List all variables and their values: `npx convex env list`",
"\u2022 List only variable names (no values): `npx convex env list --names-only`",
"\u2022 Print a variable's value: `npx convex env get NAME`",
"",
"By default, this sets and views variables on your dev deployment.",
"",
"See the environment variables guide (https://docs.convex.dev/production/environment-variables) to learn more."
].join("\n")
).addCommand(envSetCmd).addCommand(envGetCmd).addCommand(envRemoveCmd).addCommand(envListCmd).addCommand(envDefault).helpCommand(false).addDeploymentSelectionOptions(
actionDescription("Set and view environment variables on")
);
//# sourceMappingURL=env.js.map