@rehpic/vcli 0.1.0-beta.24.1 → 0.1.0-beta.26.1
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/index.js +8 -18
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -789,6 +789,9 @@ function applySetCookieHeaders(session, response) {
|
|
|
789
789
|
async function authRequest(session, appUrl, pathname, init = {}) {
|
|
790
790
|
const headers = new Headers(init.headers);
|
|
791
791
|
const origin = new URL(appUrl).origin;
|
|
792
|
+
if (session.bearerToken && !headers.has("authorization")) {
|
|
793
|
+
headers.set("authorization", `Bearer ${session.bearerToken}`);
|
|
794
|
+
}
|
|
792
795
|
if (Object.keys(session.cookies).length > 0) {
|
|
793
796
|
headers.set("cookie", cookieHeader(session.cookies));
|
|
794
797
|
}
|
|
@@ -940,21 +943,7 @@ async function pollDeviceToken(session, appUrl, deviceCode, clientId, interval,
|
|
|
940
943
|
if (response.ok) {
|
|
941
944
|
const data = await response.json();
|
|
942
945
|
if (data.access_token) {
|
|
943
|
-
|
|
944
|
-
return session;
|
|
945
|
-
}
|
|
946
|
-
const sessionResp = await fetch(
|
|
947
|
-
buildUrl(appUrl, "/api/auth/get-session"),
|
|
948
|
-
{
|
|
949
|
-
headers: {
|
|
950
|
-
authorization: `Bearer ${data.access_token}`
|
|
951
|
-
}
|
|
952
|
-
}
|
|
953
|
-
);
|
|
954
|
-
if (sessionResp.ok) {
|
|
955
|
-
const updated = applySetCookieHeaders(session, sessionResp);
|
|
956
|
-
return updated;
|
|
957
|
-
}
|
|
946
|
+
session.bearerToken = data.access_token;
|
|
958
947
|
return session;
|
|
959
948
|
}
|
|
960
949
|
}
|
|
@@ -1331,9 +1320,10 @@ async function getRuntime(command) {
|
|
|
1331
1320
|
const session = await readSession(profile);
|
|
1332
1321
|
const appUrlSource = options.appUrl ?? session?.appUrl ?? process.env.NEXT_PUBLIC_APP_URL;
|
|
1333
1322
|
const appUrl = await resolveAppUrl(requiredString(appUrlSource, "app URL"));
|
|
1334
|
-
let convexUrl = options.convexUrl ?? session?.convexUrl
|
|
1323
|
+
let convexUrl = options.convexUrl ?? session?.convexUrl;
|
|
1335
1324
|
if (!convexUrl) {
|
|
1336
|
-
|
|
1325
|
+
const fetchedUrl = await fetchConvexUrl(appUrl);
|
|
1326
|
+
convexUrl = fetchedUrl !== "http://127.0.0.1:3210" ? fetchedUrl : process.env.NEXT_PUBLIC_CONVEX_URL ?? process.env.CONVEX_URL ?? fetchedUrl;
|
|
1337
1327
|
}
|
|
1338
1328
|
return {
|
|
1339
1329
|
appUrl,
|
|
@@ -1345,7 +1335,7 @@ async function getRuntime(command) {
|
|
|
1345
1335
|
};
|
|
1346
1336
|
}
|
|
1347
1337
|
function requireSession(runtime) {
|
|
1348
|
-
if (!runtime.session || Object.keys(runtime.session.cookies).length === 0) {
|
|
1338
|
+
if (!runtime.session || Object.keys(runtime.session.cookies).length === 0 && !runtime.session.bearerToken) {
|
|
1349
1339
|
throw new Error("Not logged in. Run `vcli auth login` first.");
|
|
1350
1340
|
}
|
|
1351
1341
|
return runtime.session;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../node_modules/.pnpm/is-docker@3.0.0/node_modules/is-docker/index.js","../../../node_modules/.pnpm/is-inside-container@1.0.0/node_modules/is-inside-container/index.js","../../../node_modules/.pnpm/is-wsl@3.1.1/node_modules/is-wsl/index.js","../../../node_modules/.pnpm/powershell-utils@0.1.0/node_modules/powershell-utils/index.js","../../../node_modules/.pnpm/wsl-utils@0.3.1/node_modules/wsl-utils/utilities.js","../../../node_modules/.pnpm/wsl-utils@0.3.1/node_modules/wsl-utils/index.js","../../../node_modules/.pnpm/define-lazy-prop@3.0.0/node_modules/define-lazy-prop/index.js","../../../node_modules/.pnpm/default-browser-id@5.0.1/node_modules/default-browser-id/index.js","../../../node_modules/.pnpm/run-applescript@7.1.0/node_modules/run-applescript/index.js","../../../node_modules/.pnpm/bundle-name@4.1.0/node_modules/bundle-name/index.js","../../../node_modules/.pnpm/default-browser@5.5.0/node_modules/default-browser/windows.js","../../../node_modules/.pnpm/default-browser@5.5.0/node_modules/default-browser/index.js","../../../node_modules/.pnpm/is-in-ssh@1.0.0/node_modules/is-in-ssh/index.js","../../../node_modules/.pnpm/open@11.0.0/node_modules/open/index.js","../../../src/cli/index.ts","../../../convex/_generated/api.js","../../../src/cli/auth.ts","../../../src/cli/convex.ts","../../../src/cli/output.ts","../../../src/cli/session.ts"],"sourcesContent":["import fs from 'node:fs';\n\nlet isDockerCached;\n\nfunction hasDockerEnv() {\n\ttry {\n\t\tfs.statSync('/.dockerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nfunction hasDockerCGroup() {\n\ttry {\n\t\treturn fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nexport default function isDocker() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (isDockerCached === undefined) {\n\t\tisDockerCached = hasDockerEnv() || hasDockerCGroup();\n\t}\n\n\treturn isDockerCached;\n}\n","import fs from 'node:fs';\nimport isDocker from 'is-docker';\n\nlet cachedResult;\n\n// Podman detection\nconst hasContainerEnv = () => {\n\ttry {\n\t\tfs.statSync('/run/.containerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default function isInsideContainer() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (cachedResult === undefined) {\n\t\tcachedResult = hasContainerEnv() || isDocker();\n\t}\n\n\treturn cachedResult;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nimport isInsideContainer from 'is-inside-container';\n\nconst isWsl = () => {\n\tif (process.platform !== 'linux') {\n\t\treturn false;\n\t}\n\n\tif (os.release().toLowerCase().includes('microsoft')) {\n\t\tif (isInsideContainer()) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\ttry {\n\t\tif (fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft')) {\n\t\t\treturn !isInsideContainer();\n\t\t}\n\t} catch {}\n\n\t// Fallback for custom kernels: check WSL-specific paths.\n\tif (\n\t\tfs.existsSync('/proc/sys/fs/binfmt_misc/WSLInterop')\n\t\t|| fs.existsSync('/run/WSL')\n\t) {\n\t\treturn !isInsideContainer();\n\t}\n\n\treturn false;\n};\n\nexport default process.env.__IS_WSL_TEST__ ? isWsl : isWsl();\n","import process from 'node:process';\nimport {Buffer} from 'node:buffer';\nimport {promisify} from 'node:util';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\n\nconst execFile = promisify(childProcess.execFile);\n\nexport const powerShellPath = () => `${process.env.SYSTEMROOT || process.env.windir || String.raw`C:\\Windows`}\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell.exe`;\n\n// Cache for PowerShell accessibility check\nlet canAccessCache;\n\nexport const canAccessPowerShell = async () => {\n\tcanAccessCache ??= (async () => {\n\t\ttry {\n\t\t\tawait fs.access(powerShellPath(), fsConstants.X_OK);\n\t\t\treturn true;\n\t\t} catch {\n\t\t\treturn false;\n\t\t}\n\t})();\n\n\treturn canAccessCache;\n};\n\nexport const executePowerShell = async (command, options = {}) => {\n\tconst {\n\t\tpowerShellPath: psPath,\n\t\t...execFileOptions\n\t} = options;\n\n\tconst encodedCommand = executePowerShell.encodeCommand(command);\n\n\treturn execFile(\n\t\tpsPath ?? powerShellPath(),\n\t\t[\n\t\t\t...executePowerShell.argumentsPrefix,\n\t\t\tencodedCommand,\n\t\t],\n\t\t{\n\t\t\tencoding: 'utf8',\n\t\t\t...execFileOptions,\n\t\t},\n\t);\n};\n\nexecutePowerShell.argumentsPrefix = [\n\t'-NoProfile',\n\t'-NonInteractive',\n\t'-ExecutionPolicy',\n\t'Bypass',\n\t'-EncodedCommand',\n];\n\nexecutePowerShell.encodeCommand = command => Buffer.from(command, 'utf16le').toString('base64');\n\nexecutePowerShell.escapeArgument = value => `'${String(value).replaceAll('\\'', '\\'\\'')}'`;\n","export function parseMountPointFromConfig(content) {\n\tfor (const line of content.split('\\n')) {\n\t\t// Skip comment lines\n\t\tif (/^\\s*#/.test(line)) {\n\t\t\tcontinue;\n\t\t}\n\n\t\t// Match root at start of line (after optional whitespace)\n\t\tconst match = /^\\s*root\\s*=\\s*(?<mountPoint>\"[^\"]*\"|'[^']*'|[^#]*)/.exec(line);\n\t\tif (!match) {\n\t\t\tcontinue;\n\t\t}\n\n\t\treturn match.groups.mountPoint\n\t\t\t.trim()\n\t\t\t// Strip surrounding quotes\n\t\t\t.replaceAll(/^[\"']|[\"']$/g, '');\n\t}\n}\n","import {promisify} from 'node:util';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\nimport isWsl from 'is-wsl';\nimport {powerShellPath as windowsPowerShellPath, executePowerShell} from 'powershell-utils';\nimport {parseMountPointFromConfig} from './utilities.js';\n\nconst execFile = promisify(childProcess.execFile);\n\nexport const wslDrivesMountPoint = (() => {\n\t// Default value for \"root\" param\n\t// according to https://docs.microsoft.com/en-us/windows/wsl/wsl-config\n\tconst defaultMountPoint = '/mnt/';\n\n\tlet mountPoint;\n\n\treturn async function () {\n\t\tif (mountPoint) {\n\t\t\t// Return memoized mount point value\n\t\t\treturn mountPoint;\n\t\t}\n\n\t\tconst configFilePath = '/etc/wsl.conf';\n\n\t\tlet isConfigFileExists = false;\n\t\ttry {\n\t\t\tawait fs.access(configFilePath, fsConstants.F_OK);\n\t\t\tisConfigFileExists = true;\n\t\t} catch {}\n\n\t\tif (!isConfigFileExists) {\n\t\t\treturn defaultMountPoint;\n\t\t}\n\n\t\tconst configContent = await fs.readFile(configFilePath, {encoding: 'utf8'});\n\t\tconst parsedMountPoint = parseMountPointFromConfig(configContent);\n\n\t\tif (parsedMountPoint === undefined) {\n\t\t\treturn defaultMountPoint;\n\t\t}\n\n\t\tmountPoint = parsedMountPoint;\n\t\tmountPoint = mountPoint.endsWith('/') ? mountPoint : `${mountPoint}/`;\n\n\t\treturn mountPoint;\n\t};\n})();\n\nexport const powerShellPathFromWsl = async () => {\n\tconst mountPoint = await wslDrivesMountPoint();\n\treturn `${mountPoint}c/Windows/System32/WindowsPowerShell/v1.0/powershell.exe`;\n};\n\nexport const powerShellPath = isWsl ? powerShellPathFromWsl : windowsPowerShellPath;\n\n// Cache for PowerShell accessibility check\nlet canAccessPowerShellPromise;\n\nexport const canAccessPowerShell = async () => {\n\tcanAccessPowerShellPromise ??= (async () => {\n\t\ttry {\n\t\t\tconst psPath = await powerShellPath();\n\t\t\tawait fs.access(psPath, fsConstants.X_OK);\n\t\t\treturn true;\n\t\t} catch {\n\t\t\t// PowerShell is not accessible (either doesn't exist, no execute permission, or other error)\n\t\t\treturn false;\n\t\t}\n\t})();\n\n\treturn canAccessPowerShellPromise;\n};\n\nexport const wslDefaultBrowser = async () => {\n\tconst psPath = await powerShellPath();\n\tconst command = String.raw`(Get-ItemProperty -Path \"HKCU:\\Software\\Microsoft\\Windows\\Shell\\Associations\\UrlAssociations\\http\\UserChoice\").ProgId`;\n\n\tconst {stdout} = await executePowerShell(command, {powerShellPath: psPath});\n\n\treturn stdout.trim();\n};\n\nexport const convertWslPathToWindows = async path => {\n\t// Don't convert URLs\n\tif (/^[a-z]+:\\/\\//i.test(path)) {\n\t\treturn path;\n\t}\n\n\ttry {\n\t\tconst {stdout} = await execFile('wslpath', ['-aw', path], {encoding: 'utf8'});\n\t\treturn stdout.trim();\n\t} catch {\n\t\t// If wslpath fails, return the original path\n\t\treturn path;\n\t}\n};\n\nexport {default as isWsl} from 'is-wsl';\n","export default function defineLazyProperty(object, propertyName, valueGetter) {\n\tconst define = value => Object.defineProperty(object, propertyName, {value, enumerable: true, writable: true});\n\n\tObject.defineProperty(object, propertyName, {\n\t\tconfigurable: true,\n\t\tenumerable: true,\n\t\tget() {\n\t\t\tconst result = valueGetter();\n\t\t\tdefine(result);\n\t\t\treturn result;\n\t\t},\n\t\tset(value) {\n\t\t\tdefine(value);\n\t\t}\n\t});\n\n\treturn object;\n}\n","import {promisify} from 'node:util';\nimport process from 'node:process';\nimport {execFile} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\nexport default async function defaultBrowserId() {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst {stdout} = await execFileAsync('defaults', ['read', 'com.apple.LaunchServices/com.apple.launchservices.secure', 'LSHandlers']);\n\n\t// `(?!-)` is to prevent matching `LSHandlerRoleAll = \"-\";`.\n\tconst match = /LSHandlerRoleAll = \"(?!-)(?<id>[^\"]+?)\";\\s+?LSHandlerURLScheme = (?:http|https);/.exec(stdout);\n\n\tconst browserId = match?.groups.id ?? 'com.apple.Safari';\n\n\t// Correct the case for Safari's bundle identifier\n\tif (browserId === 'com.apple.safari') {\n\t\treturn 'com.apple.Safari';\n\t}\n\n\treturn browserId;\n}\n","import process from 'node:process';\nimport {promisify} from 'node:util';\nimport {execFile, execFileSync} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\nexport async function runAppleScript(script, {humanReadableOutput = true, signal} = {}) {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst outputArguments = humanReadableOutput ? [] : ['-ss'];\n\n\tconst execOptions = {};\n\tif (signal) {\n\t\texecOptions.signal = signal;\n\t}\n\n\tconst {stdout} = await execFileAsync('osascript', ['-e', script, outputArguments], execOptions);\n\treturn stdout.trim();\n}\n\nexport function runAppleScriptSync(script, {humanReadableOutput = true} = {}) {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst outputArguments = humanReadableOutput ? [] : ['-ss'];\n\n\tconst stdout = execFileSync('osascript', ['-e', script, ...outputArguments], {\n\t\tencoding: 'utf8',\n\t\tstdio: ['ignore', 'pipe', 'ignore'],\n\t\ttimeout: 500,\n\t});\n\n\treturn stdout.trim();\n}\n","import {runAppleScript} from 'run-applescript';\n\nexport default async function bundleName(bundleId) {\n\treturn runAppleScript(`tell application \"Finder\" to set app_path to application file id \"${bundleId}\" as string\\ntell application \"System Events\" to get value of property list item \"CFBundleName\" of property list file (app_path & \":Contents:Info.plist\")`);\n}\n","import {promisify} from 'node:util';\nimport {execFile} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\n// TODO: Fix the casing of bundle identifiers in the next major version.\n\n// Windows doesn't have browser IDs in the same way macOS/Linux does so we give fake\n// ones that look real and match the macOS/Linux versions for cross-platform apps.\nconst windowsBrowserProgIds = {\n\tMSEdgeHTM: {name: 'Edge', id: 'com.microsoft.edge'}, // The missing `L` is correct.\n\tMSEdgeBHTML: {name: 'Edge Beta', id: 'com.microsoft.edge.beta'},\n\tMSEdgeDHTML: {name: 'Edge Dev', id: 'com.microsoft.edge.dev'},\n\tAppXq0fevzme2pys62n3e0fbqa7peapykr8v: {name: 'Edge', id: 'com.microsoft.edge.old'},\n\tChromeHTML: {name: 'Chrome', id: 'com.google.chrome'},\n\tChromeBHTML: {name: 'Chrome Beta', id: 'com.google.chrome.beta'},\n\tChromeDHTML: {name: 'Chrome Dev', id: 'com.google.chrome.dev'},\n\tChromiumHTM: {name: 'Chromium', id: 'org.chromium.Chromium'},\n\tBraveHTML: {name: 'Brave', id: 'com.brave.Browser'},\n\tBraveBHTML: {name: 'Brave Beta', id: 'com.brave.Browser.beta'},\n\tBraveDHTML: {name: 'Brave Dev', id: 'com.brave.Browser.dev'},\n\tBraveSSHTM: {name: 'Brave Nightly', id: 'com.brave.Browser.nightly'},\n\tFirefoxURL: {name: 'Firefox', id: 'org.mozilla.firefox'},\n\tOperaStable: {name: 'Opera', id: 'com.operasoftware.Opera'},\n\tVivaldiHTM: {name: 'Vivaldi', id: 'com.vivaldi.Vivaldi'},\n\t'IE.HTTP': {name: 'Internet Explorer', id: 'com.microsoft.ie'},\n};\n\nexport const _windowsBrowserProgIdMap = new Map(Object.entries(windowsBrowserProgIds));\n\nexport class UnknownBrowserError extends Error {}\n\nexport default async function defaultBrowser(_execFileAsync = execFileAsync) {\n\tconst {stdout} = await _execFileAsync('reg', [\n\t\t'QUERY',\n\t\t' HKEY_CURRENT_USER\\\\Software\\\\Microsoft\\\\Windows\\\\Shell\\\\Associations\\\\UrlAssociations\\\\http\\\\UserChoice',\n\t\t'/v',\n\t\t'ProgId',\n\t]);\n\n\tconst match = /ProgId\\s*REG_SZ\\s*(?<id>\\S+)/.exec(stdout);\n\tif (!match) {\n\t\tthrow new UnknownBrowserError(`Cannot find Windows browser in stdout: ${JSON.stringify(stdout)}`);\n\t}\n\n\tconst {id} = match.groups;\n\n\t// Windows can append a hash suffix to ProgIds using a dot or hyphen\n\t// (e.g., `ChromeHTML.ABC123`, `FirefoxURL-6F193CCC56814779`).\n\t// Try exact match first, then try without the suffix.\n\tconst dotIndex = id.lastIndexOf('.');\n\tconst hyphenIndex = id.lastIndexOf('-');\n\tconst baseIdByDot = dotIndex === -1 ? undefined : id.slice(0, dotIndex);\n\tconst baseIdByHyphen = hyphenIndex === -1 ? undefined : id.slice(0, hyphenIndex);\n\n\treturn windowsBrowserProgIds[id] ?? windowsBrowserProgIds[baseIdByDot] ?? windowsBrowserProgIds[baseIdByHyphen] ?? {name: id, id};\n}\n","import {promisify} from 'node:util';\nimport process from 'node:process';\nimport {execFile} from 'node:child_process';\nimport defaultBrowserId from 'default-browser-id';\nimport bundleName from 'bundle-name';\nimport windows from './windows.js';\n\nexport {_windowsBrowserProgIdMap} from './windows.js';\n\nconst execFileAsync = promisify(execFile);\n\n// Inlined: https://github.com/sindresorhus/titleize/blob/main/index.js\nconst titleize = string => string.toLowerCase().replaceAll(/(?:^|\\s|-)\\S/g, x => x.toUpperCase());\n\nexport default async function defaultBrowser() {\n\tif (process.platform === 'darwin') {\n\t\tconst id = await defaultBrowserId();\n\t\tconst name = await bundleName(id);\n\t\treturn {name, id};\n\t}\n\n\tif (process.platform === 'linux') {\n\t\tconst {stdout} = await execFileAsync('xdg-mime', ['query', 'default', 'x-scheme-handler/http']);\n\t\tconst id = stdout.trim();\n\t\tconst name = titleize(id.replace(/.desktop$/, '').replace('-', ' '));\n\t\treturn {name, id};\n\t}\n\n\tif (process.platform === 'win32') {\n\t\treturn windows();\n\t}\n\n\tthrow new Error('Only macOS, Linux, and Windows are supported');\n}\n","import process from 'node:process';\n\nconst isInSsh = Boolean(process.env.SSH_CONNECTION\n\t|| process.env.SSH_CLIENT\n\t|| process.env.SSH_TTY);\n\nexport default isInSsh;\n","import process from 'node:process';\nimport path from 'node:path';\nimport {fileURLToPath} from 'node:url';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\nimport {\n\tisWsl,\n\tpowerShellPath,\n\tconvertWslPathToWindows,\n\tcanAccessPowerShell,\n\twslDefaultBrowser,\n} from 'wsl-utils';\nimport {executePowerShell} from 'powershell-utils';\nimport defineLazyProperty from 'define-lazy-prop';\nimport defaultBrowser, {_windowsBrowserProgIdMap} from 'default-browser';\nimport isInsideContainer from 'is-inside-container';\nimport isInSsh from 'is-in-ssh';\n\nconst fallbackAttemptSymbol = Symbol('fallbackAttempt');\n\n// Path to included `xdg-open`.\nconst __dirname = import.meta.url ? path.dirname(fileURLToPath(import.meta.url)) : '';\nconst localXdgOpenPath = path.join(__dirname, 'xdg-open');\n\nconst {platform, arch} = process;\n\nconst tryEachApp = async (apps, opener) => {\n\tif (apps.length === 0) {\n\t\t// No app was provided\n\t\treturn;\n\t}\n\n\tconst errors = [];\n\n\tfor (const app of apps) {\n\t\ttry {\n\t\t\treturn await opener(app); // eslint-disable-line no-await-in-loop\n\t\t} catch (error) {\n\t\t\terrors.push(error);\n\t\t}\n\t}\n\n\tthrow new AggregateError(errors, 'Failed to open in all supported apps');\n};\n\n// eslint-disable-next-line complexity\nconst baseOpen = async options => {\n\toptions = {\n\t\twait: false,\n\t\tbackground: false,\n\t\tnewInstance: false,\n\t\tallowNonzeroExitCode: false,\n\t\t...options,\n\t};\n\n\tconst isFallbackAttempt = options[fallbackAttemptSymbol] === true;\n\tdelete options[fallbackAttemptSymbol];\n\n\tif (Array.isArray(options.app)) {\n\t\treturn tryEachApp(options.app, singleApp => baseOpen({\n\t\t\t...options,\n\t\t\tapp: singleApp,\n\t\t\t[fallbackAttemptSymbol]: true,\n\t\t}));\n\t}\n\n\tlet {name: app, arguments: appArguments = []} = options.app ?? {};\n\tappArguments = [...appArguments];\n\n\tif (Array.isArray(app)) {\n\t\treturn tryEachApp(app, appName => baseOpen({\n\t\t\t...options,\n\t\t\tapp: {\n\t\t\t\tname: appName,\n\t\t\t\targuments: appArguments,\n\t\t\t},\n\t\t\t[fallbackAttemptSymbol]: true,\n\t\t}));\n\t}\n\n\tif (app === 'browser' || app === 'browserPrivate') {\n\t\t// IDs from default-browser for macOS and windows are the same.\n\t\t// IDs are lowercased to increase chances of a match.\n\t\tconst ids = {\n\t\t\t'com.google.chrome': 'chrome',\n\t\t\t'google-chrome.desktop': 'chrome',\n\t\t\t'com.brave.browser': 'brave',\n\t\t\t'org.mozilla.firefox': 'firefox',\n\t\t\t'firefox.desktop': 'firefox',\n\t\t\t'com.microsoft.msedge': 'edge',\n\t\t\t'com.microsoft.edge': 'edge',\n\t\t\t'com.microsoft.edgemac': 'edge',\n\t\t\t'microsoft-edge.desktop': 'edge',\n\t\t\t'com.apple.safari': 'safari',\n\t\t};\n\n\t\t// Incognito flags for each browser in `apps`.\n\t\tconst flags = {\n\t\t\tchrome: '--incognito',\n\t\t\tbrave: '--incognito',\n\t\t\tfirefox: '--private-window',\n\t\t\tedge: '--inPrivate',\n\t\t\t// Safari doesn't support private mode via command line\n\t\t};\n\n\t\tlet browser;\n\t\tif (isWsl) {\n\t\t\tconst progId = await wslDefaultBrowser();\n\t\t\tconst browserInfo = _windowsBrowserProgIdMap.get(progId);\n\t\t\tbrowser = browserInfo ?? {};\n\t\t} else {\n\t\t\tbrowser = await defaultBrowser();\n\t\t}\n\n\t\tif (browser.id in ids) {\n\t\t\tconst browserName = ids[browser.id.toLowerCase()];\n\n\t\t\tif (app === 'browserPrivate') {\n\t\t\t\t// Safari doesn't support private mode via command line\n\t\t\t\tif (browserName === 'safari') {\n\t\t\t\t\tthrow new Error('Safari doesn\\'t support opening in private mode via command line');\n\t\t\t\t}\n\n\t\t\t\tappArguments.push(flags[browserName]);\n\t\t\t}\n\n\t\t\treturn baseOpen({\n\t\t\t\t...options,\n\t\t\t\tapp: {\n\t\t\t\t\tname: apps[browserName],\n\t\t\t\t\targuments: appArguments,\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\tthrow new Error(`${browser.name} is not supported as a default browser`);\n\t}\n\n\tlet command;\n\tconst cliArguments = [];\n\tconst childProcessOptions = {};\n\n\t// Determine if we should use Windows/PowerShell behavior in WSL.\n\t// We only use Windows integration if PowerShell is actually accessible.\n\t// This allows the package to work in sandboxed WSL environments where Windows access is restricted.\n\tlet shouldUseWindowsInWsl = false;\n\tif (isWsl && !isInsideContainer() && !isInSsh && !app) {\n\t\tshouldUseWindowsInWsl = await canAccessPowerShell();\n\t}\n\n\tif (platform === 'darwin') {\n\t\tcommand = 'open';\n\n\t\tif (options.wait) {\n\t\t\tcliArguments.push('--wait-apps');\n\t\t}\n\n\t\tif (options.background) {\n\t\t\tcliArguments.push('--background');\n\t\t}\n\n\t\tif (options.newInstance) {\n\t\t\tcliArguments.push('--new');\n\t\t}\n\n\t\tif (app) {\n\t\t\tcliArguments.push('-a', app);\n\t\t}\n\t} else if (platform === 'win32' || shouldUseWindowsInWsl) {\n\t\tcommand = await powerShellPath();\n\n\t\tcliArguments.push(...executePowerShell.argumentsPrefix);\n\n\t\tif (!isWsl) {\n\t\t\tchildProcessOptions.windowsVerbatimArguments = true;\n\t\t}\n\n\t\t// Convert WSL Linux paths to Windows paths\n\t\tif (isWsl && options.target) {\n\t\t\toptions.target = await convertWslPathToWindows(options.target);\n\t\t}\n\n\t\t// Suppress PowerShell progress messages that are written to stderr\n\t\tconst encodedArguments = ['$ProgressPreference = \\'SilentlyContinue\\';', 'Start'];\n\n\t\tif (options.wait) {\n\t\t\tencodedArguments.push('-Wait');\n\t\t}\n\n\t\tif (app) {\n\t\t\tencodedArguments.push(executePowerShell.escapeArgument(app));\n\t\t\tif (options.target) {\n\t\t\t\tappArguments.push(options.target);\n\t\t\t}\n\t\t} else if (options.target) {\n\t\t\tencodedArguments.push(executePowerShell.escapeArgument(options.target));\n\t\t}\n\n\t\tif (appArguments.length > 0) {\n\t\t\tappArguments = appArguments.map(argument => executePowerShell.escapeArgument(argument));\n\t\t\tencodedArguments.push('-ArgumentList', appArguments.join(','));\n\t\t}\n\n\t\t// Using Base64-encoded command, accepted by PowerShell, to allow special characters.\n\t\toptions.target = executePowerShell.encodeCommand(encodedArguments.join(' '));\n\n\t\tif (!options.wait) {\n\t\t\t// PowerShell will keep the parent process alive unless stdio is ignored.\n\t\t\tchildProcessOptions.stdio = 'ignore';\n\t\t}\n\t} else {\n\t\tif (app) {\n\t\t\tcommand = app;\n\t\t} else {\n\t\t\t// When bundled by Webpack, there's no actual package file path and no local `xdg-open`.\n\t\t\tconst isBundled = !__dirname || __dirname === '/';\n\n\t\t\t// Check if local `xdg-open` exists and is executable.\n\t\t\tlet exeLocalXdgOpen = false;\n\t\t\ttry {\n\t\t\t\tawait fs.access(localXdgOpenPath, fsConstants.X_OK);\n\t\t\t\texeLocalXdgOpen = true;\n\t\t\t} catch {}\n\n\t\t\tconst useSystemXdgOpen = process.versions.electron\n\t\t\t\t?? (platform === 'android' || isBundled || !exeLocalXdgOpen);\n\t\t\tcommand = useSystemXdgOpen ? 'xdg-open' : localXdgOpenPath;\n\t\t}\n\n\t\tif (appArguments.length > 0) {\n\t\t\tcliArguments.push(...appArguments);\n\t\t}\n\n\t\tif (!options.wait) {\n\t\t\t// `xdg-open` will block the process unless stdio is ignored\n\t\t\t// and it's detached from the parent even if it's unref'd.\n\t\t\tchildProcessOptions.stdio = 'ignore';\n\t\t\tchildProcessOptions.detached = true;\n\t\t}\n\t}\n\n\tif (platform === 'darwin' && appArguments.length > 0) {\n\t\tcliArguments.push('--args', ...appArguments);\n\t}\n\n\t// IMPORTANT: On macOS, the target MUST come AFTER '--args'.\n\t// When using --args, ALL following arguments are passed to the app.\n\t// Example: open -a \"chrome\" --args --incognito https://site.com\n\t// This passes BOTH --incognito AND https://site.com to Chrome.\n\t// Without this order, Chrome won't open in incognito. See #332.\n\tif (options.target) {\n\t\tcliArguments.push(options.target);\n\t}\n\n\tconst subprocess = childProcess.spawn(command, cliArguments, childProcessOptions);\n\n\tif (options.wait) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tsubprocess.once('error', reject);\n\n\t\t\tsubprocess.once('close', exitCode => {\n\t\t\t\tif (!options.allowNonzeroExitCode && exitCode !== 0) {\n\t\t\t\t\treject(new Error(`Exited with code ${exitCode}`));\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tresolve(subprocess);\n\t\t\t});\n\t\t});\n\t}\n\n\t// When we're in a fallback attempt, we need to detect launch failures before trying the next app.\n\t// Wait for the close event to check the exit code before unreffing.\n\t// The launcher (open/xdg-open/PowerShell) exits quickly (~10-30ms) even on success.\n\tif (isFallbackAttempt) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tsubprocess.once('error', reject);\n\n\t\t\tsubprocess.once('spawn', () => {\n\t\t\t\t// Keep error handler active for post-spawn errors\n\t\t\t\tsubprocess.once('close', exitCode => {\n\t\t\t\t\tsubprocess.off('error', reject);\n\n\t\t\t\t\tif (exitCode !== 0) {\n\t\t\t\t\t\treject(new Error(`Exited with code ${exitCode}`));\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tsubprocess.unref();\n\t\t\t\t\tresolve(subprocess);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n\n\tsubprocess.unref();\n\n\t// Handle spawn errors before the caller can attach listeners.\n\t// This prevents unhandled error events from crashing the process.\n\treturn new Promise((resolve, reject) => {\n\t\tsubprocess.once('error', reject);\n\n\t\t// Wait for the subprocess to spawn before resolving.\n\t\t// This ensures the process is established before the caller continues,\n\t\t// preventing issues when process.exit() is called immediately after.\n\t\tsubprocess.once('spawn', () => {\n\t\t\tsubprocess.off('error', reject);\n\t\t\tresolve(subprocess);\n\t\t});\n\t});\n};\n\nconst open = (target, options) => {\n\tif (typeof target !== 'string') {\n\t\tthrow new TypeError('Expected a `target`');\n\t}\n\n\treturn baseOpen({\n\t\t...options,\n\t\ttarget,\n\t});\n};\n\nexport const openApp = (name, options) => {\n\tif (typeof name !== 'string' && !Array.isArray(name)) {\n\t\tthrow new TypeError('Expected a valid `name`');\n\t}\n\n\tconst {arguments: appArguments = []} = options ?? {};\n\tif (appArguments !== undefined && appArguments !== null && !Array.isArray(appArguments)) {\n\t\tthrow new TypeError('Expected `appArguments` as Array type');\n\t}\n\n\treturn baseOpen({\n\t\t...options,\n\t\tapp: {\n\t\t\tname,\n\t\t\targuments: appArguments,\n\t\t},\n\t});\n};\n\nfunction detectArchBinary(binary) {\n\tif (typeof binary === 'string' || Array.isArray(binary)) {\n\t\treturn binary;\n\t}\n\n\tconst {[arch]: archBinary} = binary;\n\n\tif (!archBinary) {\n\t\tthrow new Error(`${arch} is not supported`);\n\t}\n\n\treturn archBinary;\n}\n\nfunction detectPlatformBinary({[platform]: platformBinary}, {wsl} = {}) {\n\tif (wsl && isWsl) {\n\t\treturn detectArchBinary(wsl);\n\t}\n\n\tif (!platformBinary) {\n\t\tthrow new Error(`${platform} is not supported`);\n\t}\n\n\treturn detectArchBinary(platformBinary);\n}\n\nexport const apps = {\n\tbrowser: 'browser',\n\tbrowserPrivate: 'browserPrivate',\n};\n\ndefineLazyProperty(apps, 'chrome', () => detectPlatformBinary({\n\tdarwin: 'google chrome',\n\twin32: 'chrome',\n\t// `chromium-browser` is the older deb package name used by Ubuntu/Debian before snap.\n\tlinux: ['google-chrome', 'google-chrome-stable', 'chromium', 'chromium-browser'],\n}, {\n\twsl: {\n\t\tia32: '/mnt/c/Program Files (x86)/Google/Chrome/Application/chrome.exe',\n\t\tx64: ['/mnt/c/Program Files/Google/Chrome/Application/chrome.exe', '/mnt/c/Program Files (x86)/Google/Chrome/Application/chrome.exe'],\n\t},\n}));\n\ndefineLazyProperty(apps, 'brave', () => detectPlatformBinary({\n\tdarwin: 'brave browser',\n\twin32: 'brave',\n\tlinux: ['brave-browser', 'brave'],\n}, {\n\twsl: {\n\t\tia32: '/mnt/c/Program Files (x86)/BraveSoftware/Brave-Browser/Application/brave.exe',\n\t\tx64: ['/mnt/c/Program Files/BraveSoftware/Brave-Browser/Application/brave.exe', '/mnt/c/Program Files (x86)/BraveSoftware/Brave-Browser/Application/brave.exe'],\n\t},\n}));\n\ndefineLazyProperty(apps, 'firefox', () => detectPlatformBinary({\n\tdarwin: 'firefox',\n\twin32: String.raw`C:\\Program Files\\Mozilla Firefox\\firefox.exe`,\n\tlinux: 'firefox',\n}, {\n\twsl: '/mnt/c/Program Files/Mozilla Firefox/firefox.exe',\n}));\n\ndefineLazyProperty(apps, 'edge', () => detectPlatformBinary({\n\tdarwin: 'microsoft edge',\n\twin32: 'msedge',\n\tlinux: ['microsoft-edge', 'microsoft-edge-dev'],\n}, {\n\twsl: '/mnt/c/Program Files (x86)/Microsoft/Edge/Application/msedge.exe',\n}));\n\ndefineLazyProperty(apps, 'safari', () => detectPlatformBinary({\n\tdarwin: 'Safari',\n}));\n\nexport default open;\n","#!/usr/bin/env node\n\nimport { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { dirname, extname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { config as loadEnv } from 'dotenv';\nimport { Command } from 'commander';\nimport { makeFunctionReference } from 'convex/server';\nimport { api } from '../../convex/_generated/api';\nimport type { Id } from '../../convex/_generated/dataModel';\nimport type { Permission } from '../../convex/_shared/permissions';\nimport {\n fetchAuthSession,\n loginWithPassword,\n logout,\n pollDeviceToken,\n prompt,\n promptSecret,\n requestDeviceCode,\n signUpWithEmail,\n} from './auth';\nimport { createConvexClient, runAction, runMutation, runQuery } from './convex';\nimport { printOutput } from './output';\nimport {\n clearSession,\n createEmptySession,\n readSession,\n writeSession,\n type CliSession,\n} from './session';\n\nloadEnv({ path: '.env.local', override: false });\nloadEnv({ path: '.env', override: false });\n\nconst cliApi = {\n listWorkspaceReferenceData: makeFunctionReference<'action'>(\n 'cli:listWorkspaceReferenceData',\n ),\n searchIcons: makeFunctionReference<'action'>('cli:searchIcons'),\n listDocuments: makeFunctionReference<'action'>('cli:listDocuments'),\n getDocument: makeFunctionReference<'action'>('cli:getDocument'),\n createDocument: makeFunctionReference<'action'>('cli:createDocument'),\n updateDocument: makeFunctionReference<'action'>('cli:updateDocument'),\n deleteDocument: makeFunctionReference<'action'>('cli:deleteDocument'),\n moveDocumentToFolder: makeFunctionReference<'action'>(\n 'cli:moveDocumentToFolder',\n ),\n listIssues: makeFunctionReference<'action'>('cli:listIssues'),\n getIssue: makeFunctionReference<'action'>('cli:getIssue'),\n createIssue: makeFunctionReference<'action'>('cli:createIssue'),\n updateIssue: makeFunctionReference<'action'>('cli:updateIssue'),\n deleteIssue: makeFunctionReference<'action'>('cli:deleteIssue'),\n assignIssue: makeFunctionReference<'action'>('cli:assignIssue'),\n unassignIssue: makeFunctionReference<'action'>('cli:unassignIssue'),\n listProjects: makeFunctionReference<'action'>('cli:listProjects'),\n getProject: makeFunctionReference<'action'>('cli:getProject'),\n createProject: makeFunctionReference<'action'>('cli:createProject'),\n updateProject: makeFunctionReference<'action'>('cli:updateProject'),\n deleteProject: makeFunctionReference<'action'>('cli:deleteProject'),\n addProjectMember: makeFunctionReference<'action'>('cli:addProjectMember'),\n removeProjectMember: makeFunctionReference<'action'>(\n 'cli:removeProjectMember',\n ),\n changeProjectLead: makeFunctionReference<'action'>('cli:changeProjectLead'),\n listTeams: makeFunctionReference<'action'>('cli:listTeams'),\n getTeam: makeFunctionReference<'action'>('cli:getTeam'),\n createTeam: makeFunctionReference<'action'>('cli:createTeam'),\n updateTeam: makeFunctionReference<'action'>('cli:updateTeam'),\n deleteTeam: makeFunctionReference<'action'>('cli:deleteTeam'),\n addTeamMember: makeFunctionReference<'action'>('cli:addTeamMember'),\n removeTeamMember: makeFunctionReference<'action'>('cli:removeTeamMember'),\n changeTeamLead: makeFunctionReference<'action'>('cli:changeTeamLead'),\n listFolders: makeFunctionReference<'action'>('cli:listFolders'),\n createFolder: makeFunctionReference<'action'>('cli:createFolder'),\n updateFolder: makeFunctionReference<'action'>('cli:updateFolder'),\n deleteFolder: makeFunctionReference<'action'>('cli:deleteFolder'),\n};\n\nconst rolesApi = api.roles.index;\ntype OrganizationRoleId = Id<'roles'> | Id<'orgRoles'>;\n\ntype GlobalOptions = {\n appUrl?: string;\n convexUrl?: string;\n json?: boolean;\n org?: string;\n profile?: string;\n};\n\ntype Runtime = {\n appUrl: string;\n convexUrl: string;\n json: boolean;\n org?: string;\n profile: string;\n session: CliSession | null;\n};\n\nconst ISSUE_STATE_TYPES = [\n 'backlog',\n 'todo',\n 'in_progress',\n 'done',\n 'canceled',\n] as const;\n\nconst PROJECT_STATUS_TYPES = [\n 'backlog',\n 'planned',\n 'in_progress',\n 'completed',\n 'canceled',\n] as const;\n\nconst NOTIFICATION_CATEGORIES = [\n 'invites',\n 'assignments',\n 'mentions',\n 'comments',\n] as const;\n\nfunction requiredString(value: string | undefined, label: string) {\n if (!value?.trim()) {\n throw new Error(`${label} is required`);\n }\n return value.trim();\n}\n\nfunction optionalNumber(value: string | undefined, label: string) {\n if (value === undefined) {\n return undefined;\n }\n\n const parsed = Number(value);\n if (!Number.isFinite(parsed)) {\n throw new Error(`${label} must be a valid number`);\n }\n\n return parsed;\n}\n\nfunction requiredNumber(value: string | undefined, label: string) {\n const parsed = optionalNumber(value, label);\n if (parsed === undefined) {\n throw new Error(`${label} is required`);\n }\n return parsed;\n}\n\nfunction parseBoolean(value: string, label: string) {\n const normalized = value.trim().toLowerCase();\n if (normalized === 'true') return true;\n if (normalized === 'false') return false;\n throw new Error(`${label} must be \"true\" or \"false\"`);\n}\n\nfunction parseList(value: string | undefined) {\n if (!value) return [];\n return value\n .split(',')\n .map(item => item.trim())\n .filter(Boolean);\n}\n\nfunction buildPaginationOptions(limit?: string, cursor?: string) {\n return {\n cursor: cursor ?? null,\n numItems: optionalNumber(limit, 'limit') ?? 20,\n };\n}\n\nfunction normalizeMatch(value: string | undefined | null) {\n return value?.trim().toLowerCase();\n}\n\ntype ListItem = Record<string, unknown>;\n\nfunction parseDate(value: string): number {\n const ms = Date.parse(value);\n if (!Number.isFinite(ms)) {\n throw new Error(`Invalid date: ${value}`);\n }\n return ms;\n}\n\nfunction applyListFilters(\n items: ListItem[],\n options: {\n createdAfter?: string;\n createdBefore?: string;\n updatedAfter?: string;\n updatedBefore?: string;\n sort?: string;\n order?: string;\n limit?: string;\n },\n): ListItem[] {\n let result = [...items];\n\n if (options.createdAfter) {\n const threshold = parseDate(options.createdAfter);\n result = result.filter(\n item => typeof item.createdAt === 'number' && item.createdAt >= threshold,\n );\n }\n if (options.createdBefore) {\n const threshold = parseDate(options.createdBefore);\n result = result.filter(\n item => typeof item.createdAt === 'number' && item.createdAt <= threshold,\n );\n }\n if (options.updatedAfter) {\n const threshold = parseDate(options.updatedAfter);\n result = result.filter(\n item =>\n typeof item.lastEditedAt === 'number' && item.lastEditedAt >= threshold,\n );\n }\n if (options.updatedBefore) {\n const threshold = parseDate(options.updatedBefore);\n result = result.filter(\n item =>\n typeof item.lastEditedAt === 'number' && item.lastEditedAt <= threshold,\n );\n }\n\n if (options.sort) {\n const field = options.sort;\n const desc = options.order?.toLowerCase() === 'desc';\n result.sort((a, b) => {\n const aVal = a[field];\n const bVal = b[field];\n if (aVal == null && bVal == null) return 0;\n if (aVal == null) return 1;\n if (bVal == null) return -1;\n if (typeof aVal === 'number' && typeof bVal === 'number')\n return desc ? bVal - aVal : aVal - bVal;\n return desc\n ? String(bVal).localeCompare(String(aVal))\n : String(aVal).localeCompare(String(bVal));\n });\n }\n\n if (options.limit) {\n const limit = Number(options.limit);\n if (Number.isFinite(limit) && limit > 0) {\n result = result.slice(0, limit);\n }\n }\n\n return result;\n}\n\nfunction addEntityUrls(\n items: ListItem[],\n appUrl: string,\n orgSlug: string,\n entityType: 'issues' | 'projects' | 'teams' | 'documents' | 'folders',\n): ListItem[] {\n return items.map(item => {\n let path: string;\n switch (entityType) {\n case 'issues':\n path = `/${orgSlug}/issues/${item.key}`;\n break;\n case 'projects':\n path = `/${orgSlug}/projects/${item.key}`;\n break;\n case 'teams':\n path = `/${orgSlug}/teams/${item.key}`;\n break;\n case 'documents':\n path = `/${orgSlug}/documents/${item.id}`;\n break;\n case 'folders':\n path = `/${orgSlug}/documents/folders/${item.id}`;\n break;\n }\n return { ...item, url: `${appUrl}${path}` };\n });\n}\n\nfunction normalizeAppUrl(raw: string): string {\n let url = raw.trim();\n if (!/^https?:\\/\\//i.test(url)) {\n const isLocal =\n /^localhost(:\\d+)?/i.test(url) || /^127\\.0\\.0\\.1(:\\d+)?/.test(url);\n url = isLocal ? `http://${url}` : `https://${url}`;\n }\n // Strip trailing slash for consistency\n return url.replace(/\\/+$/, '');\n}\n\nasync function resolveAppUrl(raw: string): Promise<string> {\n const url = normalizeAppUrl(raw);\n try {\n const response = await fetch(url, { method: 'HEAD', redirect: 'follow' });\n // Use the final URL after redirects, stripped of trailing slash and path\n const resolved = new URL(response.url).origin;\n return resolved;\n } catch {\n return url;\n }\n}\n\nasync function fetchConvexUrl(appUrl: string): Promise<string> {\n try {\n const url = new URL('/api/config', appUrl).toString();\n const response = await fetch(url);\n if (!response.ok) {\n throw new Error(`HTTP ${response.status}`);\n }\n const data = (await response.json()) as { convexUrl?: string };\n if (data.convexUrl) {\n return data.convexUrl;\n }\n } catch {\n // Fall through to default\n }\n return 'http://127.0.0.1:3210';\n}\n\nasync function getRuntime(command: Command) {\n const options = command.optsWithGlobals<GlobalOptions>();\n const profile = options.profile ?? 'default';\n const session = await readSession(profile);\n const appUrlSource =\n options.appUrl ?? session?.appUrl ?? process.env.NEXT_PUBLIC_APP_URL;\n const appUrl = await resolveAppUrl(requiredString(appUrlSource, 'app URL'));\n let convexUrl =\n options.convexUrl ??\n session?.convexUrl ??\n process.env.NEXT_PUBLIC_CONVEX_URL ??\n process.env.CONVEX_URL;\n\n if (!convexUrl) {\n convexUrl = await fetchConvexUrl(appUrl);\n }\n\n return {\n appUrl,\n convexUrl,\n json: Boolean(options.json),\n org: options.org ?? session?.activeOrgSlug,\n profile,\n session,\n } satisfies Runtime;\n}\n\nfunction requireSession(runtime: Runtime) {\n if (!runtime.session || Object.keys(runtime.session.cookies).length === 0) {\n throw new Error('Not logged in. Run `vcli auth login` first.');\n }\n return runtime.session;\n}\n\nfunction requireOrg(runtime: Runtime, explicit?: string) {\n const orgSlug = explicit ?? runtime.org;\n if (!orgSlug) {\n throw new Error(\n 'Organization slug is required. Pass `--org <slug>` or run `vcli org use <slug>`.',\n );\n }\n return orgSlug;\n}\n\nasync function getClient(command: Command) {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n return { client, runtime, session };\n}\n\nasync function resolveMemberId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n): Promise<Id<'users'>> {\n const members = await runQuery(\n client,\n api.organizations.queries.listMembers,\n {\n orgSlug,\n },\n );\n const needle = normalizeMatch(ref);\n const matches = members.filter(member => {\n const user = member.user;\n if (!user) return false;\n return (\n normalizeMatch(String(user._id)) === needle ||\n normalizeMatch(user.email) === needle ||\n normalizeMatch(user.name) === needle ||\n normalizeMatch(user.username) === needle\n );\n });\n\n if (matches.length === 0) {\n throw new Error(`No member matched \"${ref}\"`);\n }\n if (matches.length > 1) {\n throw new Error(`Multiple members matched \"${ref}\"`);\n }\n return matches[0]!.user!._id;\n}\n\nasync function resolveRoleId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n): Promise<OrganizationRoleId> {\n const roles = await runQuery(client, rolesApi.list, { orgSlug });\n const needle = normalizeMatch(ref);\n const matches = roles.filter(role => {\n const candidate = role as { _id: string; name?: string; key?: string };\n return (\n normalizeMatch(String(candidate._id)) === needle ||\n normalizeMatch(candidate.name) === needle ||\n normalizeMatch(candidate.key) === needle\n );\n });\n\n if (matches.length === 0) {\n throw new Error(`No role matched \"${ref}\"`);\n }\n if (matches.length > 1) {\n throw new Error(`Multiple roles matched \"${ref}\"`);\n }\n return matches[0]!._id;\n}\n\nfunction parsePermissions(value: string): Permission[] {\n return value\n .split(',')\n .map(permission => permission.trim())\n .filter(Boolean) as Permission[];\n}\n\nfunction nullableOption(value: string | undefined, clear = false) {\n if (clear) return null;\n return value;\n}\n\nfunction mimeTypeForFile(filePath: string) {\n switch (extname(filePath).toLowerCase()) {\n case '.png':\n return 'image/png';\n case '.jpg':\n case '.jpeg':\n return 'image/jpeg';\n case '.webp':\n return 'image/webp';\n case '.gif':\n return 'image/gif';\n case '.svg':\n return 'image/svg+xml';\n default:\n return 'application/octet-stream';\n }\n}\n\nasync function uploadFile(uploadUrl: string, filePath: string) {\n const body = await readFile(filePath);\n const response = await fetch(uploadUrl, {\n method: 'POST',\n headers: {\n 'Content-Type': mimeTypeForFile(filePath),\n },\n body,\n });\n\n if (!response.ok) {\n throw new Error(`Upload failed with HTTP ${response.status}`);\n }\n\n const data = (await response.json()) as { storageId?: Id<'_storage'> };\n if (!data.storageId) {\n throw new Error('Upload response did not include a storageId');\n }\n\n return data.storageId;\n}\n\nasync function resolveTeamId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n teamKey?: string,\n) {\n if (!teamKey) {\n return undefined;\n }\n const team = await runAction(client, cliApi.getTeam, { orgSlug, teamKey });\n return team.id as Id<'teams'>;\n}\n\nasync function resolveProjectId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n projectKey?: string,\n) {\n if (!projectKey) {\n return undefined;\n }\n const project = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n return project.id as Id<'projects'>;\n}\n\nasync function resolveIssueId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n issueKey: string,\n) {\n const issue = await runAction(client, cliApi.getIssue, { orgSlug, issueKey });\n return issue.id as Id<'issues'>;\n}\n\nasync function resolveDocumentId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n documentId: string,\n) {\n const document = await runAction(client, cliApi.getDocument, {\n orgSlug,\n documentId,\n });\n return document.id as Id<'documents'>;\n}\n\nasync function resolveIssueStateId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const states = await runQuery(\n client,\n api.organizations.queries.listIssueStates,\n {\n orgSlug,\n },\n );\n const needle = normalizeMatch(ref);\n const match = states.find(state => {\n return (\n normalizeMatch(String(state._id)) === needle ||\n normalizeMatch(state.name) === needle ||\n normalizeMatch(state.type) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No issue state matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function resolveIssuePriorityId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const priorities = await runQuery(\n client,\n api.organizations.queries.listIssuePriorities,\n { orgSlug },\n );\n const needle = normalizeMatch(ref);\n const match = priorities.find(priority => {\n return (\n normalizeMatch(String(priority._id)) === needle ||\n normalizeMatch(priority.name) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No issue priority matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function resolveProjectStatusId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const statuses = await runQuery(\n client,\n api.organizations.queries.listProjectStatuses,\n { orgSlug },\n );\n const needle = normalizeMatch(ref);\n const match = statuses.find(status => {\n return (\n normalizeMatch(String(status._id)) === needle ||\n normalizeMatch(status.name) === needle ||\n normalizeMatch(status.type) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No project status matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function parseEstimatedTimes(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n value: string,\n) {\n const entries = parseList(value);\n const estimatedTimes: Record<string, number> = {};\n\n for (const entry of entries) {\n const separatorIndex = entry.indexOf('=');\n if (separatorIndex <= 0) {\n throw new Error(\n 'estimated times must use the format \"state=hours,state=hours\"',\n );\n }\n\n const stateRef = entry.slice(0, separatorIndex).trim();\n const hours = Number(entry.slice(separatorIndex + 1).trim());\n if (!Number.isFinite(hours)) {\n throw new Error(`Invalid estimate for \"${stateRef}\"`);\n }\n\n const stateId = await resolveIssueStateId(client, orgSlug, stateRef);\n estimatedTimes[String(stateId)] = hours;\n }\n\n return estimatedTimes;\n}\n\nconst program = new Command();\n\nfunction readPackageVersionSync(): string {\n try {\n const dir = import.meta.dirname ?? dirname(fileURLToPath(import.meta.url));\n const raw = readFileSync(join(dir, '..', 'package.json'), 'utf8');\n return (JSON.parse(raw) as { version?: string }).version ?? 'unknown';\n } catch {\n return 'unknown';\n }\n}\n\nprogram\n .name('vcli')\n .description('Vector CLI')\n .version(readPackageVersionSync(), '-v, --version')\n .showHelpAfterError()\n .option(\n '--app-url <url>',\n 'Vector app URL. Required unless saved in the profile or NEXT_PUBLIC_APP_URL is set.',\n )\n .option('--convex-url <url>', 'Convex deployment URL')\n .option('--org <slug>', 'Organization slug override')\n .option('--profile <name>', 'CLI profile name', 'default')\n .option('--json', 'Output JSON');\n\nconst authCommand = program.command('auth').description('Authentication');\n\nauthCommand\n .command('signup')\n .option('--email <email>', 'Email address')\n .option('--username <username>', 'Username')\n .option('--password <password>', 'Password')\n .action(async (options, command) => {\n const runtime = await getRuntime(command);\n const email = requiredString(\n options.email?.trim() || (await prompt('Email: ')),\n 'email',\n ).toLowerCase();\n const username = requiredString(\n options.username?.trim() || (await prompt('Username: ')),\n 'username',\n );\n const password =\n options.password?.trim() || (await promptSecret('Password: '));\n\n let session = createEmptySession();\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n\n session = await signUpWithEmail(\n session,\n runtime.appUrl,\n email,\n username,\n password,\n );\n const authState = await fetchAuthSession(session, runtime.appUrl);\n session = authState.session;\n\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n session.activeOrgSlug = orgs[0]?.slug ?? session.activeOrgSlug;\n\n await writeSession(session, runtime.profile);\n printOutput(\n {\n signedUpAs:\n authState.user?.email ??\n authState.user?.username ??\n authState.user?.name,\n activeOrgSlug: session.activeOrgSlug ?? null,\n },\n runtime.json,\n );\n });\n\nauthCommand\n .command('login [identifier]')\n .option('--password <password>', 'Password (uses device flow if omitted)')\n .action(async (identifier, options, command) => {\n const runtime = await getRuntime(command);\n let session = createEmptySession();\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n\n const usePassword = Boolean(identifier || options.password);\n\n if (usePassword) {\n const loginId =\n identifier?.trim() || (await prompt('Email or username: '));\n const password =\n options.password?.trim() || (await promptSecret('Password: '));\n session = await loginWithPassword(\n session,\n runtime.appUrl,\n loginId,\n password,\n );\n } else {\n const deviceResp = await requestDeviceCode(runtime.appUrl, 'vcli');\n const verifyUrl = `${runtime.appUrl}/device?user_code=${deviceResp.user_code}`;\n\n console.log();\n console.log(` Open this URL in your browser to log in:`);\n console.log();\n console.log(` ${verifyUrl}`);\n console.log();\n console.log(` Or go to ${runtime.appUrl}/device and enter code:`);\n console.log();\n console.log(` ${deviceResp.user_code}`);\n console.log();\n\n const open = await import('open').then(m => m.default).catch(() => null);\n if (open) {\n await open(verifyUrl).catch(() => {});\n }\n\n console.log(' Waiting for authorization...');\n session = await pollDeviceToken(\n session,\n runtime.appUrl,\n deviceResp.device_code,\n 'vcli',\n deviceResp.interval,\n deviceResp.expires_in,\n );\n }\n\n const authState = await fetchAuthSession(session, runtime.appUrl);\n session = authState.session;\n\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n session.activeOrgSlug = orgs[0]?.slug ?? session.activeOrgSlug;\n\n await writeSession(session, runtime.profile);\n printOutput(\n {\n loggedInAs:\n authState.user?.email ??\n authState.user?.username ??\n authState.user?.name,\n activeOrgSlug: session.activeOrgSlug ?? null,\n },\n runtime.json,\n );\n });\n\nauthCommand.command('logout').action(async (_options, command) => {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n await logout(session, runtime.appUrl);\n await clearSession(runtime.profile);\n printOutput({ success: true }, runtime.json);\n});\n\nauthCommand.command('whoami').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const [user, orgs] = await Promise.all([\n runQuery(client, api.users.getCurrentUser, {}),\n runQuery(client, api.users.getOrganizations, {}),\n ]);\n printOutput(\n {\n user,\n organizations: orgs,\n activeOrgSlug: runtime.org ?? null,\n },\n runtime.json,\n );\n});\n\nconst orgCommand = program.command('org').description('Organizations');\n\norgCommand.command('list').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n printOutput(orgs, runtime.json);\n});\n\norgCommand.command('current').action(async (_options, command) => {\n const runtime = await getRuntime(command);\n printOutput({ activeOrgSlug: runtime.org ?? null }, runtime.json);\n});\n\norgCommand.command('use <slug>').action(async (slug, _options, command) => {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n session.activeOrgSlug = slug;\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n await writeSession(session, runtime.profile);\n printOutput({ activeOrgSlug: slug }, runtime.json);\n});\n\norgCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--slug <slug>')\n .action(async (options, command) => {\n const { client, runtime, session } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.create,\n {\n data: {\n name: options.name,\n slug: options.slug,\n },\n },\n );\n if (session) {\n session.activeOrgSlug = options.slug;\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n await writeSession(session, runtime.profile);\n }\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('update [slug]')\n .option('--name <name>')\n .option('--new-slug <slug>')\n .action(async (slug, options, command) => {\n const { client, runtime, session } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.update,\n {\n orgSlug,\n data: {\n ...(options.name ? { name: options.name } : {}),\n ...(options.newSlug ? { slug: options.newSlug } : {}),\n },\n },\n );\n if (session && options.newSlug && session.activeOrgSlug === orgSlug) {\n session.activeOrgSlug = options.newSlug;\n await writeSession(session, runtime.profile);\n }\n printOutput(result, runtime.json);\n });\n\norgCommand.command('stats [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.getOrganizationStats,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n});\n\norgCommand\n .command('logo [slug]')\n .option('--file <path>')\n .option('--remove')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n\n if (options.remove) {\n throw new Error(\n 'Organization logo removal is not exposed by the current backend API.',\n );\n }\n\n const filePath = requiredString(options.file, 'file');\n const uploadUrl = await runMutation(\n client,\n api.organizations.mutations.generateLogoUploadUrl,\n { orgSlug },\n );\n const storageId = await uploadFile(uploadUrl, filePath);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateLogoWithStorageId,\n {\n orgSlug,\n storageId,\n },\n );\n printOutput(\n { ...(result ?? { success: true }), storageId, orgSlug },\n runtime.json,\n );\n });\n\norgCommand.command('members [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const members = await runQuery(\n client,\n api.organizations.queries.listMembersWithRoles,\n {\n orgSlug,\n },\n );\n printOutput(members, runtime.json);\n});\n\norgCommand.command('invites [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const invites = await runQuery(\n client,\n api.organizations.queries.listInvites,\n {\n orgSlug,\n },\n );\n printOutput(invites, runtime.json);\n});\n\norgCommand\n .command('invite [slug]')\n .requiredOption('--email <email>')\n .option('--role <role>', 'member or admin', 'member')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.invite,\n {\n orgSlug,\n email: options.email,\n role: options.role,\n },\n );\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('member-role <member>')\n .requiredOption('--role <role>', 'member or admin')\n .action(async (member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const userId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateMemberRole,\n {\n orgSlug,\n userId,\n role: options.role,\n },\n );\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('remove-member <member>')\n .action(async (member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const userId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.organizations.mutations.removeMember,\n {\n orgSlug,\n userId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\norgCommand\n .command('revoke-invite <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.revokeInvite,\n {\n inviteId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst roleCommand = program.command('role').description('Organization roles');\n\nroleCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const roles = await runQuery(client, rolesApi.list, { orgSlug });\n printOutput(roles, runtime.json);\n});\n\nroleCommand.command('get <role>').action(async (role, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const roleId = await resolveRoleId(client, orgSlug, role);\n const [summary, permissions] = await Promise.all([\n runQuery(client, rolesApi.get, { orgSlug, roleId }),\n runQuery(client, rolesApi.getPermissions, { roleId }),\n ]);\n printOutput({ summary, permissions }, runtime.json);\n});\n\nroleCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--permissions <permissions>', 'Comma-separated permissions')\n .option('--description <description>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runMutation(client, rolesApi.create, {\n orgSlug,\n name: options.name,\n description: options.description,\n permissions: parsePermissions(options.permissions),\n });\n printOutput({ roleId: result }, runtime.json);\n });\n\nroleCommand\n .command('update <role>')\n .requiredOption('--name <name>')\n .requiredOption('--permissions <permissions>', 'Comma-separated permissions')\n .option('--description <description>')\n .action(async (role, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const roleId = await resolveRoleId(client, orgSlug, role);\n const result = await runMutation(client, rolesApi.update, {\n orgSlug,\n roleId,\n name: options.name,\n description: options.description,\n permissions: parsePermissions(options.permissions),\n });\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nroleCommand\n .command('assign <role> <member>')\n .action(async (role, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [roleId, userId] = await Promise.all([\n resolveRoleId(client, orgSlug, role),\n resolveMemberId(client, orgSlug, member),\n ]);\n const result = await runMutation(client, rolesApi.assign, {\n orgSlug,\n roleId,\n userId,\n });\n printOutput({ assignmentId: result }, runtime.json);\n });\n\nroleCommand\n .command('unassign <role> <member>')\n .action(async (role, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [roleId, userId] = await Promise.all([\n resolveRoleId(client, orgSlug, role),\n resolveMemberId(client, orgSlug, member),\n ]);\n const result = await runMutation(client, rolesApi.removeAssignment, {\n orgSlug,\n roleId,\n userId,\n });\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst inviteCommand = program.command('invite').description('Invitations');\n\ninviteCommand.command('list').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const invites = await runQuery(client, api.users.getPendingInvitations, {});\n printOutput(invites, runtime.json);\n});\n\ninviteCommand\n .command('accept <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.acceptInvitation,\n { inviteId },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\ninviteCommand\n .command('decline <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.declineInvitation,\n { inviteId },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nprogram.command('refdata [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runAction(client, cliApi.listWorkspaceReferenceData, {\n orgSlug,\n });\n printOutput(result, runtime.json);\n});\n\nprogram\n .command('icons <query>')\n .option('--limit <n>')\n .action(async (query, options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runAction(client, cliApi.searchIcons, {\n query,\n limit: options.limit ? Number(options.limit) : undefined,\n });\n printOutput(result, runtime.json);\n });\n\nprogram\n .command('search <query>')\n .option('--limit <n>')\n .action(async (query, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runQuery(client, api.search.queries.searchEntities, {\n orgSlug,\n query,\n limit: optionalNumber(options.limit, 'limit'),\n });\n printOutput(result, runtime.json);\n });\n\nconst permissionCommand = program\n .command('permission')\n .description('Permission checks');\n\npermissionCommand\n .command('check <permission>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .action(async (permission, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [teamId, projectId] = await Promise.all([\n resolveTeamId(client, orgSlug, options.team),\n resolveProjectId(client, orgSlug, options.project),\n ]);\n const result = await runQuery(client, api.permissions.utils.has, {\n orgSlug,\n permission,\n teamId,\n projectId,\n });\n printOutput(\n { permission, allowed: result, teamId, projectId },\n runtime.json,\n );\n });\n\npermissionCommand\n .command('check-many <permissions>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .action(async (permissions, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [teamId, projectId] = await Promise.all([\n resolveTeamId(client, orgSlug, options.team),\n resolveProjectId(client, orgSlug, options.project),\n ]);\n const permissionList = parsePermissions(permissions);\n const result = await runQuery(client, api.permissions.utils.hasMultiple, {\n orgSlug,\n permissions: permissionList,\n teamId,\n projectId,\n });\n printOutput(result, runtime.json);\n });\n\nconst activityCommand = program\n .command('activity')\n .description('Activity feed');\n\nactivityCommand\n .command('project <projectKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (projectKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const projectId = await resolveProjectId(client, orgSlug, projectKey);\n const result = await runQuery(\n client,\n api.activities.queries.listProjectActivity,\n {\n projectId: projectId!,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('team <teamKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (teamKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const teamId = await resolveTeamId(client, orgSlug, teamKey);\n const result = await runQuery(\n client,\n api.activities.queries.listTeamActivity,\n {\n teamId: teamId!,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('issue <issueKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const result = await runQuery(\n client,\n api.activities.queries.listIssueActivity,\n {\n issueId,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('document <documentId>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const resolvedDocumentId = await resolveDocumentId(\n client,\n orgSlug,\n documentId,\n );\n const result = await runQuery(\n client,\n api.activities.queries.listDocumentActivity,\n {\n documentId: resolvedDocumentId,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nconst notificationCommand = program\n .command('notification')\n .description('Notifications');\n\nnotificationCommand\n .command('inbox')\n .option('--filter <filter>', 'all or unread')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(client, api.notifications.queries.listInbox, {\n filter: options.filter,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n });\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('unread-count')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.unreadCount,\n {},\n );\n printOutput({ unreadCount: result }, runtime.json);\n });\n\nnotificationCommand\n .command('mark-read <recipientId>')\n .action(async (recipientId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.markRead,\n {\n recipientId,\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('mark-all-read')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.markAllRead,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('archive <recipientId>')\n .action(async (recipientId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.archive,\n {\n recipientId,\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand.command('preferences').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.getPreferences,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nnotificationCommand\n .command('set-preference <category>')\n .requiredOption('--in-app <true|false>')\n .requiredOption('--email <true|false>')\n .requiredOption('--push <true|false>')\n .action(async (category, options, command) => {\n const { client, runtime } = await getClient(command);\n if (!NOTIFICATION_CATEGORIES.includes(category)) {\n throw new Error(\n `category must be one of: ${NOTIFICATION_CATEGORIES.join(', ')}`,\n );\n }\n const result = await runMutation(\n client,\n api.notifications.mutations.updatePreferences,\n {\n category,\n inAppEnabled: parseBoolean(options.inApp, 'in-app'),\n emailEnabled: parseBoolean(options.email, 'email'),\n pushEnabled: parseBoolean(options.push, 'push'),\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('subscriptions')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.listPushSubscriptions,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('remove-subscription <subscriptionId>')\n .action(async (subscriptionId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.removePushSubscription,\n { subscriptionId },\n );\n printOutput(result, runtime.json);\n });\n\nconst priorityCommand = program\n .command('priority')\n .description('Issue priorities');\n\npriorityCommand\n .command('list [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listIssuePriorities,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n });\n\npriorityCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--weight <n>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runMutation(\n client,\n api.organizations.mutations.createIssuePriority,\n {\n orgSlug,\n name: options.name,\n weight: requiredNumber(options.weight, 'weight'),\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\npriorityCommand\n .command('update <priority>')\n .requiredOption('--name <name>')\n .requiredOption('--color <hex>')\n .option('--weight <n>')\n .option('--icon <icon>')\n .action(async (priority, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const priorityId = await resolveIssuePriorityId(client, orgSlug, priority);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateIssuePriority,\n {\n orgSlug,\n priorityId,\n name: options.name,\n weight: optionalNumber(options.weight, 'weight'),\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\npriorityCommand\n .command('delete <priority>')\n .action(async (priority, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const priorityId = await resolveIssuePriorityId(client, orgSlug, priority);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteIssuePriority,\n {\n orgSlug,\n priorityId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\npriorityCommand\n .command('reset [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetIssuePriorities,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst stateCommand = program.command('state').description('Issue states');\n\nstateCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listIssueStates,\n {\n orgSlug,\n },\n );\n printOutput(result, runtime.json);\n});\n\nstateCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!ISSUE_STATE_TYPES.includes(options.type)) {\n throw new Error(`type must be one of: ${ISSUE_STATE_TYPES.join(', ')}`);\n }\n const result = await runMutation(\n client,\n api.organizations.mutations.createIssueState,\n {\n orgSlug,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\nstateCommand\n .command('update <state>')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (state, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!ISSUE_STATE_TYPES.includes(options.type)) {\n throw new Error(`type must be one of: ${ISSUE_STATE_TYPES.join(', ')}`);\n }\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateIssueState,\n {\n orgSlug,\n stateId,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstateCommand\n .command('delete <state>')\n .action(async (state, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteIssueState,\n {\n orgSlug,\n stateId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstateCommand.command('reset [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetIssueStates,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n});\n\nconst statusCommand = program.command('status').description('Project statuses');\n\nstatusCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listProjectStatuses,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n});\n\nstatusCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!PROJECT_STATUS_TYPES.includes(options.type)) {\n throw new Error(\n `type must be one of: ${PROJECT_STATUS_TYPES.join(', ')}`,\n );\n }\n const result = await runMutation(\n client,\n api.organizations.mutations.createProjectStatus,\n {\n orgSlug,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\nstatusCommand\n .command('update <status>')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (status, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!PROJECT_STATUS_TYPES.includes(options.type)) {\n throw new Error(\n `type must be one of: ${PROJECT_STATUS_TYPES.join(', ')}`,\n );\n }\n const statusId = await resolveProjectStatusId(client, orgSlug, status);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateProjectStatus,\n {\n orgSlug,\n statusId,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstatusCommand\n .command('delete <status>')\n .action(async (status, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const statusId = await resolveProjectStatusId(client, orgSlug, status);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteProjectStatus,\n {\n orgSlug,\n statusId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstatusCommand\n .command('reset [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetProjectStatuses,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst adminCommand = program.command('admin').description('Platform admin');\n\nadminCommand.command('branding').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.platformAdmin.queries.getBranding,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nadminCommand\n .command('set-branding')\n .option('--name <name>')\n .option('--description <description>')\n .option('--theme-color <hex>')\n .option('--accent-color <hex>')\n .option('--logo <path>')\n .option('--remove-logo')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n let logoStorageId: Id<'_storage'> | undefined;\n if (options.logo) {\n const uploadUrl = await runMutation(\n client,\n api.platformAdmin.mutations.generateBrandLogoUploadUrl,\n {},\n );\n logoStorageId = await uploadFile(uploadUrl, options.logo);\n }\n\n const result = await runMutation(\n client,\n api.platformAdmin.mutations.updateBranding,\n {\n name: options.name,\n description: options.description,\n logoStorageId,\n removeLogo: options.removeLogo ? true : undefined,\n themeColor: options.themeColor,\n accentColor: options.accentColor,\n },\n );\n printOutput(\n {\n ...(result ?? { success: true }),\n logoStorageId: logoStorageId ?? null,\n },\n runtime.json,\n );\n });\n\nadminCommand.command('signup-policy').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.platformAdmin.queries.getSignupPolicy,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nadminCommand\n .command('set-signup-policy')\n .option('--blocked <domains>')\n .option('--allowed <domains>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.platformAdmin.mutations.updateSignupEmailDomainPolicy,\n {\n blockedDomains: parseList(options.blocked),\n allowedDomains: parseList(options.allowed),\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nadminCommand\n .command('sync-disposable-domains')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runAction(\n client,\n api.platformAdmin.actions.runDisposableDomainSyncNow,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nconst teamCommand = program.command('team').description('Teams');\n\nteamCommand\n .command('list [slug]')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listTeams, {\n orgSlug,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'teams');\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('get <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getTeam, {\n orgSlug,\n teamKey,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('create')\n .requiredOption('--key <key>')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createTeam, {\n orgSlug,\n key: options.key,\n name: options.name,\n description: options.description,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('update <teamKey>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--clear-description')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (teamKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateTeam, {\n orgSlug,\n teamKey,\n name: options.name,\n description: nullableOption(\n options.description,\n options.clearDescription,\n ),\n visibility: options.visibility,\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('delete <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteTeam, {\n orgSlug,\n teamKey,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('members <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const team = await runAction(client, cliApi.getTeam, { orgSlug, teamKey });\n const result = await runQuery(client, api.teams.queries.listMembers, {\n teamId: team.id as any,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('add-member <teamKey> <member>')\n .option('--role <role>', 'member or lead', 'member')\n .action(async (teamKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.addTeamMember, {\n orgSlug,\n teamKey,\n memberName: member,\n role: options.role,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('remove-member <teamKey> <member>')\n .action(async (teamKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.removeTeamMember, {\n orgSlug,\n teamKey,\n memberName: member,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('set-lead <teamKey> <member>')\n .action(async (teamKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const leadName = member === 'null' ? null : member;\n const result = await runAction(client, cliApi.changeTeamLead, {\n orgSlug,\n teamKey,\n leadName,\n });\n printOutput(result, runtime.json);\n });\n\nconst projectCommand = program.command('project').description('Projects');\n\nprojectCommand\n .command('list [slug]')\n .option('--team <teamKey>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listProjects, {\n orgSlug,\n teamKey: options.team,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'projects');\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('get <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('create')\n .requiredOption('--key <key>')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--team <teamKey>')\n .option('--status <statusName>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createProject, {\n orgSlug,\n key: options.key,\n name: options.name,\n description: options.description,\n teamKey: options.team,\n statusName: options.status,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('update <projectKey>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--status <statusName>')\n .option('--clear-status')\n .option('--visibility <visibility>')\n .option('--start-date <date>')\n .option('--clear-start-date')\n .option('--due-date <date>')\n .option('--clear-due-date')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (projectKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateProject, {\n orgSlug,\n projectKey,\n name: options.name,\n description: options.description,\n teamKey: nullableOption(options.team, options.clearTeam),\n statusName: nullableOption(options.status, options.clearStatus),\n visibility: options.visibility,\n startDate: nullableOption(options.startDate, options.clearStartDate),\n dueDate: nullableOption(options.dueDate, options.clearDueDate),\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('delete <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteProject, {\n orgSlug,\n projectKey,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('members <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const project = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n const result = await runQuery(client, api.projects.queries.listMembers, {\n projectId: project.id as any,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('add-member <projectKey> <member>')\n .option('--role <role>', 'member or lead', 'member')\n .action(async (projectKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.addProjectMember, {\n orgSlug,\n projectKey,\n memberName: member,\n role: options.role,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('remove-member <projectKey> <member>')\n .action(async (projectKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.removeProjectMember, {\n orgSlug,\n projectKey,\n memberName: member,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('set-lead <projectKey> <member>')\n .action(async (projectKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const leadName = member === 'null' ? null : member;\n const result = await runAction(client, cliApi.changeProjectLead, {\n orgSlug,\n projectKey,\n leadName,\n });\n printOutput(result, runtime.json);\n });\n\nconst issueCommand = program.command('issue').description('Issues');\n\nissueCommand\n .command('list [slug]')\n .option('--project <projectKey>')\n .option('--team <teamKey>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, title, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listIssues, {\n orgSlug,\n projectKey: options.project,\n teamKey: options.team,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'issues');\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('get <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getIssue, {\n orgSlug,\n issueKey,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('create')\n .requiredOption('--title <title>')\n .option('--description <description>')\n .option('--project <projectKey>')\n .option('--team <teamKey>')\n .option('--priority <priorityName>')\n .option('--visibility <visibility>')\n .option('--assignee <member>')\n .option('--state <stateName>')\n .option('--start-date <date>')\n .option('--due-date <date>')\n .option('--parent <issueKey>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createIssue, {\n orgSlug,\n title: options.title,\n description: options.description,\n projectKey: options.project,\n teamKey: options.team,\n priorityName: options.priority,\n visibility: options.visibility,\n assigneeName: options.assignee,\n stateName: options.state,\n startDate: options.startDate,\n dueDate: options.dueDate,\n parentIssueKey: options.parent,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('update <issueKey>')\n .option('--title <title>')\n .option('--description <description>')\n .option('--priority <priorityName>')\n .option('--clear-priority')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--project <projectKey>')\n .option('--clear-project')\n .option('--visibility <visibility>')\n .option('--assignee <member>')\n .option('--clear-assignee')\n .option('--state <stateName>')\n .option('--start-date <date>')\n .option('--clear-start-date')\n .option('--due-date <date>')\n .option('--clear-due-date')\n .option('--parent <issueKey>')\n .option('--clear-parent')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateIssue, {\n orgSlug,\n issueKey,\n title: options.title,\n description: options.description,\n priorityName: nullableOption(options.priority, options.clearPriority),\n teamKey: nullableOption(options.team, options.clearTeam),\n projectKey: nullableOption(options.project, options.clearProject),\n visibility: options.visibility,\n assigneeName: nullableOption(options.assignee, options.clearAssignee),\n stateName: options.state,\n startDate: nullableOption(options.startDate, options.clearStartDate),\n dueDate: nullableOption(options.dueDate, options.clearDueDate),\n parentIssueKey: nullableOption(options.parent, options.clearParent),\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('delete <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteIssue, {\n orgSlug,\n issueKey,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('assign <issueKey> <member>')\n .option('--state <stateName>')\n .action(async (issueKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.assignIssue, {\n orgSlug,\n issueKey,\n assigneeName: member,\n stateName: options.state,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('unassign <issueKey> <member>')\n .action(async (issueKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.unassignIssue, {\n orgSlug,\n issueKey,\n assigneeName: member,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('assignments <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const result = await runQuery(client, api.issues.queries.getAssignments, {\n issueId,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('set-assignment-state <assignmentId> <state>')\n .action(async (assignmentId, state, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.issues.mutations.changeAssignmentState,\n {\n assignmentId,\n stateId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('reassign-assignment <assignmentId> <member>')\n .action(async (assignmentId, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const assigneeId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.issues.mutations.updateAssignmentAssignee,\n {\n assignmentId,\n assigneeId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('remove-assignment <assignmentId>')\n .action(async (assignmentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.issues.mutations.deleteAssignment,\n {\n assignmentId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('set-priority <issueKey> <priority>')\n .action(async (issueKey, priority, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [issueId, priorityId] = await Promise.all([\n resolveIssueId(client, orgSlug, issueKey),\n resolveIssuePriorityId(client, orgSlug, priority),\n ]);\n const result = await runMutation(\n client,\n api.issues.mutations.changePriority,\n {\n issueId,\n priorityId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('replace-assignees <issueKey> <members>')\n .action(async (issueKey, members, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const assigneeIds = await Promise.all(\n parseList(members).map(member =>\n resolveMemberId(client, orgSlug, member),\n ),\n );\n const result = await runMutation(\n client,\n api.issues.mutations.updateAssignees,\n {\n issueId,\n assigneeIds,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('set-estimates <issueKey>')\n .requiredOption('--values <state=hours,...>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const estimatedTimes = await parseEstimatedTimes(\n client,\n orgSlug,\n options.values,\n );\n const result = await runMutation(\n client,\n api.issues.mutations.updateEstimatedTimes,\n {\n issueId,\n estimatedTimes,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('comment <issueKey>')\n .requiredOption('--body <body>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issue = await runAction(client, cliApi.getIssue, {\n orgSlug,\n issueKey,\n });\n const result = await runMutation(client, api.issues.mutations.addComment, {\n issueId: issue.id as any,\n body: options.body,\n });\n printOutput(result, runtime.json);\n });\n\nconst documentCommand = program.command('document').description('Documents');\n\ndocumentCommand\n .command('list [slug]')\n .option('--folder-id <id>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option(\n '--updated-after <date>',\n 'Filter: last edited on or after date (ISO)',\n )\n .option(\n '--updated-before <date>',\n 'Filter: last edited on or before date (ISO)',\n )\n .option(\n '--sort <field>',\n 'Sort by field (e.g. createdAt, title, lastEditedAt)',\n )\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listDocuments, {\n orgSlug,\n folderId: options.folderId,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(\n filtered,\n runtime.appUrl,\n orgSlug,\n 'documents',\n );\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('get <documentId>')\n .action(async (documentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getDocument, {\n orgSlug,\n documentId,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('create')\n .requiredOption('--title <title>')\n .option('--content <content>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .option('--folder-id <id>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createDocument, {\n orgSlug,\n title: options.title,\n content: options.content,\n teamKey: options.team,\n projectKey: options.project,\n folderId: options.folderId,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('update <documentId>')\n .option('--title <title>')\n .option('--content <content>')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--project <projectKey>')\n .option('--clear-project')\n .option('--folder-id <id>')\n .option('--clear-folder')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateDocument, {\n orgSlug,\n documentId,\n title: options.title,\n content: options.content,\n teamKey: nullableOption(options.team, options.clearTeam),\n projectKey: nullableOption(options.project, options.clearProject),\n folderId: nullableOption(options.folderId, options.clearFolder),\n visibility: options.visibility,\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('move <documentId>')\n .option('--folder-id <id>')\n .option('--clear-folder')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const folderId = options.clearFolder\n ? null\n : requiredString(options.folderId, 'folder-id');\n const result = await runAction(client, cliApi.moveDocumentToFolder, {\n orgSlug,\n documentId,\n folderId,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('delete <documentId>')\n .action(async (documentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteDocument, {\n orgSlug,\n documentId,\n });\n printOutput(result, runtime.json);\n });\n\nconst folderCommand = program.command('folder').description('Document folders');\n\nfolderCommand\n .command('list [slug]')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listFolders, { orgSlug });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'folders');\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('create')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createFolder, {\n orgSlug,\n name: options.name,\n description: options.description,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('update <folderId>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--clear-description')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (folderId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateFolder, {\n orgSlug,\n folderId,\n name: options.name,\n description: nullableOption(\n options.description,\n options.clearDescription,\n ),\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('delete <folderId>')\n .action(async (folderId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteFolder, {\n orgSlug,\n folderId,\n });\n printOutput(result, runtime.json);\n });\n\nasync function main() {\n await program.parseAsync(process.argv);\n}\n\nmain().catch(error => {\n console.error(error instanceof Error ? error.message : String(error));\n process.exitCode = 1;\n});\n","/* eslint-disable */\n/**\n * Generated `api` utility.\n *\n * THIS CODE IS AUTOMATICALLY GENERATED.\n *\n * To regenerate, run `npx convex dev`.\n * @module\n */\n\nimport { anyApi, componentsGeneric } from \"convex/server\";\n\n/**\n * A utility for referencing Convex functions in your app's API.\n *\n * Usage:\n * ```js\n * const myFunctionReference = api.myModule.myFunction;\n * ```\n */\nexport const api = anyApi;\nexport const internal = anyApi;\nexport const components = componentsGeneric();\n","import { isCancel, password as passwordPrompt, text } from '@clack/prompts';\nimport { CliSession } from './session';\n\ntype AuthUser = {\n id?: string;\n email?: string;\n name?: string;\n username?: string;\n};\n\ntype AuthSessionResponse = {\n user?: AuthUser | null;\n session?: Record<string, unknown> | null;\n};\n\nfunction buildUrl(appUrl: string, pathname: string) {\n return new URL(pathname, appUrl).toString();\n}\n\nfunction cookieHeader(cookies: Record<string, string>) {\n return Object.entries(cookies)\n .map(([name, value]) => `${name}=${value}`)\n .join('; ');\n}\n\nfunction splitSetCookieHeader(value: string) {\n return value.split(/,(?=[^;,]+=)/g);\n}\n\nfunction applySetCookieHeaders(\n session: CliSession,\n response: Response,\n): CliSession {\n const nextCookies = { ...session.cookies };\n const rawSetCookies =\n response.headers.getSetCookie?.() ??\n (response.headers.get('set-cookie')\n ? splitSetCookieHeader(response.headers.get('set-cookie')!)\n : []);\n\n for (const rawCookie of rawSetCookies) {\n const [cookiePart, ...attributeParts] = rawCookie.split(';');\n const separatorIndex = cookiePart.indexOf('=');\n if (separatorIndex <= 0) {\n continue;\n }\n\n const name = cookiePart.slice(0, separatorIndex).trim();\n const value = cookiePart.slice(separatorIndex + 1).trim();\n const attributes = attributeParts.map(part => part.trim().toLowerCase());\n const maxAge = attributes.find(part => part.startsWith('max-age='));\n const expires = attributes.find(part => part.startsWith('expires='));\n const expired =\n value.length === 0 ||\n maxAge === 'max-age=0' ||\n (expires\n ? Number.isFinite(Date.parse(expires.slice(8))) &&\n Date.parse(expires.slice(8)) <= Date.now()\n : false);\n\n if (expired) {\n delete nextCookies[name];\n } else {\n nextCookies[name] = value;\n }\n }\n\n return {\n ...session,\n cookies: nextCookies,\n };\n}\n\nasync function authRequest(\n session: CliSession,\n appUrl: string,\n pathname: string,\n init: RequestInit = {},\n) {\n const headers = new Headers(init.headers);\n const origin = new URL(appUrl).origin;\n if (Object.keys(session.cookies).length > 0) {\n headers.set('cookie', cookieHeader(session.cookies));\n }\n if (!headers.has('origin')) {\n headers.set('origin', origin);\n }\n if (!headers.has('referer')) {\n headers.set('referer', `${origin}/`);\n }\n if (init.body && !headers.has('content-type')) {\n headers.set('content-type', 'application/json');\n }\n\n const response = await fetch(buildUrl(appUrl, pathname), {\n ...init,\n headers,\n redirect: 'manual',\n });\n const nextSession = applySetCookieHeaders(session, response);\n return { response, session: nextSession };\n}\n\nasync function parseError(response: Response) {\n try {\n const data = (await response.json()) as { error?: { message?: string } };\n return data.error?.message ?? `Request failed with HTTP ${response.status}`;\n } catch {\n return `Request failed with HTTP ${response.status}`;\n }\n}\n\nexport async function loginWithPassword(\n session: CliSession,\n appUrl: string,\n identifier: string,\n password: string,\n) {\n const pathname = identifier.includes('@')\n ? '/api/auth/sign-in/email'\n : '/api/auth/sign-in/username';\n const body = identifier.includes('@')\n ? { email: identifier, password }\n : { username: identifier, password };\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n pathname,\n {\n method: 'POST',\n body: JSON.stringify(body),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n return nextSession;\n}\n\nexport async function signUpWithEmail(\n session: CliSession,\n appUrl: string,\n email: string,\n username: string,\n password: string,\n) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/sign-up/email',\n {\n method: 'POST',\n body: JSON.stringify({\n email,\n password,\n name: username,\n username,\n }),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n return nextSession;\n}\n\nexport async function logout(session: CliSession, appUrl: string) {\n const { response } = await authRequest(\n session,\n appUrl,\n '/api/auth/sign-out',\n {\n method: 'POST',\n body: JSON.stringify({}),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n}\n\nexport async function fetchAuthSession(session: CliSession, appUrl: string) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/get-session',\n {\n method: 'GET',\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n const data = (await response.json()) as AuthSessionResponse | null;\n return {\n session: nextSession,\n user: data?.user ?? null,\n };\n}\n\nexport async function fetchConvexToken(session: CliSession, appUrl: string) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/convex/token',\n {\n method: 'GET',\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n const data = (await response.json()) as { token?: string };\n if (!data.token) {\n throw new Error('Missing Convex token');\n }\n\n return {\n session: nextSession,\n token: data.token,\n };\n}\n\ntype DeviceCodeResponse = {\n device_code: string;\n user_code: string;\n verification_uri: string;\n verification_uri_complete: string;\n expires_in: number;\n interval: number;\n};\n\ntype DeviceTokenResponse = {\n access_token?: string;\n token_type?: string;\n error?: string;\n};\n\nexport async function requestDeviceCode(\n appUrl: string,\n clientId: string,\n): Promise<DeviceCodeResponse> {\n const response = await fetch(buildUrl(appUrl, '/api/auth/device/code'), {\n method: 'POST',\n headers: { 'content-type': 'application/json' },\n body: JSON.stringify({ client_id: clientId }),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to request device code: HTTP ${response.status}`);\n }\n\n return (await response.json()) as DeviceCodeResponse;\n}\n\nexport async function pollDeviceToken(\n session: CliSession,\n appUrl: string,\n deviceCode: string,\n clientId: string,\n interval: number,\n expiresIn: number,\n): Promise<CliSession> {\n const deadline = Date.now() + expiresIn * 1000;\n let pollInterval = interval * 1000;\n\n while (Date.now() < deadline) {\n await new Promise(resolve => setTimeout(resolve, pollInterval));\n\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/device/token',\n {\n method: 'POST',\n body: JSON.stringify({\n grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\n device_code: deviceCode,\n client_id: clientId,\n }),\n },\n );\n\n session = nextSession;\n\n if (response.ok) {\n const data = (await response.json()) as DeviceTokenResponse;\n if (data.access_token) {\n // The device/token response may set session cookies directly\n if (Object.keys(session.cookies).length > 0) {\n return session;\n }\n // Otherwise use the token to call get-session with Bearer auth\n const sessionResp = await fetch(\n buildUrl(appUrl, '/api/auth/get-session'),\n {\n headers: {\n authorization: `Bearer ${data.access_token}`,\n },\n },\n );\n if (sessionResp.ok) {\n const updated = applySetCookieHeaders(session, sessionResp);\n return updated;\n }\n return session;\n }\n }\n\n let errorData: DeviceTokenResponse;\n try {\n errorData = (await response.json()) as DeviceTokenResponse;\n } catch {\n errorData = { error: `HTTP ${response.status}` };\n }\n\n switch (errorData.error) {\n case 'authorization_pending':\n break;\n case 'slow_down':\n pollInterval += 5000;\n break;\n case 'access_denied':\n throw new Error('Authorization denied by user.');\n case 'expired_token':\n throw new Error('Device code expired. Please try again.');\n default:\n throw new Error(`Device auth error: ${errorData.error}`);\n }\n }\n\n throw new Error('Device code expired. Please try again.');\n}\n\nexport async function prompt(question: string) {\n const value = await text({\n message: question.replace(/:\\s*$/, ''),\n });\n if (isCancel(value)) {\n throw new Error('Canceled');\n }\n return String(value).trim();\n}\n\nexport async function promptSecret(question: string) {\n const value = await passwordPrompt({\n message: question.replace(/:\\s*$/, ''),\n mask: '*',\n });\n if (isCancel(value)) {\n throw new Error('Canceled');\n }\n return String(value);\n}\n","import { ConvexHttpClient } from 'convex/browser';\nimport { FunctionReference, OptionalRestArgs } from 'convex/server';\nimport { fetchConvexToken } from './auth';\nimport { CliSession } from './session';\n\nexport async function createConvexClient(\n session: CliSession,\n appUrl: string,\n convexUrl: string,\n) {\n const { token } = await fetchConvexToken(session, appUrl);\n const client = new ConvexHttpClient(convexUrl);\n client.setAuth(token);\n return client;\n}\n\nexport async function runQuery<Query extends FunctionReference<'query'>>(\n client: ConvexHttpClient,\n ref: Query,\n ...args: OptionalRestArgs<Query>\n) {\n return await client.query(ref, ...args);\n}\n\nexport async function runMutation<\n Mutation extends FunctionReference<'mutation'>,\n>(\n client: ConvexHttpClient,\n ref: Mutation,\n ...args: OptionalRestArgs<Mutation>\n) {\n return await client.mutation(ref, ...args);\n}\n\nexport async function runAction<Action extends FunctionReference<'action'>>(\n client: ConvexHttpClient,\n ref: Action,\n ...args: OptionalRestArgs<Action>\n) {\n return await client.action(ref, ...args);\n}\n","function simplify(value: unknown): unknown {\n if (value === null || value === undefined) {\n return value;\n }\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return [];\n }\n if (value.every(item => typeof item !== 'object' || item === null)) {\n return value.join(', ');\n }\n return JSON.stringify(value);\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n return value;\n}\n\nexport function printOutput(data: unknown, json = false) {\n if (json) {\n console.log(JSON.stringify(data, null, 2));\n return;\n }\n\n if (Array.isArray(data)) {\n if (data.length === 0) {\n console.log('No results.');\n return;\n }\n if (data.every(item => typeof item === 'object' && item !== null)) {\n console.table(\n data.map(item =>\n Object.fromEntries(\n Object.entries(item).map(([key, value]) => [key, simplify(value)]),\n ),\n ),\n );\n return;\n }\n }\n\n if (typeof data === 'object' && data !== null) {\n console.dir(data, { depth: null, colors: true });\n return;\n }\n\n console.log(String(data));\n}\n","import { mkdir, readFile, rm, writeFile } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport path from 'node:path';\n\nexport type CliSession = {\n version: 1;\n appUrl?: string;\n convexUrl?: string;\n activeOrgSlug?: string;\n cookies: Record<string, string>;\n};\n\nconst SESSION_ROOT = path.join(homedir(), '.vector');\n\nexport function getSessionPath(profile = 'default') {\n return path.join(SESSION_ROOT, `cli-${profile}.json`);\n}\n\nexport async function readSession(profile = 'default') {\n try {\n const raw = await readFile(getSessionPath(profile), 'utf8');\n const parsed = JSON.parse(raw) as Partial<CliSession>;\n return {\n version: 1,\n cookies: {},\n ...parsed,\n } satisfies CliSession;\n } catch {\n return null;\n }\n}\n\nexport async function writeSession(session: CliSession, profile = 'default') {\n await mkdir(SESSION_ROOT, { recursive: true });\n await writeFile(\n getSessionPath(profile),\n `${JSON.stringify(session, null, 2)}\\n`,\n 'utf8',\n );\n}\n\nexport async function clearSession(profile = 'default') {\n await rm(getSessionPath(profile), { force: true });\n}\n\nexport function createEmptySession(): CliSession {\n return {\n version: 1,\n cookies: {},\n };\n}\n"],"mappings":"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","names":["fs","process","fs","process","Buffer","fs","promisify","childProcess","fs","fsConstants","execFile","powerShellPath","path","promisify","process","execFile","process","promisify","execFile","execFileAsync","promisify","execFile","execFileAsync","promisify","process","execFile","defaultBrowser","execFileAsync","process","process","path","childProcess","fs","fsConstants","apps","defaultBrowser","powerShellPath","readFile","fileURLToPath","path","readFile","fileURLToPath","open"]}
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/.pnpm/is-docker@3.0.0/node_modules/is-docker/index.js","../../../node_modules/.pnpm/is-inside-container@1.0.0/node_modules/is-inside-container/index.js","../../../node_modules/.pnpm/is-wsl@3.1.1/node_modules/is-wsl/index.js","../../../node_modules/.pnpm/powershell-utils@0.1.0/node_modules/powershell-utils/index.js","../../../node_modules/.pnpm/wsl-utils@0.3.1/node_modules/wsl-utils/utilities.js","../../../node_modules/.pnpm/wsl-utils@0.3.1/node_modules/wsl-utils/index.js","../../../node_modules/.pnpm/define-lazy-prop@3.0.0/node_modules/define-lazy-prop/index.js","../../../node_modules/.pnpm/default-browser-id@5.0.1/node_modules/default-browser-id/index.js","../../../node_modules/.pnpm/run-applescript@7.1.0/node_modules/run-applescript/index.js","../../../node_modules/.pnpm/bundle-name@4.1.0/node_modules/bundle-name/index.js","../../../node_modules/.pnpm/default-browser@5.5.0/node_modules/default-browser/windows.js","../../../node_modules/.pnpm/default-browser@5.5.0/node_modules/default-browser/index.js","../../../node_modules/.pnpm/is-in-ssh@1.0.0/node_modules/is-in-ssh/index.js","../../../node_modules/.pnpm/open@11.0.0/node_modules/open/index.js","../../../src/cli/index.ts","../../../convex/_generated/api.js","../../../src/cli/auth.ts","../../../src/cli/convex.ts","../../../src/cli/output.ts","../../../src/cli/session.ts"],"sourcesContent":["import fs from 'node:fs';\n\nlet isDockerCached;\n\nfunction hasDockerEnv() {\n\ttry {\n\t\tfs.statSync('/.dockerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nfunction hasDockerCGroup() {\n\ttry {\n\t\treturn fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nexport default function isDocker() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (isDockerCached === undefined) {\n\t\tisDockerCached = hasDockerEnv() || hasDockerCGroup();\n\t}\n\n\treturn isDockerCached;\n}\n","import fs from 'node:fs';\nimport isDocker from 'is-docker';\n\nlet cachedResult;\n\n// Podman detection\nconst hasContainerEnv = () => {\n\ttry {\n\t\tfs.statSync('/run/.containerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default function isInsideContainer() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (cachedResult === undefined) {\n\t\tcachedResult = hasContainerEnv() || isDocker();\n\t}\n\n\treturn cachedResult;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nimport isInsideContainer from 'is-inside-container';\n\nconst isWsl = () => {\n\tif (process.platform !== 'linux') {\n\t\treturn false;\n\t}\n\n\tif (os.release().toLowerCase().includes('microsoft')) {\n\t\tif (isInsideContainer()) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\ttry {\n\t\tif (fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft')) {\n\t\t\treturn !isInsideContainer();\n\t\t}\n\t} catch {}\n\n\t// Fallback for custom kernels: check WSL-specific paths.\n\tif (\n\t\tfs.existsSync('/proc/sys/fs/binfmt_misc/WSLInterop')\n\t\t|| fs.existsSync('/run/WSL')\n\t) {\n\t\treturn !isInsideContainer();\n\t}\n\n\treturn false;\n};\n\nexport default process.env.__IS_WSL_TEST__ ? isWsl : isWsl();\n","import process from 'node:process';\nimport {Buffer} from 'node:buffer';\nimport {promisify} from 'node:util';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\n\nconst execFile = promisify(childProcess.execFile);\n\nexport const powerShellPath = () => `${process.env.SYSTEMROOT || process.env.windir || String.raw`C:\\Windows`}\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell.exe`;\n\n// Cache for PowerShell accessibility check\nlet canAccessCache;\n\nexport const canAccessPowerShell = async () => {\n\tcanAccessCache ??= (async () => {\n\t\ttry {\n\t\t\tawait fs.access(powerShellPath(), fsConstants.X_OK);\n\t\t\treturn true;\n\t\t} catch {\n\t\t\treturn false;\n\t\t}\n\t})();\n\n\treturn canAccessCache;\n};\n\nexport const executePowerShell = async (command, options = {}) => {\n\tconst {\n\t\tpowerShellPath: psPath,\n\t\t...execFileOptions\n\t} = options;\n\n\tconst encodedCommand = executePowerShell.encodeCommand(command);\n\n\treturn execFile(\n\t\tpsPath ?? powerShellPath(),\n\t\t[\n\t\t\t...executePowerShell.argumentsPrefix,\n\t\t\tencodedCommand,\n\t\t],\n\t\t{\n\t\t\tencoding: 'utf8',\n\t\t\t...execFileOptions,\n\t\t},\n\t);\n};\n\nexecutePowerShell.argumentsPrefix = [\n\t'-NoProfile',\n\t'-NonInteractive',\n\t'-ExecutionPolicy',\n\t'Bypass',\n\t'-EncodedCommand',\n];\n\nexecutePowerShell.encodeCommand = command => Buffer.from(command, 'utf16le').toString('base64');\n\nexecutePowerShell.escapeArgument = value => `'${String(value).replaceAll('\\'', '\\'\\'')}'`;\n","export function parseMountPointFromConfig(content) {\n\tfor (const line of content.split('\\n')) {\n\t\t// Skip comment lines\n\t\tif (/^\\s*#/.test(line)) {\n\t\t\tcontinue;\n\t\t}\n\n\t\t// Match root at start of line (after optional whitespace)\n\t\tconst match = /^\\s*root\\s*=\\s*(?<mountPoint>\"[^\"]*\"|'[^']*'|[^#]*)/.exec(line);\n\t\tif (!match) {\n\t\t\tcontinue;\n\t\t}\n\n\t\treturn match.groups.mountPoint\n\t\t\t.trim()\n\t\t\t// Strip surrounding quotes\n\t\t\t.replaceAll(/^[\"']|[\"']$/g, '');\n\t}\n}\n","import {promisify} from 'node:util';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\nimport isWsl from 'is-wsl';\nimport {powerShellPath as windowsPowerShellPath, executePowerShell} from 'powershell-utils';\nimport {parseMountPointFromConfig} from './utilities.js';\n\nconst execFile = promisify(childProcess.execFile);\n\nexport const wslDrivesMountPoint = (() => {\n\t// Default value for \"root\" param\n\t// according to https://docs.microsoft.com/en-us/windows/wsl/wsl-config\n\tconst defaultMountPoint = '/mnt/';\n\n\tlet mountPoint;\n\n\treturn async function () {\n\t\tif (mountPoint) {\n\t\t\t// Return memoized mount point value\n\t\t\treturn mountPoint;\n\t\t}\n\n\t\tconst configFilePath = '/etc/wsl.conf';\n\n\t\tlet isConfigFileExists = false;\n\t\ttry {\n\t\t\tawait fs.access(configFilePath, fsConstants.F_OK);\n\t\t\tisConfigFileExists = true;\n\t\t} catch {}\n\n\t\tif (!isConfigFileExists) {\n\t\t\treturn defaultMountPoint;\n\t\t}\n\n\t\tconst configContent = await fs.readFile(configFilePath, {encoding: 'utf8'});\n\t\tconst parsedMountPoint = parseMountPointFromConfig(configContent);\n\n\t\tif (parsedMountPoint === undefined) {\n\t\t\treturn defaultMountPoint;\n\t\t}\n\n\t\tmountPoint = parsedMountPoint;\n\t\tmountPoint = mountPoint.endsWith('/') ? mountPoint : `${mountPoint}/`;\n\n\t\treturn mountPoint;\n\t};\n})();\n\nexport const powerShellPathFromWsl = async () => {\n\tconst mountPoint = await wslDrivesMountPoint();\n\treturn `${mountPoint}c/Windows/System32/WindowsPowerShell/v1.0/powershell.exe`;\n};\n\nexport const powerShellPath = isWsl ? powerShellPathFromWsl : windowsPowerShellPath;\n\n// Cache for PowerShell accessibility check\nlet canAccessPowerShellPromise;\n\nexport const canAccessPowerShell = async () => {\n\tcanAccessPowerShellPromise ??= (async () => {\n\t\ttry {\n\t\t\tconst psPath = await powerShellPath();\n\t\t\tawait fs.access(psPath, fsConstants.X_OK);\n\t\t\treturn true;\n\t\t} catch {\n\t\t\t// PowerShell is not accessible (either doesn't exist, no execute permission, or other error)\n\t\t\treturn false;\n\t\t}\n\t})();\n\n\treturn canAccessPowerShellPromise;\n};\n\nexport const wslDefaultBrowser = async () => {\n\tconst psPath = await powerShellPath();\n\tconst command = String.raw`(Get-ItemProperty -Path \"HKCU:\\Software\\Microsoft\\Windows\\Shell\\Associations\\UrlAssociations\\http\\UserChoice\").ProgId`;\n\n\tconst {stdout} = await executePowerShell(command, {powerShellPath: psPath});\n\n\treturn stdout.trim();\n};\n\nexport const convertWslPathToWindows = async path => {\n\t// Don't convert URLs\n\tif (/^[a-z]+:\\/\\//i.test(path)) {\n\t\treturn path;\n\t}\n\n\ttry {\n\t\tconst {stdout} = await execFile('wslpath', ['-aw', path], {encoding: 'utf8'});\n\t\treturn stdout.trim();\n\t} catch {\n\t\t// If wslpath fails, return the original path\n\t\treturn path;\n\t}\n};\n\nexport {default as isWsl} from 'is-wsl';\n","export default function defineLazyProperty(object, propertyName, valueGetter) {\n\tconst define = value => Object.defineProperty(object, propertyName, {value, enumerable: true, writable: true});\n\n\tObject.defineProperty(object, propertyName, {\n\t\tconfigurable: true,\n\t\tenumerable: true,\n\t\tget() {\n\t\t\tconst result = valueGetter();\n\t\t\tdefine(result);\n\t\t\treturn result;\n\t\t},\n\t\tset(value) {\n\t\t\tdefine(value);\n\t\t}\n\t});\n\n\treturn object;\n}\n","import {promisify} from 'node:util';\nimport process from 'node:process';\nimport {execFile} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\nexport default async function defaultBrowserId() {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst {stdout} = await execFileAsync('defaults', ['read', 'com.apple.LaunchServices/com.apple.launchservices.secure', 'LSHandlers']);\n\n\t// `(?!-)` is to prevent matching `LSHandlerRoleAll = \"-\";`.\n\tconst match = /LSHandlerRoleAll = \"(?!-)(?<id>[^\"]+?)\";\\s+?LSHandlerURLScheme = (?:http|https);/.exec(stdout);\n\n\tconst browserId = match?.groups.id ?? 'com.apple.Safari';\n\n\t// Correct the case for Safari's bundle identifier\n\tif (browserId === 'com.apple.safari') {\n\t\treturn 'com.apple.Safari';\n\t}\n\n\treturn browserId;\n}\n","import process from 'node:process';\nimport {promisify} from 'node:util';\nimport {execFile, execFileSync} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\nexport async function runAppleScript(script, {humanReadableOutput = true, signal} = {}) {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst outputArguments = humanReadableOutput ? [] : ['-ss'];\n\n\tconst execOptions = {};\n\tif (signal) {\n\t\texecOptions.signal = signal;\n\t}\n\n\tconst {stdout} = await execFileAsync('osascript', ['-e', script, outputArguments], execOptions);\n\treturn stdout.trim();\n}\n\nexport function runAppleScriptSync(script, {humanReadableOutput = true} = {}) {\n\tif (process.platform !== 'darwin') {\n\t\tthrow new Error('macOS only');\n\t}\n\n\tconst outputArguments = humanReadableOutput ? [] : ['-ss'];\n\n\tconst stdout = execFileSync('osascript', ['-e', script, ...outputArguments], {\n\t\tencoding: 'utf8',\n\t\tstdio: ['ignore', 'pipe', 'ignore'],\n\t\ttimeout: 500,\n\t});\n\n\treturn stdout.trim();\n}\n","import {runAppleScript} from 'run-applescript';\n\nexport default async function bundleName(bundleId) {\n\treturn runAppleScript(`tell application \"Finder\" to set app_path to application file id \"${bundleId}\" as string\\ntell application \"System Events\" to get value of property list item \"CFBundleName\" of property list file (app_path & \":Contents:Info.plist\")`);\n}\n","import {promisify} from 'node:util';\nimport {execFile} from 'node:child_process';\n\nconst execFileAsync = promisify(execFile);\n\n// TODO: Fix the casing of bundle identifiers in the next major version.\n\n// Windows doesn't have browser IDs in the same way macOS/Linux does so we give fake\n// ones that look real and match the macOS/Linux versions for cross-platform apps.\nconst windowsBrowserProgIds = {\n\tMSEdgeHTM: {name: 'Edge', id: 'com.microsoft.edge'}, // The missing `L` is correct.\n\tMSEdgeBHTML: {name: 'Edge Beta', id: 'com.microsoft.edge.beta'},\n\tMSEdgeDHTML: {name: 'Edge Dev', id: 'com.microsoft.edge.dev'},\n\tAppXq0fevzme2pys62n3e0fbqa7peapykr8v: {name: 'Edge', id: 'com.microsoft.edge.old'},\n\tChromeHTML: {name: 'Chrome', id: 'com.google.chrome'},\n\tChromeBHTML: {name: 'Chrome Beta', id: 'com.google.chrome.beta'},\n\tChromeDHTML: {name: 'Chrome Dev', id: 'com.google.chrome.dev'},\n\tChromiumHTM: {name: 'Chromium', id: 'org.chromium.Chromium'},\n\tBraveHTML: {name: 'Brave', id: 'com.brave.Browser'},\n\tBraveBHTML: {name: 'Brave Beta', id: 'com.brave.Browser.beta'},\n\tBraveDHTML: {name: 'Brave Dev', id: 'com.brave.Browser.dev'},\n\tBraveSSHTM: {name: 'Brave Nightly', id: 'com.brave.Browser.nightly'},\n\tFirefoxURL: {name: 'Firefox', id: 'org.mozilla.firefox'},\n\tOperaStable: {name: 'Opera', id: 'com.operasoftware.Opera'},\n\tVivaldiHTM: {name: 'Vivaldi', id: 'com.vivaldi.Vivaldi'},\n\t'IE.HTTP': {name: 'Internet Explorer', id: 'com.microsoft.ie'},\n};\n\nexport const _windowsBrowserProgIdMap = new Map(Object.entries(windowsBrowserProgIds));\n\nexport class UnknownBrowserError extends Error {}\n\nexport default async function defaultBrowser(_execFileAsync = execFileAsync) {\n\tconst {stdout} = await _execFileAsync('reg', [\n\t\t'QUERY',\n\t\t' HKEY_CURRENT_USER\\\\Software\\\\Microsoft\\\\Windows\\\\Shell\\\\Associations\\\\UrlAssociations\\\\http\\\\UserChoice',\n\t\t'/v',\n\t\t'ProgId',\n\t]);\n\n\tconst match = /ProgId\\s*REG_SZ\\s*(?<id>\\S+)/.exec(stdout);\n\tif (!match) {\n\t\tthrow new UnknownBrowserError(`Cannot find Windows browser in stdout: ${JSON.stringify(stdout)}`);\n\t}\n\n\tconst {id} = match.groups;\n\n\t// Windows can append a hash suffix to ProgIds using a dot or hyphen\n\t// (e.g., `ChromeHTML.ABC123`, `FirefoxURL-6F193CCC56814779`).\n\t// Try exact match first, then try without the suffix.\n\tconst dotIndex = id.lastIndexOf('.');\n\tconst hyphenIndex = id.lastIndexOf('-');\n\tconst baseIdByDot = dotIndex === -1 ? undefined : id.slice(0, dotIndex);\n\tconst baseIdByHyphen = hyphenIndex === -1 ? undefined : id.slice(0, hyphenIndex);\n\n\treturn windowsBrowserProgIds[id] ?? windowsBrowserProgIds[baseIdByDot] ?? windowsBrowserProgIds[baseIdByHyphen] ?? {name: id, id};\n}\n","import {promisify} from 'node:util';\nimport process from 'node:process';\nimport {execFile} from 'node:child_process';\nimport defaultBrowserId from 'default-browser-id';\nimport bundleName from 'bundle-name';\nimport windows from './windows.js';\n\nexport {_windowsBrowserProgIdMap} from './windows.js';\n\nconst execFileAsync = promisify(execFile);\n\n// Inlined: https://github.com/sindresorhus/titleize/blob/main/index.js\nconst titleize = string => string.toLowerCase().replaceAll(/(?:^|\\s|-)\\S/g, x => x.toUpperCase());\n\nexport default async function defaultBrowser() {\n\tif (process.platform === 'darwin') {\n\t\tconst id = await defaultBrowserId();\n\t\tconst name = await bundleName(id);\n\t\treturn {name, id};\n\t}\n\n\tif (process.platform === 'linux') {\n\t\tconst {stdout} = await execFileAsync('xdg-mime', ['query', 'default', 'x-scheme-handler/http']);\n\t\tconst id = stdout.trim();\n\t\tconst name = titleize(id.replace(/.desktop$/, '').replace('-', ' '));\n\t\treturn {name, id};\n\t}\n\n\tif (process.platform === 'win32') {\n\t\treturn windows();\n\t}\n\n\tthrow new Error('Only macOS, Linux, and Windows are supported');\n}\n","import process from 'node:process';\n\nconst isInSsh = Boolean(process.env.SSH_CONNECTION\n\t|| process.env.SSH_CLIENT\n\t|| process.env.SSH_TTY);\n\nexport default isInSsh;\n","import process from 'node:process';\nimport path from 'node:path';\nimport {fileURLToPath} from 'node:url';\nimport childProcess from 'node:child_process';\nimport fs, {constants as fsConstants} from 'node:fs/promises';\nimport {\n\tisWsl,\n\tpowerShellPath,\n\tconvertWslPathToWindows,\n\tcanAccessPowerShell,\n\twslDefaultBrowser,\n} from 'wsl-utils';\nimport {executePowerShell} from 'powershell-utils';\nimport defineLazyProperty from 'define-lazy-prop';\nimport defaultBrowser, {_windowsBrowserProgIdMap} from 'default-browser';\nimport isInsideContainer from 'is-inside-container';\nimport isInSsh from 'is-in-ssh';\n\nconst fallbackAttemptSymbol = Symbol('fallbackAttempt');\n\n// Path to included `xdg-open`.\nconst __dirname = import.meta.url ? path.dirname(fileURLToPath(import.meta.url)) : '';\nconst localXdgOpenPath = path.join(__dirname, 'xdg-open');\n\nconst {platform, arch} = process;\n\nconst tryEachApp = async (apps, opener) => {\n\tif (apps.length === 0) {\n\t\t// No app was provided\n\t\treturn;\n\t}\n\n\tconst errors = [];\n\n\tfor (const app of apps) {\n\t\ttry {\n\t\t\treturn await opener(app); // eslint-disable-line no-await-in-loop\n\t\t} catch (error) {\n\t\t\terrors.push(error);\n\t\t}\n\t}\n\n\tthrow new AggregateError(errors, 'Failed to open in all supported apps');\n};\n\n// eslint-disable-next-line complexity\nconst baseOpen = async options => {\n\toptions = {\n\t\twait: false,\n\t\tbackground: false,\n\t\tnewInstance: false,\n\t\tallowNonzeroExitCode: false,\n\t\t...options,\n\t};\n\n\tconst isFallbackAttempt = options[fallbackAttemptSymbol] === true;\n\tdelete options[fallbackAttemptSymbol];\n\n\tif (Array.isArray(options.app)) {\n\t\treturn tryEachApp(options.app, singleApp => baseOpen({\n\t\t\t...options,\n\t\t\tapp: singleApp,\n\t\t\t[fallbackAttemptSymbol]: true,\n\t\t}));\n\t}\n\n\tlet {name: app, arguments: appArguments = []} = options.app ?? {};\n\tappArguments = [...appArguments];\n\n\tif (Array.isArray(app)) {\n\t\treturn tryEachApp(app, appName => baseOpen({\n\t\t\t...options,\n\t\t\tapp: {\n\t\t\t\tname: appName,\n\t\t\t\targuments: appArguments,\n\t\t\t},\n\t\t\t[fallbackAttemptSymbol]: true,\n\t\t}));\n\t}\n\n\tif (app === 'browser' || app === 'browserPrivate') {\n\t\t// IDs from default-browser for macOS and windows are the same.\n\t\t// IDs are lowercased to increase chances of a match.\n\t\tconst ids = {\n\t\t\t'com.google.chrome': 'chrome',\n\t\t\t'google-chrome.desktop': 'chrome',\n\t\t\t'com.brave.browser': 'brave',\n\t\t\t'org.mozilla.firefox': 'firefox',\n\t\t\t'firefox.desktop': 'firefox',\n\t\t\t'com.microsoft.msedge': 'edge',\n\t\t\t'com.microsoft.edge': 'edge',\n\t\t\t'com.microsoft.edgemac': 'edge',\n\t\t\t'microsoft-edge.desktop': 'edge',\n\t\t\t'com.apple.safari': 'safari',\n\t\t};\n\n\t\t// Incognito flags for each browser in `apps`.\n\t\tconst flags = {\n\t\t\tchrome: '--incognito',\n\t\t\tbrave: '--incognito',\n\t\t\tfirefox: '--private-window',\n\t\t\tedge: '--inPrivate',\n\t\t\t// Safari doesn't support private mode via command line\n\t\t};\n\n\t\tlet browser;\n\t\tif (isWsl) {\n\t\t\tconst progId = await wslDefaultBrowser();\n\t\t\tconst browserInfo = _windowsBrowserProgIdMap.get(progId);\n\t\t\tbrowser = browserInfo ?? {};\n\t\t} else {\n\t\t\tbrowser = await defaultBrowser();\n\t\t}\n\n\t\tif (browser.id in ids) {\n\t\t\tconst browserName = ids[browser.id.toLowerCase()];\n\n\t\t\tif (app === 'browserPrivate') {\n\t\t\t\t// Safari doesn't support private mode via command line\n\t\t\t\tif (browserName === 'safari') {\n\t\t\t\t\tthrow new Error('Safari doesn\\'t support opening in private mode via command line');\n\t\t\t\t}\n\n\t\t\t\tappArguments.push(flags[browserName]);\n\t\t\t}\n\n\t\t\treturn baseOpen({\n\t\t\t\t...options,\n\t\t\t\tapp: {\n\t\t\t\t\tname: apps[browserName],\n\t\t\t\t\targuments: appArguments,\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\tthrow new Error(`${browser.name} is not supported as a default browser`);\n\t}\n\n\tlet command;\n\tconst cliArguments = [];\n\tconst childProcessOptions = {};\n\n\t// Determine if we should use Windows/PowerShell behavior in WSL.\n\t// We only use Windows integration if PowerShell is actually accessible.\n\t// This allows the package to work in sandboxed WSL environments where Windows access is restricted.\n\tlet shouldUseWindowsInWsl = false;\n\tif (isWsl && !isInsideContainer() && !isInSsh && !app) {\n\t\tshouldUseWindowsInWsl = await canAccessPowerShell();\n\t}\n\n\tif (platform === 'darwin') {\n\t\tcommand = 'open';\n\n\t\tif (options.wait) {\n\t\t\tcliArguments.push('--wait-apps');\n\t\t}\n\n\t\tif (options.background) {\n\t\t\tcliArguments.push('--background');\n\t\t}\n\n\t\tif (options.newInstance) {\n\t\t\tcliArguments.push('--new');\n\t\t}\n\n\t\tif (app) {\n\t\t\tcliArguments.push('-a', app);\n\t\t}\n\t} else if (platform === 'win32' || shouldUseWindowsInWsl) {\n\t\tcommand = await powerShellPath();\n\n\t\tcliArguments.push(...executePowerShell.argumentsPrefix);\n\n\t\tif (!isWsl) {\n\t\t\tchildProcessOptions.windowsVerbatimArguments = true;\n\t\t}\n\n\t\t// Convert WSL Linux paths to Windows paths\n\t\tif (isWsl && options.target) {\n\t\t\toptions.target = await convertWslPathToWindows(options.target);\n\t\t}\n\n\t\t// Suppress PowerShell progress messages that are written to stderr\n\t\tconst encodedArguments = ['$ProgressPreference = \\'SilentlyContinue\\';', 'Start'];\n\n\t\tif (options.wait) {\n\t\t\tencodedArguments.push('-Wait');\n\t\t}\n\n\t\tif (app) {\n\t\t\tencodedArguments.push(executePowerShell.escapeArgument(app));\n\t\t\tif (options.target) {\n\t\t\t\tappArguments.push(options.target);\n\t\t\t}\n\t\t} else if (options.target) {\n\t\t\tencodedArguments.push(executePowerShell.escapeArgument(options.target));\n\t\t}\n\n\t\tif (appArguments.length > 0) {\n\t\t\tappArguments = appArguments.map(argument => executePowerShell.escapeArgument(argument));\n\t\t\tencodedArguments.push('-ArgumentList', appArguments.join(','));\n\t\t}\n\n\t\t// Using Base64-encoded command, accepted by PowerShell, to allow special characters.\n\t\toptions.target = executePowerShell.encodeCommand(encodedArguments.join(' '));\n\n\t\tif (!options.wait) {\n\t\t\t// PowerShell will keep the parent process alive unless stdio is ignored.\n\t\t\tchildProcessOptions.stdio = 'ignore';\n\t\t}\n\t} else {\n\t\tif (app) {\n\t\t\tcommand = app;\n\t\t} else {\n\t\t\t// When bundled by Webpack, there's no actual package file path and no local `xdg-open`.\n\t\t\tconst isBundled = !__dirname || __dirname === '/';\n\n\t\t\t// Check if local `xdg-open` exists and is executable.\n\t\t\tlet exeLocalXdgOpen = false;\n\t\t\ttry {\n\t\t\t\tawait fs.access(localXdgOpenPath, fsConstants.X_OK);\n\t\t\t\texeLocalXdgOpen = true;\n\t\t\t} catch {}\n\n\t\t\tconst useSystemXdgOpen = process.versions.electron\n\t\t\t\t?? (platform === 'android' || isBundled || !exeLocalXdgOpen);\n\t\t\tcommand = useSystemXdgOpen ? 'xdg-open' : localXdgOpenPath;\n\t\t}\n\n\t\tif (appArguments.length > 0) {\n\t\t\tcliArguments.push(...appArguments);\n\t\t}\n\n\t\tif (!options.wait) {\n\t\t\t// `xdg-open` will block the process unless stdio is ignored\n\t\t\t// and it's detached from the parent even if it's unref'd.\n\t\t\tchildProcessOptions.stdio = 'ignore';\n\t\t\tchildProcessOptions.detached = true;\n\t\t}\n\t}\n\n\tif (platform === 'darwin' && appArguments.length > 0) {\n\t\tcliArguments.push('--args', ...appArguments);\n\t}\n\n\t// IMPORTANT: On macOS, the target MUST come AFTER '--args'.\n\t// When using --args, ALL following arguments are passed to the app.\n\t// Example: open -a \"chrome\" --args --incognito https://site.com\n\t// This passes BOTH --incognito AND https://site.com to Chrome.\n\t// Without this order, Chrome won't open in incognito. See #332.\n\tif (options.target) {\n\t\tcliArguments.push(options.target);\n\t}\n\n\tconst subprocess = childProcess.spawn(command, cliArguments, childProcessOptions);\n\n\tif (options.wait) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tsubprocess.once('error', reject);\n\n\t\t\tsubprocess.once('close', exitCode => {\n\t\t\t\tif (!options.allowNonzeroExitCode && exitCode !== 0) {\n\t\t\t\t\treject(new Error(`Exited with code ${exitCode}`));\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tresolve(subprocess);\n\t\t\t});\n\t\t});\n\t}\n\n\t// When we're in a fallback attempt, we need to detect launch failures before trying the next app.\n\t// Wait for the close event to check the exit code before unreffing.\n\t// The launcher (open/xdg-open/PowerShell) exits quickly (~10-30ms) even on success.\n\tif (isFallbackAttempt) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tsubprocess.once('error', reject);\n\n\t\t\tsubprocess.once('spawn', () => {\n\t\t\t\t// Keep error handler active for post-spawn errors\n\t\t\t\tsubprocess.once('close', exitCode => {\n\t\t\t\t\tsubprocess.off('error', reject);\n\n\t\t\t\t\tif (exitCode !== 0) {\n\t\t\t\t\t\treject(new Error(`Exited with code ${exitCode}`));\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tsubprocess.unref();\n\t\t\t\t\tresolve(subprocess);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n\n\tsubprocess.unref();\n\n\t// Handle spawn errors before the caller can attach listeners.\n\t// This prevents unhandled error events from crashing the process.\n\treturn new Promise((resolve, reject) => {\n\t\tsubprocess.once('error', reject);\n\n\t\t// Wait for the subprocess to spawn before resolving.\n\t\t// This ensures the process is established before the caller continues,\n\t\t// preventing issues when process.exit() is called immediately after.\n\t\tsubprocess.once('spawn', () => {\n\t\t\tsubprocess.off('error', reject);\n\t\t\tresolve(subprocess);\n\t\t});\n\t});\n};\n\nconst open = (target, options) => {\n\tif (typeof target !== 'string') {\n\t\tthrow new TypeError('Expected a `target`');\n\t}\n\n\treturn baseOpen({\n\t\t...options,\n\t\ttarget,\n\t});\n};\n\nexport const openApp = (name, options) => {\n\tif (typeof name !== 'string' && !Array.isArray(name)) {\n\t\tthrow new TypeError('Expected a valid `name`');\n\t}\n\n\tconst {arguments: appArguments = []} = options ?? {};\n\tif (appArguments !== undefined && appArguments !== null && !Array.isArray(appArguments)) {\n\t\tthrow new TypeError('Expected `appArguments` as Array type');\n\t}\n\n\treturn baseOpen({\n\t\t...options,\n\t\tapp: {\n\t\t\tname,\n\t\t\targuments: appArguments,\n\t\t},\n\t});\n};\n\nfunction detectArchBinary(binary) {\n\tif (typeof binary === 'string' || Array.isArray(binary)) {\n\t\treturn binary;\n\t}\n\n\tconst {[arch]: archBinary} = binary;\n\n\tif (!archBinary) {\n\t\tthrow new Error(`${arch} is not supported`);\n\t}\n\n\treturn archBinary;\n}\n\nfunction detectPlatformBinary({[platform]: platformBinary}, {wsl} = {}) {\n\tif (wsl && isWsl) {\n\t\treturn detectArchBinary(wsl);\n\t}\n\n\tif (!platformBinary) {\n\t\tthrow new Error(`${platform} is not supported`);\n\t}\n\n\treturn detectArchBinary(platformBinary);\n}\n\nexport const apps = {\n\tbrowser: 'browser',\n\tbrowserPrivate: 'browserPrivate',\n};\n\ndefineLazyProperty(apps, 'chrome', () => detectPlatformBinary({\n\tdarwin: 'google chrome',\n\twin32: 'chrome',\n\t// `chromium-browser` is the older deb package name used by Ubuntu/Debian before snap.\n\tlinux: ['google-chrome', 'google-chrome-stable', 'chromium', 'chromium-browser'],\n}, {\n\twsl: {\n\t\tia32: '/mnt/c/Program Files (x86)/Google/Chrome/Application/chrome.exe',\n\t\tx64: ['/mnt/c/Program Files/Google/Chrome/Application/chrome.exe', '/mnt/c/Program Files (x86)/Google/Chrome/Application/chrome.exe'],\n\t},\n}));\n\ndefineLazyProperty(apps, 'brave', () => detectPlatformBinary({\n\tdarwin: 'brave browser',\n\twin32: 'brave',\n\tlinux: ['brave-browser', 'brave'],\n}, {\n\twsl: {\n\t\tia32: '/mnt/c/Program Files (x86)/BraveSoftware/Brave-Browser/Application/brave.exe',\n\t\tx64: ['/mnt/c/Program Files/BraveSoftware/Brave-Browser/Application/brave.exe', '/mnt/c/Program Files (x86)/BraveSoftware/Brave-Browser/Application/brave.exe'],\n\t},\n}));\n\ndefineLazyProperty(apps, 'firefox', () => detectPlatformBinary({\n\tdarwin: 'firefox',\n\twin32: String.raw`C:\\Program Files\\Mozilla Firefox\\firefox.exe`,\n\tlinux: 'firefox',\n}, {\n\twsl: '/mnt/c/Program Files/Mozilla Firefox/firefox.exe',\n}));\n\ndefineLazyProperty(apps, 'edge', () => detectPlatformBinary({\n\tdarwin: 'microsoft edge',\n\twin32: 'msedge',\n\tlinux: ['microsoft-edge', 'microsoft-edge-dev'],\n}, {\n\twsl: '/mnt/c/Program Files (x86)/Microsoft/Edge/Application/msedge.exe',\n}));\n\ndefineLazyProperty(apps, 'safari', () => detectPlatformBinary({\n\tdarwin: 'Safari',\n}));\n\nexport default open;\n","#!/usr/bin/env node\n\nimport { readFileSync } from 'node:fs';\nimport { readFile } from 'node:fs/promises';\nimport { dirname, extname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { config as loadEnv } from 'dotenv';\nimport { Command } from 'commander';\nimport { makeFunctionReference } from 'convex/server';\nimport { api } from '../../convex/_generated/api';\nimport type { Id } from '../../convex/_generated/dataModel';\nimport type { Permission } from '../../convex/_shared/permissions';\nimport {\n fetchAuthSession,\n loginWithPassword,\n logout,\n pollDeviceToken,\n prompt,\n promptSecret,\n requestDeviceCode,\n signUpWithEmail,\n} from './auth';\nimport { createConvexClient, runAction, runMutation, runQuery } from './convex';\nimport { printOutput } from './output';\nimport {\n clearSession,\n createEmptySession,\n readSession,\n writeSession,\n type CliSession,\n} from './session';\n\nloadEnv({ path: '.env.local', override: false });\nloadEnv({ path: '.env', override: false });\n\nconst cliApi = {\n listWorkspaceReferenceData: makeFunctionReference<'action'>(\n 'cli:listWorkspaceReferenceData',\n ),\n searchIcons: makeFunctionReference<'action'>('cli:searchIcons'),\n listDocuments: makeFunctionReference<'action'>('cli:listDocuments'),\n getDocument: makeFunctionReference<'action'>('cli:getDocument'),\n createDocument: makeFunctionReference<'action'>('cli:createDocument'),\n updateDocument: makeFunctionReference<'action'>('cli:updateDocument'),\n deleteDocument: makeFunctionReference<'action'>('cli:deleteDocument'),\n moveDocumentToFolder: makeFunctionReference<'action'>(\n 'cli:moveDocumentToFolder',\n ),\n listIssues: makeFunctionReference<'action'>('cli:listIssues'),\n getIssue: makeFunctionReference<'action'>('cli:getIssue'),\n createIssue: makeFunctionReference<'action'>('cli:createIssue'),\n updateIssue: makeFunctionReference<'action'>('cli:updateIssue'),\n deleteIssue: makeFunctionReference<'action'>('cli:deleteIssue'),\n assignIssue: makeFunctionReference<'action'>('cli:assignIssue'),\n unassignIssue: makeFunctionReference<'action'>('cli:unassignIssue'),\n listProjects: makeFunctionReference<'action'>('cli:listProjects'),\n getProject: makeFunctionReference<'action'>('cli:getProject'),\n createProject: makeFunctionReference<'action'>('cli:createProject'),\n updateProject: makeFunctionReference<'action'>('cli:updateProject'),\n deleteProject: makeFunctionReference<'action'>('cli:deleteProject'),\n addProjectMember: makeFunctionReference<'action'>('cli:addProjectMember'),\n removeProjectMember: makeFunctionReference<'action'>(\n 'cli:removeProjectMember',\n ),\n changeProjectLead: makeFunctionReference<'action'>('cli:changeProjectLead'),\n listTeams: makeFunctionReference<'action'>('cli:listTeams'),\n getTeam: makeFunctionReference<'action'>('cli:getTeam'),\n createTeam: makeFunctionReference<'action'>('cli:createTeam'),\n updateTeam: makeFunctionReference<'action'>('cli:updateTeam'),\n deleteTeam: makeFunctionReference<'action'>('cli:deleteTeam'),\n addTeamMember: makeFunctionReference<'action'>('cli:addTeamMember'),\n removeTeamMember: makeFunctionReference<'action'>('cli:removeTeamMember'),\n changeTeamLead: makeFunctionReference<'action'>('cli:changeTeamLead'),\n listFolders: makeFunctionReference<'action'>('cli:listFolders'),\n createFolder: makeFunctionReference<'action'>('cli:createFolder'),\n updateFolder: makeFunctionReference<'action'>('cli:updateFolder'),\n deleteFolder: makeFunctionReference<'action'>('cli:deleteFolder'),\n};\n\nconst rolesApi = api.roles.index;\ntype OrganizationRoleId = Id<'roles'> | Id<'orgRoles'>;\n\ntype GlobalOptions = {\n appUrl?: string;\n convexUrl?: string;\n json?: boolean;\n org?: string;\n profile?: string;\n};\n\ntype Runtime = {\n appUrl: string;\n convexUrl: string;\n json: boolean;\n org?: string;\n profile: string;\n session: CliSession | null;\n};\n\nconst ISSUE_STATE_TYPES = [\n 'backlog',\n 'todo',\n 'in_progress',\n 'done',\n 'canceled',\n] as const;\n\nconst PROJECT_STATUS_TYPES = [\n 'backlog',\n 'planned',\n 'in_progress',\n 'completed',\n 'canceled',\n] as const;\n\nconst NOTIFICATION_CATEGORIES = [\n 'invites',\n 'assignments',\n 'mentions',\n 'comments',\n] as const;\n\nfunction requiredString(value: string | undefined, label: string) {\n if (!value?.trim()) {\n throw new Error(`${label} is required`);\n }\n return value.trim();\n}\n\nfunction optionalNumber(value: string | undefined, label: string) {\n if (value === undefined) {\n return undefined;\n }\n\n const parsed = Number(value);\n if (!Number.isFinite(parsed)) {\n throw new Error(`${label} must be a valid number`);\n }\n\n return parsed;\n}\n\nfunction requiredNumber(value: string | undefined, label: string) {\n const parsed = optionalNumber(value, label);\n if (parsed === undefined) {\n throw new Error(`${label} is required`);\n }\n return parsed;\n}\n\nfunction parseBoolean(value: string, label: string) {\n const normalized = value.trim().toLowerCase();\n if (normalized === 'true') return true;\n if (normalized === 'false') return false;\n throw new Error(`${label} must be \"true\" or \"false\"`);\n}\n\nfunction parseList(value: string | undefined) {\n if (!value) return [];\n return value\n .split(',')\n .map(item => item.trim())\n .filter(Boolean);\n}\n\nfunction buildPaginationOptions(limit?: string, cursor?: string) {\n return {\n cursor: cursor ?? null,\n numItems: optionalNumber(limit, 'limit') ?? 20,\n };\n}\n\nfunction normalizeMatch(value: string | undefined | null) {\n return value?.trim().toLowerCase();\n}\n\ntype ListItem = Record<string, unknown>;\n\nfunction parseDate(value: string): number {\n const ms = Date.parse(value);\n if (!Number.isFinite(ms)) {\n throw new Error(`Invalid date: ${value}`);\n }\n return ms;\n}\n\nfunction applyListFilters(\n items: ListItem[],\n options: {\n createdAfter?: string;\n createdBefore?: string;\n updatedAfter?: string;\n updatedBefore?: string;\n sort?: string;\n order?: string;\n limit?: string;\n },\n): ListItem[] {\n let result = [...items];\n\n if (options.createdAfter) {\n const threshold = parseDate(options.createdAfter);\n result = result.filter(\n item => typeof item.createdAt === 'number' && item.createdAt >= threshold,\n );\n }\n if (options.createdBefore) {\n const threshold = parseDate(options.createdBefore);\n result = result.filter(\n item => typeof item.createdAt === 'number' && item.createdAt <= threshold,\n );\n }\n if (options.updatedAfter) {\n const threshold = parseDate(options.updatedAfter);\n result = result.filter(\n item =>\n typeof item.lastEditedAt === 'number' && item.lastEditedAt >= threshold,\n );\n }\n if (options.updatedBefore) {\n const threshold = parseDate(options.updatedBefore);\n result = result.filter(\n item =>\n typeof item.lastEditedAt === 'number' && item.lastEditedAt <= threshold,\n );\n }\n\n if (options.sort) {\n const field = options.sort;\n const desc = options.order?.toLowerCase() === 'desc';\n result.sort((a, b) => {\n const aVal = a[field];\n const bVal = b[field];\n if (aVal == null && bVal == null) return 0;\n if (aVal == null) return 1;\n if (bVal == null) return -1;\n if (typeof aVal === 'number' && typeof bVal === 'number')\n return desc ? bVal - aVal : aVal - bVal;\n return desc\n ? String(bVal).localeCompare(String(aVal))\n : String(aVal).localeCompare(String(bVal));\n });\n }\n\n if (options.limit) {\n const limit = Number(options.limit);\n if (Number.isFinite(limit) && limit > 0) {\n result = result.slice(0, limit);\n }\n }\n\n return result;\n}\n\nfunction addEntityUrls(\n items: ListItem[],\n appUrl: string,\n orgSlug: string,\n entityType: 'issues' | 'projects' | 'teams' | 'documents' | 'folders',\n): ListItem[] {\n return items.map(item => {\n let path: string;\n switch (entityType) {\n case 'issues':\n path = `/${orgSlug}/issues/${item.key}`;\n break;\n case 'projects':\n path = `/${orgSlug}/projects/${item.key}`;\n break;\n case 'teams':\n path = `/${orgSlug}/teams/${item.key}`;\n break;\n case 'documents':\n path = `/${orgSlug}/documents/${item.id}`;\n break;\n case 'folders':\n path = `/${orgSlug}/documents/folders/${item.id}`;\n break;\n }\n return { ...item, url: `${appUrl}${path}` };\n });\n}\n\nfunction normalizeAppUrl(raw: string): string {\n let url = raw.trim();\n if (!/^https?:\\/\\//i.test(url)) {\n const isLocal =\n /^localhost(:\\d+)?/i.test(url) || /^127\\.0\\.0\\.1(:\\d+)?/.test(url);\n url = isLocal ? `http://${url}` : `https://${url}`;\n }\n // Strip trailing slash for consistency\n return url.replace(/\\/+$/, '');\n}\n\nasync function resolveAppUrl(raw: string): Promise<string> {\n const url = normalizeAppUrl(raw);\n try {\n const response = await fetch(url, { method: 'HEAD', redirect: 'follow' });\n // Use the final URL after redirects, stripped of trailing slash and path\n const resolved = new URL(response.url).origin;\n return resolved;\n } catch {\n return url;\n }\n}\n\nasync function fetchConvexUrl(appUrl: string): Promise<string> {\n try {\n const url = new URL('/api/config', appUrl).toString();\n const response = await fetch(url);\n if (!response.ok) {\n throw new Error(`HTTP ${response.status}`);\n }\n const data = (await response.json()) as { convexUrl?: string };\n if (data.convexUrl) {\n return data.convexUrl;\n }\n } catch {\n // Fall through to default\n }\n return 'http://127.0.0.1:3210';\n}\n\nasync function getRuntime(command: Command) {\n const options = command.optsWithGlobals<GlobalOptions>();\n const profile = options.profile ?? 'default';\n const session = await readSession(profile);\n const appUrlSource =\n options.appUrl ?? session?.appUrl ?? process.env.NEXT_PUBLIC_APP_URL;\n const appUrl = await resolveAppUrl(requiredString(appUrlSource, 'app URL'));\n let convexUrl = options.convexUrl ?? session?.convexUrl;\n\n if (!convexUrl) {\n // When an explicit --app-url is provided, always fetch from the app\n // to avoid using local env vars that may point at a different deployment.\n const fetchedUrl = await fetchConvexUrl(appUrl);\n convexUrl =\n fetchedUrl !== 'http://127.0.0.1:3210'\n ? fetchedUrl\n : (process.env.NEXT_PUBLIC_CONVEX_URL ??\n process.env.CONVEX_URL ??\n fetchedUrl);\n }\n\n return {\n appUrl,\n convexUrl,\n json: Boolean(options.json),\n org: options.org ?? session?.activeOrgSlug,\n profile,\n session,\n } satisfies Runtime;\n}\n\nfunction requireSession(runtime: Runtime) {\n if (\n !runtime.session ||\n (Object.keys(runtime.session.cookies).length === 0 &&\n !runtime.session.bearerToken)\n ) {\n throw new Error('Not logged in. Run `vcli auth login` first.');\n }\n return runtime.session;\n}\n\nfunction requireOrg(runtime: Runtime, explicit?: string) {\n const orgSlug = explicit ?? runtime.org;\n if (!orgSlug) {\n throw new Error(\n 'Organization slug is required. Pass `--org <slug>` or run `vcli org use <slug>`.',\n );\n }\n return orgSlug;\n}\n\nasync function getClient(command: Command) {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n return { client, runtime, session };\n}\n\nasync function resolveMemberId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n): Promise<Id<'users'>> {\n const members = await runQuery(\n client,\n api.organizations.queries.listMembers,\n {\n orgSlug,\n },\n );\n const needle = normalizeMatch(ref);\n const matches = members.filter(member => {\n const user = member.user;\n if (!user) return false;\n return (\n normalizeMatch(String(user._id)) === needle ||\n normalizeMatch(user.email) === needle ||\n normalizeMatch(user.name) === needle ||\n normalizeMatch(user.username) === needle\n );\n });\n\n if (matches.length === 0) {\n throw new Error(`No member matched \"${ref}\"`);\n }\n if (matches.length > 1) {\n throw new Error(`Multiple members matched \"${ref}\"`);\n }\n return matches[0]!.user!._id;\n}\n\nasync function resolveRoleId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n): Promise<OrganizationRoleId> {\n const roles = await runQuery(client, rolesApi.list, { orgSlug });\n const needle = normalizeMatch(ref);\n const matches = roles.filter(role => {\n const candidate = role as { _id: string; name?: string; key?: string };\n return (\n normalizeMatch(String(candidate._id)) === needle ||\n normalizeMatch(candidate.name) === needle ||\n normalizeMatch(candidate.key) === needle\n );\n });\n\n if (matches.length === 0) {\n throw new Error(`No role matched \"${ref}\"`);\n }\n if (matches.length > 1) {\n throw new Error(`Multiple roles matched \"${ref}\"`);\n }\n return matches[0]!._id;\n}\n\nfunction parsePermissions(value: string): Permission[] {\n return value\n .split(',')\n .map(permission => permission.trim())\n .filter(Boolean) as Permission[];\n}\n\nfunction nullableOption(value: string | undefined, clear = false) {\n if (clear) return null;\n return value;\n}\n\nfunction mimeTypeForFile(filePath: string) {\n switch (extname(filePath).toLowerCase()) {\n case '.png':\n return 'image/png';\n case '.jpg':\n case '.jpeg':\n return 'image/jpeg';\n case '.webp':\n return 'image/webp';\n case '.gif':\n return 'image/gif';\n case '.svg':\n return 'image/svg+xml';\n default:\n return 'application/octet-stream';\n }\n}\n\nasync function uploadFile(uploadUrl: string, filePath: string) {\n const body = await readFile(filePath);\n const response = await fetch(uploadUrl, {\n method: 'POST',\n headers: {\n 'Content-Type': mimeTypeForFile(filePath),\n },\n body,\n });\n\n if (!response.ok) {\n throw new Error(`Upload failed with HTTP ${response.status}`);\n }\n\n const data = (await response.json()) as { storageId?: Id<'_storage'> };\n if (!data.storageId) {\n throw new Error('Upload response did not include a storageId');\n }\n\n return data.storageId;\n}\n\nasync function resolveTeamId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n teamKey?: string,\n) {\n if (!teamKey) {\n return undefined;\n }\n const team = await runAction(client, cliApi.getTeam, { orgSlug, teamKey });\n return team.id as Id<'teams'>;\n}\n\nasync function resolveProjectId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n projectKey?: string,\n) {\n if (!projectKey) {\n return undefined;\n }\n const project = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n return project.id as Id<'projects'>;\n}\n\nasync function resolveIssueId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n issueKey: string,\n) {\n const issue = await runAction(client, cliApi.getIssue, { orgSlug, issueKey });\n return issue.id as Id<'issues'>;\n}\n\nasync function resolveDocumentId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n documentId: string,\n) {\n const document = await runAction(client, cliApi.getDocument, {\n orgSlug,\n documentId,\n });\n return document.id as Id<'documents'>;\n}\n\nasync function resolveIssueStateId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const states = await runQuery(\n client,\n api.organizations.queries.listIssueStates,\n {\n orgSlug,\n },\n );\n const needle = normalizeMatch(ref);\n const match = states.find(state => {\n return (\n normalizeMatch(String(state._id)) === needle ||\n normalizeMatch(state.name) === needle ||\n normalizeMatch(state.type) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No issue state matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function resolveIssuePriorityId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const priorities = await runQuery(\n client,\n api.organizations.queries.listIssuePriorities,\n { orgSlug },\n );\n const needle = normalizeMatch(ref);\n const match = priorities.find(priority => {\n return (\n normalizeMatch(String(priority._id)) === needle ||\n normalizeMatch(priority.name) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No issue priority matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function resolveProjectStatusId(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n ref: string,\n) {\n const statuses = await runQuery(\n client,\n api.organizations.queries.listProjectStatuses,\n { orgSlug },\n );\n const needle = normalizeMatch(ref);\n const match = statuses.find(status => {\n return (\n normalizeMatch(String(status._id)) === needle ||\n normalizeMatch(status.name) === needle ||\n normalizeMatch(status.type) === needle\n );\n });\n\n if (!match) {\n throw new Error(`No project status matched \"${ref}\"`);\n }\n\n return match._id;\n}\n\nasync function parseEstimatedTimes(\n client: Awaited<ReturnType<typeof createConvexClient>>,\n orgSlug: string,\n value: string,\n) {\n const entries = parseList(value);\n const estimatedTimes: Record<string, number> = {};\n\n for (const entry of entries) {\n const separatorIndex = entry.indexOf('=');\n if (separatorIndex <= 0) {\n throw new Error(\n 'estimated times must use the format \"state=hours,state=hours\"',\n );\n }\n\n const stateRef = entry.slice(0, separatorIndex).trim();\n const hours = Number(entry.slice(separatorIndex + 1).trim());\n if (!Number.isFinite(hours)) {\n throw new Error(`Invalid estimate for \"${stateRef}\"`);\n }\n\n const stateId = await resolveIssueStateId(client, orgSlug, stateRef);\n estimatedTimes[String(stateId)] = hours;\n }\n\n return estimatedTimes;\n}\n\nconst program = new Command();\n\nfunction readPackageVersionSync(): string {\n try {\n const dir = import.meta.dirname ?? dirname(fileURLToPath(import.meta.url));\n const raw = readFileSync(join(dir, '..', 'package.json'), 'utf8');\n return (JSON.parse(raw) as { version?: string }).version ?? 'unknown';\n } catch {\n return 'unknown';\n }\n}\n\nprogram\n .name('vcli')\n .description('Vector CLI')\n .version(readPackageVersionSync(), '-v, --version')\n .showHelpAfterError()\n .option(\n '--app-url <url>',\n 'Vector app URL. Required unless saved in the profile or NEXT_PUBLIC_APP_URL is set.',\n )\n .option('--convex-url <url>', 'Convex deployment URL')\n .option('--org <slug>', 'Organization slug override')\n .option('--profile <name>', 'CLI profile name', 'default')\n .option('--json', 'Output JSON');\n\nconst authCommand = program.command('auth').description('Authentication');\n\nauthCommand\n .command('signup')\n .option('--email <email>', 'Email address')\n .option('--username <username>', 'Username')\n .option('--password <password>', 'Password')\n .action(async (options, command) => {\n const runtime = await getRuntime(command);\n const email = requiredString(\n options.email?.trim() || (await prompt('Email: ')),\n 'email',\n ).toLowerCase();\n const username = requiredString(\n options.username?.trim() || (await prompt('Username: ')),\n 'username',\n );\n const password =\n options.password?.trim() || (await promptSecret('Password: '));\n\n let session = createEmptySession();\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n\n session = await signUpWithEmail(\n session,\n runtime.appUrl,\n email,\n username,\n password,\n );\n const authState = await fetchAuthSession(session, runtime.appUrl);\n session = authState.session;\n\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n session.activeOrgSlug = orgs[0]?.slug ?? session.activeOrgSlug;\n\n await writeSession(session, runtime.profile);\n printOutput(\n {\n signedUpAs:\n authState.user?.email ??\n authState.user?.username ??\n authState.user?.name,\n activeOrgSlug: session.activeOrgSlug ?? null,\n },\n runtime.json,\n );\n });\n\nauthCommand\n .command('login [identifier]')\n .option('--password <password>', 'Password (uses device flow if omitted)')\n .action(async (identifier, options, command) => {\n const runtime = await getRuntime(command);\n let session = createEmptySession();\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n\n const usePassword = Boolean(identifier || options.password);\n\n if (usePassword) {\n const loginId =\n identifier?.trim() || (await prompt('Email or username: '));\n const password =\n options.password?.trim() || (await promptSecret('Password: '));\n session = await loginWithPassword(\n session,\n runtime.appUrl,\n loginId,\n password,\n );\n } else {\n const deviceResp = await requestDeviceCode(runtime.appUrl, 'vcli');\n const verifyUrl = `${runtime.appUrl}/device?user_code=${deviceResp.user_code}`;\n\n console.log();\n console.log(` Open this URL in your browser to log in:`);\n console.log();\n console.log(` ${verifyUrl}`);\n console.log();\n console.log(` Or go to ${runtime.appUrl}/device and enter code:`);\n console.log();\n console.log(` ${deviceResp.user_code}`);\n console.log();\n\n const open = await import('open').then(m => m.default).catch(() => null);\n if (open) {\n await open(verifyUrl).catch(() => {});\n }\n\n console.log(' Waiting for authorization...');\n session = await pollDeviceToken(\n session,\n runtime.appUrl,\n deviceResp.device_code,\n 'vcli',\n deviceResp.interval,\n deviceResp.expires_in,\n );\n }\n\n const authState = await fetchAuthSession(session, runtime.appUrl);\n session = authState.session;\n\n const client = await createConvexClient(\n session,\n runtime.appUrl,\n runtime.convexUrl,\n );\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n session.activeOrgSlug = orgs[0]?.slug ?? session.activeOrgSlug;\n\n await writeSession(session, runtime.profile);\n printOutput(\n {\n loggedInAs:\n authState.user?.email ??\n authState.user?.username ??\n authState.user?.name,\n activeOrgSlug: session.activeOrgSlug ?? null,\n },\n runtime.json,\n );\n });\n\nauthCommand.command('logout').action(async (_options, command) => {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n await logout(session, runtime.appUrl);\n await clearSession(runtime.profile);\n printOutput({ success: true }, runtime.json);\n});\n\nauthCommand.command('whoami').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const [user, orgs] = await Promise.all([\n runQuery(client, api.users.getCurrentUser, {}),\n runQuery(client, api.users.getOrganizations, {}),\n ]);\n printOutput(\n {\n user,\n organizations: orgs,\n activeOrgSlug: runtime.org ?? null,\n },\n runtime.json,\n );\n});\n\nconst orgCommand = program.command('org').description('Organizations');\n\norgCommand.command('list').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const orgs = await runQuery(client, api.users.getOrganizations, {});\n printOutput(orgs, runtime.json);\n});\n\norgCommand.command('current').action(async (_options, command) => {\n const runtime = await getRuntime(command);\n printOutput({ activeOrgSlug: runtime.org ?? null }, runtime.json);\n});\n\norgCommand.command('use <slug>').action(async (slug, _options, command) => {\n const runtime = await getRuntime(command);\n const session = requireSession(runtime);\n session.activeOrgSlug = slug;\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n await writeSession(session, runtime.profile);\n printOutput({ activeOrgSlug: slug }, runtime.json);\n});\n\norgCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--slug <slug>')\n .action(async (options, command) => {\n const { client, runtime, session } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.create,\n {\n data: {\n name: options.name,\n slug: options.slug,\n },\n },\n );\n if (session) {\n session.activeOrgSlug = options.slug;\n session.appUrl = runtime.appUrl;\n session.convexUrl = runtime.convexUrl;\n await writeSession(session, runtime.profile);\n }\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('update [slug]')\n .option('--name <name>')\n .option('--new-slug <slug>')\n .action(async (slug, options, command) => {\n const { client, runtime, session } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.update,\n {\n orgSlug,\n data: {\n ...(options.name ? { name: options.name } : {}),\n ...(options.newSlug ? { slug: options.newSlug } : {}),\n },\n },\n );\n if (session && options.newSlug && session.activeOrgSlug === orgSlug) {\n session.activeOrgSlug = options.newSlug;\n await writeSession(session, runtime.profile);\n }\n printOutput(result, runtime.json);\n });\n\norgCommand.command('stats [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.getOrganizationStats,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n});\n\norgCommand\n .command('logo [slug]')\n .option('--file <path>')\n .option('--remove')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n\n if (options.remove) {\n throw new Error(\n 'Organization logo removal is not exposed by the current backend API.',\n );\n }\n\n const filePath = requiredString(options.file, 'file');\n const uploadUrl = await runMutation(\n client,\n api.organizations.mutations.generateLogoUploadUrl,\n { orgSlug },\n );\n const storageId = await uploadFile(uploadUrl, filePath);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateLogoWithStorageId,\n {\n orgSlug,\n storageId,\n },\n );\n printOutput(\n { ...(result ?? { success: true }), storageId, orgSlug },\n runtime.json,\n );\n });\n\norgCommand.command('members [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const members = await runQuery(\n client,\n api.organizations.queries.listMembersWithRoles,\n {\n orgSlug,\n },\n );\n printOutput(members, runtime.json);\n});\n\norgCommand.command('invites [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const invites = await runQuery(\n client,\n api.organizations.queries.listInvites,\n {\n orgSlug,\n },\n );\n printOutput(invites, runtime.json);\n});\n\norgCommand\n .command('invite [slug]')\n .requiredOption('--email <email>')\n .option('--role <role>', 'member or admin', 'member')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.invite,\n {\n orgSlug,\n email: options.email,\n role: options.role,\n },\n );\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('member-role <member>')\n .requiredOption('--role <role>', 'member or admin')\n .action(async (member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const userId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateMemberRole,\n {\n orgSlug,\n userId,\n role: options.role,\n },\n );\n printOutput(result, runtime.json);\n });\n\norgCommand\n .command('remove-member <member>')\n .action(async (member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const userId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.organizations.mutations.removeMember,\n {\n orgSlug,\n userId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\norgCommand\n .command('revoke-invite <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.revokeInvite,\n {\n inviteId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst roleCommand = program.command('role').description('Organization roles');\n\nroleCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const roles = await runQuery(client, rolesApi.list, { orgSlug });\n printOutput(roles, runtime.json);\n});\n\nroleCommand.command('get <role>').action(async (role, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const roleId = await resolveRoleId(client, orgSlug, role);\n const [summary, permissions] = await Promise.all([\n runQuery(client, rolesApi.get, { orgSlug, roleId }),\n runQuery(client, rolesApi.getPermissions, { roleId }),\n ]);\n printOutput({ summary, permissions }, runtime.json);\n});\n\nroleCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--permissions <permissions>', 'Comma-separated permissions')\n .option('--description <description>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runMutation(client, rolesApi.create, {\n orgSlug,\n name: options.name,\n description: options.description,\n permissions: parsePermissions(options.permissions),\n });\n printOutput({ roleId: result }, runtime.json);\n });\n\nroleCommand\n .command('update <role>')\n .requiredOption('--name <name>')\n .requiredOption('--permissions <permissions>', 'Comma-separated permissions')\n .option('--description <description>')\n .action(async (role, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const roleId = await resolveRoleId(client, orgSlug, role);\n const result = await runMutation(client, rolesApi.update, {\n orgSlug,\n roleId,\n name: options.name,\n description: options.description,\n permissions: parsePermissions(options.permissions),\n });\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nroleCommand\n .command('assign <role> <member>')\n .action(async (role, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [roleId, userId] = await Promise.all([\n resolveRoleId(client, orgSlug, role),\n resolveMemberId(client, orgSlug, member),\n ]);\n const result = await runMutation(client, rolesApi.assign, {\n orgSlug,\n roleId,\n userId,\n });\n printOutput({ assignmentId: result }, runtime.json);\n });\n\nroleCommand\n .command('unassign <role> <member>')\n .action(async (role, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [roleId, userId] = await Promise.all([\n resolveRoleId(client, orgSlug, role),\n resolveMemberId(client, orgSlug, member),\n ]);\n const result = await runMutation(client, rolesApi.removeAssignment, {\n orgSlug,\n roleId,\n userId,\n });\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst inviteCommand = program.command('invite').description('Invitations');\n\ninviteCommand.command('list').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const invites = await runQuery(client, api.users.getPendingInvitations, {});\n printOutput(invites, runtime.json);\n});\n\ninviteCommand\n .command('accept <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.acceptInvitation,\n { inviteId },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\ninviteCommand\n .command('decline <inviteId>')\n .action(async (inviteId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.organizations.mutations.declineInvitation,\n { inviteId },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nprogram.command('refdata [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runAction(client, cliApi.listWorkspaceReferenceData, {\n orgSlug,\n });\n printOutput(result, runtime.json);\n});\n\nprogram\n .command('icons <query>')\n .option('--limit <n>')\n .action(async (query, options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runAction(client, cliApi.searchIcons, {\n query,\n limit: options.limit ? Number(options.limit) : undefined,\n });\n printOutput(result, runtime.json);\n });\n\nprogram\n .command('search <query>')\n .option('--limit <n>')\n .action(async (query, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runQuery(client, api.search.queries.searchEntities, {\n orgSlug,\n query,\n limit: optionalNumber(options.limit, 'limit'),\n });\n printOutput(result, runtime.json);\n });\n\nconst permissionCommand = program\n .command('permission')\n .description('Permission checks');\n\npermissionCommand\n .command('check <permission>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .action(async (permission, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [teamId, projectId] = await Promise.all([\n resolveTeamId(client, orgSlug, options.team),\n resolveProjectId(client, orgSlug, options.project),\n ]);\n const result = await runQuery(client, api.permissions.utils.has, {\n orgSlug,\n permission,\n teamId,\n projectId,\n });\n printOutput(\n { permission, allowed: result, teamId, projectId },\n runtime.json,\n );\n });\n\npermissionCommand\n .command('check-many <permissions>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .action(async (permissions, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [teamId, projectId] = await Promise.all([\n resolveTeamId(client, orgSlug, options.team),\n resolveProjectId(client, orgSlug, options.project),\n ]);\n const permissionList = parsePermissions(permissions);\n const result = await runQuery(client, api.permissions.utils.hasMultiple, {\n orgSlug,\n permissions: permissionList,\n teamId,\n projectId,\n });\n printOutput(result, runtime.json);\n });\n\nconst activityCommand = program\n .command('activity')\n .description('Activity feed');\n\nactivityCommand\n .command('project <projectKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (projectKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const projectId = await resolveProjectId(client, orgSlug, projectKey);\n const result = await runQuery(\n client,\n api.activities.queries.listProjectActivity,\n {\n projectId: projectId!,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('team <teamKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (teamKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const teamId = await resolveTeamId(client, orgSlug, teamKey);\n const result = await runQuery(\n client,\n api.activities.queries.listTeamActivity,\n {\n teamId: teamId!,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('issue <issueKey>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const result = await runQuery(\n client,\n api.activities.queries.listIssueActivity,\n {\n issueId,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nactivityCommand\n .command('document <documentId>')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const resolvedDocumentId = await resolveDocumentId(\n client,\n orgSlug,\n documentId,\n );\n const result = await runQuery(\n client,\n api.activities.queries.listDocumentActivity,\n {\n documentId: resolvedDocumentId,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n },\n );\n printOutput(result, runtime.json);\n });\n\nconst notificationCommand = program\n .command('notification')\n .description('Notifications');\n\nnotificationCommand\n .command('inbox')\n .option('--filter <filter>', 'all or unread')\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(client, api.notifications.queries.listInbox, {\n filter: options.filter,\n paginationOpts: buildPaginationOptions(options.limit, options.cursor),\n });\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('unread-count')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.unreadCount,\n {},\n );\n printOutput({ unreadCount: result }, runtime.json);\n });\n\nnotificationCommand\n .command('mark-read <recipientId>')\n .action(async (recipientId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.markRead,\n {\n recipientId,\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('mark-all-read')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.markAllRead,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('archive <recipientId>')\n .action(async (recipientId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.archive,\n {\n recipientId,\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand.command('preferences').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.getPreferences,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nnotificationCommand\n .command('set-preference <category>')\n .requiredOption('--in-app <true|false>')\n .requiredOption('--email <true|false>')\n .requiredOption('--push <true|false>')\n .action(async (category, options, command) => {\n const { client, runtime } = await getClient(command);\n if (!NOTIFICATION_CATEGORIES.includes(category)) {\n throw new Error(\n `category must be one of: ${NOTIFICATION_CATEGORIES.join(', ')}`,\n );\n }\n const result = await runMutation(\n client,\n api.notifications.mutations.updatePreferences,\n {\n category,\n inAppEnabled: parseBoolean(options.inApp, 'in-app'),\n emailEnabled: parseBoolean(options.email, 'email'),\n pushEnabled: parseBoolean(options.push, 'push'),\n },\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('subscriptions')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.notifications.queries.listPushSubscriptions,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nnotificationCommand\n .command('remove-subscription <subscriptionId>')\n .action(async (subscriptionId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.notifications.mutations.removePushSubscription,\n { subscriptionId },\n );\n printOutput(result, runtime.json);\n });\n\nconst priorityCommand = program\n .command('priority')\n .description('Issue priorities');\n\npriorityCommand\n .command('list [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listIssuePriorities,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n });\n\npriorityCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--weight <n>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runMutation(\n client,\n api.organizations.mutations.createIssuePriority,\n {\n orgSlug,\n name: options.name,\n weight: requiredNumber(options.weight, 'weight'),\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\npriorityCommand\n .command('update <priority>')\n .requiredOption('--name <name>')\n .requiredOption('--color <hex>')\n .option('--weight <n>')\n .option('--icon <icon>')\n .action(async (priority, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const priorityId = await resolveIssuePriorityId(client, orgSlug, priority);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateIssuePriority,\n {\n orgSlug,\n priorityId,\n name: options.name,\n weight: optionalNumber(options.weight, 'weight'),\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\npriorityCommand\n .command('delete <priority>')\n .action(async (priority, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const priorityId = await resolveIssuePriorityId(client, orgSlug, priority);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteIssuePriority,\n {\n orgSlug,\n priorityId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\npriorityCommand\n .command('reset [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetIssuePriorities,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst stateCommand = program.command('state').description('Issue states');\n\nstateCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listIssueStates,\n {\n orgSlug,\n },\n );\n printOutput(result, runtime.json);\n});\n\nstateCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!ISSUE_STATE_TYPES.includes(options.type)) {\n throw new Error(`type must be one of: ${ISSUE_STATE_TYPES.join(', ')}`);\n }\n const result = await runMutation(\n client,\n api.organizations.mutations.createIssueState,\n {\n orgSlug,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\nstateCommand\n .command('update <state>')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (state, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!ISSUE_STATE_TYPES.includes(options.type)) {\n throw new Error(`type must be one of: ${ISSUE_STATE_TYPES.join(', ')}`);\n }\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateIssueState,\n {\n orgSlug,\n stateId,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstateCommand\n .command('delete <state>')\n .action(async (state, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteIssueState,\n {\n orgSlug,\n stateId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstateCommand.command('reset [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetIssueStates,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n});\n\nconst statusCommand = program.command('status').description('Project statuses');\n\nstatusCommand.command('list [slug]').action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runQuery(\n client,\n api.organizations.queries.listProjectStatuses,\n { orgSlug },\n );\n printOutput(result, runtime.json);\n});\n\nstatusCommand\n .command('create')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!PROJECT_STATUS_TYPES.includes(options.type)) {\n throw new Error(\n `type must be one of: ${PROJECT_STATUS_TYPES.join(', ')}`,\n );\n }\n const result = await runMutation(\n client,\n api.organizations.mutations.createProjectStatus,\n {\n orgSlug,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result, runtime.json);\n });\n\nstatusCommand\n .command('update <status>')\n .requiredOption('--name <name>')\n .requiredOption('--position <n>')\n .requiredOption('--type <type>')\n .requiredOption('--color <hex>')\n .option('--icon <icon>')\n .action(async (status, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n if (!PROJECT_STATUS_TYPES.includes(options.type)) {\n throw new Error(\n `type must be one of: ${PROJECT_STATUS_TYPES.join(', ')}`,\n );\n }\n const statusId = await resolveProjectStatusId(client, orgSlug, status);\n const result = await runMutation(\n client,\n api.organizations.mutations.updateProjectStatus,\n {\n orgSlug,\n statusId,\n name: options.name,\n position: requiredNumber(options.position, 'position'),\n type: options.type,\n color: options.color,\n icon: options.icon,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstatusCommand\n .command('delete <status>')\n .action(async (status, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const statusId = await resolveProjectStatusId(client, orgSlug, status);\n const result = await runMutation(\n client,\n api.organizations.mutations.deleteProjectStatus,\n {\n orgSlug,\n statusId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nstatusCommand\n .command('reset [slug]')\n .action(async (slug, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const result = await runMutation(\n client,\n api.organizations.mutations.resetProjectStatuses,\n { orgSlug },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nconst adminCommand = program.command('admin').description('Platform admin');\n\nadminCommand.command('branding').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.platformAdmin.queries.getBranding,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nadminCommand\n .command('set-branding')\n .option('--name <name>')\n .option('--description <description>')\n .option('--theme-color <hex>')\n .option('--accent-color <hex>')\n .option('--logo <path>')\n .option('--remove-logo')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n let logoStorageId: Id<'_storage'> | undefined;\n if (options.logo) {\n const uploadUrl = await runMutation(\n client,\n api.platformAdmin.mutations.generateBrandLogoUploadUrl,\n {},\n );\n logoStorageId = await uploadFile(uploadUrl, options.logo);\n }\n\n const result = await runMutation(\n client,\n api.platformAdmin.mutations.updateBranding,\n {\n name: options.name,\n description: options.description,\n logoStorageId,\n removeLogo: options.removeLogo ? true : undefined,\n themeColor: options.themeColor,\n accentColor: options.accentColor,\n },\n );\n printOutput(\n {\n ...(result ?? { success: true }),\n logoStorageId: logoStorageId ?? null,\n },\n runtime.json,\n );\n });\n\nadminCommand.command('signup-policy').action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runQuery(\n client,\n api.platformAdmin.queries.getSignupPolicy,\n {},\n );\n printOutput(result, runtime.json);\n});\n\nadminCommand\n .command('set-signup-policy')\n .option('--blocked <domains>')\n .option('--allowed <domains>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.platformAdmin.mutations.updateSignupEmailDomainPolicy,\n {\n blockedDomains: parseList(options.blocked),\n allowedDomains: parseList(options.allowed),\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nadminCommand\n .command('sync-disposable-domains')\n .action(async (_options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runAction(\n client,\n api.platformAdmin.actions.runDisposableDomainSyncNow,\n {},\n );\n printOutput(result, runtime.json);\n });\n\nconst teamCommand = program.command('team').description('Teams');\n\nteamCommand\n .command('list [slug]')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listTeams, {\n orgSlug,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'teams');\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('get <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getTeam, {\n orgSlug,\n teamKey,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('create')\n .requiredOption('--key <key>')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createTeam, {\n orgSlug,\n key: options.key,\n name: options.name,\n description: options.description,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('update <teamKey>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--clear-description')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (teamKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateTeam, {\n orgSlug,\n teamKey,\n name: options.name,\n description: nullableOption(\n options.description,\n options.clearDescription,\n ),\n visibility: options.visibility,\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('delete <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteTeam, {\n orgSlug,\n teamKey,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('members <teamKey>')\n .action(async (teamKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const team = await runAction(client, cliApi.getTeam, { orgSlug, teamKey });\n const result = await runQuery(client, api.teams.queries.listMembers, {\n teamId: team.id as any,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('add-member <teamKey> <member>')\n .option('--role <role>', 'member or lead', 'member')\n .action(async (teamKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.addTeamMember, {\n orgSlug,\n teamKey,\n memberName: member,\n role: options.role,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('remove-member <teamKey> <member>')\n .action(async (teamKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.removeTeamMember, {\n orgSlug,\n teamKey,\n memberName: member,\n });\n printOutput(result, runtime.json);\n });\n\nteamCommand\n .command('set-lead <teamKey> <member>')\n .action(async (teamKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const leadName = member === 'null' ? null : member;\n const result = await runAction(client, cliApi.changeTeamLead, {\n orgSlug,\n teamKey,\n leadName,\n });\n printOutput(result, runtime.json);\n });\n\nconst projectCommand = program.command('project').description('Projects');\n\nprojectCommand\n .command('list [slug]')\n .option('--team <teamKey>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listProjects, {\n orgSlug,\n teamKey: options.team,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'projects');\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('get <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('create')\n .requiredOption('--key <key>')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--team <teamKey>')\n .option('--status <statusName>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createProject, {\n orgSlug,\n key: options.key,\n name: options.name,\n description: options.description,\n teamKey: options.team,\n statusName: options.status,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('update <projectKey>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--status <statusName>')\n .option('--clear-status')\n .option('--visibility <visibility>')\n .option('--start-date <date>')\n .option('--clear-start-date')\n .option('--due-date <date>')\n .option('--clear-due-date')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (projectKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateProject, {\n orgSlug,\n projectKey,\n name: options.name,\n description: options.description,\n teamKey: nullableOption(options.team, options.clearTeam),\n statusName: nullableOption(options.status, options.clearStatus),\n visibility: options.visibility,\n startDate: nullableOption(options.startDate, options.clearStartDate),\n dueDate: nullableOption(options.dueDate, options.clearDueDate),\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('delete <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteProject, {\n orgSlug,\n projectKey,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('members <projectKey>')\n .action(async (projectKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const project = await runAction(client, cliApi.getProject, {\n orgSlug,\n projectKey,\n });\n const result = await runQuery(client, api.projects.queries.listMembers, {\n projectId: project.id as any,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('add-member <projectKey> <member>')\n .option('--role <role>', 'member or lead', 'member')\n .action(async (projectKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.addProjectMember, {\n orgSlug,\n projectKey,\n memberName: member,\n role: options.role,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('remove-member <projectKey> <member>')\n .action(async (projectKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.removeProjectMember, {\n orgSlug,\n projectKey,\n memberName: member,\n });\n printOutput(result, runtime.json);\n });\n\nprojectCommand\n .command('set-lead <projectKey> <member>')\n .action(async (projectKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const leadName = member === 'null' ? null : member;\n const result = await runAction(client, cliApi.changeProjectLead, {\n orgSlug,\n projectKey,\n leadName,\n });\n printOutput(result, runtime.json);\n });\n\nconst issueCommand = program.command('issue').description('Issues');\n\nissueCommand\n .command('list [slug]')\n .option('--project <projectKey>')\n .option('--team <teamKey>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, title, key)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listIssues, {\n orgSlug,\n projectKey: options.project,\n teamKey: options.team,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'issues');\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('get <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getIssue, {\n orgSlug,\n issueKey,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('create')\n .requiredOption('--title <title>')\n .option('--description <description>')\n .option('--project <projectKey>')\n .option('--team <teamKey>')\n .option('--priority <priorityName>')\n .option('--visibility <visibility>')\n .option('--assignee <member>')\n .option('--state <stateName>')\n .option('--start-date <date>')\n .option('--due-date <date>')\n .option('--parent <issueKey>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createIssue, {\n orgSlug,\n title: options.title,\n description: options.description,\n projectKey: options.project,\n teamKey: options.team,\n priorityName: options.priority,\n visibility: options.visibility,\n assigneeName: options.assignee,\n stateName: options.state,\n startDate: options.startDate,\n dueDate: options.dueDate,\n parentIssueKey: options.parent,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('update <issueKey>')\n .option('--title <title>')\n .option('--description <description>')\n .option('--priority <priorityName>')\n .option('--clear-priority')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--project <projectKey>')\n .option('--clear-project')\n .option('--visibility <visibility>')\n .option('--assignee <member>')\n .option('--clear-assignee')\n .option('--state <stateName>')\n .option('--start-date <date>')\n .option('--clear-start-date')\n .option('--due-date <date>')\n .option('--clear-due-date')\n .option('--parent <issueKey>')\n .option('--clear-parent')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateIssue, {\n orgSlug,\n issueKey,\n title: options.title,\n description: options.description,\n priorityName: nullableOption(options.priority, options.clearPriority),\n teamKey: nullableOption(options.team, options.clearTeam),\n projectKey: nullableOption(options.project, options.clearProject),\n visibility: options.visibility,\n assigneeName: nullableOption(options.assignee, options.clearAssignee),\n stateName: options.state,\n startDate: nullableOption(options.startDate, options.clearStartDate),\n dueDate: nullableOption(options.dueDate, options.clearDueDate),\n parentIssueKey: nullableOption(options.parent, options.clearParent),\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('delete <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteIssue, {\n orgSlug,\n issueKey,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('assign <issueKey> <member>')\n .option('--state <stateName>')\n .action(async (issueKey, member, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.assignIssue, {\n orgSlug,\n issueKey,\n assigneeName: member,\n stateName: options.state,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('unassign <issueKey> <member>')\n .action(async (issueKey, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.unassignIssue, {\n orgSlug,\n issueKey,\n assigneeName: member,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('assignments <issueKey>')\n .action(async (issueKey, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const result = await runQuery(client, api.issues.queries.getAssignments, {\n issueId,\n });\n printOutput(result, runtime.json);\n });\n\nissueCommand\n .command('set-assignment-state <assignmentId> <state>')\n .action(async (assignmentId, state, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const stateId = await resolveIssueStateId(client, orgSlug, state);\n const result = await runMutation(\n client,\n api.issues.mutations.changeAssignmentState,\n {\n assignmentId,\n stateId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('reassign-assignment <assignmentId> <member>')\n .action(async (assignmentId, member, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const assigneeId = await resolveMemberId(client, orgSlug, member);\n const result = await runMutation(\n client,\n api.issues.mutations.updateAssignmentAssignee,\n {\n assignmentId,\n assigneeId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('remove-assignment <assignmentId>')\n .action(async (assignmentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const result = await runMutation(\n client,\n api.issues.mutations.deleteAssignment,\n {\n assignmentId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('set-priority <issueKey> <priority>')\n .action(async (issueKey, priority, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const [issueId, priorityId] = await Promise.all([\n resolveIssueId(client, orgSlug, issueKey),\n resolveIssuePriorityId(client, orgSlug, priority),\n ]);\n const result = await runMutation(\n client,\n api.issues.mutations.changePriority,\n {\n issueId,\n priorityId,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('replace-assignees <issueKey> <members>')\n .action(async (issueKey, members, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const assigneeIds = await Promise.all(\n parseList(members).map(member =>\n resolveMemberId(client, orgSlug, member),\n ),\n );\n const result = await runMutation(\n client,\n api.issues.mutations.updateAssignees,\n {\n issueId,\n assigneeIds,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('set-estimates <issueKey>')\n .requiredOption('--values <state=hours,...>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issueId = await resolveIssueId(client, orgSlug, issueKey);\n const estimatedTimes = await parseEstimatedTimes(\n client,\n orgSlug,\n options.values,\n );\n const result = await runMutation(\n client,\n api.issues.mutations.updateEstimatedTimes,\n {\n issueId,\n estimatedTimes,\n },\n );\n printOutput(result ?? { success: true }, runtime.json);\n });\n\nissueCommand\n .command('comment <issueKey>')\n .requiredOption('--body <body>')\n .action(async (issueKey, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const issue = await runAction(client, cliApi.getIssue, {\n orgSlug,\n issueKey,\n });\n const result = await runMutation(client, api.issues.mutations.addComment, {\n issueId: issue.id as any,\n body: options.body,\n });\n printOutput(result, runtime.json);\n });\n\nconst documentCommand = program.command('document').description('Documents');\n\ndocumentCommand\n .command('list [slug]')\n .option('--folder-id <id>')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option(\n '--updated-after <date>',\n 'Filter: last edited on or after date (ISO)',\n )\n .option(\n '--updated-before <date>',\n 'Filter: last edited on or before date (ISO)',\n )\n .option(\n '--sort <field>',\n 'Sort by field (e.g. createdAt, title, lastEditedAt)',\n )\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listDocuments, {\n orgSlug,\n folderId: options.folderId,\n });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(\n filtered,\n runtime.appUrl,\n orgSlug,\n 'documents',\n );\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('get <documentId>')\n .action(async (documentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.getDocument, {\n orgSlug,\n documentId,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('create')\n .requiredOption('--title <title>')\n .option('--content <content>')\n .option('--team <teamKey>')\n .option('--project <projectKey>')\n .option('--folder-id <id>')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createDocument, {\n orgSlug,\n title: options.title,\n content: options.content,\n teamKey: options.team,\n projectKey: options.project,\n folderId: options.folderId,\n visibility: options.visibility,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('update <documentId>')\n .option('--title <title>')\n .option('--content <content>')\n .option('--team <teamKey>')\n .option('--clear-team')\n .option('--project <projectKey>')\n .option('--clear-project')\n .option('--folder-id <id>')\n .option('--clear-folder')\n .option('--visibility <visibility>')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateDocument, {\n orgSlug,\n documentId,\n title: options.title,\n content: options.content,\n teamKey: nullableOption(options.team, options.clearTeam),\n projectKey: nullableOption(options.project, options.clearProject),\n folderId: nullableOption(options.folderId, options.clearFolder),\n visibility: options.visibility,\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('move <documentId>')\n .option('--folder-id <id>')\n .option('--clear-folder')\n .action(async (documentId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const folderId = options.clearFolder\n ? null\n : requiredString(options.folderId, 'folder-id');\n const result = await runAction(client, cliApi.moveDocumentToFolder, {\n orgSlug,\n documentId,\n folderId,\n });\n printOutput(result, runtime.json);\n });\n\ndocumentCommand\n .command('delete <documentId>')\n .action(async (documentId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteDocument, {\n orgSlug,\n documentId,\n });\n printOutput(result, runtime.json);\n });\n\nconst folderCommand = program.command('folder').description('Document folders');\n\nfolderCommand\n .command('list [slug]')\n .option('--limit <n>')\n .option('--created-after <date>', 'Filter: created on or after date (ISO)')\n .option('--created-before <date>', 'Filter: created on or before date (ISO)')\n .option('--sort <field>', 'Sort by field (e.g. createdAt, name)')\n .option('--order <direction>', 'Sort order: asc or desc (default: asc)')\n .action(async (slug, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime, slug);\n const raw = await runAction(client, cliApi.listFolders, { orgSlug });\n const filtered = applyListFilters(raw, options);\n const result = addEntityUrls(filtered, runtime.appUrl, orgSlug, 'folders');\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('create')\n .requiredOption('--name <name>')\n .option('--description <description>')\n .option('--icon <icon>')\n .option('--color <color>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.createFolder, {\n orgSlug,\n name: options.name,\n description: options.description,\n icon: options.icon,\n color: options.color,\n });\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('update <folderId>')\n .option('--name <name>')\n .option('--description <description>')\n .option('--clear-description')\n .option('--icon <icon>')\n .option('--clear-icon')\n .option('--color <color>')\n .option('--clear-color')\n .action(async (folderId, options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.updateFolder, {\n orgSlug,\n folderId,\n name: options.name,\n description: nullableOption(\n options.description,\n options.clearDescription,\n ),\n icon: nullableOption(options.icon, options.clearIcon),\n color: nullableOption(options.color, options.clearColor),\n });\n printOutput(result, runtime.json);\n });\n\nfolderCommand\n .command('delete <folderId>')\n .action(async (folderId, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n const result = await runAction(client, cliApi.deleteFolder, {\n orgSlug,\n folderId,\n });\n printOutput(result, runtime.json);\n });\n\nasync function main() {\n await program.parseAsync(process.argv);\n}\n\nmain().catch(error => {\n console.error(error instanceof Error ? error.message : String(error));\n process.exitCode = 1;\n});\n","/* eslint-disable */\n/**\n * Generated `api` utility.\n *\n * THIS CODE IS AUTOMATICALLY GENERATED.\n *\n * To regenerate, run `npx convex dev`.\n * @module\n */\n\nimport { anyApi, componentsGeneric } from \"convex/server\";\n\n/**\n * A utility for referencing Convex functions in your app's API.\n *\n * Usage:\n * ```js\n * const myFunctionReference = api.myModule.myFunction;\n * ```\n */\nexport const api = anyApi;\nexport const internal = anyApi;\nexport const components = componentsGeneric();\n","import { isCancel, password as passwordPrompt, text } from '@clack/prompts';\nimport { CliSession } from './session';\n\ntype AuthUser = {\n id?: string;\n email?: string;\n name?: string;\n username?: string;\n};\n\ntype AuthSessionResponse = {\n user?: AuthUser | null;\n session?: Record<string, unknown> | null;\n};\n\nfunction buildUrl(appUrl: string, pathname: string) {\n return new URL(pathname, appUrl).toString();\n}\n\nfunction cookieHeader(cookies: Record<string, string>) {\n return Object.entries(cookies)\n .map(([name, value]) => `${name}=${value}`)\n .join('; ');\n}\n\nfunction splitSetCookieHeader(value: string) {\n return value.split(/,(?=[^;,]+=)/g);\n}\n\nfunction applySetCookieHeaders(\n session: CliSession,\n response: Response,\n): CliSession {\n const nextCookies = { ...session.cookies };\n const rawSetCookies =\n response.headers.getSetCookie?.() ??\n (response.headers.get('set-cookie')\n ? splitSetCookieHeader(response.headers.get('set-cookie')!)\n : []);\n\n for (const rawCookie of rawSetCookies) {\n const [cookiePart, ...attributeParts] = rawCookie.split(';');\n const separatorIndex = cookiePart.indexOf('=');\n if (separatorIndex <= 0) {\n continue;\n }\n\n const name = cookiePart.slice(0, separatorIndex).trim();\n const value = cookiePart.slice(separatorIndex + 1).trim();\n const attributes = attributeParts.map(part => part.trim().toLowerCase());\n const maxAge = attributes.find(part => part.startsWith('max-age='));\n const expires = attributes.find(part => part.startsWith('expires='));\n const expired =\n value.length === 0 ||\n maxAge === 'max-age=0' ||\n (expires\n ? Number.isFinite(Date.parse(expires.slice(8))) &&\n Date.parse(expires.slice(8)) <= Date.now()\n : false);\n\n if (expired) {\n delete nextCookies[name];\n } else {\n nextCookies[name] = value;\n }\n }\n\n return {\n ...session,\n cookies: nextCookies,\n };\n}\n\nasync function authRequest(\n session: CliSession,\n appUrl: string,\n pathname: string,\n init: RequestInit = {},\n) {\n const headers = new Headers(init.headers);\n const origin = new URL(appUrl).origin;\n if (session.bearerToken && !headers.has('authorization')) {\n headers.set('authorization', `Bearer ${session.bearerToken}`);\n }\n if (Object.keys(session.cookies).length > 0) {\n headers.set('cookie', cookieHeader(session.cookies));\n }\n if (!headers.has('origin')) {\n headers.set('origin', origin);\n }\n if (!headers.has('referer')) {\n headers.set('referer', `${origin}/`);\n }\n if (init.body && !headers.has('content-type')) {\n headers.set('content-type', 'application/json');\n }\n\n const response = await fetch(buildUrl(appUrl, pathname), {\n ...init,\n headers,\n redirect: 'manual',\n });\n const nextSession = applySetCookieHeaders(session, response);\n return { response, session: nextSession };\n}\n\nasync function parseError(response: Response) {\n try {\n const data = (await response.json()) as { error?: { message?: string } };\n return data.error?.message ?? `Request failed with HTTP ${response.status}`;\n } catch {\n return `Request failed with HTTP ${response.status}`;\n }\n}\n\nexport async function loginWithPassword(\n session: CliSession,\n appUrl: string,\n identifier: string,\n password: string,\n) {\n const pathname = identifier.includes('@')\n ? '/api/auth/sign-in/email'\n : '/api/auth/sign-in/username';\n const body = identifier.includes('@')\n ? { email: identifier, password }\n : { username: identifier, password };\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n pathname,\n {\n method: 'POST',\n body: JSON.stringify(body),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n return nextSession;\n}\n\nexport async function signUpWithEmail(\n session: CliSession,\n appUrl: string,\n email: string,\n username: string,\n password: string,\n) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/sign-up/email',\n {\n method: 'POST',\n body: JSON.stringify({\n email,\n password,\n name: username,\n username,\n }),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n return nextSession;\n}\n\nexport async function logout(session: CliSession, appUrl: string) {\n const { response } = await authRequest(\n session,\n appUrl,\n '/api/auth/sign-out',\n {\n method: 'POST',\n body: JSON.stringify({}),\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n}\n\nexport async function fetchAuthSession(session: CliSession, appUrl: string) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/get-session',\n {\n method: 'GET',\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n const data = (await response.json()) as AuthSessionResponse | null;\n return {\n session: nextSession,\n user: data?.user ?? null,\n };\n}\n\nexport async function fetchConvexToken(session: CliSession, appUrl: string) {\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/convex/token',\n {\n method: 'GET',\n },\n );\n\n if (!response.ok) {\n throw new Error(await parseError(response));\n }\n\n const data = (await response.json()) as { token?: string };\n if (!data.token) {\n throw new Error('Missing Convex token');\n }\n\n return {\n session: nextSession,\n token: data.token,\n };\n}\n\ntype DeviceCodeResponse = {\n device_code: string;\n user_code: string;\n verification_uri: string;\n verification_uri_complete: string;\n expires_in: number;\n interval: number;\n};\n\ntype DeviceTokenResponse = {\n access_token?: string;\n token_type?: string;\n error?: string;\n};\n\nexport async function requestDeviceCode(\n appUrl: string,\n clientId: string,\n): Promise<DeviceCodeResponse> {\n const response = await fetch(buildUrl(appUrl, '/api/auth/device/code'), {\n method: 'POST',\n headers: { 'content-type': 'application/json' },\n body: JSON.stringify({ client_id: clientId }),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to request device code: HTTP ${response.status}`);\n }\n\n return (await response.json()) as DeviceCodeResponse;\n}\n\nexport async function pollDeviceToken(\n session: CliSession,\n appUrl: string,\n deviceCode: string,\n clientId: string,\n interval: number,\n expiresIn: number,\n): Promise<CliSession> {\n const deadline = Date.now() + expiresIn * 1000;\n let pollInterval = interval * 1000;\n\n while (Date.now() < deadline) {\n await new Promise(resolve => setTimeout(resolve, pollInterval));\n\n const { response, session: nextSession } = await authRequest(\n session,\n appUrl,\n '/api/auth/device/token',\n {\n method: 'POST',\n body: JSON.stringify({\n grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\n device_code: deviceCode,\n client_id: clientId,\n }),\n },\n );\n\n session = nextSession;\n\n if (response.ok) {\n const data = (await response.json()) as DeviceTokenResponse;\n if (data.access_token) {\n session.bearerToken = data.access_token;\n return session;\n }\n }\n\n let errorData: DeviceTokenResponse;\n try {\n errorData = (await response.json()) as DeviceTokenResponse;\n } catch {\n errorData = { error: `HTTP ${response.status}` };\n }\n\n switch (errorData.error) {\n case 'authorization_pending':\n break;\n case 'slow_down':\n pollInterval += 5000;\n break;\n case 'access_denied':\n throw new Error('Authorization denied by user.');\n case 'expired_token':\n throw new Error('Device code expired. Please try again.');\n default:\n throw new Error(`Device auth error: ${errorData.error}`);\n }\n }\n\n throw new Error('Device code expired. Please try again.');\n}\n\nexport async function prompt(question: string) {\n const value = await text({\n message: question.replace(/:\\s*$/, ''),\n });\n if (isCancel(value)) {\n throw new Error('Canceled');\n }\n return String(value).trim();\n}\n\nexport async function promptSecret(question: string) {\n const value = await passwordPrompt({\n message: question.replace(/:\\s*$/, ''),\n mask: '*',\n });\n if (isCancel(value)) {\n throw new Error('Canceled');\n }\n return String(value);\n}\n","import { ConvexHttpClient } from 'convex/browser';\nimport { FunctionReference, OptionalRestArgs } from 'convex/server';\nimport { fetchConvexToken } from './auth';\nimport { CliSession } from './session';\n\nexport async function createConvexClient(\n session: CliSession,\n appUrl: string,\n convexUrl: string,\n) {\n const { token } = await fetchConvexToken(session, appUrl);\n const client = new ConvexHttpClient(convexUrl);\n client.setAuth(token);\n return client;\n}\n\nexport async function runQuery<Query extends FunctionReference<'query'>>(\n client: ConvexHttpClient,\n ref: Query,\n ...args: OptionalRestArgs<Query>\n) {\n return await client.query(ref, ...args);\n}\n\nexport async function runMutation<\n Mutation extends FunctionReference<'mutation'>,\n>(\n client: ConvexHttpClient,\n ref: Mutation,\n ...args: OptionalRestArgs<Mutation>\n) {\n return await client.mutation(ref, ...args);\n}\n\nexport async function runAction<Action extends FunctionReference<'action'>>(\n client: ConvexHttpClient,\n ref: Action,\n ...args: OptionalRestArgs<Action>\n) {\n return await client.action(ref, ...args);\n}\n","function simplify(value: unknown): unknown {\n if (value === null || value === undefined) {\n return value;\n }\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return [];\n }\n if (value.every(item => typeof item !== 'object' || item === null)) {\n return value.join(', ');\n }\n return JSON.stringify(value);\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n return value;\n}\n\nexport function printOutput(data: unknown, json = false) {\n if (json) {\n console.log(JSON.stringify(data, null, 2));\n return;\n }\n\n if (Array.isArray(data)) {\n if (data.length === 0) {\n console.log('No results.');\n return;\n }\n if (data.every(item => typeof item === 'object' && item !== null)) {\n console.table(\n data.map(item =>\n Object.fromEntries(\n Object.entries(item).map(([key, value]) => [key, simplify(value)]),\n ),\n ),\n );\n return;\n }\n }\n\n if (typeof data === 'object' && data !== null) {\n console.dir(data, { depth: null, colors: true });\n return;\n }\n\n console.log(String(data));\n}\n","import { mkdir, readFile, rm, writeFile } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport path from 'node:path';\n\nexport type CliSession = {\n version: 1;\n appUrl?: string;\n convexUrl?: string;\n activeOrgSlug?: string;\n cookies: Record<string, string>;\n bearerToken?: string;\n};\n\nconst SESSION_ROOT = path.join(homedir(), '.vector');\n\nexport function getSessionPath(profile = 'default') {\n return path.join(SESSION_ROOT, `cli-${profile}.json`);\n}\n\nexport async function readSession(profile = 'default') {\n try {\n const raw = await readFile(getSessionPath(profile), 'utf8');\n const parsed = JSON.parse(raw) as Partial<CliSession>;\n return {\n version: 1,\n cookies: {},\n ...parsed,\n } satisfies CliSession;\n } catch {\n return null;\n }\n}\n\nexport async function writeSession(session: CliSession, profile = 'default') {\n await mkdir(SESSION_ROOT, { recursive: true });\n await writeFile(\n getSessionPath(profile),\n `${JSON.stringify(session, null, 2)}\\n`,\n 'utf8',\n );\n}\n\nexport async function clearSession(profile = 'default') {\n await rm(getSessionPath(profile), { force: true });\n}\n\nexport function createEmptySession(): CliSession {\n return {\n version: 1,\n cookies: {},\n };\n}\n"],"mappings":"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","names":["fs","process","fs","process","Buffer","fs","promisify","childProcess","fs","fsConstants","execFile","powerShellPath","path","promisify","process","execFile","process","promisify","execFile","execFileAsync","promisify","execFile","execFileAsync","promisify","process","execFile","defaultBrowser","execFileAsync","process","process","path","childProcess","fs","fsConstants","apps","defaultBrowser","powerShellPath","readFile","fileURLToPath","path","readFile","fileURLToPath","open"]}
|