@rehpic/vcli 0.1.0-beta.34.1 → 0.1.0-beta.35.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 +621 -16
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
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 = 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\nissueCommand\n .command('link-github <issueKey> <url>')\n .description('Link a GitHub pull request, issue, or commit URL to an issue')\n .action(async (issueKey, url, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n await runAction(client, api.github.actions.linkArtifactByUrl, {\n orgSlug,\n issueKey,\n url,\n });\n printOutput({ success: true, issueKey, url }, 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"]}
|
|
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","../../../src/cli/bridge-service.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('list')\n .description(\n 'List org-wide activity with optional filters by entity type, event type, and time range',\n )\n .option(\n '--entity-type <type>',\n 'Filter by entity type: issue, project, team, document',\n )\n .option(\n '--event-type <type>',\n 'Filter by event type (e.g. issue_created, issue_priority_changed)',\n )\n .option(\n '--since <datetime>',\n 'Start of time range (ISO date or shorthand: today, yesterday, 7d, 30d)',\n )\n .option(\n '--until <datetime>',\n 'End of time range (ISO date or shorthand: today, now)',\n )\n .option('--limit <n>')\n .option('--cursor <cursor>')\n .action(async (options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n\n function parseTimeArg(\n value: string | undefined,\n bound: 'start' | 'end',\n ): number | undefined {\n if (!value) return undefined;\n const now = new Date();\n const startOfToday = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate(),\n );\n const endOfToday = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate(),\n 23,\n 59,\n 59,\n 999,\n );\n switch (value) {\n case 'now':\n return now.getTime();\n case 'today':\n return bound === 'start'\n ? startOfToday.getTime()\n : endOfToday.getTime();\n case 'yesterday':\n return bound === 'start'\n ? startOfToday.getTime() - 86400000\n : startOfToday.getTime() - 1;\n default: {\n const daysMatch = value.match(/^(\\d+)d$/);\n if (daysMatch) {\n return now.getTime() - Number(daysMatch[1]) * 86400000;\n }\n const parsed = new Date(value).getTime();\n if (Number.isNaN(parsed)) {\n throw new Error(`Invalid time value: ${value}`);\n }\n return parsed;\n }\n }\n }\n\n const result = await runQuery(\n client,\n api.activities.queries.listOrgActivity,\n {\n orgSlug,\n entityType: options.entityType ?? undefined,\n eventType: options.eventType ?? undefined,\n since: parseTimeArg(options.since, 'start'),\n until: parseTimeArg(options.until, 'end'),\n limit: optionalNumber(options.limit, 'limit') ?? undefined,\n cursor: options.cursor ?? undefined,\n },\n );\n printOutput(result, runtime.json);\n });\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('--assignee <name>', 'Filter by assignee name or email')\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 assigneeName: options.assignee,\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\nissueCommand\n .command('link-github <issueKey> <url>')\n .description('Link a GitHub pull request, issue, or commit URL to an issue')\n .action(async (issueKey, url, _options, command) => {\n const { client, runtime } = await getClient(command);\n const orgSlug = requireOrg(runtime);\n await runAction(client, api.github.actions.linkArtifactByUrl, {\n orgSlug,\n issueKey,\n url,\n });\n printOutput({ success: true, issueKey, url }, 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\n// ═══════════════════════════════════════════════════════════════════════════════\n// Agent Bridge Service\n// ═══════════════════════════════════════════════════════════════════════════════\n\nimport {\n BridgeService,\n getBridgeStatus,\n installLaunchAgent,\n loadBridgeConfig,\n loadLaunchAgent,\n saveBridgeConfig,\n setupBridgeDevice,\n stopBridge,\n uninstallLaunchAgent,\n} from './bridge-service';\nimport { platform as osPlatform } from 'os';\n\nconst serviceCommand = program\n .command('service')\n .description('Manage the local bridge service');\n\nserviceCommand\n .command('start')\n .description('Run the bridge service in the foreground')\n .action(async (_options, command) => {\n let config = loadBridgeConfig();\n\n if (!config) {\n // Need to set up first — get convex URL and user\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 const user = await runQuery(client, api.users.currentUser);\n if (!user) throw new Error('Not logged in. Run `vcli auth login` first.');\n\n config = await setupBridgeDevice(runtime.convexUrl, user._id);\n console.log(`Device registered: ${config.deviceId}`);\n }\n\n const bridge = new BridgeService(config);\n await bridge.run();\n });\n\nserviceCommand\n .command('stop')\n .description('Stop the running bridge service')\n .action(() => {\n if (stopBridge()) {\n console.log('Bridge stopped.');\n } else {\n console.log('Bridge is not running.');\n }\n });\n\nserviceCommand\n .command('status')\n .description('Show bridge service status')\n .action((_options, command) => {\n const status = getBridgeStatus();\n if (!status.configured) {\n console.log('Bridge not configured. Run: vcli service start');\n return;\n }\n console.log('Vector Bridge');\n console.log(\n ` Device: ${status.config!.displayName} (${status.config!.deviceId})`,\n );\n console.log(` User: ${status.config!.userId}`);\n console.log(\n ` Status: ${status.running ? `Running (PID ${status.pid})` : 'Not running'}`,\n );\n console.log(` Config: ~/.vector/bridge.json`);\n });\n\nserviceCommand\n .command('install')\n .description('Install the bridge as a system service (macOS LaunchAgent)')\n .action(async (_options, command) => {\n if (osPlatform() !== 'darwin') {\n console.error('Service install is currently macOS only (LaunchAgent).');\n console.error('On Linux, use systemd --user manually for now.');\n return;\n }\n const vcliPath = process.argv[1] ?? 'vcli';\n installLaunchAgent(vcliPath);\n loadLaunchAgent();\n });\n\nserviceCommand\n .command('uninstall')\n .description('Uninstall the bridge system service')\n .action(() => {\n uninstallLaunchAgent();\n });\n\nserviceCommand\n .command('logs')\n .description('Show bridge service logs')\n .action(() => {\n const { existsSync: exists, readFileSync: read } = require('fs');\n const logPath = require('path').join(\n require('os').homedir(),\n '.vector',\n 'bridge.log',\n );\n if (exists(logPath)) {\n const content = read(logPath, 'utf-8');\n const lines = content.split('\\n');\n console.log(lines.slice(-50).join('\\n'));\n } else {\n console.log('No log file found at ~/.vector/bridge.log');\n }\n });\n\n// `vcli bridge` — top-level shortcut commands\nconst bridgeCommand = program\n .command('bridge')\n .description('Start/stop the local agent bridge');\n\nbridgeCommand\n .command('start')\n .description('Register device, install service, and start the bridge')\n .action(async (_options, command) => {\n let config = loadBridgeConfig();\n\n if (!config) {\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 const user = await runQuery(client, api.users.currentUser);\n if (!user) throw new Error('Not logged in. Run `vcli auth login` first.');\n\n config = await setupBridgeDevice(runtime.convexUrl, user._id);\n console.log(\n `Device registered: ${config.displayName} (${config.deviceId})`,\n );\n }\n\n if (osPlatform() === 'darwin') {\n const vcliPath = process.argv[1] ?? 'vcli';\n installLaunchAgent(vcliPath);\n loadLaunchAgent();\n console.log('\\nBridge installed and started as LaunchAgent.');\n console.log('It will restart automatically on login.');\n console.log('Run `vcli service status` to check.');\n } else {\n console.log('Starting bridge in foreground...');\n const bridge = new BridgeService(config);\n await bridge.run();\n }\n });\n\nbridgeCommand\n .command('stop')\n .description('Stop the bridge service')\n .action(() => {\n if (osPlatform() === 'darwin') {\n uninstallLaunchAgent();\n }\n if (stopBridge()) {\n console.log('Bridge stopped.');\n } else {\n console.log('Bridge is not running.');\n }\n });\n\nbridgeCommand\n .command('status')\n .description('Show bridge status')\n .action(() => {\n const s = getBridgeStatus();\n if (!s.configured) {\n console.log('Bridge not configured. Run: vcli bridge start');\n return;\n }\n console.log('Vector Bridge');\n console.log(` Device: ${s.config!.displayName} (${s.config!.deviceId})`);\n console.log(\n ` Status: ${s.running ? `Running (PID ${s.pid})` : 'Not running'}`,\n );\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","/**\n * Vector Bridge Service — runs as a foreground process or installed as a system service.\n *\n * Called by:\n * vcli service start — runs the bridge loop in the foreground\n * vcli start — installs + starts via LaunchAgent (macOS) or systemd (Linux)\n */\n\nimport { ConvexHttpClient } from 'convex/browser';\nimport { api } from '../../convex/_generated/api';\nimport type { Id } from '../../convex/_generated/dataModel';\nimport { execSync } from 'child_process';\nimport {\n existsSync,\n mkdirSync,\n readFileSync,\n writeFileSync,\n unlinkSync,\n} from 'fs';\nimport { homedir, hostname, platform } from 'os';\nimport { join } from 'path';\nimport { randomUUID } from 'crypto';\n\n// ── Config ──────────────────────────────────────────────────────────────────\n\nconst CONFIG_DIR = join(homedir(), '.vector');\nconst BRIDGE_CONFIG_FILE = join(CONFIG_DIR, 'bridge.json');\nconst PID_FILE = join(CONFIG_DIR, 'bridge.pid');\nconst LIVE_ACTIVITIES_CACHE = join(CONFIG_DIR, 'live-activities.json');\nconst LAUNCHAGENT_DIR = join(homedir(), 'Library', 'LaunchAgents');\nconst LAUNCHAGENT_PLIST = join(LAUNCHAGENT_DIR, 'com.vector.bridge.plist');\nconst LAUNCHAGENT_LABEL = 'com.vector.bridge';\n\nconst HEARTBEAT_INTERVAL_MS = 30_000;\nconst COMMAND_POLL_INTERVAL_MS = 5_000;\nconst PROCESS_DISCOVERY_INTERVAL_MS = 60_000;\n\nexport interface BridgeConfig {\n deviceId: string;\n deviceKey: string;\n deviceSecret: string;\n userId: string;\n displayName: string;\n convexUrl: string;\n registeredAt: string;\n}\n\n// ── Config persistence ──────────────────────────────────────────────────────\n\nexport function loadBridgeConfig(): BridgeConfig | null {\n if (!existsSync(BRIDGE_CONFIG_FILE)) return null;\n try {\n return JSON.parse(readFileSync(BRIDGE_CONFIG_FILE, 'utf-8'));\n } catch {\n return null;\n }\n}\n\nexport function saveBridgeConfig(config: BridgeConfig): void {\n if (!existsSync(CONFIG_DIR)) mkdirSync(CONFIG_DIR, { recursive: true });\n writeFileSync(BRIDGE_CONFIG_FILE, JSON.stringify(config, null, 2));\n}\n\n// ── Process Discovery ───────────────────────────────────────────────────────\n\ninterface DiscoveredProcess {\n provider: 'claude_code' | 'codex';\n providerLabel: string;\n localProcessId: string;\n sessionKey: string;\n cwd?: string;\n repoRoot?: string;\n branch?: string;\n mode: 'observed';\n status: 'observed';\n supportsInboundMessages: false;\n}\n\nfunction discoverLocalProcesses(): DiscoveredProcess[] {\n const processes: DiscoveredProcess[] = [];\n\n const patterns: Array<{\n grep: string;\n provider: 'claude_code' | 'codex';\n label: string;\n prefix: string;\n }> = [\n {\n grep: '[c]laude',\n provider: 'claude_code',\n label: 'Claude',\n prefix: 'claude',\n },\n { grep: '[c]odex', provider: 'codex', label: 'Codex', prefix: 'codex' },\n ];\n\n for (const { grep, provider, label, prefix } of patterns) {\n try {\n const ps = execSync(\n `ps aux | grep -E '${grep}' | grep -v vector-bridge | grep -v grep`,\n { encoding: 'utf-8', timeout: 5000 },\n );\n for (const line of ps.trim().split('\\n').filter(Boolean)) {\n const pid = line.split(/\\s+/)[1];\n if (!pid) continue;\n\n let cwd: string | undefined;\n try {\n cwd =\n execSync(\n `lsof -p ${pid} 2>/dev/null | grep cwd | awk '{print $NF}'`,\n { encoding: 'utf-8', timeout: 3000 },\n ).trim() || undefined;\n } catch {\n /* skip */\n }\n\n const gitInfo = cwd ? getGitInfo(cwd) : {};\n processes.push({\n provider,\n providerLabel: label,\n localProcessId: pid,\n sessionKey: `${prefix}-${pid}`,\n cwd,\n ...gitInfo,\n mode: 'observed',\n status: 'observed',\n supportsInboundMessages: false,\n });\n }\n } catch {\n /* no processes */\n }\n }\n\n return processes;\n}\n\nfunction getGitInfo(cwd: string): { repoRoot?: string; branch?: string } {\n try {\n const branch = execSync('git rev-parse --abbrev-ref HEAD', {\n encoding: 'utf-8',\n cwd,\n timeout: 3000,\n }).trim();\n const repoRoot = execSync('git rev-parse --show-toplevel', {\n encoding: 'utf-8',\n cwd,\n timeout: 3000,\n }).trim();\n return { branch, repoRoot };\n } catch {\n return {};\n }\n}\n\n// ── Reply generation (placeholder until real agent integration) ─────────────\n\nfunction generateReply(userMessage: string): string {\n const lower = userMessage.toLowerCase().trim();\n if (['hey', 'hi', 'hello'].includes(lower)) {\n return \"Hey! I'm running on your local machine via the Vector bridge. What would you like me to work on?\";\n }\n if (lower.includes('status') || lower.includes('progress')) {\n return \"I'm making good progress. Currently reviewing the changes and running tests.\";\n }\n if (lower.includes('stop') || lower.includes('cancel')) {\n return 'Understood — wrapping up the current step.';\n }\n return `Got it — \"${userMessage}\". I'll incorporate that into my current work.`;\n}\n\n// ── Bridge Service Class ────────────────────────────────────────────────────\n\nexport class BridgeService {\n private client: ConvexHttpClient;\n private config: BridgeConfig;\n private timers: ReturnType<typeof setInterval>[] = [];\n\n constructor(config: BridgeConfig) {\n this.config = config;\n this.client = new ConvexHttpClient(config.convexUrl);\n }\n\n async heartbeat(): Promise<void> {\n await this.client.mutation(api.agentBridge.bridgePublic.heartbeat, {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n });\n }\n\n async pollCommands(): Promise<void> {\n const commands = await this.client.query(\n api.agentBridge.bridgePublic.getPendingCommands,\n {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n },\n );\n\n if (commands.length > 0) {\n console.log(`[${ts()}] ${commands.length} pending command(s)`);\n }\n\n for (const cmd of commands) {\n await this.handleCommand(cmd);\n }\n }\n\n private async handleCommand(cmd: {\n _id: Id<'agentCommands'>;\n kind: string;\n payload?: unknown;\n liveActivityId?: Id<'issueLiveActivities'>;\n }): Promise<void> {\n console.log(` ${cmd.kind}: ${cmd._id}`);\n\n if (cmd.kind === 'message' && cmd.liveActivityId) {\n const payload = cmd.payload as { body?: string } | undefined;\n const body = payload?.body ?? '';\n console.log(` > \"${body}\"`);\n\n const reply = generateReply(body);\n await this.client.mutation(\n api.agentBridge.bridgePublic.postAgentMessage,\n {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n liveActivityId: cmd.liveActivityId,\n role: 'assistant',\n body: reply,\n },\n );\n console.log(` < \"${reply.slice(0, 60)}...\"`);\n }\n\n await this.client.mutation(api.agentBridge.bridgePublic.completeCommand, {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n commandId: cmd._id,\n status: 'delivered',\n });\n }\n\n async reportProcesses(): Promise<void> {\n const processes = discoverLocalProcesses();\n for (const proc of processes) {\n try {\n await this.client.mutation(api.agentBridge.bridgePublic.reportProcess, {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n ...proc,\n });\n } catch {\n /* skip individual failures */\n }\n }\n if (processes.length > 0) {\n console.log(`[${ts()}] Discovered ${processes.length} local process(es)`);\n }\n }\n\n async refreshLiveActivities(): Promise<void> {\n try {\n const activities = await this.client.query(\n api.agentBridge.bridgePublic.getDeviceLiveActivities,\n {\n deviceId: this.config.deviceId as Id<'agentDevices'>,\n deviceSecret: this.config.deviceSecret,\n },\n );\n // Write cache for the menu bar app to read\n writeFileSync(LIVE_ACTIVITIES_CACHE, JSON.stringify(activities, null, 2));\n } catch {\n /* non-critical */\n }\n }\n\n async run(): Promise<void> {\n console.log('Vector Bridge Service');\n console.log(\n ` Device: ${this.config.displayName} (${this.config.deviceId})`,\n );\n console.log(` Convex: ${this.config.convexUrl}`);\n console.log(` PID: ${process.pid}`);\n console.log('');\n\n // Write PID\n if (!existsSync(CONFIG_DIR)) mkdirSync(CONFIG_DIR, { recursive: true });\n writeFileSync(PID_FILE, String(process.pid));\n\n // Initial sync\n await this.heartbeat();\n await this.reportProcesses();\n await this.refreshLiveActivities();\n console.log(`[${ts()}] Service running. Ctrl+C to stop.\\n`);\n\n // Loops\n this.timers.push(\n setInterval(() => {\n this.heartbeat().catch(e =>\n console.error(`[${ts()}] Heartbeat error:`, e.message),\n );\n this.refreshLiveActivities().catch(() => {});\n }, HEARTBEAT_INTERVAL_MS),\n );\n\n this.timers.push(\n setInterval(() => {\n this.pollCommands().catch(e =>\n console.error(`[${ts()}] Command poll error:`, e.message),\n );\n }, COMMAND_POLL_INTERVAL_MS),\n );\n\n this.timers.push(\n setInterval(() => {\n this.reportProcesses().catch(e =>\n console.error(`[${ts()}] Discovery error:`, e.message),\n );\n }, PROCESS_DISCOVERY_INTERVAL_MS),\n );\n\n // Graceful shutdown\n const shutdown = () => {\n console.log(`\\n[${ts()}] Shutting down...`);\n for (const t of this.timers) clearInterval(t);\n try {\n unlinkSync(PID_FILE);\n } catch {\n /* ok */\n }\n process.exit(0);\n };\n process.on('SIGINT', shutdown);\n process.on('SIGTERM', shutdown);\n\n // Keep alive\n await new Promise(() => {});\n }\n}\n\n// ── Device Setup ────────────────────────────────────────────────────────────\n\nexport async function setupBridgeDevice(\n convexUrl: string,\n userId: string,\n): Promise<BridgeConfig> {\n const client = new ConvexHttpClient(convexUrl);\n const deviceKey = `${hostname()}-${randomUUID().slice(0, 8)}`;\n const deviceSecret = randomUUID();\n const displayName = `${process.env.USER ?? 'user'}'s ${platform() === 'darwin' ? 'Mac' : 'machine'}`;\n\n const result = await client.mutation(\n api.agentBridge.bridgePublic.setupDevice,\n {\n userId: userId as Id<'users'>,\n deviceKey,\n deviceSecret,\n displayName,\n hostname: hostname(),\n platform: platform(),\n cliVersion: '0.1.0',\n capabilities: ['codex', 'claude_code'],\n },\n );\n\n const config: BridgeConfig = {\n deviceId: result.deviceId,\n deviceKey,\n deviceSecret,\n userId,\n displayName,\n convexUrl,\n registeredAt: new Date().toISOString(),\n };\n\n saveBridgeConfig(config);\n return config;\n}\n\n// ── LaunchAgent (macOS) ─────────────────────────────────────────────────────\n\nexport function installLaunchAgent(vcliPath: string): void {\n if (platform() !== 'darwin') {\n console.error('LaunchAgent is macOS only. Use systemd on Linux.');\n return;\n }\n\n const plist = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>${LAUNCHAGENT_LABEL}</string>\n <key>ProgramArguments</key>\n <array>\n <string>${vcliPath}</string>\n <string>service</string>\n <string>start</string>\n </array>\n <key>RunAtLoad</key>\n <true/>\n <key>KeepAlive</key>\n <true/>\n <key>StandardOutPath</key>\n <string>${CONFIG_DIR}/bridge.log</string>\n <key>StandardErrorPath</key>\n <string>${CONFIG_DIR}/bridge.err.log</string>\n <key>EnvironmentVariables</key>\n <dict>\n <key>PATH</key>\n <string>/usr/local/bin:/opt/homebrew/bin:/usr/bin:/bin</string>\n </dict>\n</dict>\n</plist>`;\n\n // Also install the menu bar helper LaunchAgent if the binary exists\n const menuBarBinary = join(\n __dirname,\n '..',\n '..',\n 'cli',\n 'macos',\n 'VectorMenuBar',\n );\n if (existsSync(menuBarBinary)) {\n const menuBarPlist = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n<plist version=\"1.0\">\n<dict>\n <key>Label</key>\n <string>com.vector.menubar</string>\n <key>ProgramArguments</key>\n <array>\n <string>${menuBarBinary}</string>\n </array>\n <key>RunAtLoad</key>\n <true/>\n <key>KeepAlive</key>\n <false/>\n</dict>\n</plist>`;\n const menuBarPlistPath = join(LAUNCHAGENT_DIR, 'com.vector.menubar.plist');\n writeFileSync(menuBarPlistPath, menuBarPlist);\n try {\n execSync(`launchctl load ${menuBarPlistPath}`, { stdio: 'pipe' });\n console.log('Menu bar helper installed.');\n } catch {\n // Already loaded or failed — non-critical\n }\n }\n\n if (!existsSync(LAUNCHAGENT_DIR)) {\n mkdirSync(LAUNCHAGENT_DIR, { recursive: true });\n }\n writeFileSync(LAUNCHAGENT_PLIST, plist);\n console.log(`Installed LaunchAgent: ${LAUNCHAGENT_PLIST}`);\n}\n\nexport function loadLaunchAgent(): void {\n try {\n execSync(`launchctl load ${LAUNCHAGENT_PLIST}`, { stdio: 'inherit' });\n console.log(\n 'LaunchAgent loaded. Bridge will start automatically on login.',\n );\n } catch {\n console.error('Failed to load LaunchAgent');\n }\n}\n\nexport function unloadLaunchAgent(): void {\n try {\n execSync(`launchctl unload ${LAUNCHAGENT_PLIST}`, { stdio: 'inherit' });\n console.log('LaunchAgent unloaded.');\n } catch {\n console.error('Failed to unload LaunchAgent (may not be loaded)');\n }\n}\n\nexport function uninstallLaunchAgent(): void {\n unloadLaunchAgent();\n try {\n unlinkSync(LAUNCHAGENT_PLIST);\n console.log('LaunchAgent removed.');\n } catch {\n /* already gone */\n }\n}\n\n// ── Status ──────────────────────────────────────────────────────────────────\n\nexport function getBridgeStatus(): {\n configured: boolean;\n running: boolean;\n pid?: number;\n config?: BridgeConfig;\n} {\n const config = loadBridgeConfig();\n if (!config) return { configured: false, running: false };\n\n let running = false;\n let pid: number | undefined;\n if (existsSync(PID_FILE)) {\n const pidStr = readFileSync(PID_FILE, 'utf-8').trim();\n pid = Number(pidStr);\n try {\n process.kill(pid, 0);\n running = true;\n } catch {\n running = false;\n }\n }\n\n return { configured: true, running, pid, config };\n}\n\nexport function stopBridge(): boolean {\n if (!existsSync(PID_FILE)) return false;\n const pid = Number(readFileSync(PID_FILE, 'utf-8').trim());\n try {\n process.kill(pid, 'SIGTERM');\n return true;\n } catch {\n return false;\n }\n}\n\nfunction ts(): string {\n return new Date().toLocaleTimeString();\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","platform","__dirname","apps","defaultBrowser","powerShellPath","readFileSync","readFile","join","fileURLToPath","ConvexHttpClient","homedir","ConvexHttpClient","path","readFile","fileURLToPath","readFileSync","join","open"]}
|