@todesktop/cli 1.6.0 → 1.6.2-0
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/README.md +8 -0
- package/dist/cli.js +247 -222
- package/dist/cli.js.map +4 -4
- package/package.json +2 -2
package/dist/cli.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/index.ts", "../src/components/Build.tsx", "../src/components/BuildProgress.tsx", "../src/components/BuildCompleteMessage.tsx", "../src/utilities/logForCI.ts", "../src/utilities/logger.ts", "../src/utilities/useExit.ts", "../src/utilities/analytics.ts", "../src/utilities/getEnvironmentVariables.ts", "../src/utilities/firestore.ts", "../src/utilities/configStore.ts", "../src/utilities/getToDesktopPackageJson.ts", "../src/utilities/readJson.ts", "../src/utilities/getCliVersion.ts", "../src/components/PlatformProgress.tsx", "../src/utilities/buildStatus.ts", "../src/components/ErrorDisplay.tsx", "../src/components/Preparation.tsx", "../src/components/ProgressBar.tsx", "../src/libs/ink-progress-bar/index.tsx", "../src/components/InitialLoadingState.tsx", "../src/components/MainLayout.tsx", "../src/components/CancelBuild.tsx", "../src/utilities/getCallableFirebaseFunction.ts", "../src/components/Footer.tsx", "../src/components/Header.tsx", "../src/utilities/useInput.ts", "../src/utilities/runBuild.ts", "../src/utilities/getVersionControlInfo.ts", "../src/utilities/projectConfig/getProjectConfig.ts", "../src/utilities/projectConfig/loadConfig.ts", "../src/utilities/projectConfig/resolveConfigPaths.ts", "../src/utilities/projectConfig/validateConfig.ts", "../src/utilities/projectConfig/addCustomKeywords.ts", "../src/utilities/projectConfig/validatePackageJSON.ts", "../src/utilities/projectConfig/schema/packageJSON.ts", "../src/utilities/projectConfig/schema/full.ts", "../src/utilities/projectConfig/computeFullProjectConfig.ts", "../src/utilities/postToFirebaseFunction.ts", "../src/utilities/subscribeToFirebaseDoc.ts", "../src/utilities/subscribeToBuild.ts", "../src/utilities/uploadApplicationSource.ts", "../src/utilities/generateS3Key.ts", "../src/utilities/uploadToS3.ts", "../src/utilities/zip.ts", "../src/utilities/getPackageJson.ts", "../src/utilities/shouldExitOnBuildFailure.ts", "../src/utilities/checkIfReactIsUsable.ts", "../src/components/LoginHOC.tsx", "../src/components/Login.tsx", "../src/components/TextInput.tsx", "../src/components/ErrorBoundary.tsx", "../src/components/OngoingBuildGuard.tsx", "../src/components/CustomSelectInputIndicator.tsx", "../src/components/CustomSelectInputItem.tsx", "../src/components/ViewBuild.tsx", "../src/utilities/getLatestBuildId.ts", "../src/utilities/findAppUserId.ts", "../src/utilities/useAnalytics.ts", "../src/commands/BuildCommand.tsx", "../src/components/ViewBuilds.tsx", "../src/components/Table.tsx", "../src/components/TableEnd.tsx", "../src/components/TableHead.tsx", "../src/components/TableBody.tsx", "../src/components/TableRow.tsx", "../src/utilities/getKeyDetails.ts", "../src/utilities/capitalize.ts", "../src/utilities/getBuilds.ts", "../src/utilities/getRelativeDateFromDateString.ts", "../src/components/SyntaxHighlight.tsx", "../src/commands/BuildsCommand.tsx", "../src/commands/LogoutCommand.tsx", "../src/commands/ReleaseCommand.tsx", "../src/components/ReleaseBuild.tsx", "../src/utilities/getBuildById.ts", "../src/components/PickBuildForRelease.tsx", "../src/components/SelectTable.tsx", "../src/commands/WhoamiCommand.tsx", "../src/utilities/exitIfCLIOutOfDate.ts", "../src/utilities/initSentry.ts", "../src/utilities/onCommand.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\nimport { InvalidArgumentError, Option, program } from \"commander\";\nimport { render } from \"ink\";\nimport { FC, createElement } from \"react\";\nimport \"source-map-support/register\";\n\nimport BuildCommand from \"./commands/BuildCommand\";\nimport BuildsCommand from \"./commands/BuildsCommand\";\nimport LogoutCommand from \"./commands/LogoutCommand\";\nimport ReleaseCommand from \"./commands/ReleaseCommand\";\nimport WhoamiCommand from \"./commands/WhoamiCommand\";\nimport getCliVersion from \"./utilities/getCliVersion\";\nimport onCommand from \"./utilities/onCommand\";\n\nconst parseCount = (value) => {\n const parsedValue = Number.parseInt(value, 10);\n if (parsedValue > 0) {\n return parsedValue;\n }\n\n throw new InvalidArgumentError(\"Should be a positive number\");\n};\n\nprogram.name(\"todekstop\").version(getCliVersion());\n\nprogram\n .command(\"build\")\n .description(\n \"Build an Electron app with native installers, code signing baked-in, \" +\n \"etc. but without releasing it (existing users won't get an auto-update). \" +\n \"For quicker builds, you can append `--code-sign=false` to disable\" +\n \"code-signing and notarization.\"\n )\n .option(\n \"--code-sign [bool]\",\n \"Whether or not code-signing and notarization should be performed. \" +\n \"Disable this for quicker builds\"\n )\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .action(({ codeSign, config }) => {\n runCommand(BuildCommand, {\n shouldCodeSign: codeSign,\n configPath: config,\n });\n });\n\nprogram\n .command(\"builds\")\n .description(\"View your builds\")\n .argument(\"[id]\", \"View a specific build by ID\")\n .option(\"--latest\", \"View the latest build\")\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .option(\"--count [number]\", \"Number of builds to show per page\", parseCount)\n .addOption(\n new Option(\"--format <type>\", \"Format to output the build details in\")\n .choices([\"json\", \"table\"])\n .default(\"table\")\n )\n .option(\"--exit\", \"View the latest build\")\n .action((id, { config, count, exit, format, latest }) => {\n runCommand(BuildsCommand, {\n configPath: config,\n count,\n exit,\n format,\n id,\n shouldViewLatest: latest,\n });\n });\n\nprogram\n .command(\"logout\")\n .description(\"Logs you out\")\n .action(() => {\n runCommand(LogoutCommand, null, { exitIfOutOfDate: false });\n });\n\nprogram\n .command(\"release\")\n .description(\"Release a build\")\n .argument(\"[id]\", \"A specific build ID to release\")\n .option(\"--force\", \"Skips interactive confirmation step\")\n .option(\"--latest\", \"Release the latest build\")\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .action((id, { config, force, latest }) => {\n runCommand(ReleaseCommand, {\n configPath: config,\n force,\n id,\n shouldReleaseLatest: latest,\n });\n });\n\nprogram\n .command(\"whoami\")\n .description(\"Prints the email of the account you're signed into\")\n .action(() => {\n runCommand(WhoamiCommand);\n });\n\nconst runCommand = <T extends FC>(\n component: T,\n props: Parameters<T>[0] = null,\n { exitIfOutOfDate = true } = {}\n) => {\n onCommand({ exitIfOutOfDate });\n\n const { waitUntilExit } = render(createElement(component, props));\n\n waitUntilExit().catch((error) => {\n console.error(error.stack);\n });\n};\n\n// Don't exist with status 1 if no command specified\nconst args = [...process.argv];\nif (args.length === 2) {\n args.push(\"help\");\n}\n\nprogram.parse(args);\n", "// libs\nimport { useEffect, useState } from \"react\";\nimport PropTypes from \"prop-types\";\n\n// components\nimport BuildProgress from \"./BuildProgress\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport Preparation from \"./Preparation\";\nimport InitialLoadingState from \"./InitialLoadingState\";\nimport MainLayout from \"./MainLayout\";\n\n// utils\nimport logForCI from \"../utilities/logForCI\";\nimport logger from \"../utilities/logger\";\nimport runBuild from \"../utilities/runBuild\";\nimport shouldExitOnBuildFailure from \"../utilities/shouldExitOnBuildFailure\";\nimport useExit from \"../utilities/useExit\";\n\nconst initalState = {\n appId: null,\n appPkg: null,\n build: null,\n error: null,\n hasBuildEverFailed: false,\n isPreparationComplete: false,\n preparationStageLabel: \"Preparing\",\n preparationProgress: 0,\n preparationUploadedSize: null,\n};\n\nconst Build = ({ commandUsed, shouldCodeSign = true, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n appPkg,\n build,\n error,\n hasBuildEverFailed,\n isPreparationComplete,\n preparationStageLabel,\n preparationProgress,\n preparationUploadedSize,\n },\n setState,\n ] = useState(initalState);\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n let firebaseUnsubscribe;\n\n runBuild({\n onEvent: (eventName, data) => {\n logger.debug({ eventName, data }, \"Build component: runBuild.onEvent\");\n if (eventName === \"firebase-subscribed\") {\n firebaseUnsubscribe = data.firebaseUnsubscribe;\n } else if (eventName === \"progress\") {\n setState((prevState) => ({ ...prevState, ...data }));\n }\n },\n shouldCodeSign,\n configPath,\n }).catch(onError);\n\n return () => {\n if (firebaseUnsubscribe) {\n firebaseUnsubscribe();\n }\n };\n }, [commandUsed, shouldCodeSign, configPath]);\n\n // Exit if the build has errored and settled\n useEffect(() => {\n if (hasBuildEverFailed && shouldExitOnBuildFailure(build)) {\n setTimeout(() => exit(new Error(\"Build has failed\")), 10);\n }\n }, [build, exit, hasBuildEverFailed]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (!appPkg) {\n return <InitialLoadingState />;\n }\n\n const onBuildFailure = () => {\n if (hasBuildEverFailed) {\n return;\n }\n setState((prevState) => ({\n ...prevState,\n hasBuildEverFailed: true,\n }));\n };\n\n return (\n <MainLayout\n appId={appId}\n appName={(build && build.appName) || appPkg.name}\n appVersion={(build && build.appVersion) || appPkg.version}\n build={build}\n commandUsed={commandUsed}\n hasBuildEverFailed={hasBuildEverFailed}\n >\n {isPreparationComplete ? (\n <BuildProgress build={build} onBuildFailure={onBuildFailure} />\n ) : (\n <Preparation\n progressPercentage={preparationProgress}\n stageLabel={preparationStageLabel}\n uploadedSize={preparationUploadedSize}\n />\n )}\n </MainLayout>\n );\n};\n\nBuild.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n shouldCodeSign: PropTypes.bool,\n configPath: PropTypes.string,\n};\n\nexport default Build;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport throttle from \"lodash.throttle\";\nimport BuildCompleteMessage from \"./BuildCompleteMessage\";\nimport PlatformProgress from \"./PlatformProgress\";\nimport { hasBuildKickedOff } from \"../utilities/buildStatus\";\nimport logger from \"../utilities/logger\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\n\nconst logForCIThrottled = throttle(logForCI, 60 * 1000, { trailing: true });\n\nconst BuildProgress = ({ build, onBuildFailure }) => {\n logger.debug(\"BuildProgress component: render\");\n const exit = useExit();\n\n const [{ hasKickedOff }, setState] = useState({\n hasKickedOff: false,\n });\n const platformsNotSkipped = [\"windows\", \"mac\", \"linux\"].filter(\n (platform) => !build[platform].shouldSkip\n );\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n hasKickedOff: hasBuildKickedOff(build),\n }));\n }, [build]);\n\n useEffect(() => {\n if (build.status === \"failed\") {\n onBuildFailure(build.errorMessage);\n } else if (build.status === \"cancelled\") {\n setTimeout(exit, 10);\n } else {\n const ciPlatformProgress = platformsNotSkipped.map(\n (platform) =>\n `${platform.charAt(0).toUpperCase() + platform.slice(1)}: ${\n build[platform].progressActivityName\n } (${build[platform].progressPercentage}%)`\n );\n logForCIThrottled(ciPlatformProgress.join(\", \"));\n }\n }, [build, exit, onBuildFailure, platformsNotSkipped]);\n\n if (build.status === \"succeeded\") {\n return <BuildCompleteMessage build={build} />;\n }\n\n if (build.status === \"cancelled\") {\n return (\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text>Build cancelled</Text>\n </Box>\n );\n }\n\n if (!hasKickedOff) {\n return null;\n }\n\n return (\n <>\n <Box flexDirection=\"column\">\n {platformsNotSkipped.map((platform) => (\n <Box flexDirection=\"column\" key={platform}>\n <PlatformProgress\n activityName={\n build[platform].status === \"failed\"\n ? build[platform].errorMessage\n : build[platform].progressActivityName\n }\n activityType={\n build[platform].status === \"failed\"\n ? \"error\"\n : build[platform].progressActivityType\n }\n downloadUrl={build[platform].standardDownloadUrl}\n percent={build[platform].progressPercentage}\n platform={platform}\n shouldShowReadyPrefix={\n !(build && [\"failed\", \"succeeded\"].includes(build.status))\n }\n />\n </Box>\n ))}\n </Box>\n </>\n );\n};\n\nBuildProgress.propTypes = {\n build: PropTypes.object.isRequired,\n onBuildFailure: PropTypes.func.isRequired,\n};\n\nexport default BuildProgress;\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport PropTypes from \"prop-types\";\nimport { useEffect } from \"react\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport path from \"path\";\n\nconst addTrailingSlash = (url) => {\n return url.endsWith(\"/\") ? url : `${url}/`;\n};\n\nconst BuildCompleteMessage = ({ build }) => {\n const exit = useExit();\n let url = build.standardUniversalDownloadUrl;\n\n if (process.platform === \"darwin\") {\n // Otherwise the download link may link to a Intel file when on Apple Silicon\n url = new URL(\n path.posix.join(\"mac\", \"zip\", process.arch),\n addTrailingSlash(url)\n ).href;\n }\n\n logForCI(`Build complete! ${url}`);\n\n // On build completion, exit with non-error code\n useEffect(() => {\n if (url) {\n // Just to avoid updating state after exiting the React app\n setTimeout(exit, 10);\n }\n }, [exit, url]);\n\n return (\n <Box marginBottom={1}>\n <Text>\n <Text bold>Build complete!</Text>{\" \"}\n <Link fallback={false} url={url}>\n {url || \"\"}\n </Link>\n </Text>\n </Box>\n );\n};\n\nBuildCompleteMessage.propTypes = {\n build: PropTypes.object.isRequired,\n};\n\nexport default BuildCompleteMessage;\n", "import isCi from \"is-ci\";\nimport logger from \"./logger\";\n\nexport default (...args) => {\n logger.info({ args }, \"logForCI\");\n\n if (isCi || !process.stdin.isTTY) {\n console.log(...args);\n }\n};\n", "import bunyan from \"bunyan\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as path from \"path\";\nimport * as Sentry from \"@sentry/node\";\n\nlet logger;\n\ntry {\n const name = \"todesktop-cli\";\n\n let parentDirectory;\n const homePath = os.homedir();\n if (process.platform === \"darwin\") {\n parentDirectory = path.join(homePath, \"Library\", \"Logs\", name);\n } else if (process.platform === \"win32\") {\n parentDirectory = path.join(\n process.env.APPDATA || path.join(homePath, \"AppData\", \"Roaming\"),\n name,\n \"logs\"\n );\n } else {\n parentDirectory = path.join(\n process.env.XDG_CONFIG_HOME || path.join(homePath, \".config\"),\n name,\n \"logs\"\n );\n }\n\n fs.mkdirSync(parentDirectory, { recursive: true });\n\n logger = bunyan.createLogger({\n name,\n src: true,\n streams: [\n {\n level: \"debug\",\n path: path.join(parentDirectory, \"main.log\"),\n },\n ],\n });\n} catch (e) {\n // Ignore\n\n const noOp = () => {};\n logger = {\n debug: noOp,\n error: noOp,\n fatal: noOp,\n info: noOp,\n trace: noOp,\n warn: noOp,\n };\n\n try {\n Sentry.captureException(e);\n } catch (err) {\n // Ignore\n }\n}\n\nexport default logger;\n", "import { useApp } from \"ink\";\nimport { flush } from \"./analytics\";\nimport firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default () => {\n const { exit } = useApp();\n\n return (error = undefined) => {\n logger.debug({ error }, \"Exit called\");\n\n /*\n First, destroy connections.\n Why do we need to do this if we're going to call process.exit\n below anyway? Just to be safe in case a Firestore subscription\n triggers a state update after the React app is exited.\n */\n firestore.terminate().catch((e) =>\n // Ignore\n logger.error(e)\n );\n\n let timeoutId;\n Promise.race([\n // flush the analytics to make sure all outstanding events are pushed to segment\n new Promise<void>((resolve) => flush(() => resolve())),\n // If it takes longer than 1 second, resolve early to proceed with program exit\n new Promise<void>(\n (resolve) => (timeoutId = setTimeout(() => resolve(), 1000))\n ),\n ])\n .catch(() => {})\n .finally(() => {\n clearTimeout(timeoutId);\n /*\n Then, exit the React app. We don't pass the error because:\n 1. We don't want it displayed. We could give it a dummy error but\n that will output an empty line.\n 2. It doesn't exit with the correct code anyway, see\n https://github.com/vadimdemedes/pastel/issues/39.\n\n Side note: your component must not perform state updates after\n calling this, it will error.\n\n The try-catch shouldn't be needed here, but let's be safe\n */\n try {\n exit();\n } catch (e) {\n logger.error(e);\n // Ignore\n }\n\n /*\n Then exit the process.\n It should happen if all connections, etc. are destroyed. We manually\n exit with a code because:\n 1. We might not clean up properly, it could fail or take a long time.\n 2. The exit function above doesn't exit the CLI with the correct\n code anyway.\n\n If we had a way to detect when the app exits, we would use that\n and then call process.exit / destroy connections appropriately\n (https://github.com/vadimdemedes/pastel/issues/38).\n */\n setTimeout(() => process.exit(error ? 1 : 0), 10);\n });\n };\n};\n", "import os from \"os\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport Analytics from \"analytics-node\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport { currentUser } from \"./firestore\";\nimport { getAuthConfig } from \"./configStore\";\nimport getCliVersion from \"./getCliVersion\";\n\nconst environmentVariables = getEnvironmentVariables();\n\nconst analytics = new Analytics(environmentVariables.SEGMENT_WRITE_KEY, {\n flushAt: 1,\n flushInterval: 1,\n});\n\nexport const ANALYTICS_EVENT = {\n CLI_COMMAND: \"CLI Command\",\n};\n\nfunction getAnalyticsBaseProperties() {\n const baseProps = {\n app: {\n cliVersion: \"\",\n },\n client: \"cli\",\n user: {\n email: \"\",\n },\n os: {\n name: \"\",\n version: \"\",\n },\n runtime: {\n name: \"Node.js\",\n version: \"\",\n },\n };\n try {\n baseProps.os = {\n name: os.platform(),\n version: os.release(),\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.user = {\n email: getAuthConfig().email as string,\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.app = {\n cliVersion: getCliVersion(),\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.runtime = {\n name: \"Node.js\",\n version: process.version,\n };\n } catch (err) {\n // nothing\n }\n\n return baseProps;\n}\n\nconst anonymousId = uuidv4();\nexport const track = (event, properties = {}, callback = () => {}) => {\n try {\n const user = currentUser();\n\n analytics.track(\n {\n event,\n userId: user ? user.uid : undefined,\n anonymousId,\n properties: {\n ...properties,\n ...getAnalyticsBaseProperties(),\n },\n },\n callback\n );\n } catch (err) {\n // nothing\n }\n};\n\nexport const identify = (id, traits = {}, callback = () => {}) => {\n try {\n analytics.identify({ userId: id, anonymousId, traits }, callback);\n } catch (err) {\n // nothing\n }\n};\n\nexport const flush = (callback = () => {}) => analytics.flush(callback);\n", "import dotenv from \"dotenv\";\nimport path from \"path\";\n\nlet hasInitialized = false;\n\nconst init = () => {\n if (hasInitialized) {\n return;\n }\n\n dotenv.config({\n path: path.resolve(__dirname, \"../.env\"),\n });\n hasInitialized = true;\n};\n\nexport default () => {\n init();\n return process.env;\n};\n", "import firebase from \"firebase/app\";\nimport \"firebase/firestore\";\nimport \"firebase/auth\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nconst environmentVariables = getEnvironmentVariables();\n\n// if (environmentVariables.NODE_ENV === \"development\") {\n// if (true) {\n// firebase.firestore.setLogLevel(\"debug\");\n// }\n\nconst firebaseDB = firebase.initializeApp({\n apiKey: environmentVariables.TODESKTOP_CLI_FIREBASE_API_KEY,\n authDomain: environmentVariables.TODESKTOP_CLI_FIREBASE_AUTH_DOMAIN,\n databaseURL: environmentVariables.TODESKTOP_CLI_FIREBASE_DATABASE_URL,\n projectId: environmentVariables.TODESKTOP_CLI_FIREBASE_PROJECT_ID,\n storageBucket: environmentVariables.TODESKTOP_CLI_FIREBASE_STORAGE_BUCKET,\n messagingSenderId:\n environmentVariables.TODESKTOP_CLI_FIREBASE_MESSAGING_SENDER_ID,\n appId: environmentVariables.TODESKTOP_CLI_FIREBASE_ID,\n});\n\nexport const currentUser = () => firebase.auth().currentUser;\nexport const signInWithCustomToken = async (token) => {\n return firebase.auth().signInWithCustomToken(token);\n};\n\n/**\n * onUserAuth is only triggered on sign-in. This\n * happens once signInWithCustomToken is successful.\n *\n * It technically also triggers on sign-out but there's\n * no concept of signing out of firebase with the CLI app.\n * (See logout command which just deletes a local file)\n */\nexport const onUserAuth = (handler) =>\n firebase.auth().onAuthStateChanged((user) => {\n handler(user || {});\n });\n\nexport default firebaseDB.firestore();\n", "import * as fs from \"fs\";\nimport del from \"del\";\nimport Conf from \"conf\";\nimport xdgBasedir from \"xdg-basedir\";\n\nconst config = new Conf({ configName: \"todesktop-cli\" });\n\nexport const accessTokenConfigKey = \"accessToken\";\nexport const emailConfigKey = \"email\";\nexport const jwtTokenConfigKey = \"jwtToken\";\n\nexport const setConfig = (key, value) => config.set(key, value);\nexport const getConfig = (key) => config.get(key) as string;\n\nexport const setAuthConfig = (email, accessToken, jwtToken) => {\n setConfig(emailConfigKey, email);\n setConfig(accessTokenConfigKey, accessToken);\n setConfig(jwtTokenConfigKey, jwtToken);\n};\n\nexport const getAuthConfig = () => {\n const accessToken = getConfig(accessTokenConfigKey);\n const jwtToken = getConfig(jwtTokenConfigKey);\n const email = getConfig(emailConfigKey);\n\n return { accessToken, jwtToken, email };\n};\n\nexport const deleteAuthConfig = () => {\n config.delete(emailConfigKey);\n config.delete(accessTokenConfigKey);\n config.delete(jwtTokenConfigKey);\n};\n\n// TODO - Delete by end of April: backwards compatibility for old configstore\nconst oldConfigPath = `${xdgBasedir.config}/configstore/config.json.json`;\nif (fs.existsSync(oldConfigPath)) {\n try {\n // copy config from old json file to new json file, delete old file\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { email, accessToken, jwtToken } = require(oldConfigPath);\n setAuthConfig(email, accessToken, jwtToken);\n del(oldConfigPath, { force: true });\n } catch (err) {\n // if invalid json, delete file to prompt new login\n del(oldConfigPath, { force: true });\n }\n}\n", "import pkgUp from \"pkg-up\";\nimport readJson from \"./readJson\";\n\nconst packageJson = readJson(pkgUp.sync({ cwd: __dirname }));\n\nexport default function getToDesktopPackageJson() {\n return packageJson;\n}\n", "// This exists so it can be mocked in tests\nexport default (filePath) => require(filePath);\n", "import getToDesktopPackageJson from \"./getToDesktopPackageJson\";\n\nconst cliVersion = getToDesktopPackageJson().version;\n\nexport default () => cliVersion;\n", "import PropTypes from \"prop-types\";\nimport { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport path from \"path\";\n\nconst preLabelMaxWidth = \"More info: \".length;\n\nconst getProgressPercentageLabel = (\n percentage: number,\n activityType?: \"error\"\n) => {\n let backgroundColor = \"white\";\n let color = \"black\";\n\n if (activityType === \"error\") {\n backgroundColor = \"red\";\n } else if (percentage === 100) {\n backgroundColor = \"green\";\n color = \"black\";\n }\n\n return (\n <>\n <Text backgroundColor={backgroundColor} color={color}>\n {\" \"}\n {Math.round(percentage).toString().padStart(2, \"0\")}%{\" \"}\n </Text>\n <Text> </Text>\n </>\n );\n};\n\nconst PlatformProgress = ({\n activityName,\n activityType,\n downloadUrl,\n percent,\n platform,\n shouldShowReadyPrefix,\n}) => {\n let progressIndicator;\n if (activityType === \"done\") {\n if (process.platform === \"darwin\") {\n // Otherwise the download link may link to a Intel file when on Apple Silicon\n downloadUrl = path.posix.join(downloadUrl, \"mac\", \"zip\", process.arch);\n }\n progressIndicator = (\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text>\n {getProgressPercentageLabel(100)}\n {shouldShowReadyPrefix ? \"Ready!\" : \"\"}\n </Text>\n <Link fallback={false} url={downloadUrl}>\n {downloadUrl}\n </Link>\n </Box>\n );\n } else {\n let activityNameToDisplay = activityName.replace(\n /(?:\\r\\n|\\r|\\n)\\s*/g,\n \"\u21B5 \"\n );\n if (activityNameToDisplay.length > 64) {\n activityNameToDisplay = `${activityNameToDisplay.substr(0, 61)}...`;\n }\n\n progressIndicator = (\n <>\n <Box flexDirection={\"column\"} marginBottom={1}>\n <Text>\n {[\"preparation\", \"queue\"].includes(activityType)\n ? undefined\n : getProgressPercentageLabel(percent, activityType)}\n {activityNameToDisplay}\n {activityType === \"error\" ? \"\" : <Text>...</Text>}\n </Text>\n </Box>\n </>\n );\n }\n return (\n <Box>\n <Box width={preLabelMaxWidth}>\n <Text>{platform[0].toUpperCase() + platform.substr(1)}: </Text>\n </Box>\n {progressIndicator}\n </Box>\n );\n};\n\nPlatformProgress.propTypes = {\n activityName: PropTypes.string.isRequired,\n activityType: PropTypes.string.isRequired,\n downloadUrl: PropTypes.string,\n percent: PropTypes.number.isRequired,\n platform: PropTypes.string.isRequired,\n shouldShowReadyPrefix: PropTypes.bool,\n};\n\nexport default PlatformProgress;\n", "export const hasBuildKickedOff = (build) => {\n if (!build) {\n return false;\n }\n return build.status && build.status !== \"preparation\";\n};\n\n// NOTE: this relies on Firestore solely\nexport const isBuildCancellable = (build) =>\n hasBuildKickedOff(build) && isBuildRunning(build);\n\nexport const isBuildRunning = (build) => {\n if (!build) {\n return false;\n }\n return (\n ![\"cancelled\", \"succeeded\"].includes(build.status) &&\n [\"linux\", \"mac\", \"windows\"].some((platform) =>\n isPlatformBuildRunning(build[platform])\n )\n );\n};\n\nexport const isPlatformBuildRunning = (platformBuild) => {\n if (!platformBuild) {\n return false;\n }\n return (\n !platformBuild.shouldSkip && // <-- Noteworthy\n ![\"cancelled\", \"succeeded\"].includes(platformBuild.status) &&\n (\"failed\" !== platformBuild.status ||\n platformBuild.numberOfAttemptedBuilds < 2)\n );\n};\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect } from \"react\";\nimport getCliVersion from \"../utilities/getCliVersion\";\nimport logger from \"../utilities/logger\";\nimport useExit from \"../utilities/useExit\";\n\nconst ErrorDisplay = ({ commandUsed, error }) => {\n const exit = useExit();\n logger.error({ error });\n\n // After an error is set, exit\n useEffect(() => {\n if (!error) {\n return;\n }\n // Just to avoid updating state after exiting the React app\n setTimeout(() => exit(error), 10);\n }, [exit, error]);\n\n return (\n <>\n <Text backgroundColor=\"red\" color=\"white\">\n {\" \"}\n ERROR{\" \"}\n </Text>\n <Text>{error.message || error.stack || error.toString()}</Text>\n\n <Box flexDirection=\"column\" marginTop={1}>\n {commandUsed ? (\n <Text dimColor color=\"gray\">\n Command: {commandUsed}\n </Text>\n ) : null}\n <Text dimColor color=\"gray\">\n @todesktop/cli: {getCliVersion()}\n </Text>\n <Text dimColor color=\"gray\">\n Node: {process.version}\n </Text>\n <Text dimColor color=\"gray\">\n cwd: {process.cwd()}\n </Text>\n </Box>\n </>\n );\n};\n\nErrorDisplay.propTypes = {\n commandUsed: PropTypes.string,\n error: PropTypes.object.isRequired,\n};\n\nexport default ErrorDisplay;\n", "import { Box, Text } from \"ink\";\nimport ProgressBar from \"./ProgressBar\";\nimport PropTypes from \"prop-types\";\n\nconst Preparation = ({ progressPercentage, stageLabel, uploadedSize }) => {\n return (\n <Box marginBottom={1}>\n <Text>{stageLabel}: </Text>\n <Box flexDirection={\"column\"}>\n <ProgressBar left={11} percent={progressPercentage} />\n {uploadedSize ? <Text>{uploadedSize}</Text> : undefined}\n </Box>\n </Box>\n );\n};\n\nPreparation.propTypes = {\n progressPercentage: PropTypes.number.isRequired,\n stageLabel: PropTypes.string.isRequired,\n uploadedSize: PropTypes.string,\n};\n\nexport default Preparation;\n", "import PropTypes from \"prop-types\";\nimport Gradient from \"ink-gradient\";\nimport Bar from \"../libs/ink-progress-bar\";\n\nconst ProgressBar = ({ left, right, percent }) => (\n <Gradient colors={[\"gray\", \"white\"]}>\n <Bar left={left} right={right} percent={percent} />\n </Gradient>\n);\n\nProgressBar.propTypes = {\n left: PropTypes.number,\n right: PropTypes.number,\n // 0 -> 1\n percent: PropTypes.number.isRequired,\n};\n\nexport default ProgressBar;\n", "/**\n * Ported from https://github.com/brigand/ink-progress-bar/blob/master/src/index.js\n * `ink-progress-bar` doesn't list react or ink as a direct dependency which messes up\n * installation for users of yarn v2+.\n */\nimport { Text } from \"ink\";\n\nconst Bar = ({\n percent = 1,\n columns = 0,\n left = 0,\n right = 0,\n character = \"\u2588\",\n rightPad = false,\n ...rest\n}) => {\n const getString = () => {\n const screen = columns || process.stdout.columns || 80;\n const space = screen - right - left;\n const max = Math.min(Math.floor(space * percent), space);\n const chars = character.repeat(max);\n\n if (!rightPad) {\n return chars;\n }\n\n return chars + \" \".repeat(space - max);\n };\n\n return <Text {...rest}>{getString()}</Text>;\n};\n\nexport default Bar;\n", "import { Text } from \"ink\";\n\nconst InitialLoadingState = () => {\n return <Text>Getting app info...</Text>;\n};\n\nexport default InitialLoadingState;\n", "// libs\nimport { Box, Text, useStdin } from \"ink\";\nimport isCi from \"is-ci\";\nimport { ReactNode, useEffect, useState } from \"react\";\nimport { Build } from \"../types\";\n\n// components\nimport CancelBuild from \"./CancelBuild\";\nimport Footer from \"./Footer\";\nimport Header from \"./Header\";\n\n// utilities\nimport {\n hasBuildKickedOff,\n isBuildCancellable,\n} from \"../utilities/buildStatus\";\nimport logger from \"../utilities/logger\";\nimport useInput from \"../utilities/useInput\";\n\nconst MainLayout = ({\n appId,\n appName,\n appVersion,\n build,\n children,\n commandUsed,\n hasBuildEverFailed,\n}: {\n appId?: string;\n appName: string;\n appVersion?: string;\n build?: Build;\n children?: ReactNode;\n commandUsed?: string;\n hasBuildEverFailed?: boolean;\n}) => {\n logger.debug(\"MainLayout component: render\");\n const onInput = useInput();\n const { isRawModeSupported } = useStdin();\n\n const [\n { canCancelBuild, hasKickedOff, isCancellingBuild, wasCtrlCPressed },\n setState,\n ] = useState({\n canCancelBuild: null,\n hasKickedOff: false,\n isCancellingBuild: false,\n wasCtrlCPressed: false,\n });\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n hasKickedOff: hasBuildKickedOff(build),\n }));\n }, [build]);\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n canCancelBuild:\n !isCi &&\n isRawModeSupported &&\n !isCancellingBuild &&\n isBuildCancellable(build),\n }));\n }, [build, isCancellingBuild]);\n\n onInput(\n async (input, key) => {\n if (key.escape && canCancelBuild) {\n logger.debug(\"MainLayout component: esc pressed, cancelling build\");\n\n setState((previousState) => ({\n ...previousState,\n isCancellingBuild: true,\n }));\n }\n },\n {},\n {\n onCtrlCPressed: () => {\n setState((previousState) => ({\n ...previousState,\n wasCtrlCPressed: true,\n }));\n },\n }\n );\n\n return (\n <>\n <Header build={build} name={appName} version={appVersion} />\n\n {isCancellingBuild ? (\n <Box flexDirection=\"column\" marginBottom={1}>\n <CancelBuild appId={appId} commandUsed={commandUsed} id={build.id} />\n </Box>\n ) : (\n children\n )}\n\n <Footer\n hasBuildEverFailed={hasBuildEverFailed}\n shouldShowCancelBuildInstructions={canCancelBuild && !wasCtrlCPressed}\n uiUrl={build ? build.url : null}\n />\n\n {wasCtrlCPressed && hasKickedOff ? (\n <>\n <Box flexDirection=\"column\" marginTop={1}>\n <Text color=\"gray\">\n The build will continue in the background. To view it, run:\n </Text>\n </Box>\n <Box>\n <Text bold color=\"gray\">\n todesktop builds {build.id}\n </Text>\n </Box>\n </>\n ) : null}\n </>\n );\n};\n\nexport default MainLayout;\n", "// libs\nimport { Text } from \"ink\";\nimport { ReactNode, useEffect, useState } from \"react\";\n\n// components\nimport ErrorDisplay from \"./ErrorDisplay\";\n\n// utils\nimport getCallableFirebaseFunction from \"../utilities/getCallableFirebaseFunction\";\nimport logForCI from \"../utilities/logForCI\";\nimport logger from \"../utilities/logger\";\nimport useExit from \"../utilities/useExit\";\n\nconst cancelBuild = getCallableFirebaseFunction(\"cancelBuild\");\n\nconst CancelBuild = ({\n appId,\n children: postCancelContents,\n commandUsed,\n id,\n}: {\n appId: string;\n children?: ReactNode;\n commandUsed: string;\n id: string;\n}) => {\n logger.debug({ appId, buildId: id }, \"CancelBuild component: render\");\n\n const exit = useExit();\n const [\n { arbitraryMessageComponent, error, hasCompleted, hasStarted },\n setState,\n ] = useState({\n arbitraryMessageComponent: null,\n error: null,\n hasCompleted: false,\n hasStarted: false,\n });\n\n useEffect(() => {\n if (hasCompleted || hasStarted) {\n return;\n }\n\n setState((previousState) => ({ ...previousState, hasStarted: true }));\n logForCI(\"Cancelling build...\");\n cancelBuild({ appId, buildId: id })\n .then((result) => {\n logger.debug(\n { appId, buildId: id, result },\n \"CancelBuild component: cancellation request complete\"\n );\n setState((previousState) => ({ ...previousState, hasCompleted: true }));\n })\n .catch((e) => {\n logger.debug(\n { appId, buildId: id, code: e.code },\n \"CancelBuild component: cancellation request failed\"\n );\n logger.error(e);\n const stateUpdates = {\n arbitraryMessageComponent: undefined,\n error: undefined,\n hasCompleted: true,\n };\n\n if (e.code === \"internal\") {\n stateUpdates.error = e;\n } else {\n stateUpdates.arbitraryMessageComponent = (\n <Text>\n <Text color=\"red\">Cannot cancel build ({id}).</Text> {e.message}\n </Text>\n );\n }\n\n setState((prevState) => ({\n ...prevState,\n ...stateUpdates,\n }));\n });\n }, [appId, id, hasStarted, hasCompleted]);\n\n // Exit when done, unless there are custom contents to display\n useEffect(() => {\n if (hasCompleted && !postCancelContents) {\n logger.debug(\n \"CancelBuild component: exiting now that build is cancelled\"\n );\n exit();\n }\n }, [postCancelContents, exit, hasCompleted]);\n\n if (error) {\n error.message = `Failed to cancel build (${id}). ${error.message}`;\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (hasCompleted) {\n return postCancelContents ? (\n <>{postCancelContents}</>\n ) : (\n <Text>Build cancelled</Text>\n );\n }\n\n return <Text>Cancelling build ({id})...</Text>;\n};\n\nexport default CancelBuild;\n", "import firebase from \"firebase\";\nimport \"firebase/functions\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nif (getEnvironmentVariables().TODESKTOP_CLI_ENV === \"development\") {\n firebase.functions().useFunctionsEmulator(\"http://localhost:5000\");\n}\n\nexport default (functionName) =>\n firebase.functions().httpsCallable(functionName);\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport PropTypes from \"prop-types\";\n\nconst Footer = ({\n hasBuildEverFailed,\n shouldShowCancelBuildInstructions,\n uiUrl,\n}) => {\n if (!uiUrl) {\n return null;\n }\n\n let buildFailedMessage;\n if (hasBuildEverFailed) {\n buildFailedMessage = <Text color=\"red\">An error has occurred. </Text>;\n }\n\n return (\n <Box flexDirection=\"column\">\n <Box flexDirection=\"column\">\n <Text bold>{buildFailedMessage}See web UI for more information: </Text>\n <Text>\n <Link fallback={false} url={uiUrl}>\n {uiUrl}\n </Link>\n </Text>\n </Box>\n {shouldShowCancelBuildInstructions ? (\n <Text color=\"gray\">\n <Text bold>[esc]:</Text> cancel build\n </Text>\n ) : null}\n </Box>\n );\n};\n\nFooter.propTypes = {\n hasBuildEverFailed: PropTypes.bool,\n shouldShowCancelBuildInstructions: PropTypes.bool,\n uiUrl: PropTypes.string,\n};\n\nexport default Footer;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst getText = (build, name, version) => {\n const suffix = name + (version ? ` v${version}` : \"\");\n\n if (build && [\"cancelled\", \"succeeded\", \"failed\"].includes(build.status)) {\n if (build.status === \"succeeded\") {\n return <Text>\u2705 {suffix}</Text>;\n } else if (build.status === \"failed\") {\n return <Text>\u274C {suffix}</Text>;\n } else if (build.status === \"cancelled\") {\n return (\n <Text>\n <Text bold color=\"gray\">\n X\n </Text>{\" \"}\n {suffix}\n </Text>\n );\n }\n } else {\n return <Text>{suffix}</Text>;\n }\n};\n\nconst Header = ({ build, name, version }) => (\n <Box marginBottom={1}>{getText(build, name, version)}</Box>\n);\n\nHeader.propTypes = {\n build: PropTypes.object,\n name: PropTypes.string.isRequired,\n version: PropTypes.string,\n};\n\nexport default Header;\n", "import isCi from \"is-ci\";\nimport { useInput, useStdin } from \"ink\";\nimport useExit from \"./useExit\";\n\nlet hasSubscribed = false;\nconst ctrlCSubscriptions = [];\n\nconst onStdin = (data, exit) => {\n let input = String(data);\n let wasCtrlPressed = false;\n if (input <= \"\\u001A\" && input !== \"\\r\") {\n input = String.fromCharCode(input.charCodeAt(0) + \"a\".charCodeAt(0) - 1);\n wasCtrlPressed = true;\n }\n if (wasCtrlPressed && input === \"c\") {\n ctrlCSubscriptions.forEach((subscription) => subscription());\n setTimeout(exit, 10);\n }\n};\n\n/*\n See https://github.com/vadimdemedes/pastel/issues/38\n*/\nexport default () => {\n const exit = useExit();\n const { stdin, isRawModeSupported } = useStdin();\n\n if (isCi || !isRawModeSupported) {\n return () => () => {};\n }\n\n return (callback, useInputOptions = {}, { onCtrlCPressed = null } = {}) => {\n const onStdinData = (data) => onStdin(data, exit);\n\n if (onCtrlCPressed) {\n ctrlCSubscriptions.push(onCtrlCPressed);\n }\n\n if (!hasSubscribed) {\n hasSubscribed = true;\n\n // This is based on the Ink (useInput) source\n stdin.on(\"data\", onStdinData);\n }\n\n const cleanUpInputHook = useInput(callback, useInputOptions) as any;\n\n return () => {\n if (hasSubscribed) {\n stdin.off(\"data\", onStdinData);\n }\n cleanUpInputHook?.();\n };\n };\n};\n", "// libs\n\nimport prettyBytes from \"pretty-bytes\";\n\n// utils\nimport { currentUser } from \"./firestore\";\nimport getVersionControlInfo from \"./getVersionControlInfo\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\nimport logForCI from \"./logForCI\";\nimport postToFirebaseFunction from \"./postToFirebaseFunction\";\nimport subscribeToBuild from \"./subscribeToBuild\";\nimport uploadApplicationSource from \"./uploadApplicationSource\";\nimport getAppPkgJson from \"./getPackageJson\";\n\nexport default async ({ onEvent, shouldCodeSign = true, configPath }) => {\n logForCI(\"Getting application information...\");\n\n const primaryUserId = currentUser().uid;\n\n // This will throw if validation fails or project root can not be found:\n const { config, unprocessedConfig } = getProjectConfig(configPath);\n\n const appId = config.id;\n\n const appPkgJson = getAppPkgJson({ config });\n\n onEvent(\"progress\", {\n appId,\n appPkg: appPkgJson,\n preparationProgress: 0.02,\n });\n logForCI(\"Preparing...\");\n\n // Create build in Firebase\n let buildId;\n try {\n const prepareResult = await postToFirebaseFunction(\"prepareNewBuild\", {\n appPkgName: appPkgJson.name,\n appPkgProductName: appPkgJson.productName,\n appVersion: appPkgJson.version,\n id: config.id,\n projectConfig: unprocessedConfig,\n shouldCodeSign: shouldCodeSign !== false,\n shouldRelease: false,\n userId: primaryUserId,\n versionControlInfo: await getVersionControlInfo(config.appPath),\n });\n buildId = prepareResult.appData.meta.currentBuildProgress.id;\n\n const firebaseUnsubscribe = await subscribeToBuild({\n appId,\n buildId,\n onDataReceived: (data) => onEvent(\"progress\", { build: data }),\n userId: prepareResult.userId,\n });\n\n onEvent(\"firebase-subscribed\", { firebaseUnsubscribe });\n } catch (e) {\n e.message = `Failed while preparing new build; ${e.message}`;\n throw e;\n }\n\n onEvent(\"progress\", {\n preparationProgress: 0.05,\n preparationStageLabel: \"Uploading\",\n });\n\n logForCI(\"Uploading...\");\n\n let sourceArchiveDetails;\n try {\n const uploadAppSourceResult = await uploadApplicationSource({\n appId,\n appPkgJson,\n buildId,\n config,\n onProgress(progress, uploadedSize) {\n // Upload is treated as 95% of preparation\n const dataToEmit = {\n preparationProgress: 0.05 + (progress / 100) * 0.95,\n preparationUploadedSize: \"\",\n };\n\n if (uploadedSize) {\n dataToEmit.preparationUploadedSize = prettyBytes(uploadedSize);\n }\n\n onEvent(\"progress\", dataToEmit);\n },\n });\n\n sourceArchiveDetails = uploadAppSourceResult;\n } catch (e) {\n e.message = `Failed while uploading application source; ${e.message}`;\n throw e;\n }\n\n onEvent(\"progress\", { isPreparationComplete: true });\n logForCI(\"Kicking off build...\");\n\n try {\n await postToFirebaseFunction(\"kickOffBuild\", {\n appId,\n appPkgName: appPkgJson.name,\n appVersion: appPkgJson.version,\n buildId,\n userId: primaryUserId,\n sourceArchiveDetails,\n });\n } catch (e) {\n e.message = `Failed while kicking off build; ${e.message}`;\n throw e;\n }\n};\n", "import * as gitRevSync from \"git-rev-sync\";\n\nexport default async (directory) => {\n let result = {};\n\n try {\n const gitCommitHash = gitRevSync.long(directory);\n\n if (gitCommitHash) {\n result = {\n branchName: gitRevSync.branch(directory),\n commitDate: gitRevSync.date().toISOString(),\n commitId: gitCommitHash,\n commitMessage: gitRevSync.message(),\n hasUncommittedChanges: gitRevSync.isDirty(),\n repositoryRemoteUrl: gitRevSync.remoteUrl(),\n versionControlSystemName: \"git\",\n };\n }\n } catch (e) {\n // Ignore\n }\n\n return result;\n};\n", "import { dirname, resolve } from \"path\";\nimport { existsSync } from \"fs\";\nimport findUp from \"find-up\";\nimport loadConfig from \"./loadConfig\";\nimport resolveConfigPaths from \"./resolveConfigPaths\";\nimport validateConfig from \"./validateConfig\";\nimport logger from \"../logger\";\nimport computeFullProjectConfig from \"./computeFullProjectConfig\";\n\nexport default (configPath = null) => {\n // If no config path is provided, we'll try to find one\n if (configPath === null) {\n logger.debug(\"No config path provided, searching for one\");\n configPath = findUp.sync(\"todesktop.json\");\n if (!configPath) {\n throw new Error(\n \"Can not find todesktop.json in this folder or any parent folders\"\n );\n }\n } else {\n if (typeof configPath === \"undefined\" || configPath === \"\") {\n logger.error(\"Provided config path is empty\");\n throw new Error(\"No config path provided\");\n }\n\n configPath = resolve(process.cwd(), configPath);\n\n // If the config path is provided\n if (!existsSync(configPath)) {\n logger.error(\"Provided config path does not exist\");\n throw new Error(`Config file not found at ${configPath}`);\n }\n }\n\n const projectRoot = dirname(configPath);\n\n // This will throw if it's not valid JSON\n const partialConfig = loadConfig(configPath);\n partialConfig.appPath = partialConfig.appPath || \".\";\n\n // compute the full project config\n\n const config = computeFullProjectConfig(partialConfig, projectRoot);\n\n // This will throw if invalid\n validateConfig({ config, projectRoot });\n\n const result = resolveConfigPaths({ config, projectRoot });\n\n return { config: result, unprocessedConfig: config, projectRoot };\n};\n", "// This is its own file just so we can mock it more easily\nexport default (configPath) => require(configPath);\n", "import * as path from \"path\";\n\nexport default ({ config, projectRoot }) => {\n const appRoot = config.appPath\n ? path.isAbsolute(config.appPath)\n ? config.appPath\n : path.join(projectRoot, config.appPath)\n : projectRoot;\n\n const transformIfExists = (value, transformer) =>\n value ? transformer(value) : undefined;\n const resolvePath = (filePath) =>\n path.isAbsolute(filePath) ? filePath : path.join(projectRoot, filePath);\n\n const result = {\n ...config,\n appPath: appRoot,\n icon: resolvePath(config.icon),\n };\n\n if (config.extraContentFiles) {\n result.extraContentFiles = transformIfExists(\n config.extraContentFiles,\n (extraContentFiles) =>\n extraContentFiles.map((extraContentFile) => ({\n ...extraContentFile,\n from: resolvePath(extraContentFile.from),\n }))\n );\n }\n\n if (config.extraResources) {\n result.extraResources = transformIfExists(\n config.extraResources,\n (extraResources) =>\n extraResources.map((extraResource) => ({\n ...extraResource,\n from: resolvePath(extraResource.from),\n }))\n );\n }\n\n if (config.linux) {\n result.linux = { ...config.linux };\n\n if (config.linux.icon) {\n result.linux.icon = resolvePath(config.linux.icon);\n }\n }\n\n if (config.mac) {\n result.mac = { ...config.mac };\n\n if (config.mac.entitlements) {\n result.mac.entitlements = resolvePath(config.mac.entitlements);\n }\n\n if (config.mac.icon) {\n result.mac.icon = resolvePath(config.mac.icon);\n }\n }\n\n if (config.dmg) {\n if (config.dmg.background) {\n result.dmg.background = resolvePath(config.dmg.background);\n }\n }\n\n if (config.windows) {\n result.windows = { ...config.windows };\n\n if (config.windows.icon) {\n result.windows.icon = resolvePath(config.windows.icon);\n }\n }\n\n return result;\n};\n", "import Ajv from \"ajv\";\nimport addFormats from \"ajv-formats\";\nimport betterAjvErrors from \"better-ajv-errors\";\nimport addCustomKeywords from \"./addCustomKeywords\";\nimport getFullSchema from \"./schema/full\";\n\nexport default ({ config, projectRoot }) => {\n const context = { projectRoot };\n const schema = getFullSchema(context);\n\n const ajv = new Ajv({ allErrors: true });\n addFormats(ajv);\n addCustomKeywords(ajv, context);\n const validate = ajv.compile(schema);\n\n if (!validate(config)) {\n const output = betterAjvErrors(schema, config, validate.errors, {\n indent: 2,\n });\n\n throw new Error(\n `todesktop.json invalid. \\nLearn more here: https://www.npmjs.com/package/@todesktop/cli#project-configuration-todesktopjson \\n\\n${output}`\n );\n }\n\n if ((config as any).productName) {\n throw new Error(\n `todesktop.json invalid.\n\nThe \"productName\" property is no longer supported in todesktop.json. Please remove it and add it to your app's package.json instead.\n\nWe made this change because Electron also uses the \"productName\" if it exists in your app's package.json. If you do not add it to your package.json, your app name will default to the value of the \"name\" property in your package.json.`\n );\n }\n};\n", "/*\n See https://ajv.js.org/keywords.html\n*/\nimport Ajv, {\n FuncKeywordDefinition,\n SchemaValidateFunction,\n ValidationError,\n} from \"ajv\";\nimport emailRegex from \"email-regex\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport parseAuthor from \"parse-author\";\nimport * as semver from \"semver\";\nimport validatePackageJSON from \"./validatePackageJSON\";\n\nexport default (ajv: Ajv, context) => {\n const addKeyword = (def: FuncKeywordDefinition) => {\n const validate: SchemaValidateFunction = (schema, data) => {\n try {\n return (def.validate as SchemaValidateFunction)(schema, data);\n } catch (e) {\n if (e instanceof ValidationError) {\n validate.errors = e.errors;\n return false;\n }\n\n throw e;\n }\n };\n\n ajv.addKeyword({ ...def, validate });\n };\n\n // validate that dependencies object doesn't contain packageNames in the blacklist\n addKeyword({\n keyword: \"excludedDependencies\",\n validate: (schema, data) => {\n const matchingPackages = schema.blacklist.filter(\n (packageName) => data[packageName]\n );\n\n if (matchingPackages.length) {\n throw new ValidationError([\n {\n keyword: \"Dependency\",\n message: `${matchingPackages.join(\", \")} should not be in ${\n schema.dependencyKey\n }`,\n instancePath: `/${schema.dependencyKey}`,\n },\n ]);\n }\n\n return true;\n },\n });\n\n // TODO: Remove if isn't used\n addKeyword({\n keyword: \"email\",\n type: \"string\",\n validate: (schema, data) => {\n if (!emailRegex({ exact: true }).test(data)) {\n throw new ValidationError([\n {\n keyword: \"email\",\n message: \"invalid\",\n },\n ]);\n }\n return true;\n },\n });\n\n addKeyword({\n keyword: \"file\",\n type: \"string\",\n validate: (schema, data) => {\n const mustBeDirectory =\n schema.mustBeDirectory || schema.mustBeElectronApp;\n\n // Value is empty\n if (!data.trim().length) {\n if (schema.isOptional) {\n return true;\n }\n\n throw new ValidationError([\n {\n keyword: schema.mustBeDirectory ? \"Directory\" : \"File\",\n message: \"is empty\",\n },\n ]);\n }\n\n const filePath = path.isAbsolute(data)\n ? data\n : path.join(schema.from, data);\n\n // Isn't in project\n if (path.relative(schema.from, filePath).startsWith(\"..\")) {\n throw new ValidationError([\n {\n keyword: mustBeDirectory ? \"Directory\" : \"File\",\n message: `is not in project (${filePath})`,\n },\n ]);\n }\n\n // Extension isn't allowed\n if (\n schema.extensions &&\n !schema.extensions.includes(path.extname(filePath).substr(1))\n ) {\n throw new ValidationError([\n {\n keyword: \"File extension\",\n message: `invalid. ${path.extname(data)} Must be${\n schema.extensions > 1 ? \"one of the following:\" : \"\"\n } \"${schema.extensions.join('\", \"')}\"`,\n },\n ]);\n }\n\n // Doesn't exist\n if (!fs.existsSync(filePath)) {\n throw new ValidationError([\n {\n keyword: mustBeDirectory ? \"Directory\" : \"File\",\n message: `does not exist (${filePath})`,\n },\n ]);\n }\n\n const stats = fs.statSync(filePath);\n\n if (mustBeDirectory && stats.isFile()) {\n throw new ValidationError([\n {\n keyword: \"Directory\",\n message: `must be a directory, not a file (${filePath})`,\n },\n ]);\n } else if (schema.mustBeFile && stats.isDirectory()) {\n throw new ValidationError([\n {\n keyword: \"File\",\n message: `must be a file, not a directory (${filePath})`,\n },\n ]);\n }\n\n if (schema.mustBeElectronApp) {\n const appRoot = path.resolve(filePath);\n const pkgPath = path.join(appRoot, \"package.json\");\n\n if (!fs.existsSync(pkgPath)) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. There is no package.json at ${pkgPath}`,\n },\n ]);\n }\n\n let pkg;\n try {\n pkg = require(pkgPath);\n } catch (e) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. Invalid JSON in package.json (${pkgPath})`,\n },\n ]);\n }\n\n context.projectRoot = appRoot;\n // This throws and bubbles all the way up to the user\n validatePackageJSON(pkg, pkgPath, context);\n\n // Validate that either an index.js or valid \"main\" property exists\n const mainFilePath = pkg.main;\n if (mainFilePath) {\n const resolvedMainFilePath = path.join(appRoot, mainFilePath);\n if (!fs.existsSync(resolvedMainFilePath)) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. The \"main\" file specified in your package.json (${mainFilePath}) does not exist (${resolvedMainFilePath})`,\n },\n ]);\n }\n } else {\n if (!fs.existsSync(path.join(appRoot, \"index.js\"))) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message:\n 'invalid. There is neither a \"main\" property in your package.json nor an index.js at the root of your app',\n },\n ]);\n }\n }\n }\n\n return true;\n },\n errors: true,\n });\n\n addKeyword({\n keyword: \"npmAuthor\",\n validate: (schema, data) => {\n const dataType = typeof data;\n if (dataType === \"undefined\") {\n return true;\n } else if (dataType === \"string\") {\n const parsedAuthor = parseAuthor(data);\n if (!parsedAuthor || !parsedAuthor.email) {\n throw new ValidationError([\n {\n keyword: \"author\",\n message:\n 'invalid. If you\\'re using a string, it must look something like \"Barney Rubble <b@rubble.com>\", see https://docs.npmjs.com/files/package.json#people-fields-author-contributors',\n },\n ]);\n }\n } else if (dataType === \"object\") {\n if (typeof data.name === \"undefined\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `invalid. \"name\" property is missing.`,\n },\n ]);\n } else {\n if (typeof data.name !== \"string\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.name invalid. It must be a string`,\n },\n ]);\n }\n\n if (typeof data.email === \"undefined\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `invalid. \"email\" property is missing.`,\n },\n ]);\n } else {\n if (typeof data.email === \"string\") {\n if (!emailRegex({ exact: true }).test(data.email)) {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.email invalid. It does not look like an email.`,\n },\n ]);\n }\n } else {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.email invalid. It must be a string.`,\n },\n ]);\n }\n }\n }\n } else {\n // Neither object nor string\n throw new ValidationError([\n {\n keyword: \"author\",\n message:\n \"invalid. It must either be an object or string. See https://docs.npmjs.com/files/package.json#people-fields-author-contributors\",\n },\n ]);\n }\n\n return true;\n },\n errors: true,\n });\n\n addKeyword({\n keyword: \"semanticVersion\",\n type: \"string\",\n validate: (schema, data) => {\n const keyword =\n (schema.packageName ? `${schema.packageName} ` : \"\") + \"version\";\n\n if (!(semver.valid(data) || semver.validRange(data))) {\n throw new ValidationError([\n {\n keyword,\n message:\n \"invalid. It must be a semantic version (see https://semver.org/)\",\n },\n ]);\n }\n\n if (\n schema.mustBeExact &&\n (data.startsWith(\"~\") || data.startsWith(\"^\"))\n ) {\n throw new ValidationError([\n {\n keyword,\n message:\n \"invalid. It must be an exact version. Good: 9.0.0. Bad: ^9.0.0\",\n },\n ]);\n }\n return true;\n },\n });\n};\n", "import Ajv from \"ajv\";\nimport addFormats from \"ajv-formats\";\nimport betterAjvErrors from \"better-ajv-errors\";\nimport addCustomKeywords from \"./addCustomKeywords\";\nimport getPackageJsonSchema from \"./schema/packageJSON\";\n\nexport default (pkg, pkgPath, context) => {\n const ajv = new Ajv({ allErrors: true });\n addFormats(ajv);\n addCustomKeywords(ajv, context);\n const schema = getPackageJsonSchema(context);\n const validate = ajv.compile(schema);\n if (!validate(pkg)) {\n const output = betterAjvErrors(schema, pkg, validate.errors, {\n indent: 2,\n });\n\n const error = new Error(`package.json invalid (${pkgPath}); \\n${output}`);\n (error as any).isValidationError = true;\n // This throws and bubbles all the way up to the user\n throw error;\n }\n};\n", "export default (context) => {\n return {\n type: \"object\",\n required: [\n \"author\",\n \"dependencies\",\n \"devDependencies\",\n \"homepage\",\n \"name\",\n \"version\",\n ],\n properties: {\n author: {\n npmAuthor: {},\n },\n dependencies: {\n type: \"object\",\n required: [\"@todesktop/runtime\"],\n // custom keyword that checks package names aren't included in dependencies\n excludedDependencies: {\n dependencyKey: \"dependencies\",\n blacklist: [\"@todesktop/cli\"],\n },\n properties: {\n \"@todesktop/runtime\": {\n type: \"string\",\n },\n },\n },\n devDependencies: {\n type: \"object\",\n required: [\"electron\"],\n properties: {\n electron: {\n type: \"string\",\n semanticVersion: {\n packageName: \"electron\",\n mustBeExact: true,\n },\n },\n },\n },\n name: {\n type: \"string\",\n minLength: 1,\n },\n scripts: {\n type: \"object\",\n properties: {\n \"todesktop:beforeInstall\": {\n type: \"string\",\n file: {\n from: context.projectRoot,\n mustBeFile: true,\n },\n },\n \"todesktop:afterPack\": {\n type: \"string\",\n file: {\n from: context.projectRoot,\n mustBeFile: true,\n },\n },\n },\n },\n version: {\n type: \"string\",\n semanticVersion: {},\n },\n },\n };\n};\n", "const getItemOrArrayOfItemsSchema = (itemSchema) => {\n return {\n oneOf: [\n itemSchema,\n {\n type: \"array\",\n items: itemSchema,\n },\n ],\n };\n};\n\nexport default (context) => {\n const getIconSchema = (additionalAllowedExtensions = []) => {\n return {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"icns\", \"png\", ...additionalAllowedExtensions],\n mustBeFile: true,\n },\n minLength: 3,\n };\n };\n\n return {\n type: \"object\",\n required: [\"id\", \"icon\", \"schemaVersion\"],\n properties: {\n appId: { type: \"string\", minLength: 1 },\n appFiles: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n appProtocolScheme: { type: \"string\", minLength: 1 },\n appPath: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n isOptional: true,\n mustBeElectronApp: true,\n },\n },\n asarUnpack: {\n oneOf: [\n { type: \"boolean\" },\n {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n ],\n },\n copyright: { type: \"string\", minLength: 1 },\n electronMirror: {\n type: \"string\",\n format: \"uri\",\n },\n electronVersion: {\n type: \"string\",\n minLength: 1,\n },\n extraContentFiles: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"from\"],\n properties: {\n from: {\n type: \"string\",\n file: { from: context.projectRoot },\n },\n to: { type: \"string\" },\n },\n },\n },\n extraResources: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"from\"],\n properties: {\n from: {\n type: \"string\",\n file: { from: context.projectRoot },\n },\n to: { type: \"string\" },\n },\n },\n },\n fileAssociations: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"ext\"],\n properties: {\n ext: getItemOrArrayOfItemsSchema({\n type: \"string\",\n minLength: 1,\n }),\n description: {\n type: \"string\",\n minLength: 1,\n },\n name: {\n type: \"string\",\n minLength: 1,\n },\n mimeType: {\n type: \"string\",\n minLength: 1,\n },\n icon: {\n type: \"string\",\n minLength: 1,\n },\n role: {\n type: \"string\",\n minLength: 1,\n },\n isPackage: {\n type: \"boolean\",\n },\n rank: {\n type: \"string\",\n minLength: 1,\n },\n },\n },\n minItems: 1,\n },\n filesForDistribution: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n icon: getIconSchema(),\n linux: {\n type: \"object\",\n properties: {\n category: { type: \"string\", minLength: 1 },\n icon: getIconSchema(),\n noSandbox: { type: \"boolean\" },\n },\n },\n id: { type: \"string\", minLength: 1 },\n mac: {\n type: \"object\",\n properties: {\n category: { type: \"string\", minLength: 1 },\n additionalBinariesToSign: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n entitlements: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"plist\"],\n mustBeFile: true,\n },\n minLength: 1,\n },\n extendInfo: {\n type: \"object\",\n },\n icon: getIconSchema(),\n },\n },\n dmg: {\n type: \"object\",\n properties: {\n background: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"tiff\"],\n mustBeFile: true,\n },\n minLength: 1,\n },\n artifactName: { type: \"string\", minLength: 1 },\n backgroundColor: { type: \"string\", minLength: 1 },\n iconSize: { type: \"number\" },\n iconTextSize: { type: \"number\" },\n title: { type: \"string\", minLength: 1 },\n contents: {\n type: \"array\",\n items: {\n type: \"object\",\n properties: {\n x: { type: \"number\" },\n y: { type: \"number\" },\n },\n },\n },\n window: {\n type: \"object\",\n properties: {\n x: { type: \"number\" },\n y: { type: \"number\" },\n width: { type: \"number\" },\n height: { type: \"number\" },\n },\n },\n },\n },\n schemaVersion: { type: \"number\", minimum: 1, maximum: 1 },\n snap: {\n type: \"object\",\n properties: {\n after: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n appPartStage: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n assumes: getItemOrArrayOfItemsSchema({\n type: \"string\",\n minLength: 1,\n }),\n autoStart: {\n type: \"boolean\",\n },\n buildPackages: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n confinement: {\n type: \"string\",\n enum: [\"classic\", \"devmode\", \"strict\"],\n },\n environment: {\n type: \"object\",\n },\n grade: {\n type: \"string\",\n enum: [\"devel\", \"stable\"],\n },\n layout: {\n type: \"object\",\n },\n plugs: {\n type: \"array\",\n items: {\n anyOf: [\n {\n type: \"string\",\n minLength: 1,\n },\n {\n type: \"object\",\n },\n ],\n },\n },\n stagePackages: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n summary: {\n type: \"string\",\n maxLength: 78,\n },\n useTemplateApp: {\n type: \"boolean\",\n },\n },\n },\n uploadSizeLimit: {\n type: \"number\",\n },\n windows: {\n type: \"object\",\n properties: {\n icon: getIconSchema([\"ico\"]),\n },\n },\n },\n };\n};\n", "import logger from \"../logger\";\nimport loadConfig from \"./loadConfig\";\nimport { resolve } from \"path\";\nimport merge from \"lodash.merge\";\n\nconst computeFullProjectConfig = (partialConfig, projectRoot) => {\n if (!partialConfig.extends) {\n logger.debug(\"No extends field, returning partial config\");\n return partialConfig;\n } else {\n logger.debug(\"Extends field found, resolving\");\n const parentConfigPath = resolve(projectRoot, partialConfig.extends);\n const parentConfig = loadConfig(parentConfigPath);\n const parentFullConfig = computeFullProjectConfig(\n parentConfig,\n projectRoot\n );\n\n const result = merge({}, parentFullConfig, partialConfig);\n\n delete result.extends;\n return result;\n }\n};\n\nexport default computeFullProjectConfig;\n", "import axios from \"axios\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport logger from \"./logger\";\n\nconst { TODESKTOP_CLI_FIREBASE_FUNCTIONS_BASE } = getEnvironmentVariables();\n\nexport default async function (functionName, body = {}, config = {}) {\n logger.debug({ functionName, body, config }, \"postToFirebaseFunction\");\n\n try {\n const response = await axios.post(\n `${TODESKTOP_CLI_FIREBASE_FUNCTIONS_BASE}${functionName}`,\n body,\n config\n );\n\n logger.debug(\n { responseData: response.data },\n \"postToFirebaseFunction: success\"\n );\n return response.data;\n } catch (e) {\n logger.error({ error: e }, \"postToFirebaseFunction: error\");\n throw e;\n }\n}\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async (key, receiver) => {\n const hasResolved = false;\n\n return new Promise<void>((resolve, reject) => {\n logger.debug({ key }, \"subscribeToFirebaseDoc\");\n firestore.doc(key).onSnapshot(\n (snapshot) => {\n receiver({\n snapshot,\n data: snapshot.exists ? snapshot.data() : undefined,\n });\n if (!hasResolved) {\n resolve();\n }\n },\n (err) => {\n reject(err);\n }\n );\n });\n};\n", "import subscribeToFirebaseDoc from \"./subscribeToFirebaseDoc\";\n\nexport default async ({ appId, buildId, onDataReceived, userId }) => {\n try {\n return await subscribeToFirebaseDoc(\n `users/${userId}/applications/${appId}/builds/${buildId}`,\n async ({ data }) => {\n onDataReceived(data);\n }\n );\n } catch (e) {\n e.message = `Failed while subscribing to build; ${e.message}`;\n throw e;\n }\n};\n", "import fastGlob from \"fast-glob\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport generateS3Key from \"./generateS3Key\";\nimport logger from \"./logger\";\nimport uploadToS3 from \"./uploadToS3\";\nimport zip from \"./zip\";\n\nconst getAppFiles = async (globsInput, appPath, appPkgJson) => {\n const globs = [\"!node_modules\", \"!**/node_modules\", \"!.git\", \"!**/.git\"];\n\n if (globsInput && globsInput.length) {\n globs.push(\n ...globsInput,\n path.join(appPath, \"package.json\"),\n path.join(appPath, \"package-lock.json\"),\n path.join(appPath, \"yarn.lock\"),\n path.join(appPath, \"pnpm-lock.yaml\"),\n path.join(appPath, \"shrinkwrap.yaml\")\n );\n } else {\n globs.push(\"**\");\n }\n\n // automatically add hooks to `appFiles` if they exist\n for (const hookName of [\"todesktop:beforeInstall\", \"todesktop:afterPack\"]) {\n if (appPkgJson.scripts && appPkgJson.scripts[hookName]) {\n globs.push(path.join(appPath, appPkgJson.scripts[hookName]));\n }\n }\n\n const normalizedGlobs = globs\n .map((glob) => {\n // Make relative if it's not\n const globToUse = path.isAbsolute(glob)\n ? path.relative(appPath, glob)\n : glob;\n\n return (\n globToUse\n // Globs must always have forward slashes\n .replace(/\\\\/g, \"/\")\n // Remove trailing slash\n .replace(/\\/+$/, \"\")\n );\n })\n .filter((glob) => !glob.startsWith(\"..\") && !glob.startsWith(\"!..\"));\n\n let absolutePaths = await fastGlob(normalizedGlobs, {\n absolute: true,\n cwd: appPath,\n dot: true,\n followSymbolicLinks: false,\n onlyDirectories: false,\n onlyFiles: true,\n globstar: true,\n unique: true,\n });\n\n if (process.platform === \"win32\") {\n absolutePaths = absolutePaths.map((absolutePath) =>\n absolutePath.replace(/\\//g, path.sep)\n );\n }\n\n if (!absolutePaths || !absolutePaths.length) {\n throw new Error(\"No files found to upload\");\n } else if (\n !absolutePaths.filter((absolutePath) => absolutePath.endsWith(\".js\")).length\n ) {\n throw new Error(\n `No .js files found to upload (${absolutePaths[0]}). There's likely an issue with the appFiles option. Learn more at https://www.npmjs.com/package/@todesktop/cli#appfiles----optional-array-of-glob-patterns. If this is not the case, please contact us.`\n );\n } else {\n let mainFilePath = appPath;\n if (appPkgJson.main) {\n mainFilePath = path.join(mainFilePath, appPkgJson.main);\n }\n\n if (fs.statSync(mainFilePath).isDirectory()) {\n mainFilePath = path.join(mainFilePath, \"index.js\");\n }\n\n // Make sure the \"main\" file is included\n if (!absolutePaths.includes(mainFilePath)) {\n throw new Error(\n `The \"main\" file specified in your package.json (${\n appPkgJson.main\n ? path.relative(appPath, mainFilePath)\n : \"defaults to index.js\"\n }) is not set to be uploaded to our servers. This is likely due to how you have configured the \\`appFiles\\` option. Learn more at https://www.npmjs.com/package/@todesktop/cli#appfiles----optional-array-of-glob-patterns. If this is not the case, please contact us.`\n );\n }\n }\n\n return absolutePaths.map((absolutePath) => {\n return {\n from: absolutePath,\n to: path.join(\"app\", path.relative(appPath, absolutePath)),\n };\n });\n};\n\nexport default async ({ appId, appPkgJson, buildId, config, onProgress }) => {\n logger.debug(\n {\n appId,\n appPkgJson,\n buildId,\n config,\n onProgress,\n },\n \"uploadApplicationSource\"\n );\n // eslint-disable-next-line no-unused-vars,@typescript-eslint/no-unused-vars\n let totalBytes = 0;\n\n const files = [\n /*\n App files (stored in app/ in the ZIP)\n */\n ...(await getAppFiles(config.appFiles, config.appPath, appPkgJson)),\n\n /*\n Optional extra content files (stored in extraContentFiles/ in the ZIP). Their\n paths within is the their relative path from the project root so\n there will be no issues with clashing filenames. We also don't\n also any file paths in our todesktop.json that are outside of the\n project directory\n */\n ...(config.extraContentFiles || []).map(({ from, to = \".\" }) => {\n return {\n from,\n to: path.join(\"extraContentFiles\", to, path.basename(from)),\n };\n }),\n\n /*\n Optional extra resources (stored in extraResources/ in the ZIP).\n Similar to extra content files above\n */\n ...(config.extraResources || []).map(({ from, to = \".\" }) => {\n return {\n from,\n to: path.join(\"extraResources\", to, path.basename(from)),\n };\n }),\n\n /*\n Icons (more may be added below)\n */\n {\n from: config.icon,\n to: path.join(\"icons\", \"appIcon\" + path.extname(config.icon)),\n },\n ];\n\n if (config.linux) {\n if (config.linux.icon) {\n files.push({\n from: config.linux.icon,\n to: path.join(\n \"icons\",\n \"appIcon-linux\" + path.extname(config.linux.icon)\n ),\n });\n }\n }\n\n if (config.mac) {\n if (config.mac.entitlements) {\n files.push({\n from: config.mac.entitlements,\n to: path.join(\"other\", \"mac\", \"entitlements.mac.plist\"),\n });\n }\n\n if (config.mac.icon) {\n files.push({\n from: config.mac.icon,\n to: path.join(\"icons\", \"appIcon-mac\" + path.extname(config.mac.icon)),\n });\n }\n }\n\n if (config.dmg) {\n if (config.dmg.background) {\n files.push({\n from: config.dmg.background,\n to: path.join(\"other\", \"mac\", \"dmg-background.tiff\"),\n });\n }\n }\n\n if (config.windows) {\n if (config.windows.icon) {\n files.push({\n from: config.windows.icon,\n to: path.join(\n \"icons\",\n \"appIcon-windows\" + path.extname(config.windows.icon)\n ),\n });\n }\n }\n\n return uploadToS3({\n bucket: config.bucket || undefined,\n inputStream: await zip({\n files,\n fileSizeLimit: config.uploadSizeLimit,\n onError: (e) => {\n throw e;\n },\n onProgress({ fs }) {\n totalBytes = fs.totalBytes;\n },\n appPkgJson,\n }),\n key: generateS3Key({\n appId,\n buildId,\n filenameSuffix: `${appPkgJson.name}.zip`,\n }),\n onProgress({ loaded, total }) {\n onProgress((loaded / total) * 100, loaded);\n },\n });\n};\n", "export default ({ appId, buildId, filenameSuffix }) =>\n `${appId}/sourceArchives/${buildId}--${filenameSuffix}`;\n", "import superagent from \"superagent\";\nimport util from \"util\";\nimport streamToArray from \"stream-to-array\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport logger from \"./logger\";\nimport getCallableFirebaseFunction from \"./getCallableFirebaseFunction\";\n\nconst { TODESKTOP_CLI_S3_BUCKET } = getEnvironmentVariables();\n\nexport default async ({\n bucket = TODESKTOP_CLI_S3_BUCKET,\n inputStream,\n key,\n onProgress = () => {},\n}: {\n bucket?: string;\n inputStream;\n key: string;\n onProgress: (event: { loaded: number; total: number }) => void;\n}) => {\n const { data } = await getCallableFirebaseFunction(\"getSignedURL\")({\n key,\n });\n const body = await new Promise((resolve) => {\n streamToArray(inputStream).then(function (parts) {\n const buffers = parts.map((part) =>\n util.isBuffer(part) ? part : Buffer.from(part)\n );\n return resolve(Buffer.concat(buffers));\n });\n });\n\n return new Promise((resolve) => {\n superagent\n .put(data.signedURL)\n .send(body)\n .set(\"content-type\", \"application/zip\")\n .on(\"progress\", (event) => onProgress(event))\n .end(() => {\n logger.debug({ bucket, key, url: data.uploadURL }, \"uploadToS3\");\n resolve({ bucket, key, url: data.uploadURL });\n });\n\n return { bucket, key, url: data.uploadURL };\n });\n};\n", "import archiver from \"archiver\";\nimport du from \"du\";\nimport fs from \"fs\";\nimport chalk from \"chalk\";\nimport logger from \"./logger\";\nimport path from \"path\";\n\nexport default async function ({\n files,\n fileSizeLimit = 20,\n onError,\n onProgress,\n appPkgJson,\n}) {\n logger.debug({ files }, \"zip\");\n const stream = archiver(\"zip\");\n\n // good practice to catch warnings (ie stat failures and other non-blocking errors)\n stream.on(\"warning\", function (err) {\n if (err.code === \"ENOENT\") {\n console.warn(err);\n logger.warn({ err }, \"zip: stream warning ENOENT\");\n } else {\n // throw error\n onError(err);\n }\n });\n\n // good practice to catch this error explicitly\n stream.on(\"error\", function (err) {\n onError(err);\n });\n\n // Grab the file size and more\n const processedFiles = await Promise.all(\n files.map(async (file) => {\n const stats = fs.lstatSync(file.from);\n const isDirectory = stats.isDirectory();\n\n return {\n ...file,\n isDirectory,\n stats,\n size: isDirectory ? await du(file.from) : stats.size,\n };\n })\n );\n\n const totalFileSize = processedFiles.reduce((sum, b) => sum + b.size, 0);\n // Does file size sum exceed limit?\n if (totalFileSize > fileSizeLimit * 1000000) {\n onError(\n new Error(\n [\n `\\n\\nYour app is larger than ${fileSizeLimit}MB. Your app is ${chalk.bold.red.underline(\n (totalFileSize / 1000000).toFixed(1) + \"MB\"\n )}.\\n`,\n `You may be including unnecessary files in your app(see the \\`appPath\\` and \\`appFiles\\` options).`,\n `If not, this limit can be raised by setting the \\`uploadSizeLimit\\` option.`,\n `Learn more at https://www.npmjs.com/package/@todesktop/cli#uploadsizelimit---optional-number`,\n ].join(\"\\n\")\n )\n );\n return stream;\n }\n\n // Add the files to the ZIP\n processedFiles.forEach(({ from, isDirectory, stats, to }) => {\n if (isDirectory) {\n stream.directory(from, to);\n } else if (appPkgJson && to === path.join(\"app\", \"package.json\")) {\n stream.append(JSON.stringify(appPkgJson), {\n name: to,\n });\n } else {\n stream.file(from, { name: to, mode: stats.mode });\n }\n });\n\n // finalize the archive (ie we are done appending files but streams have to finish yet)\n // 'close', 'end' or 'finish' may be fired right after calling this method so register to them beforehand\n stream.finalize();\n\n stream.on(\"progress\", (progress) =>\n onProgress({\n ...progress,\n percentage: (progress.entries.processed / progress.entries.total) * 100,\n })\n );\n\n return stream;\n}\n", "import merge from \"lodash.merge\";\nimport path from \"path\";\nimport readJson from \"./readJson\";\n\nfunction deleteNullDeps(dep) {\n Object.keys(dep).forEach((key) => {\n if (dep[key] === null) {\n delete dep[key];\n }\n });\n return dep;\n}\n\n/**\n * Remove any dependencies or devDependencies that have a version of null.\n * This is useful for removing dependencies that are not to be used when building\n * in ToDesktop. For example this will remove the `electron-builder` dev dependency\n * from the package.json file when building in ToDesktop:\n * {\n * \"devDependencies\": {\n * \"electron-builder\": null\n * }\n * }\n */\nfunction removeNullDependencies(pkgJson) {\n const { dependencies, devDependencies } = pkgJson;\n\n if (dependencies) {\n pkgJson.dependencies = deleteNullDeps(dependencies);\n }\n\n if (devDependencies) {\n pkgJson.devDependencies = deleteNullDeps(devDependencies);\n }\n\n return pkgJson;\n}\n\nfunction getAppPkgJson({ config }) {\n const packageJsonFromConfig = config.packageJson || {};\n const extendsFrom = packageJsonFromConfig.extends || \"package.json\";\n const packageJsonFromFile = readJson(path.join(config.appPath, extendsFrom));\n\n return removeNullDependencies(\n merge({}, packageJsonFromFile, packageJsonFromConfig)\n );\n}\n\nexport default getAppPkgJson;\n", "// X build has failed, should we exit? I.e. is it settled?\nexport default (build) => {\n const hasBuildSettled = [\"linux\", \"mac\", \"windows\"].every(\n (platform) =>\n build[platform].shouldSkip ||\n \"succeeded\" === build[platform].status ||\n (\"failed\" === build[platform].status &&\n build[platform].numberOfAttemptedBuilds === 2)\n );\n\n const hasSettledWithError = [\"linux\", \"mac\", \"windows\"].some(\n (platform) => \"failed\" === build[platform].status\n );\n\n return hasBuildSettled && hasSettledWithError;\n};\n", "import { useState } from \"react\";\n\n/*\n This should be called at the top of all commands to test if React\n is OK and if not, to exit cleanly.\n\n If React throws an error (e.g. when there are multiple versions of\n React in the customer's dependency tree), then we need to exit with\n a non-zero error code and not with an uncaught exception somewhere.\n\n These parameters exist only to make things more testable\n*/\nexport default ({ cons = console, proc = process } = {}) => {\n try {\n useState(null);\n } catch (e) {\n cons.error(e);\n proc.exit(1);\n }\n};\n", "import { Text, useStdin } from \"ink\";\nimport { useState, useEffect } from \"react\";\nimport PropTypes from \"prop-types\";\nimport isCi from \"is-ci\";\n\n// components\nimport Login from \"./Login\";\n\n// logic\nimport { signInWithCustomToken } from \"../utilities/firestore\";\nimport { getAuthConfig, setAuthConfig } from \"../utilities/configStore\";\nimport postToFirebaseFunction from \"../utilities/postToFirebaseFunction\";\nimport getEnvironmentVariables from \"../utilities/getEnvironmentVariables\";\nimport ErrorDisplay from \"./ErrorDisplay\";\n\nconst LoginHOC = ({ children, isInteractive = true }) => {\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n const [isEffectDone, setEffectDone] = useState(false);\n const [error, setError] = useState(null);\n const { isRawModeSupported } = useStdin();\n\n const onFailure = (message, err = {}) => {\n setError({\n ...err,\n message,\n });\n };\n\n // use effect for determining if tokens exist and are valid\n useEffect(() => {\n async function isAccessTokenValid() {\n const { accessToken, email, jwtToken } = getAuthConfig();\n let userCreds = null;\n\n const { TODESKTOP_ACCESS_TOKEN, TODESKTOP_EMAIL } =\n getEnvironmentVariables();\n\n // 1. attempt log in with environment variables if present\n try {\n if (TODESKTOP_ACCESS_TOKEN && TODESKTOP_EMAIL) {\n const newJwtToken = await postToFirebaseFunction(\n \"loginWithAccessToken\",\n {\n email: TODESKTOP_EMAIL,\n accessToken: TODESKTOP_ACCESS_TOKEN,\n }\n );\n\n if (newJwtToken) {\n userCreds = await signInWithCustomToken(newJwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n // if no environment variables set and is in a CI, set alert message and exit\n } else if (!isRawModeSupported || isCi) {\n onFailure(\n \"ToDesktop environment variables not found. When automating builds with your CI provider, you need to specify environment variables for TODESKTOP_EMAIL and TODESKTOP_ACCESS_TOKEN.\"\n );\n }\n } catch (err) {\n // print error and stop the app execution if env variables attempted\n onFailure(\"Log in with environment variables failed.\", err);\n }\n\n // 2. attempt log in with jwtToken if present\n try {\n if (!userCreds && jwtToken) {\n userCreds = await signInWithCustomToken(jwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n } catch (err) {\n // do nothing, attempt login with accessToken and email\n }\n\n // 3. attempt log in with accessToken and email on disk\n try {\n if (!userCreds && accessToken && email) {\n const newJwtToken = await postToFirebaseFunction(\n \"loginWithAccessToken\",\n { email, accessToken }\n );\n\n if (newJwtToken) {\n userCreds = await signInWithCustomToken(newJwtToken);\n setAuthConfig(email, accessToken, newJwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n }\n } catch (err) {\n // do nothing: no error state and not logged in state means render login\n }\n\n setEffectDone(true);\n }\n\n isAccessTokenValid();\n }, []);\n\n if (error && isInteractive) {\n return <ErrorDisplay error={error} />;\n }\n\n if (!isEffectDone) {\n return <Text>...</Text>;\n }\n\n if (!isLoggedIn && isInteractive) {\n return <Login setIsLoggedIn={setIsLoggedIn} />;\n }\n\n return <>{children}</>;\n};\n\nLoginHOC.propTypes = {\n children: PropTypes.object,\n isInteractive: PropTypes.bool,\n};\n\nexport default LoginHOC;\n", "// modules\nimport { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useState } from \"react\";\nimport { Form, Field } from \"react-final-form\";\n\n// components\nimport TextInput from \"./TextInput\";\nimport ErrorDisplay from \"./ErrorDisplay\";\n\n// logic\nimport postToFirebaseFunction from \"../utilities/postToFirebaseFunction\";\nimport { signInWithCustomToken } from \"../utilities/firestore\";\nimport { setAuthConfig } from \"../utilities/configStore\";\n\nconst loginFields = [\n {\n name: \"email\",\n label: \"Your email\",\n placeholder: \"name@email.com\",\n Input: TextInput,\n validate: (value) => {\n if (!value) return \"Required\";\n },\n },\n {\n name: \"accessToken\",\n label: \"Your access token\",\n placeholder: \"********\",\n Input: TextInput,\n validate: (value) => {\n if (!value) return \"Required\";\n },\n mask: \"*\",\n },\n];\n\nconst Login = ({ setIsLoggedIn }) => {\n const [activeField, setActiveField] = useState(0);\n const [error, setError] = useState(null);\n const [failureMessage, setFailureMessage] = useState(null);\n const [isSubmittingForm, setIsSubmittingForm] = useState(false);\n\n const onFailure = (message) => {\n setIsSubmittingForm(false);\n setFailureMessage(message);\n setActiveField(0);\n };\n\n // login handler that verifies accessToken and email with that in firebase\n const onSubmitLogin = async ({ email, accessToken }) => {\n setFailureMessage(null);\n setIsSubmittingForm(true);\n\n try {\n const jwtToken = await postToFirebaseFunction(\"loginWithAccessToken\", {\n email,\n accessToken,\n });\n\n if (jwtToken) {\n await signInWithCustomToken(jwtToken);\n setAuthConfig(email, accessToken, jwtToken);\n setIsLoggedIn(true);\n } else {\n onFailure(\"Incorrrect credentials. Try again\");\n }\n } catch (err) {\n if (err.code === 500) {\n setError(err);\n } else {\n onFailure(`Login unsuccessful: ${err.message}`);\n }\n }\n };\n\n if (error) return <ErrorDisplay error={error} />;\n\n return (\n <>\n <Text>You are not currently logged in.</Text>\n <Text>Log in below:</Text>\n <Box marginBottom={1} />\n <Form onSubmit={onSubmitLogin}>\n {({ handleSubmit, validating }) => (\n <Box flexDirection=\"column\">\n {loginFields.map(\n ({ name, label, placeholder, validate, Input, mask }, index) => (\n <Field name={name} key={name} validate={validate}>\n {({ input, meta }) => (\n <Box flexDirection=\"column\">\n {activeField >= index ? (\n <Box>\n <Text bold={activeField === index}>{label}: </Text>\n {activeField === index ? (\n <Input\n {...input}\n mask={mask}\n placeholder={placeholder}\n onSubmit={() => {\n if (meta.valid && !validating) {\n setActiveField((value) => value + 1); // go to next field\n if (activeField === loginFields.length - 1) {\n // last field, so submit\n handleSubmit();\n }\n } else {\n input.onBlur(); // mark as touched to show error\n }\n }}\n />\n ) : (\n (input.value && (\n <Text>\n {name === \"accessToken\"\n ? input.value.replace(/./gi, \"*\")\n : input.value}\n </Text>\n )) ||\n (placeholder && (\n <Text color=\"gray\">{placeholder}</Text>\n ))\n )}\n {meta.invalid && meta.touched && (\n <Box marginLeft={2} marginRight={1}>\n <Text color=\"red\">\u2716</Text>\n </Box>\n )}\n {meta.error && meta.touched && (\n <Error errorMessage={meta.error} />\n )}\n </Box>\n ) : null}\n </Box>\n )}\n </Field>\n )\n )}\n </Box>\n )}\n </Form>\n\n {isSubmittingForm && (\n <Box marginTop={1}>\n <Text>Logging in...</Text>\n </Box>\n )}\n\n {failureMessage && <Error errorMessage={failureMessage} marginTop />}\n </>\n );\n};\n\nconst Error = ({ errorMessage, marginTop }) => (\n <Box marginTop={marginTop ? 1 : 0}>\n <Text color=\"red\">{errorMessage}</Text>\n </Box>\n);\n\nError.propTypes = {\n errorMessage: PropTypes.string.isRequired,\n marginTop: PropTypes.bool,\n};\n\nLogin.propTypes = {\n setIsLoggedIn: PropTypes.func.isRequired,\n};\n\nexport default Login;\n", "import InkTextInput from \"ink-text-input\";\nimport React from \"react\";\n\nconst TextInput = ({ onBlur, onFocus, ...props }: TextInputProps) => {\n React.useEffect(() => {\n onFocus();\n return onBlur;\n }, [onFocus, onBlur]);\n return <InkTextInput {...props} showCursor />;\n};\n\nexport default TextInput;\n\ntype InkTextInputProps = React.ComponentProps<typeof InkTextInput>;\ninterface TextInputProps extends InkTextInputProps {\n onBlur: () => void;\n onFocus: () => void;\n}\n", "import React, { ReactNode } from \"react\";\nimport * as Sentry from \"@sentry/node\";\n\nclass ErrorBoundary extends React.Component<\n { children: ReactNode },\n { error?: Error; eventId?: string }\n> {\n constructor(props) {\n super(props);\n this.state = { eventId: null, error: null };\n }\n\n static getDerivedStateFromError(error) {\n return { error };\n }\n\n componentDidCatch(error, errorInfo) {\n Sentry.withScope((scope) => {\n scope.setExtras(errorInfo);\n const eventId = Sentry.captureException(error);\n this.setState({ eventId });\n });\n }\n\n render() {\n if (this.state.error) {\n throw this.state.error;\n }\n return this.props.children;\n }\n}\n\nexport default ErrorBoundary;\n", "import { Box, Text, useStdin } from \"ink\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport CancelBuild from \"./CancelBuild\";\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport CustomSelectInputItem from \"./CustomSelectInputItem\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport ViewBuild from \"./ViewBuild\";\nimport { isBuildCancellable, isBuildRunning } from \"../utilities/buildStatus\";\nimport firestore from \"../utilities/firestore\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logger from \"../utilities/logger\";\nimport useInput from \"../utilities/useInput\";\nimport useExit from \"../utilities/useExit\";\nimport isCi from \"is-ci\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst OngoingBuildGuard = ({ children, commandUsed, configPath }) => {\n const { isRawModeSupported } = useStdin();\n const onInput = useInput();\n const exit = useExit();\n const [{ appId, builds, error, isLoading, itemChosen }, setState] = useState({\n appId: null,\n builds: [],\n error: null,\n isLoading: true,\n itemChosen: null,\n });\n\n useEffect(() => {\n if (!isLoading) {\n return;\n }\n\n (async () => {\n try {\n const applicationId = getProjectConfig(configPath).config.id;\n const { id } = await findAppUserId(applicationId);\n\n const buildsResult = await firestore\n .doc(`users/${id}/applications/${applicationId}`)\n .collection(\"builds\")\n .orderBy(\"createdAt\", \"desc\")\n .limit(10)\n .get();\n\n const stateUpdates = {\n appId: applicationId,\n isLoading: false,\n builds: [],\n };\n\n if (!buildsResult.empty) {\n const latestBuild = buildsResult.docs[0].data();\n const isRunning =\n isBuildRunning(latestBuild) && latestBuild.status !== \"preparation\";\n logger.debug(\n { isRunning },\n \"OngoingBuildGuard component: got latest build\"\n );\n\n stateUpdates.builds = buildsResult.docs\n .map((doc) => doc.data())\n .filter((build) => {\n if (isBuildRunning(build) && build.status !== \"preparation\") {\n return true;\n }\n return false;\n });\n }\n\n setState((previousState) => ({\n ...previousState,\n ...stateUpdates,\n }));\n } catch (e) {\n setState((previousState) => ({\n ...previousState,\n error: e,\n }));\n }\n })();\n }, [builds, itemChosen, isLoading, isRawModeSupported]);\n\n /*\n Because we're using <SelectInput/>, we need to explicitly handle when\n ctrl+c is pressed. `onInput` takes care of that.\n See https://github.com/vadimdemedes/pastel/issues/38\n */\n if (isRawModeSupported) {\n // Input causes an error on if stdin does not support raw mode\n onInput(() => {});\n }\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (isLoading) {\n return <Text>...</Text>;\n }\n\n if (itemChosen) {\n logger.debug({ itemChosen }, \"OngoingBuildGuard component: item chosen\");\n const build = builds.find(Boolean);\n\n if (itemChosen.value === \"view\") {\n return <ViewBuild commandUsed={commandUsed} id={build.id} />;\n } else if (itemChosen.value === \"cancel\") {\n return (\n <CancelBuild appId={appId} commandUsed={commandUsed} id={build.id}>\n {children}\n </CancelBuild>\n );\n } else if (itemChosen.value === \"concurrent\") {\n return <>{children}</>;\n } else {\n setTimeout(exit, 10);\n }\n }\n\n if (builds.length && isCi === false && isRawModeSupported) {\n const latestBuild = builds.find(Boolean);\n const multiple = builds.length > 1;\n\n const items = [\n {\n label: `View ${multiple ? \"latest\" : \"it\"}`,\n value: \"view\",\n },\n ];\n\n if (builds.some((build) => isBuildCancellable(build))) {\n items.push({\n label: `Cancel ${multiple ? \"latest\" : \"it\"} and start a new build`,\n value: \"cancel\",\n });\n\n items.push({\n label: \"Start a concurrent build\",\n value: \"concurrent\",\n });\n }\n\n items.push({\n label: \"Exit\",\n value: \"exit\",\n });\n const handleSelect = (itemChosen) =>\n setState((previousState) => ({ ...previousState, itemChosen }));\n\n return (\n <>\n <Box marginBottom={1}>\n <Text bold>\n {multiple\n ? \"There are ongoing builds \"\n : \"There is an ongoing build \"}\n </Text>\n <Text>\n ({latestBuild.appName}\n {latestBuild.appVersion ? ` v${latestBuild.appVersion}` : \"\"})\n </Text>\n </Box>\n <SelectInput\n indicatorComponent={CustomSelectInputIndicator}\n itemComponent={CustomSelectInputItem}\n items={items}\n onSelect={handleSelect}\n />\n </>\n );\n } else {\n return <>{children}</>;\n }\n};\n\nOngoingBuildGuard.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n children: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n configPath: PropTypes.string,\n};\n\nexport default OngoingBuildGuard;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst CustomSelectInputIndicator = ({ isSelected, ...props }) => (\n <Box marginRight={1} {...props}>\n <Text>{isSelected ? (process.platform === \"win32\" ? \">\" : \"\u276F\") : \" \"}</Text>\n </Box>\n);\n\nCustomSelectInputIndicator.propTypes = {\n isSelected: PropTypes.bool.isRequired,\n};\n\nexport default CustomSelectInputIndicator;\n", "import { Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst CustomSelectInputItem = ({ isSelected, label, ...props }) => (\n <Text bold={isSelected} color={isSelected ? undefined : \"gray\"} {...props}>\n {label}\n </Text>\n);\n\nCustomSelectInputItem.propTypes = {\n isSelected: PropTypes.bool.isRequired,\n label: PropTypes.string.isRequired,\n};\n\nexport default CustomSelectInputItem;\n", "// libs\nimport { Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\n\n// components\nimport BuildProgress from \"./BuildProgress\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport MainLayout from \"./MainLayout\";\n\n// utils\nimport getLatestBuildId from \"../utilities/getLatestBuildId\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logForCI from \"../utilities/logForCI\";\nimport shouldExitOnBuildFailure from \"../utilities/shouldExitOnBuildFailure\";\nimport subscribeToBuild from \"../utilities/subscribeToBuild\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst ViewBuild = ({ commandUsed, id, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n arbitraryMessageComponent,\n build,\n error,\n hasBuildEverFailed,\n isLoading,\n },\n setState,\n ] = useState({\n appId: null,\n arbitraryMessageComponent: null,\n build: null,\n error: null,\n hasBuildEverFailed: false,\n isLoading: true,\n });\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n let firebaseUnsubscribe;\n\n async function viewBuild() {\n let config;\n try {\n // This will throw if validation fails:\n config = getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const { id: userId } = await findAppUserId(config.id);\n\n const subscribe = (buildId) => {\n subscribeToBuild({\n appId: config.id,\n buildId,\n onDataReceived: (data) => {\n if (!data) {\n onError(\n new Error(\n `No such build exists (${buildId}). Please contact us if this is an error`\n )\n );\n }\n setState((prevState) => ({\n ...prevState,\n appId: config.id,\n build: data,\n isLoading: false,\n }));\n },\n userId,\n })\n .then((firebaseUnsubscribeResult) => {\n firebaseUnsubscribe = firebaseUnsubscribeResult;\n })\n .catch(onError);\n };\n\n if (id) {\n subscribe(id);\n } else {\n getLatestBuildId({ appId: config.id, userId })\n .catch(onError)\n .then((latestBuildId) => {\n if (!latestBuildId) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: <Text>There are no builds yet</Text>,\n }));\n return;\n }\n return subscribe(latestBuildId);\n });\n }\n }\n\n viewBuild();\n\n return () => {\n if (firebaseUnsubscribe) {\n firebaseUnsubscribe();\n }\n };\n }, [id]);\n\n // Exit if the build has errored and settled\n useEffect(() => {\n if (hasBuildEverFailed && shouldExitOnBuildFailure(build)) {\n setTimeout(() => exit(new Error(\"Build has failed\")), 10);\n }\n }, [build, exit, hasBuildEverFailed]);\n\n // Exit once an arbitrary message exists\n useEffect(() => {\n if (arbitraryMessageComponent) {\n setTimeout(() => exit(new Error(\"Validation failed\")), 10);\n }\n }, [arbitraryMessageComponent, exit]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (isLoading) {\n return <Text>Loading...</Text>;\n }\n\n const onBuildFailure = () => {\n if (hasBuildEverFailed) {\n return;\n }\n setState((prevState) => ({\n ...prevState,\n hasBuildEverFailed: true,\n }));\n };\n\n return (\n <MainLayout\n appId={appId}\n appName={build.appName}\n appVersion={build.appVersion}\n build={build}\n commandUsed={commandUsed}\n hasBuildEverFailed={hasBuildEverFailed}\n >\n <BuildProgress build={build} onBuildFailure={onBuildFailure} />\n </MainLayout>\n );\n};\n\nViewBuild.propTypes = {\n id: (props, propName, componentName) => {\n if ([props.id, props.shouldViewLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldViewLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.id;\n if (![\"string\", \"undefined\"].includes(type)) {\n return new Error(\n `'id' is a '${type}', not a string, in '${componentName}'.`\n );\n }\n },\n commandUsed: PropTypes.string.isRequired,\n shouldViewLatest: (props, propName, componentName) => {\n if ([props.id, props.shouldViewLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldViewLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.shouldViewLatest;\n if (![\"boolean\", \"undefined\"].includes(type)) {\n return new Error(\n `'shouldViewLatest' is a '${type}', not a boolean, in '${componentName}'.`\n );\n }\n },\n configPath: PropTypes.string,\n};\n\nexport default ViewBuild;\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({ appId, userId }) => {\n logger.debug({ appId }, \"getLatestBuildId\");\n const appRef = firestore.doc(`users/${userId}/applications/${appId}`);\n const appSnapshot = await appRef.get();\n\n if (!appSnapshot.exists) {\n throw new Error(`Application with ID of ${appId} doesn't exist.`);\n }\n\n const buildsResult = await appRef\n .collection(\"builds\")\n .orderBy(\"createdAt\", \"desc\")\n .limit(1)\n .get();\n\n if (buildsResult.empty) {\n return null;\n } else {\n return buildsResult.docs[0].id;\n }\n};\n", "import firestore, { currentUser } from \"./firestore\";\n\nconst getCollection = (collectionRef) => {\n return collectionRef.get().then((resp) => {\n const result = [];\n resp.forEach((doc) => result.push(doc.data()));\n return result;\n });\n};\n\nconst acceptedUsersCollection = (id) =>\n firestore.collection(`users/${id}/acceptedUsers`);\n\nconst findAppUserId = async (appId) => {\n const { uid, email } = currentUser();\n const acceptedUsers = await getCollection(acceptedUsersCollection(uid));\n const primaryUser = { id: uid, label: email };\n\n const users = [\n primaryUser,\n ...acceptedUsers.map((user) => ({ id: user.id, label: user.email })),\n ];\n\n for (const user of users) {\n try {\n const doc = await firestore\n .doc(`users/${user.id}/applications/${appId}`)\n .get();\n\n if (doc.exists) return user;\n } catch (err) {\n // will throw an error if user doesn't have access\n }\n }\n\n return primaryUser;\n};\n\nexport default findAppUserId;\n", "import { useEffect, useState } from \"react\";\n\nimport { onUserAuth } from \"./firestore\";\nimport { identify, track, ANALYTICS_EVENT } from \"./analytics\";\nimport logger from \"./logger\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\n\nexport const useAnalyticsCommand = (\n command,\n flags: any = {},\n properties = {}\n) => {\n const [hasAttemptedTracking, setTrackingAttempt] = useState(false);\n\n logger.info({ command, flags, properties }, \"useAnalyticsCommand\");\n\n try {\n if (flags.projectPath) {\n properties = {\n ...properties,\n ...getProjectConfig(),\n };\n }\n } catch (err) {\n // do nothing\n }\n\n useEffect(() => {\n const authUnsubscribe = onUserAuth(async (user) => {\n /**\n * Only identify if there's a user id (stops use of anon id).\n * Subsequent track callback will thus always be tied to a user.\n */\n if (user.uid) {\n identify(\n user.uid,\n {\n email: user.email,\n displayName: user.displayName,\n },\n () => {\n track(\n ANALYTICS_EVENT.CLI_COMMAND,\n {\n ...properties,\n flags,\n command,\n },\n () => setTrackingAttempt(true)\n );\n authUnsubscribe && authUnsubscribe();\n }\n );\n }\n });\n\n // if it takes longer than 5 secs to identify a user, just set the\n // tracking attempt to true so that other commands aren't waiting\n // forever to terminate (see whoami component)\n setTimeout(() => setTrackingAttempt(true), 5000);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); // leave empty - this should only ever execute once (on mount)\n\n return { hasAttemptedTracking };\n};\n", "import Build from \"../components/Build\";\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport OngoingBuildGuard from \"../components/OngoingBuildGuard\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst BuildCommand = ({\n shouldCodeSign = true,\n configPath = null,\n}: {\n shouldCodeSign?: boolean;\n configPath?: string;\n}) => {\n checkIfReactIsUsable();\n\n useAnalyticsCommand(\"build\", {\n codeSign: shouldCodeSign,\n config: configPath,\n });\n\n const commandUsed = \"todesktop build\";\n\n return (\n <ErrorBoundary>\n <LoginHOC>\n <OngoingBuildGuard configPath={configPath} commandUsed={commandUsed}>\n <Build\n commandUsed={commandUsed}\n shouldCodeSign={shouldCodeSign}\n configPath={configPath}\n />\n </OngoingBuildGuard>\n </LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default BuildCommand;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport Table from \"./Table\";\nimport capitalize from \"../utilities/capitalize\";\nimport getBuilds from \"../utilities/getBuilds\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport getRelativeDateFromDateString from \"../utilities/getRelativeDateFromDateString\";\nimport logForCI from \"../utilities/logForCI\";\nimport useInput from \"../utilities/useInput\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\nimport SyntaxHighlight from \"./SyntaxHighlight\";\n\nconst ViewBuilds = ({\n commandUsed,\n configPath,\n count,\n format,\n exit: shouldExitAfterViewingBuilds = false,\n}) => {\n const exit = useExit();\n const [\n {\n builds,\n error,\n hasMoreToLoad,\n isInitialLoadComplete,\n isLoading,\n projectConfig,\n startAfter,\n user,\n },\n setState,\n ] = useState({\n builds: [],\n error: null,\n hasMoreToLoad: true,\n isInitialLoadComplete: false,\n isLoading: false,\n projectConfig: null,\n startAfter: null,\n user: null,\n });\n\n const onInput = useInput();\n\n onInput((input, key) => {\n if (key.escape) {\n exit();\n }\n\n if (input === \" \" || key.downArrow || key.pageDown || key.return) {\n if (!isInitialLoadComplete || !hasMoreToLoad) {\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n startAfter: builds[builds.length - 1].createdAt,\n }));\n }\n });\n\n useEffect(() => {\n async function viewBuilds() {\n if (\n error ||\n isLoading ||\n (isInitialLoadComplete && (!hasMoreToLoad || !startAfter))\n ) {\n return;\n }\n\n if (![\"table\", \"json\"].includes(format)) {\n setState((previousState) => ({\n ...previousState,\n error: new Error(\n `Invalid output format \"${format}\". Valid formats are \"table\" and \"json\".`\n ),\n }));\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n isLoading: true,\n }));\n\n let config;\n try {\n // This will throw if validation fails:\n config = projectConfig || getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const pageSize = count || 5;\n const user = await findAppUserId(config.id);\n\n getBuilds({\n appId: config.id,\n limit: pageSize + 1,\n startAfter,\n userId: user.id,\n })\n .then((buildsResult) => {\n setState((previousState) => {\n const stateUpdates = {\n builds: [],\n hasMoreToLoad: buildsResult.length > pageSize,\n isInitialLoadComplete: true,\n isLoading: false,\n projectConfig: config,\n startAfter: null,\n user,\n };\n\n if (buildsResult.length) {\n stateUpdates.builds = [\n ...previousState.builds,\n ...buildsResult.slice(0, pageSize),\n ];\n }\n return {\n ...previousState,\n ...stateUpdates,\n };\n });\n })\n .catch((e) => {\n logForCI(e);\n setState((previousState) => ({\n ...previousState,\n error: e,\n isLoading: false,\n }));\n });\n }\n\n viewBuilds();\n }, [\n error,\n hasMoreToLoad,\n isInitialLoadComplete,\n isLoading,\n projectConfig,\n startAfter,\n ]);\n\n // Exit once all are loaded\n useEffect(() => {\n if (!hasMoreToLoad) {\n setTimeout(exit, 10);\n }\n }, [exit, hasMoreToLoad]);\n\n // Exit the process once the initial build data has been displayed if user has set the `--exit` flag\n useEffect(() => {\n if (!isLoading && isInitialLoadComplete && shouldExitAfterViewingBuilds) {\n setTimeout(exit, 10);\n }\n }, [exit, isLoading, shouldExitAfterViewingBuilds, isInitialLoadComplete]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (!isInitialLoadComplete) {\n return <Text>Loading...</Text>;\n }\n\n if (builds.length) {\n const formatData = (builds) =>\n builds.map((build) => ({\n ID: build.id,\n Version: build.appVersion || \"n/a\",\n \"Creation date\": getRelativeDateFromDateString(build.createdAt),\n Status: capitalize(build.status),\n \"Release date\": build.releasedAt\n ? getRelativeDateFromDateString(build.releasedAt)\n : \"Unreleased\",\n Owner: user ? user.label : \"unknown\",\n }));\n\n const getCellTextProps = ({ key, props, value }) => {\n const result = { ...props };\n\n if (key === \"Status\") {\n const status = value.toLowerCase();\n if (status === \"succeeded\") {\n result.color = \"green\";\n } else if (status === \"failed\") {\n result.color = \"red\";\n } else if (status === \"cancelled\") {\n result.dimColor = true;\n }\n } else if (key === \"Version\" && value.toLowerCase() === \"n/a\") {\n result.dimColor = true;\n } else if (\n key === \"Release date\" &&\n value.toLowerCase() === \"unreleased\"\n ) {\n result.dimColor = true;\n }\n\n return result;\n };\n\n const removeAppBuilderLibConfig = (builds) => {\n // Remove the appBuilderLib config from the builds because it's difficult to display\n // and not very useful to the user.\n return builds.map((build) => {\n if (build.mac && build.mac.appBuilderLibConfig) {\n delete build.mac.appBuilderLibConfig;\n }\n if (build.windows && build.windows.appBuilderLibConfig) {\n delete build.windows.appBuilderLibConfig;\n }\n if (build.linux && build.linux.appBuilderLibConfig) {\n delete build.linux.appBuilderLibConfig;\n }\n return build;\n });\n };\n\n return (\n <>\n {format === \"table\" ? (\n <Table\n getCellTextProps={getCellTextProps}\n data={formatData(builds)}\n />\n ) : null}\n {format === \"json\" ? (\n <SyntaxHighlight\n code={JSON.stringify(removeAppBuilderLibConfig(builds), null, 2)}\n language=\"JSON\"\n />\n ) : null}\n {!shouldExitAfterViewingBuilds && builds.length > 0 ? (\n <Box>\n <Text color=\"gray\" dimColor>\n {isLoading\n ? \"Loading more...\"\n : hasMoreToLoad\n ? `Showing the latest ${builds.length} builds. Press space/down to load more.`\n : `Showing all (${builds.length}) builds`}\n </Text>\n </Box>\n ) : null}\n </>\n );\n } else {\n return <Text>There are no builds yet</Text>;\n }\n};\n\nViewBuilds.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n configPath: PropTypes.string,\n count: PropTypes.number,\n format: PropTypes.string,\n exit: PropTypes.bool,\n};\n\nexport default ViewBuilds;\n", "import { Box } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport TableEnd from \"./TableEnd\";\nimport TableHead from \"./TableHead\";\nimport TableBody from \"./TableBody\";\nimport getKeyDetails from \"../utilities/getKeyDetails\";\n\n/*\n This component prints (the array of objects given) in a table.\n The array must not be empty.\n The keys are used as headers.\n Column widths are based on the longest value (object key or value).\n It is assumed that the same keys exist in all items.\n*/\nconst Table = ({ data, getCellTextProps }) => {\n const keyDetails = getKeyDetails(data);\n\n return (\n <Box flexDirection=\"column\">\n <TableHead keyDetails={keyDetails} />\n <TableBody\n data={data}\n getCellTextProps={getCellTextProps}\n keyDetails={keyDetails}\n />\n <TableEnd keyDetails={keyDetails} />\n </Box>\n );\n};\n\nTable.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n getCellTextProps: PropTypes.func,\n};\n\nexport default Table;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\n/*\n See Table component\n*/\nconst TableEnd = ({ keyDetails, ...props }) => {\n let content = \"\u2514\";\n content += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u2534\");\n content += \"\u2518\";\n\n return (\n <Box {...props}>\n <Text>{content}</Text>\n </Box>\n );\n};\n\nTableEnd.propTypes = {\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableEnd;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { Fragment } from \"react\";\n\n/*\n See Table component\n*/\nconst TableHead = ({ keyDetails, ...props }) => {\n let topLine = \"\u250C\";\n topLine += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u252C\");\n topLine += \"\u2510\";\n\n const contentLineElements = Object.values(keyDetails).map(\n ({ key, width }, index) => {\n return (\n <Fragment key={key}>\n {index > 0 ? <Text> \u2502 </Text> : null}\n <Box width={width}>\n <Text bold>{key}</Text>\n </Box>\n </Fragment>\n );\n }\n );\n\n return (\n <Box flexDirection=\"column\" {...props}>\n <Box>\n <Text>{topLine}</Text>\n </Box>\n <Box>\n <Box>\n <Text>\u2502 </Text>\n {contentLineElements}\n <Text> \u2502</Text>\n </Box>\n </Box>\n </Box>\n );\n};\n\nTableHead.propTypes = {\n bottomLinePrefix: PropTypes.string,\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableHead;\n", "import PropTypes from \"prop-types\";\nimport TableRow from \"./TableRow\";\n\n/*\n See Table component\n*/\nconst TableBody = ({ data, getCellTextProps, keyDetails }) => {\n return (\n <>\n {data.map((rowData, index) => (\n <TableRow\n data={rowData}\n getCellTextProps={getCellTextProps}\n key={index}\n keyDetails={keyDetails}\n />\n ))}\n </>\n );\n};\n\nTableBody.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n getCellTextProps: PropTypes.func,\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableBody;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\n/*\n See Table component\n*/\nconst TableRow = ({\n data,\n getCellTextProps = ({ props }) => props,\n keyDetails,\n textProps = {},\n}: {\n data: object;\n getCellTextProps?: (...args: any[]) => any;\n keyDetails: object;\n textProps?: object;\n}) => {\n let topLine = \"\u251C\";\n topLine += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u253C\");\n topLine += \"\u2524\";\n\n const content = (\n <>\n <Text>\u2502 </Text>\n {Object.entries(data).map(([key, value], index) => {\n return (\n <Box key={key}>\n {index > 0 ? <Text> \u2502 </Text> : null}\n <Box width={keyDetails[key].width}>\n <Text\n {...getCellTextProps({\n key,\n props: textProps,\n rowData: data,\n value,\n })}\n >\n {value}\n </Text>\n </Box>\n </Box>\n );\n })}\n <Text> \u2502</Text>\n </>\n );\n\n return (\n <>\n <Box flexDirection=\"column\">\n <Text>{topLine}</Text>\n <Box>{content}</Box>\n </Box>\n </>\n );\n};\n\nTableRow.propTypes = {\n data: PropTypes.object.isRequired,\n getCellTextProps: PropTypes.func,\n keyDetails: PropTypes.object.isRequired,\n textProps: PropTypes.object,\n};\n\nexport default TableRow;\n", "// This is used to get the column widths for tables\nexport default (data) => {\n const result = {};\n Object.keys(data[0]).forEach((key) => {\n result[key] = {\n key,\n width: Math.max(\n key.length,\n data.map((item) => item[key].toString().length).sort((a, b) => b - a)[0]\n ),\n };\n });\n return result;\n};\n", "export default (input) => {\n if (typeof input !== \"string\") {\n return \"\";\n }\n return input.charAt(0).toUpperCase() + input.slice(1);\n};\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({\n addWhereClauses = (query) => query,\n userId,\n appId,\n limit = 5,\n startAfter = null,\n}) => {\n logger.debug({ appId, limit, startAfter }, \"getBuilds\");\n const appRef = firestore.doc(`users/${userId}/applications/${appId}`);\n const appSnapshot = await appRef.get();\n\n if (!appSnapshot.exists) {\n throw new Error(`Application with ID of ${appId} doesn't exist.`);\n }\n\n let query = addWhereClauses(appRef.collection(\"builds\")).orderBy(\n \"createdAt\",\n \"desc\"\n );\n\n if (startAfter) {\n query = query.startAfter(startAfter);\n }\n\n const buildsResult = await query.limit(limit).get();\n\n if (buildsResult.empty) {\n return [];\n }\n\n return buildsResult.docs.map((doc) => doc.data());\n};\n", "import * as dateFns from \"date-fns\";\n\nexport default (input) =>\n dateFns.formatDistance(new Date(input), new Date()) + \" ago\";\n", "import * as React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { Text } from \"ink\";\nimport { highlight } from \"cli-highlight\";\n\nconst SyntaxHighlight = ({ code, language }) => {\n const highlightedCode = React.useMemo(() => {\n return highlight(code, { language });\n }, [code, language]);\n\n return <Text>{highlightedCode}</Text>;\n};\n\nSyntaxHighlight.propTypes = {\n code: PropTypes.string.isRequired,\n language: PropTypes.string,\n};\n\nexport default SyntaxHighlight;\n", "import checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport ViewBuild from \"../components/ViewBuild\";\nimport ViewBuilds from \"../components/ViewBuilds\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst BuildsCommand = ({\n id,\n shouldViewLatest,\n configPath = null,\n count,\n format = \"table\",\n exit,\n}: {\n id?: string;\n shouldViewLatest?: boolean;\n configPath?: string;\n count?: number;\n format?: \"table\" | \"json\";\n exit?: boolean;\n}) => {\n checkIfReactIsUsable();\n useAnalyticsCommand(\"builds\", {\n id,\n shouldViewLatest,\n configPath,\n count,\n format,\n exit,\n });\n\n const getContents = () => {\n let commandUsed = \"todesktop builds\";\n if (id) {\n commandUsed += \" <id>\";\n return (\n <ViewBuild commandUsed={commandUsed} id={id} configPath={configPath} />\n );\n } else if (shouldViewLatest) {\n commandUsed += \" --latest\";\n return (\n <ViewBuild\n commandUsed={commandUsed}\n shouldViewLatest={true}\n configPath={configPath}\n />\n );\n } else {\n return (\n <ViewBuilds\n commandUsed={commandUsed}\n configPath={configPath}\n count={count}\n format={format}\n exit={exit}\n />\n );\n }\n };\n\n return (\n <ErrorBoundary>\n <LoginHOC>{getContents()}</LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default BuildsCommand;\n", "import { useEffect } from \"react\";\nimport { Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport { deleteAuthConfig } from \"../utilities/configStore\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\nimport useExit from \"../utilities/useExit\";\n\nconst Logout = () => {\n const exit = useExit();\n const { hasAttemptedTracking } = useAnalyticsCommand(\"logout\");\n\n checkIfReactIsUsable();\n // delete auth config deletes the credentials stored on disk\n deleteAuthConfig();\n\n // exits the program once tracking of the \"logout\" command has been attempted\n useEffect(() => {\n if (hasAttemptedTracking) {\n exit();\n }\n }, [exit, hasAttemptedTracking]);\n\n return <Text>Log out successful</Text>;\n};\n\nconst LogoutWrapper = () => {\n return (\n <ErrorBoundary>\n <LoginHOC isInteractive={false}>\n <Logout />\n </LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default LogoutWrapper;\n", "import { Box, Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport ReleaseBuild from \"../components/ReleaseBuild\";\nimport PickBuildForRelease from \"../components/PickBuildForRelease\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst ReleaseCommand = ({\n id,\n force,\n shouldReleaseLatest,\n configPath,\n}: {\n id?: string;\n force?: boolean;\n shouldReleaseLatest?: boolean;\n configPath?: string;\n}) => {\n checkIfReactIsUsable();\n useAnalyticsCommand(\"release\", {\n id,\n force,\n shouldReleaseLatest,\n config: configPath,\n });\n\n // TODO: remove some time in the future\n if (id && id.startsWith(\".\")) {\n return (\n <>\n <Box>\n <Text bold color=\"red\">\n todesktop release <project-path>\n </Text>\n <Text> is no longer supported. Run this instead:</Text>\n </Box>\n <Text bold color=\"greenBright\">\n todesktop build && todesktop release --latest --force\n </Text>\n </>\n );\n }\n\n const getContents = () => {\n if (id) {\n return (\n <ReleaseBuild\n configPath={configPath}\n commandUsed=\"todesktop release <id>\"\n id={id}\n shouldConfirm={!force}\n />\n );\n } else if (shouldReleaseLatest) {\n return (\n <ReleaseBuild\n configPath={configPath}\n commandUsed=\"todesktop release --latest\"\n shouldReleaseLatest={true}\n shouldConfirm={!force}\n />\n );\n } else {\n return (\n <PickBuildForRelease\n configPath={configPath}\n commandUsed=\"todesktop builds\"\n shouldConfirm={!force}\n />\n );\n }\n };\n\n return (\n <ErrorBoundary>\n <LoginHOC>{getContents()}</LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default ReleaseCommand;\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\n\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport CustomSelectInputItem from \"./CustomSelectInputItem\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport getBuildById from \"../utilities/getBuildById\";\nimport getCallableFirebaseFunction from \"../utilities/getCallableFirebaseFunction\";\nimport getLatestBuildId from \"../utilities/getLatestBuildId\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst getValidationErrorMessageDisplay = (build, validationMessage) => {\n return (\n <Box flexDirection=\"column\">\n <Text bold color=\"red\">\n Can't release {build.appName} v{build.appVersion}\n </Text>\n\n <Box marginBottom={1} marginTop={1}>\n <Text>{validationMessage}</Text>\n </Box>\n\n <Text bold>See web UI for more information: </Text>\n <Text>\n <Link fallback={false} url={build.url}>\n {build.url}\n </Link>\n </Text>\n </Box>\n );\n};\n\nconst ReleaseBuild = ({ commandUsed, id, shouldConfirm, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n arbitraryMessageComponent,\n build,\n error,\n hasConfirmed,\n hasBeenValidatedSuccesfully,\n isComplete,\n isReleasing,\n },\n setState,\n ] = useState({\n appId: null,\n build: null,\n error: null,\n hasConfirmed: false,\n hasBeenValidatedSuccesfully: false,\n isComplete: false,\n isReleasing: false,\n arbitraryMessageComponent: null,\n });\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n async function releaseBuild() {\n if (build) {\n return;\n }\n\n // This will throw if validation fails:\n const config = getProjectConfig(configPath).config;\n const appId = config.id;\n\n const { id: userId } = await findAppUserId(appId);\n\n const loadBuild = (buildId) => {\n getBuildById({ appId, buildId, userId })\n .then((buildResult) => {\n if (!buildResult) {\n throw new Error(\n `No such build ${buildId} for application ${appId}`\n );\n }\n\n setState((previousState) => ({\n ...previousState,\n appId,\n build: buildResult,\n }));\n })\n .catch(onError);\n };\n\n if (id) {\n loadBuild(id);\n } else {\n getLatestBuildId({ appId, userId })\n .catch(onError)\n .then((buildId) => {\n if (!buildId) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: <Text>There are no builds yet</Text>,\n }));\n return;\n }\n return loadBuild(buildId);\n });\n }\n }\n\n releaseBuild();\n }, [build, id]);\n\n useEffect(() => {\n if (!build || hasBeenValidatedSuccesfully || arbitraryMessageComponent) {\n return;\n }\n\n let validationMessage;\n if (build.releasedAt) {\n validationMessage = `It has already been released.`;\n } else if (build.status !== \"succeeded\") {\n validationMessage = `The build must have completed successfully. Actual build status: ${build.status}`;\n }\n\n if (validationMessage) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: getValidationErrorMessageDisplay(\n build,\n validationMessage\n ),\n hasBeenValidatedSuccesfully: false,\n }));\n } else {\n setState((previousState) => ({\n ...previousState,\n hasBeenValidatedSuccesfully: true,\n }));\n }\n }, [arbitraryMessageComponent, build, hasBeenValidatedSuccesfully]);\n\n useEffect(() => {\n if (\n !hasBeenValidatedSuccesfully ||\n (shouldConfirm && !hasConfirmed) ||\n isReleasing ||\n isComplete\n ) {\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n isReleasing: true,\n }));\n\n getCallableFirebaseFunction(\"releaseBuild\")({\n appId,\n buildId: build.id,\n })\n .then(() => {\n logForCI(\"Released!\");\n setState((previousState) => ({\n ...previousState,\n isReleasing: false,\n isComplete: true,\n }));\n })\n .catch((e) => {\n if ([\"failed-precondition\", \"not-found\"].includes(e.code)) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: getValidationErrorMessageDisplay(\n build,\n e.message\n ),\n isReleasing: false,\n }));\n } else {\n onError(new Error(\"Unexpected internal error while releasing build\"));\n }\n });\n }, [\n appId,\n build,\n hasConfirmed,\n hasBeenValidatedSuccesfully,\n id,\n isComplete,\n isReleasing,\n shouldConfirm,\n ]);\n\n // Exit once complete\n useEffect(() => {\n if (isComplete) {\n setTimeout(exit, 10);\n return;\n }\n if (arbitraryMessageComponent) {\n setTimeout(() => exit(new Error(\"Validation failed\")), 10);\n }\n }, [arbitraryMessageComponent, exit, isComplete]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (hasBeenValidatedSuccesfully && shouldConfirm && !hasConfirmed) {\n const items = [\n {\n label: \"Yes\",\n value: \"yes\",\n },\n {\n label: \"No\",\n value: \"no\",\n },\n ];\n const onSubmit = (item) => {\n if (item.value === \"no\") {\n setTimeout(exit, 10);\n return;\n }\n setState((previousState) => ({\n ...previousState,\n hasConfirmed: true,\n }));\n };\n return (\n <Box flexDirection=\"column\">\n <Box>\n <Text>This will release build {build.id} as </Text>\n <Text bold>\n {build.appName} v{build.appVersion}\n </Text>\n <Text>, are you sure?</Text>\n </Box>\n\n <Box marginBottom={1} marginTop={1}>\n <SelectInput\n indicatorComponent={CustomSelectInputIndicator}\n initialIndex={1}\n itemComponent={CustomSelectInputItem}\n items={items}\n onSelect={onSubmit}\n />\n </Box>\n\n <Text dimColor>\n Your users will be auto-updated to this version. You can use --force\n to bypass this confirmation in future\n </Text>\n </Box>\n );\n }\n\n if (isReleasing) {\n return <Text>Releasing...</Text>;\n }\n\n if (isComplete) {\n return (\n <Text bold color=\"greenBright\">\n Released!\n </Text>\n );\n }\n\n return <Text>...</Text>;\n};\n\nReleaseBuild.propTypes = {\n id: (props, propName, componentName) => {\n if ([props.id, props.shouldReleaseLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldReleaseLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.id;\n if (![\"string\", \"undefined\"].includes(type)) {\n return new Error(\n `'id' is a '${type}', not a string, in '${componentName}'.`\n );\n }\n },\n commandUsed: PropTypes.string.isRequired,\n shouldReleaseLatest: (props, propName, componentName) => {\n if ([props.id, props.shouldReleaseLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldReleaseLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.shouldReleaseLatest;\n if (![\"boolean\", \"undefined\"].includes(type)) {\n return new Error(\n `'shouldReleaseLatest' is a '${type}', not a boolean, in '${componentName}'.`\n );\n }\n },\n shouldConfirm: PropTypes.bool.isRequired,\n configPath: PropTypes.string,\n};\n\nexport default ReleaseBuild;\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({ appId, buildId, userId }) => {\n logger.debug({ appId, buildId }, \"getBuildById\");\n const snapshot = await firestore\n .doc(`users/${userId}/applications/${appId}/builds/${buildId}`)\n .get();\n\n if (!snapshot.exists) {\n return null;\n }\n\n return snapshot.data();\n};\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport ReleaseBuild from \"./ReleaseBuild\";\nimport SelectTable from \"./SelectTable\";\nimport getBuilds from \"../utilities/getBuilds\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport getRelativeDateFromDateString from \"../utilities/getRelativeDateFromDateString\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport useInput from \"../utilities/useInput\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst PickBuildForRelease = ({ commandUsed, shouldConfirm, configPath }) => {\n const exit = useExit();\n const [{ error, builds, chosenBuildId, isLoading, user }, setState] =\n useState({\n error: null,\n builds: null,\n chosenBuildId: null,\n isLoading: true,\n user: null,\n });\n\n const onInput = useInput();\n\n useEffect(() => {\n async function pickBuildForRelease() {\n if (builds) {\n return;\n }\n\n let config;\n try {\n // This will throw if validation fails:\n config = getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const user = await findAppUserId(config.id);\n\n getBuilds({\n addWhereClauses: (query) => query.where(\"status\", \"==\", \"succeeded\"),\n appId: config.id,\n limit: 50,\n userId: user.id,\n })\n .then((buildsResult) => {\n setState((previousState) => ({\n ...previousState,\n user,\n builds: buildsResult\n .filter((buildResult) => !buildResult.releasedAt)\n .slice(0, 5),\n isLoading: false,\n }));\n })\n .catch((e) => {\n logForCI(e);\n setState((previousState) => ({\n ...previousState,\n error: e,\n isLoading: false,\n }));\n });\n }\n\n pickBuildForRelease();\n }, [builds]);\n\n onInput((input, key) => {\n if (!builds || !builds.length || chosenBuildId) {\n return;\n }\n\n if (key.escape) {\n exit();\n }\n });\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (isLoading) {\n return <Text>Loading...</Text>;\n }\n\n if (chosenBuildId) {\n return (\n <ReleaseBuild\n commandUsed={commandUsed}\n id={chosenBuildId}\n shouldConfirm={shouldConfirm}\n />\n );\n }\n\n if (builds.length) {\n const data = builds.map((build) => ({\n ID: build.id,\n Version: build.appVersion || \"unknown\",\n \"Creation date\": getRelativeDateFromDateString(build.createdAt),\n Owner: user ? user.label : \"unknown\",\n }));\n\n const onSelect = (item) =>\n setState((previousState) => ({\n ...previousState,\n chosenBuildId: item.value.ID,\n }));\n\n return (\n <>\n <Box>\n <Text>Which build would you like to release?</Text>\n </Box>\n <SelectTable data={data} onSelect={onSelect} />\n <Box>\n <Text dimColor>\n Showing the latest {builds.length} unreleased successful builds\n </Text>\n </Box>\n </>\n );\n } else {\n return (\n <Box>\n <Text>No elligible builds found </Text>\n <Text dimColor>(i.e. unreleased and successful)</Text>\n </Box>\n );\n }\n};\n\nPickBuildForRelease.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n shouldConfirm: PropTypes.bool.isRequired,\n configPath: PropTypes.string,\n};\n\nexport default PickBuildForRelease;\n", "import { Box } from \"ink\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport TableEnd from \"./TableEnd\";\nimport TableHead from \"./TableHead\";\nimport TableRow from \"./TableRow\";\nimport getKeyDetails from \"../utilities/getKeyDetails\";\n\nconst CustomIndicator = (props) => (\n <CustomSelectInputIndicator marginTop={1} {...props} />\n);\n\n/*\n This is like if <Table/> and ink-select-input had a baby.\n Read the block comment at the top of <Table/> first.\n*/\nconst SelectTable = ({ data, onSelect }) => {\n const keyDetails = getKeyDetails(data);\n\n const getSelectItems = () => {\n return data.map((rowData, index) => {\n return {\n index,\n key: index,\n value: rowData,\n };\n });\n };\n\n const ItemComponent = ({\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n label, // Make it compatible to SelectInput type, not used actually\n index,\n isSelected,\n }: {\n label: string;\n index?: number;\n isSelected?: boolean;\n }) => {\n return (\n <TableRow\n data={data[index]}\n key={index}\n keyDetails={keyDetails}\n textProps={{ bold: isSelected, color: isSelected ? undefined : \"gray\" }}\n />\n );\n };\n\n return (\n <Box flexDirection=\"column\">\n <TableHead keyDetails={keyDetails} marginLeft={2} />\n <SelectInput\n indicatorComponent={CustomIndicator}\n itemComponent={ItemComponent}\n items={getSelectItems()}\n onSelect={onSelect}\n />\n <TableEnd keyDetails={keyDetails} marginLeft={2} />\n </Box>\n );\n};\n\nSelectTable.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n onSelect: PropTypes.func,\n};\n\nexport default SelectTable;\n", "import { useEffect } from \"react\";\nimport { Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport { getAuthConfig } from \"../utilities/configStore\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\nimport useExit from \"../utilities/useExit\";\n\nconst WhoAmI = () => {\n const exit = useExit();\n checkIfReactIsUsable();\n const auth = getAuthConfig();\n const { hasAttemptedTracking } = useAnalyticsCommand(\"whoami\", {}, {});\n\n // exits the program once tracking of the \"whoami\" command has been attempted\n useEffect(() => {\n if (hasAttemptedTracking) {\n exit();\n }\n }, [exit, hasAttemptedTracking]);\n\n if (!auth || !auth.email) {\n return <Text>{\"You're not signed in\"}</Text>;\n }\n return <Text>{auth.email}</Text>;\n};\n\nconst WhoAmIWrapper = () => (\n <ErrorBoundary>\n <LoginHOC isInteractive={false}>\n <WhoAmI />\n </LoginHOC>\n </ErrorBoundary>\n);\n\nexport default WhoAmIWrapper;\n", "import chalk from \"chalk\";\nimport isInstalledGlobally from \"is-installed-globally\";\nimport latestVersion from \"latest-version\";\nimport semver from \"semver\";\nimport getToDesktopPackageJson from \"./getToDesktopPackageJson\";\n\nexport default () => {\n // Ignore during tests\n if (process.env.AVA_PATH) {\n return;\n }\n\n const pkg = getToDesktopPackageJson();\n latestVersion(pkg.name).then((latest) => {\n if (semver.gt(latest, pkg.version)) {\n const commandToUpdate = chalk.greenBright(\n `npm install ${\n isInstalledGlobally ? \"--location=global\" : \"--save-dev\"\n } @todesktop/cli`\n );\n console.log(\n `Your version of @todesktop/cli is out of date.\\nRun ${commandToUpdate} to update to v${latest}.`\n );\n if (!semver.satisfies(latest, `^${pkg.version}`)) {\n console.log(`CLI is exiting because it is out out of date.`);\n process.exit(1);\n }\n }\n });\n};\n", "import * as Sentry from \"@sentry/node\";\nimport os from \"os\";\nimport pkgJson from \"../../package.json\";\nimport { getAuthConfig } from \"./configStore\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nexport default () => {\n const { TODESKTOP_CLI_SENTRY_DSN } = getEnvironmentVariables();\n if (!TODESKTOP_CLI_SENTRY_DSN) {\n // Don't initialise Sentry\n return;\n }\n Sentry.init({\n dsn: TODESKTOP_CLI_SENTRY_DSN,\n });\n Sentry.configureScope((scope) => {\n try {\n scope.setUser({ email: getAuthConfig().email as string });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"os\", {\n name: os.platform(),\n version: os.release(),\n });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"runtime\", {\n name: \"Node.js\",\n version: process.version,\n });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"app\", {\n app_name: pkgJson.name,\n app_version: pkgJson.version,\n });\n } catch (err) {\n // nothing\n }\n try {\n const configResult = getProjectConfig();\n scope.setExtra(\"config\", configResult);\n } catch (err) {\n // nothing\n }\n });\n};\n", "import exitIfCLIOutOfDate from \"./exitIfCLIOutOfDate\";\nimport initSentry from \"./initSentry\";\n\nexport default ({ sentry = true, exitIfOutOfDate = true } = {}) => {\n if (sentry) {\n initSentry();\n }\n\n if (exitIfOutOfDate) {\n exitIfCLIOutOfDate();\n }\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_ink", "import_react", "import_react", "import_prop_types", "import_ink", "import_prop_types", "import_react", "import_ink", "bunyan", "args", "isCi", "dotenv", "path", "firebase", "fs", "Conf", "xdgBasedir", "del", "pkgUp", "environmentVariables", "Analytics", "os", "uuidv4", "resolve", "import_path", "path", "Link", "PropTypes", "import_prop_types", "import_ink", "import_ink_link", "import_path", "import_jsx_runtime", "path", "Link", "PropTypes", "import_jsx_runtime", "throttle", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_ink", "import_jsx_runtime", "import_jsx_runtime", "Gradient", "PropTypes", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_jsx_runtime", "import_ink", "import_is_ci", "import_react", "import_ink", "import_react", "firebase", "import_jsx_runtime", "import_ink", "import_ink_link", "import_prop_types", "import_jsx_runtime", "Link", "PropTypes", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_is_ci", "import_ink", "isCi", "import_jsx_runtime", "isCi", "import_path", "path", "config", "import_ajv", "import_ajv_formats", "import_better_ajv_errors", "import_ajv", "fs", "path", "Ajv", "addFormats", "betterAjvErrors", "emailRegex", "parseAuthor", "config", "Ajv", "addFormats", "betterAjvErrors", "import_path", "import_lodash", "merge", "findUp", "config", "config", "axios", "resolve", "fs", "path", "resolve", "streamToArray", "util", "superagent", "import_fs", "import_path", "archiver", "fs", "du", "chalk", "path", "fastGlob", "config", "fs", "import_lodash", "import_path", "config", "path", "merge", "config", "prettyBytes", "import_jsx_runtime", "error", "PropTypes", "import_react", "import_ink", "import_react", "import_prop_types", "import_is_ci", "import_ink", "import_prop_types", "import_react", "import_react", "import_jsx_runtime", "React", "InkTextInput", "import_jsx_runtime", "message", "Error", "PropTypes", "import_jsx_runtime", "message", "isCi", "PropTypes", "import_react", "Sentry", "React", "import_ink", "import_prop_types", "import_react", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "error", "config", "PropTypes", "import_is_ci", "import_jsx_runtime", "isCi", "itemChosen", "SelectInput", "PropTypes", "import_react", "import_jsx_runtime", "import_ink", "import_prop_types", "import_react", "import_ink", "import_prop_types", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "PropTypes", "import_prop_types", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_jsx_runtime", "PropTypes", "import_jsx_runtime", "PropTypes", "
|
|
3
|
+
"sources": ["../src/index.ts", "../src/components/Build.tsx", "../src/components/BuildProgress.tsx", "../src/components/BuildCompleteMessage.tsx", "../src/utilities/logForCI.ts", "../src/utilities/logger.ts", "../src/utilities/useExit.ts", "../src/utilities/analytics.ts", "../src/utilities/getEnvironmentVariables.ts", "../src/utilities/firestore.ts", "../src/utilities/configStore.ts", "../src/utilities/getToDesktopPackageJson.ts", "../src/utilities/readJson.ts", "../src/utilities/getCliVersion.ts", "../src/components/PlatformProgress.tsx", "../src/utilities/buildStatus.ts", "../src/components/ErrorDisplay.tsx", "../src/components/Preparation.tsx", "../src/components/ProgressBar.tsx", "../src/libs/ink-progress-bar/index.tsx", "../src/components/InitialLoadingState.tsx", "../src/components/MainLayout.tsx", "../src/components/CancelBuild.tsx", "../src/utilities/getCallableFirebaseFunction.ts", "../src/components/Footer.tsx", "../src/components/Header.tsx", "../src/utilities/useInput.ts", "../src/utilities/runBuild.ts", "../src/utilities/getVersionControlInfo.ts", "../src/utilities/projectConfig/getProjectConfig.ts", "../src/utilities/projectConfig/loadConfig.ts", "../src/utilities/projectConfig/resolveConfigPaths.ts", "../src/utilities/projectConfig/validateConfig.ts", "../src/utilities/projectConfig/addCustomKeywords.ts", "../src/utilities/projectConfig/validatePackageJSON.ts", "../src/utilities/projectConfig/schema/packageJSON.ts", "../src/utilities/projectConfig/schema/full.ts", "../src/utilities/projectConfig/computeFullProjectConfig.ts", "../src/utilities/postToFirebaseFunction.ts", "../src/utilities/subscribeToFirebaseDoc.ts", "../src/utilities/subscribeToBuild.ts", "../src/utilities/uploadApplicationSource.ts", "../src/utilities/generateS3Key.ts", "../src/utilities/uploadToS3.ts", "../src/utilities/zip.ts", "../src/utilities/getPackageJson.ts", "../src/utilities/shouldExitOnBuildFailure.ts", "../src/utilities/checkIfReactIsUsable.ts", "../src/components/LoginHOC.tsx", "../src/components/Login.tsx", "../src/components/TextInput.tsx", "../src/components/LoadingText.tsx", "../src/components/ErrorBoundary.tsx", "../src/components/OngoingBuildGuard.tsx", "../src/components/CustomSelectInputIndicator.tsx", "../src/components/CustomSelectInputItem.tsx", "../src/components/ViewBuild.tsx", "../src/utilities/getLatestBuildId.ts", "../src/utilities/findAppUserId.ts", "../src/utilities/useAnalytics.ts", "../src/commands/BuildCommand.tsx", "../src/components/ViewBuilds.tsx", "../src/components/Table.tsx", "../src/components/TableEnd.tsx", "../src/components/TableHead.tsx", "../src/components/TableBody.tsx", "../src/components/TableRow.tsx", "../src/utilities/getKeyDetails.ts", "../src/utilities/capitalize.ts", "../src/utilities/getBuilds.ts", "../src/utilities/getRelativeDateFromDateString.ts", "../src/components/SyntaxHighlight.tsx", "../src/commands/BuildsCommand.tsx", "../src/commands/LogoutCommand.tsx", "../src/commands/ReleaseCommand.tsx", "../src/components/ReleaseBuild.tsx", "../src/utilities/getBuildById.ts", "../src/components/PickBuildForRelease.tsx", "../src/components/SelectTable.tsx", "../src/commands/WhoamiCommand.tsx", "../src/utilities/exitIfCLIOutOfDate.ts", "../src/utilities/initSentry.ts", "../src/utilities/onCommand.ts"],
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\nimport { InvalidArgumentError, Option, program } from \"commander\";\nimport { render } from \"ink\";\nimport { FC, createElement } from \"react\";\nimport \"source-map-support/register\";\n\nimport BuildCommand from \"./commands/BuildCommand\";\nimport BuildsCommand from \"./commands/BuildsCommand\";\nimport LogoutCommand from \"./commands/LogoutCommand\";\nimport ReleaseCommand from \"./commands/ReleaseCommand\";\nimport WhoamiCommand from \"./commands/WhoamiCommand\";\nimport getCliVersion from \"./utilities/getCliVersion\";\nimport onCommand from \"./utilities/onCommand\";\n\nconst parseCount = (value) => {\n const parsedValue = Number.parseInt(value, 10);\n if (parsedValue > 0) {\n return parsedValue;\n }\n\n throw new InvalidArgumentError(\"Should be a positive number\");\n};\n\nprogram.name(\"todekstop\").version(getCliVersion());\n\nprogram\n .command(\"build\")\n .description(\n \"Build an Electron app with native installers, code signing baked-in, \" +\n \"etc. but without releasing it (existing users won't get an auto-update). \" +\n \"For quicker builds, you can append `--code-sign=false` to disable\" +\n \"code-signing and notarization.\"\n )\n .option(\n \"--code-sign [bool]\",\n \"Whether or not code-signing and notarization should be performed. \" +\n \"Disable this for quicker builds\"\n )\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .action(({ codeSign, config }) => {\n runCommand(BuildCommand, {\n shouldCodeSign: codeSign,\n configPath: config,\n });\n });\n\nprogram\n .command(\"builds\")\n .description(\"View your builds\")\n .argument(\"[id]\", \"View a specific build by ID\")\n .option(\"--latest\", \"View the latest build\")\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .option(\"--count [number]\", \"Number of builds to show per page\", parseCount)\n .addOption(\n new Option(\"--format <type>\", \"Format to output the build details in\")\n .choices([\"json\", \"table\"])\n .default(\"table\")\n )\n .option(\"--exit\", \"View the latest build\")\n .action((id, { config, count, exit, format, latest }) => {\n runCommand(BuildsCommand, {\n configPath: config,\n count,\n exit,\n format,\n id,\n shouldViewLatest: latest,\n });\n });\n\nprogram\n .command(\"logout\")\n .description(\"Logs you out\")\n .action(() => {\n runCommand(LogoutCommand, null, { exitIfOutOfDate: false });\n });\n\nprogram\n .command(\"release\")\n .description(\"Release a build\")\n .argument(\"[id]\", \"A specific build ID to release\")\n .option(\"--force\", \"Skips interactive confirmation step\")\n .option(\"--latest\", \"Release the latest build\")\n .option(\n \"--config [string]\",\n \"Path to a different configuration file. If not specified, \" +\n \"`todesktop.json` in the project root will be used\"\n )\n .action((id, { config, force, latest }) => {\n runCommand(ReleaseCommand, {\n configPath: config,\n force,\n id,\n shouldReleaseLatest: latest,\n });\n });\n\nprogram\n .command(\"whoami\")\n .description(\"Prints the email of the account you're signed into\")\n .action(() => {\n runCommand(WhoamiCommand);\n });\n\nconst runCommand = <T extends FC>(\n component: T,\n props: Parameters<T>[0] = null,\n { exitIfOutOfDate = true } = {}\n) => {\n onCommand({ exitIfOutOfDate });\n\n const { waitUntilExit } = render(createElement(component, props));\n\n waitUntilExit().catch((error) => {\n console.error(error.stack);\n });\n};\n\n// Don't exist with status 1 if no command specified\nconst args = [...process.argv];\nif (args.length === 2) {\n args.push(\"help\");\n}\n\nprogram.parse(args);\n", "// libs\nimport { useEffect, useState } from \"react\";\nimport PropTypes from \"prop-types\";\n\n// components\nimport BuildProgress from \"./BuildProgress\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport Preparation from \"./Preparation\";\nimport InitialLoadingState from \"./InitialLoadingState\";\nimport MainLayout from \"./MainLayout\";\n\n// utils\nimport logForCI from \"../utilities/logForCI\";\nimport logger from \"../utilities/logger\";\nimport runBuild from \"../utilities/runBuild\";\nimport shouldExitOnBuildFailure from \"../utilities/shouldExitOnBuildFailure\";\nimport useExit from \"../utilities/useExit\";\n\nconst initalState = {\n appId: null,\n appPkg: null,\n build: null,\n error: null,\n hasBuildEverFailed: false,\n isPreparationComplete: false,\n preparationStageLabel: \"Preparing\",\n preparationProgress: 0,\n preparationUploadedSize: null,\n};\n\nconst Build = ({ commandUsed, shouldCodeSign = true, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n appPkg,\n build,\n error,\n hasBuildEverFailed,\n isPreparationComplete,\n preparationStageLabel,\n preparationProgress,\n preparationUploadedSize,\n },\n setState,\n ] = useState(initalState);\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n let firebaseUnsubscribe;\n\n runBuild({\n onEvent: (eventName, data) => {\n logger.debug({ eventName, data }, \"Build component: runBuild.onEvent\");\n if (eventName === \"firebase-subscribed\") {\n firebaseUnsubscribe = data.firebaseUnsubscribe;\n } else if (eventName === \"progress\") {\n setState((prevState) => ({ ...prevState, ...data }));\n }\n },\n shouldCodeSign,\n configPath,\n }).catch(onError);\n\n return () => {\n if (firebaseUnsubscribe) {\n firebaseUnsubscribe();\n }\n };\n }, [commandUsed, shouldCodeSign, configPath]);\n\n // Exit if the build has errored and settled\n useEffect(() => {\n if (hasBuildEverFailed && shouldExitOnBuildFailure(build)) {\n setTimeout(() => exit(new Error(\"Build has failed\")), 10);\n }\n }, [build, exit, hasBuildEverFailed]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (!appPkg) {\n return <InitialLoadingState />;\n }\n\n const onBuildFailure = () => {\n if (hasBuildEverFailed) {\n return;\n }\n setState((prevState) => ({\n ...prevState,\n hasBuildEverFailed: true,\n }));\n };\n\n return (\n <MainLayout\n appId={appId}\n appName={(build && build.appName) || appPkg.name}\n appVersion={(build && build.appVersion) || appPkg.version}\n build={build}\n commandUsed={commandUsed}\n hasBuildEverFailed={hasBuildEverFailed}\n >\n {isPreparationComplete ? (\n <BuildProgress build={build} onBuildFailure={onBuildFailure} />\n ) : (\n <Preparation\n progressPercentage={preparationProgress}\n stageLabel={preparationStageLabel}\n uploadedSize={preparationUploadedSize}\n />\n )}\n </MainLayout>\n );\n};\n\nBuild.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n shouldCodeSign: PropTypes.bool,\n configPath: PropTypes.string,\n};\n\nexport default Build;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport throttle from \"lodash.throttle\";\nimport BuildCompleteMessage from \"./BuildCompleteMessage\";\nimport PlatformProgress from \"./PlatformProgress\";\nimport { hasBuildKickedOff } from \"../utilities/buildStatus\";\nimport logger from \"../utilities/logger\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\n\nconst logForCIThrottled = throttle(logForCI, 60 * 1000, { trailing: true });\n\nconst BuildProgress = ({ build, onBuildFailure }) => {\n logger.debug(\"BuildProgress component: render\");\n const exit = useExit();\n\n const [{ hasKickedOff }, setState] = useState({\n hasKickedOff: false,\n });\n const platformsNotSkipped = [\"windows\", \"mac\", \"linux\"].filter(\n (platform) => !build[platform].shouldSkip\n );\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n hasKickedOff: hasBuildKickedOff(build),\n }));\n }, [build]);\n\n useEffect(() => {\n if (build.status === \"failed\") {\n onBuildFailure(build.errorMessage);\n } else if (build.status === \"cancelled\") {\n setTimeout(exit, 10);\n } else {\n const ciPlatformProgress = platformsNotSkipped.map(\n (platform) =>\n `${platform.charAt(0).toUpperCase() + platform.slice(1)}: ${\n build[platform].progressActivityName\n } (${build[platform].progressPercentage}%)`\n );\n logForCIThrottled(ciPlatformProgress.join(\", \"));\n }\n }, [build, exit, onBuildFailure, platformsNotSkipped]);\n\n if (build.status === \"succeeded\") {\n return <BuildCompleteMessage build={build} />;\n }\n\n if (build.status === \"cancelled\") {\n return (\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text>Build cancelled</Text>\n </Box>\n );\n }\n\n if (!hasKickedOff) {\n return null;\n }\n\n return (\n <>\n <Box flexDirection=\"column\">\n {platformsNotSkipped.map((platform) => (\n <Box flexDirection=\"column\" key={platform}>\n <PlatformProgress\n activityName={\n build[platform].status === \"failed\"\n ? build[platform].errorMessage\n : build[platform].progressActivityName\n }\n activityType={\n build[platform].status === \"failed\"\n ? \"error\"\n : build[platform].progressActivityType\n }\n downloadUrl={build[platform].standardDownloadUrl}\n percent={build[platform].progressPercentage}\n platform={platform}\n shouldShowReadyPrefix={\n !(build && [\"failed\", \"succeeded\"].includes(build.status))\n }\n />\n </Box>\n ))}\n </Box>\n </>\n );\n};\n\nBuildProgress.propTypes = {\n build: PropTypes.object.isRequired,\n onBuildFailure: PropTypes.func.isRequired,\n};\n\nexport default BuildProgress;\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport PropTypes from \"prop-types\";\nimport { useEffect } from \"react\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport path from \"path\";\n\nconst addTrailingSlash = (url) => {\n return url.endsWith(\"/\") ? url : `${url}/`;\n};\n\nconst BuildCompleteMessage = ({ build }) => {\n const exit = useExit();\n let url = build.standardUniversalDownloadUrl;\n\n if (process.platform === \"darwin\") {\n // Otherwise the download link may link to a Intel file when on Apple Silicon\n url = new URL(\n path.posix.join(\"mac\", \"zip\", process.arch),\n addTrailingSlash(url)\n ).href;\n }\n\n logForCI(`Build complete! ${url}`);\n\n // On build completion, exit with non-error code\n useEffect(() => {\n if (url) {\n // Just to avoid updating state after exiting the React app\n setTimeout(exit, 10);\n }\n }, [exit, url]);\n\n return (\n <Box marginBottom={1}>\n <Text>\n <Text bold>Build complete!</Text>{\" \"}\n <Link fallback={false} url={url}>\n {url || \"\"}\n </Link>\n </Text>\n </Box>\n );\n};\n\nBuildCompleteMessage.propTypes = {\n build: PropTypes.object.isRequired,\n};\n\nexport default BuildCompleteMessage;\n", "import isCi from \"is-ci\";\nimport logger from \"./logger\";\n\nexport default (...args) => {\n logger.info({ args }, \"logForCI\");\n\n if (isCi || !process.stdin.isTTY) {\n console.log(...args);\n }\n};\n", "import bunyan from \"bunyan\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as path from \"path\";\nimport * as Sentry from \"@sentry/node\";\n\nlet logger;\n\ntry {\n const name = \"todesktop-cli\";\n\n let parentDirectory;\n const homePath = os.homedir();\n if (process.platform === \"darwin\") {\n parentDirectory = path.join(homePath, \"Library\", \"Logs\", name);\n } else if (process.platform === \"win32\") {\n parentDirectory = path.join(\n process.env.APPDATA || path.join(homePath, \"AppData\", \"Roaming\"),\n name,\n \"logs\"\n );\n } else {\n parentDirectory = path.join(\n process.env.XDG_CONFIG_HOME || path.join(homePath, \".config\"),\n name,\n \"logs\"\n );\n }\n\n fs.mkdirSync(parentDirectory, { recursive: true });\n\n logger = bunyan.createLogger({\n name,\n src: true,\n streams: [\n {\n level: \"debug\",\n path: path.join(parentDirectory, \"main.log\"),\n },\n ],\n });\n} catch (e) {\n // Ignore\n\n const noOp = () => {};\n logger = {\n debug: noOp,\n error: noOp,\n fatal: noOp,\n info: noOp,\n trace: noOp,\n warn: noOp,\n };\n\n try {\n Sentry.captureException(e);\n } catch (err) {\n // Ignore\n }\n}\n\nexport default logger;\n", "import { useApp } from \"ink\";\nimport { flush } from \"./analytics\";\nimport firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default () => {\n const { exit } = useApp();\n\n return (error = undefined) => {\n logger.debug({ error }, \"Exit called\");\n\n /*\n First, destroy connections.\n Why do we need to do this if we're going to call process.exit\n below anyway? Just to be safe in case a Firestore subscription\n triggers a state update after the React app is exited.\n */\n firestore.terminate().catch((e) =>\n // Ignore\n logger.error(e)\n );\n\n let timeoutId;\n Promise.race([\n // flush the analytics to make sure all outstanding events are pushed to segment\n new Promise<void>((resolve) => flush(() => resolve())),\n // If it takes longer than 1 second, resolve early to proceed with program exit\n new Promise<void>(\n (resolve) => (timeoutId = setTimeout(() => resolve(), 1000))\n ),\n ])\n .catch(() => {})\n .finally(() => {\n clearTimeout(timeoutId);\n /*\n Then, exit the React app. We don't pass the error because:\n 1. We don't want it displayed. We could give it a dummy error but\n that will output an empty line.\n 2. It doesn't exit with the correct code anyway, see\n https://github.com/vadimdemedes/pastel/issues/39.\n\n Side note: your component must not perform state updates after\n calling this, it will error.\n\n The try-catch shouldn't be needed here, but let's be safe\n */\n try {\n exit();\n } catch (e) {\n logger.error(e);\n // Ignore\n }\n\n /*\n Then exit the process.\n It should happen if all connections, etc. are destroyed. We manually\n exit with a code because:\n 1. We might not clean up properly, it could fail or take a long time.\n 2. The exit function above doesn't exit the CLI with the correct\n code anyway.\n\n If we had a way to detect when the app exits, we would use that\n and then call process.exit / destroy connections appropriately\n (https://github.com/vadimdemedes/pastel/issues/38).\n */\n setTimeout(() => process.exit(error ? 1 : 0), 10);\n });\n };\n};\n", "import os from \"os\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport Analytics from \"analytics-node\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport { currentUser } from \"./firestore\";\nimport { getAuthConfig } from \"./configStore\";\nimport getCliVersion from \"./getCliVersion\";\n\nconst environmentVariables = getEnvironmentVariables();\n\nconst analytics = new Analytics(environmentVariables.SEGMENT_WRITE_KEY, {\n flushAt: 1,\n flushInterval: 1,\n});\n\nexport const ANALYTICS_EVENT = {\n CLI_COMMAND: \"CLI Command\",\n};\n\nfunction getAnalyticsBaseProperties() {\n const baseProps = {\n app: {\n cliVersion: \"\",\n },\n client: \"cli\",\n user: {\n email: \"\",\n },\n os: {\n name: \"\",\n version: \"\",\n },\n runtime: {\n name: \"Node.js\",\n version: \"\",\n },\n };\n try {\n baseProps.os = {\n name: os.platform(),\n version: os.release(),\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.user = {\n email: getAuthConfig().email as string,\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.app = {\n cliVersion: getCliVersion(),\n };\n } catch (err) {\n // nothing\n }\n\n try {\n baseProps.runtime = {\n name: \"Node.js\",\n version: process.version,\n };\n } catch (err) {\n // nothing\n }\n\n return baseProps;\n}\n\nconst anonymousId = uuidv4();\nexport const track = (event, properties = {}, callback = () => {}) => {\n try {\n const user = currentUser();\n\n analytics.track(\n {\n event,\n userId: user ? user.uid : undefined,\n anonymousId,\n properties: {\n ...properties,\n ...getAnalyticsBaseProperties(),\n },\n },\n callback\n );\n } catch (err) {\n // nothing\n }\n};\n\nexport const identify = (id, traits = {}, callback = () => {}) => {\n try {\n analytics.identify({ userId: id, anonymousId, traits }, callback);\n } catch (err) {\n // nothing\n }\n};\n\nexport const flush = (callback = () => {}) => analytics.flush(callback);\n", "import dotenv from \"dotenv\";\nimport path from \"path\";\n\nlet hasInitialized = false;\n\nconst init = () => {\n if (hasInitialized) {\n return;\n }\n\n dotenv.config({\n path: path.resolve(__dirname, \"../.env\"),\n });\n hasInitialized = true;\n};\n\nexport default () => {\n init();\n return process.env;\n};\n", "import firebase from \"firebase/app\";\nimport \"firebase/firestore\";\nimport \"firebase/auth\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nconst environmentVariables = getEnvironmentVariables();\n\n// if (environmentVariables.NODE_ENV === \"development\") {\n// if (true) {\n// firebase.firestore.setLogLevel(\"debug\");\n// }\n\nconst firebaseDB = firebase.initializeApp({\n apiKey: environmentVariables.TODESKTOP_CLI_FIREBASE_API_KEY,\n authDomain: environmentVariables.TODESKTOP_CLI_FIREBASE_AUTH_DOMAIN,\n databaseURL: environmentVariables.TODESKTOP_CLI_FIREBASE_DATABASE_URL,\n projectId: environmentVariables.TODESKTOP_CLI_FIREBASE_PROJECT_ID,\n storageBucket: environmentVariables.TODESKTOP_CLI_FIREBASE_STORAGE_BUCKET,\n messagingSenderId:\n environmentVariables.TODESKTOP_CLI_FIREBASE_MESSAGING_SENDER_ID,\n appId: environmentVariables.TODESKTOP_CLI_FIREBASE_ID,\n});\n\nexport const currentUser = () => firebase.auth().currentUser;\nexport const signInWithCustomToken = async (token) => {\n return firebase.auth().signInWithCustomToken(token);\n};\n\n/**\n * onUserAuth is only triggered on sign-in. This\n * happens once signInWithCustomToken is successful.\n *\n * It technically also triggers on sign-out but there's\n * no concept of signing out of firebase with the CLI app.\n * (See logout command which just deletes a local file)\n */\nexport const onUserAuth = (handler) =>\n firebase.auth().onAuthStateChanged((user) => {\n handler(user || {});\n });\n\nexport default firebaseDB.firestore();\n", "import * as fs from \"fs\";\nimport del from \"del\";\nimport Conf from \"conf\";\nimport xdgBasedir from \"xdg-basedir\";\n\nconst config = new Conf({ configName: \"todesktop-cli\" });\n\nexport const accessTokenConfigKey = \"accessToken\";\nexport const emailConfigKey = \"email\";\nexport const jwtTokenConfigKey = \"jwtToken\";\n\nexport const setConfig = (key, value) => config.set(key, value);\nexport const getConfig = (key) => config.get(key) as string;\n\nexport const setAuthConfig = (email, accessToken, jwtToken) => {\n setConfig(emailConfigKey, email);\n setConfig(accessTokenConfigKey, accessToken);\n setConfig(jwtTokenConfigKey, jwtToken);\n};\n\nexport const getAuthConfig = () => {\n const accessToken = getConfig(accessTokenConfigKey);\n const jwtToken = getConfig(jwtTokenConfigKey);\n const email = getConfig(emailConfigKey);\n\n return { accessToken, jwtToken, email };\n};\n\nexport const deleteAuthConfig = () => {\n config.delete(emailConfigKey);\n config.delete(accessTokenConfigKey);\n config.delete(jwtTokenConfigKey);\n};\n\n// TODO - Delete by end of April: backwards compatibility for old configstore\nconst oldConfigPath = `${xdgBasedir.config}/configstore/config.json.json`;\nif (fs.existsSync(oldConfigPath)) {\n try {\n // copy config from old json file to new json file, delete old file\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { email, accessToken, jwtToken } = require(oldConfigPath);\n setAuthConfig(email, accessToken, jwtToken);\n del(oldConfigPath, { force: true });\n } catch (err) {\n // if invalid json, delete file to prompt new login\n del(oldConfigPath, { force: true });\n }\n}\n", "import pkgUp from \"pkg-up\";\nimport type toDesktopPackageJson from \"../../package.json\";\nimport readJson from \"./readJson\";\n\ntype ToDesktopPackageJson = typeof toDesktopPackageJson;\n\nconst packageJson = readJson<ToDesktopPackageJson>(\n pkgUp.sync({ cwd: __dirname })\n);\n\nexport default function getToDesktopPackageJson(): ToDesktopPackageJson {\n return packageJson;\n}\n", "// This exists so it can be mocked in tests\nexport default function readJson<T>(filePath: string): T {\n return require(filePath);\n}\n", "import getToDesktopPackageJson from \"./getToDesktopPackageJson\";\n\nconst cliVersion = getToDesktopPackageJson().version;\n\nexport default () => cliVersion;\n", "import PropTypes from \"prop-types\";\nimport { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport path from \"path\";\n\nconst preLabelMaxWidth = \"More info: \".length;\n\nconst getProgressPercentageLabel = (\n percentage: number,\n activityType?: \"error\"\n) => {\n let backgroundColor = \"white\";\n let color = \"black\";\n\n if (activityType === \"error\") {\n backgroundColor = \"red\";\n } else if (percentage === 100) {\n backgroundColor = \"green\";\n color = \"black\";\n }\n\n return (\n <>\n <Text backgroundColor={backgroundColor} color={color}>\n {\" \"}\n {Math.round(percentage).toString().padStart(2, \"0\")}%{\" \"}\n </Text>\n <Text> </Text>\n </>\n );\n};\n\nconst PlatformProgress = ({\n activityName,\n activityType,\n downloadUrl,\n percent,\n platform,\n shouldShowReadyPrefix,\n}) => {\n let progressIndicator;\n if (activityType === \"done\") {\n if (process.platform === \"darwin\") {\n // Otherwise the download link may link to a Intel file when on Apple Silicon\n downloadUrl = path.posix.join(downloadUrl, \"mac\", \"zip\", process.arch);\n }\n progressIndicator = (\n <Box flexDirection=\"column\" marginBottom={1}>\n <Text>\n {getProgressPercentageLabel(100)}\n {shouldShowReadyPrefix ? \"Ready!\" : \"\"}\n </Text>\n <Link fallback={false} url={downloadUrl}>\n {downloadUrl}\n </Link>\n </Box>\n );\n } else {\n let activityNameToDisplay = activityName.replace(\n /(?:\\r\\n|\\r|\\n)\\s*/g,\n \"\u21B5 \"\n );\n if (activityNameToDisplay.length > 64) {\n activityNameToDisplay = `${activityNameToDisplay.substr(0, 61)}...`;\n }\n\n progressIndicator = (\n <>\n <Box flexDirection={\"column\"} marginBottom={1}>\n <Text>\n {[\"preparation\", \"queue\"].includes(activityType)\n ? undefined\n : getProgressPercentageLabel(percent, activityType)}\n {activityNameToDisplay}\n {activityType === \"error\" ? \"\" : <Text>...</Text>}\n </Text>\n </Box>\n </>\n );\n }\n return (\n <Box>\n <Box width={preLabelMaxWidth}>\n <Text>{platform[0].toUpperCase() + platform.substr(1)}: </Text>\n </Box>\n {progressIndicator}\n </Box>\n );\n};\n\nPlatformProgress.propTypes = {\n activityName: PropTypes.string.isRequired,\n activityType: PropTypes.string.isRequired,\n downloadUrl: PropTypes.string,\n percent: PropTypes.number.isRequired,\n platform: PropTypes.string.isRequired,\n shouldShowReadyPrefix: PropTypes.bool,\n};\n\nexport default PlatformProgress;\n", "export const hasBuildKickedOff = (build) => {\n if (!build) {\n return false;\n }\n return build.status && build.status !== \"preparation\";\n};\n\n// NOTE: this relies on Firestore solely\nexport const isBuildCancellable = (build) =>\n hasBuildKickedOff(build) && isBuildRunning(build);\n\nexport const isBuildRunning = (build) => {\n if (!build) {\n return false;\n }\n return (\n ![\"cancelled\", \"succeeded\"].includes(build.status) &&\n [\"linux\", \"mac\", \"windows\"].some((platform) =>\n isPlatformBuildRunning(build[platform])\n )\n );\n};\n\nexport const isPlatformBuildRunning = (platformBuild) => {\n if (!platformBuild) {\n return false;\n }\n return (\n !platformBuild.shouldSkip && // <-- Noteworthy\n ![\"cancelled\", \"succeeded\"].includes(platformBuild.status) &&\n (\"failed\" !== platformBuild.status ||\n platformBuild.numberOfAttemptedBuilds < 2)\n );\n};\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect } from \"react\";\nimport getCliVersion from \"../utilities/getCliVersion\";\nimport logger from \"../utilities/logger\";\nimport useExit from \"../utilities/useExit\";\n\nconst ErrorDisplay = ({ commandUsed, error }) => {\n const exit = useExit();\n logger.error({ error });\n\n // After an error is set, exit\n useEffect(() => {\n if (!error) {\n return;\n }\n // Just to avoid updating state after exiting the React app\n setTimeout(() => exit(error), 10);\n }, [exit, error]);\n\n return (\n <>\n <Text backgroundColor=\"red\" color=\"white\">\n {\" \"}\n ERROR{\" \"}\n </Text>\n <Text>{error.message || error.stack || error.toString()}</Text>\n\n <Box flexDirection=\"column\" marginTop={1}>\n {commandUsed ? (\n <Text dimColor color=\"gray\">\n Command: {commandUsed}\n </Text>\n ) : null}\n <Text dimColor color=\"gray\">\n @todesktop/cli: {getCliVersion()}\n </Text>\n <Text dimColor color=\"gray\">\n Node: {process.version}\n </Text>\n <Text dimColor color=\"gray\">\n cwd: {process.cwd()}\n </Text>\n </Box>\n </>\n );\n};\n\nErrorDisplay.propTypes = {\n commandUsed: PropTypes.string,\n error: PropTypes.object.isRequired,\n};\n\nexport default ErrorDisplay;\n", "import { Box, Text } from \"ink\";\nimport ProgressBar from \"./ProgressBar\";\nimport PropTypes from \"prop-types\";\n\nconst Preparation = ({ progressPercentage, stageLabel, uploadedSize }) => {\n return (\n <Box marginBottom={1}>\n <Text>{stageLabel}: </Text>\n <Box flexDirection={\"column\"}>\n <ProgressBar left={11} percent={progressPercentage} />\n {uploadedSize ? <Text>{uploadedSize}</Text> : undefined}\n </Box>\n </Box>\n );\n};\n\nPreparation.propTypes = {\n progressPercentage: PropTypes.number.isRequired,\n stageLabel: PropTypes.string.isRequired,\n uploadedSize: PropTypes.string,\n};\n\nexport default Preparation;\n", "import PropTypes from \"prop-types\";\nimport Gradient from \"ink-gradient\";\nimport Bar from \"../libs/ink-progress-bar\";\n\nconst ProgressBar = ({ left, right, percent }) => (\n <Gradient colors={[\"gray\", \"white\"]}>\n <Bar left={left} right={right} percent={percent} />\n </Gradient>\n);\n\nProgressBar.propTypes = {\n left: PropTypes.number,\n right: PropTypes.number,\n // 0 -> 1\n percent: PropTypes.number.isRequired,\n};\n\nexport default ProgressBar;\n", "/**\n * Ported from https://github.com/brigand/ink-progress-bar/blob/master/src/index.js\n * `ink-progress-bar` doesn't list react or ink as a direct dependency which messes up\n * installation for users of yarn v2+.\n */\nimport { Text } from \"ink\";\n\nconst Bar = ({\n percent = 1,\n columns = 0,\n left = 0,\n right = 0,\n character = \"\u2588\",\n rightPad = false,\n ...rest\n}) => {\n const getString = () => {\n const screen = columns || process.stdout.columns || 80;\n const space = screen - right - left;\n const max = Math.min(Math.floor(space * percent), space);\n const chars = character.repeat(max);\n\n if (!rightPad) {\n return chars;\n }\n\n return chars + \" \".repeat(space - max);\n };\n\n return <Text {...rest}>{getString()}</Text>;\n};\n\nexport default Bar;\n", "import { Text } from \"ink\";\n\nconst InitialLoadingState = () => {\n return <Text>Getting app info...</Text>;\n};\n\nexport default InitialLoadingState;\n", "// libs\nimport { Box, Text, useStdin } from \"ink\";\nimport isCi from \"is-ci\";\nimport { ReactNode, useEffect, useState } from \"react\";\nimport { Build } from \"../types\";\n\n// components\nimport CancelBuild from \"./CancelBuild\";\nimport Footer from \"./Footer\";\nimport Header from \"./Header\";\n\n// utilities\nimport {\n hasBuildKickedOff,\n isBuildCancellable,\n} from \"../utilities/buildStatus\";\nimport logger from \"../utilities/logger\";\nimport useInput from \"../utilities/useInput\";\n\nconst MainLayout = ({\n appId,\n appName,\n appVersion,\n build,\n children,\n commandUsed,\n hasBuildEverFailed,\n}: {\n appId?: string;\n appName: string;\n appVersion?: string;\n build?: Build;\n children?: ReactNode;\n commandUsed?: string;\n hasBuildEverFailed?: boolean;\n}) => {\n logger.debug(\"MainLayout component: render\");\n const onInput = useInput();\n const { isRawModeSupported } = useStdin();\n\n const [\n { canCancelBuild, hasKickedOff, isCancellingBuild, wasCtrlCPressed },\n setState,\n ] = useState({\n canCancelBuild: null,\n hasKickedOff: false,\n isCancellingBuild: false,\n wasCtrlCPressed: false,\n });\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n hasKickedOff: hasBuildKickedOff(build),\n }));\n }, [build]);\n\n useEffect(() => {\n setState((previousState) => ({\n ...previousState,\n canCancelBuild:\n !isCi &&\n isRawModeSupported &&\n !isCancellingBuild &&\n isBuildCancellable(build),\n }));\n }, [build, isCancellingBuild]);\n\n onInput(\n async (input, key) => {\n if (key.escape && canCancelBuild) {\n logger.debug(\"MainLayout component: esc pressed, cancelling build\");\n\n setState((previousState) => ({\n ...previousState,\n isCancellingBuild: true,\n }));\n }\n },\n {},\n {\n onCtrlCPressed: () => {\n setState((previousState) => ({\n ...previousState,\n wasCtrlCPressed: true,\n }));\n },\n }\n );\n\n return (\n <>\n <Header build={build} name={appName} version={appVersion} />\n\n {isCancellingBuild ? (\n <Box flexDirection=\"column\" marginBottom={1}>\n <CancelBuild appId={appId} commandUsed={commandUsed} id={build.id} />\n </Box>\n ) : (\n children\n )}\n\n <Footer\n hasBuildEverFailed={hasBuildEverFailed}\n shouldShowCancelBuildInstructions={canCancelBuild && !wasCtrlCPressed}\n uiUrl={build ? build.url : null}\n />\n\n {wasCtrlCPressed && hasKickedOff ? (\n <>\n <Box flexDirection=\"column\" marginTop={1}>\n <Text color=\"gray\">\n The build will continue in the background. To view it, run:\n </Text>\n </Box>\n <Box>\n <Text bold color=\"gray\">\n todesktop builds {build.id}\n </Text>\n </Box>\n </>\n ) : null}\n </>\n );\n};\n\nexport default MainLayout;\n", "// libs\nimport { Text } from \"ink\";\nimport { ReactNode, useEffect, useState } from \"react\";\n\n// components\nimport ErrorDisplay from \"./ErrorDisplay\";\n\n// utils\nimport getCallableFirebaseFunction from \"../utilities/getCallableFirebaseFunction\";\nimport logForCI from \"../utilities/logForCI\";\nimport logger from \"../utilities/logger\";\nimport useExit from \"../utilities/useExit\";\n\nconst cancelBuild = getCallableFirebaseFunction(\"cancelBuild\");\n\nconst CancelBuild = ({\n appId,\n children: postCancelContents,\n commandUsed,\n id,\n}: {\n appId: string;\n children?: ReactNode;\n commandUsed: string;\n id: string;\n}) => {\n logger.debug({ appId, buildId: id }, \"CancelBuild component: render\");\n\n const exit = useExit();\n const [\n { arbitraryMessageComponent, error, hasCompleted, hasStarted },\n setState,\n ] = useState({\n arbitraryMessageComponent: null,\n error: null,\n hasCompleted: false,\n hasStarted: false,\n });\n\n useEffect(() => {\n if (hasCompleted || hasStarted) {\n return;\n }\n\n setState((previousState) => ({ ...previousState, hasStarted: true }));\n logForCI(\"Cancelling build...\");\n cancelBuild({ appId, buildId: id })\n .then((result) => {\n logger.debug(\n { appId, buildId: id, result },\n \"CancelBuild component: cancellation request complete\"\n );\n setState((previousState) => ({ ...previousState, hasCompleted: true }));\n })\n .catch((e) => {\n logger.debug(\n { appId, buildId: id, code: e.code },\n \"CancelBuild component: cancellation request failed\"\n );\n logger.error(e);\n const stateUpdates = {\n arbitraryMessageComponent: undefined,\n error: undefined,\n hasCompleted: true,\n };\n\n if (e.code === \"internal\") {\n stateUpdates.error = e;\n } else {\n stateUpdates.arbitraryMessageComponent = (\n <Text>\n <Text color=\"red\">Cannot cancel build ({id}).</Text> {e.message}\n </Text>\n );\n }\n\n setState((prevState) => ({\n ...prevState,\n ...stateUpdates,\n }));\n });\n }, [appId, id, hasStarted, hasCompleted]);\n\n // Exit when done, unless there are custom contents to display\n useEffect(() => {\n if (hasCompleted && !postCancelContents) {\n logger.debug(\n \"CancelBuild component: exiting now that build is cancelled\"\n );\n exit();\n }\n }, [postCancelContents, exit, hasCompleted]);\n\n if (error) {\n error.message = `Failed to cancel build (${id}). ${error.message}`;\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (hasCompleted) {\n return postCancelContents ? (\n <>{postCancelContents}</>\n ) : (\n <Text>Build cancelled</Text>\n );\n }\n\n return <Text>Cancelling build ({id})...</Text>;\n};\n\nexport default CancelBuild;\n", "import firebase from \"firebase\";\nimport \"firebase/functions\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nif (getEnvironmentVariables().TODESKTOP_CLI_ENV === \"development\") {\n firebase.functions().useFunctionsEmulator(\"http://localhost:5000\");\n}\n\nexport default (functionName) =>\n firebase.functions().httpsCallable(functionName);\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport PropTypes from \"prop-types\";\n\nconst Footer = ({\n hasBuildEverFailed,\n shouldShowCancelBuildInstructions,\n uiUrl,\n}) => {\n if (!uiUrl) {\n return null;\n }\n\n let buildFailedMessage;\n if (hasBuildEverFailed) {\n buildFailedMessage = <Text color=\"red\">An error has occurred. </Text>;\n }\n\n return (\n <Box flexDirection=\"column\">\n <Box flexDirection=\"column\">\n <Text bold>{buildFailedMessage}See web UI for more information: </Text>\n <Text>\n <Link fallback={false} url={uiUrl}>\n {uiUrl}\n </Link>\n </Text>\n </Box>\n {shouldShowCancelBuildInstructions ? (\n <Text color=\"gray\">\n <Text bold>[esc]:</Text> cancel build\n </Text>\n ) : null}\n </Box>\n );\n};\n\nFooter.propTypes = {\n hasBuildEverFailed: PropTypes.bool,\n shouldShowCancelBuildInstructions: PropTypes.bool,\n uiUrl: PropTypes.string,\n};\n\nexport default Footer;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst getText = (build, name, version) => {\n const suffix = name + (version ? ` v${version}` : \"\");\n\n if (build && [\"cancelled\", \"succeeded\", \"failed\"].includes(build.status)) {\n if (build.status === \"succeeded\") {\n return <Text>\u2705 {suffix}</Text>;\n } else if (build.status === \"failed\") {\n return <Text>\u274C {suffix}</Text>;\n } else if (build.status === \"cancelled\") {\n return (\n <Text>\n <Text bold color=\"gray\">\n X\n </Text>{\" \"}\n {suffix}\n </Text>\n );\n }\n } else {\n return <Text>{suffix}</Text>;\n }\n};\n\nconst Header = ({ build, name, version }) => (\n <Box marginBottom={1}>{getText(build, name, version)}</Box>\n);\n\nHeader.propTypes = {\n build: PropTypes.object,\n name: PropTypes.string.isRequired,\n version: PropTypes.string,\n};\n\nexport default Header;\n", "import isCi from \"is-ci\";\nimport { useInput, useStdin } from \"ink\";\nimport useExit from \"./useExit\";\n\nlet hasSubscribed = false;\nconst ctrlCSubscriptions = [];\n\nconst onStdin = (data, exit) => {\n let input = String(data);\n let wasCtrlPressed = false;\n if (input <= \"\\u001A\" && input !== \"\\r\") {\n input = String.fromCharCode(input.charCodeAt(0) + \"a\".charCodeAt(0) - 1);\n wasCtrlPressed = true;\n }\n if (wasCtrlPressed && input === \"c\") {\n ctrlCSubscriptions.forEach((subscription) => subscription());\n setTimeout(exit, 10);\n }\n};\n\n/*\n See https://github.com/vadimdemedes/pastel/issues/38\n*/\nexport default () => {\n const exit = useExit();\n const { stdin, isRawModeSupported } = useStdin();\n\n if (isCi || !isRawModeSupported) {\n return () => () => {};\n }\n\n return (callback, useInputOptions = {}, { onCtrlCPressed = null } = {}) => {\n const onStdinData = (data) => onStdin(data, exit);\n\n if (onCtrlCPressed) {\n ctrlCSubscriptions.push(onCtrlCPressed);\n }\n\n if (!hasSubscribed) {\n hasSubscribed = true;\n\n // This is based on the Ink (useInput) source\n stdin.on(\"data\", onStdinData);\n }\n\n const cleanUpInputHook = useInput(callback, useInputOptions) as any;\n\n return () => {\n if (hasSubscribed) {\n stdin.off(\"data\", onStdinData);\n }\n cleanUpInputHook?.();\n };\n };\n};\n", "// libs\n\nimport prettyBytes from \"pretty-bytes\";\n\n// utils\nimport { currentUser } from \"./firestore\";\nimport getVersionControlInfo from \"./getVersionControlInfo\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\nimport logForCI from \"./logForCI\";\nimport postToFirebaseFunction from \"./postToFirebaseFunction\";\nimport subscribeToBuild from \"./subscribeToBuild\";\nimport uploadApplicationSource from \"./uploadApplicationSource\";\nimport getAppPkgJson from \"./getPackageJson\";\n\nexport default async ({ onEvent, shouldCodeSign = true, configPath }) => {\n logForCI(\"Getting application information...\");\n\n const primaryUserId = currentUser().uid;\n\n // This will throw if validation fails or project root can not be found:\n const { config, unprocessedConfig } = getProjectConfig(configPath);\n\n const appId = config.id;\n\n const appPkgJson = getAppPkgJson({ config });\n\n onEvent(\"progress\", {\n appId,\n appPkg: appPkgJson,\n preparationProgress: 0.02,\n });\n logForCI(\"Preparing...\");\n\n // Create build in Firebase\n let buildId;\n try {\n const prepareResult = await postToFirebaseFunction(\"prepareNewBuild\", {\n appPkgName: appPkgJson.name,\n appPkgProductName: appPkgJson.productName,\n appVersion: appPkgJson.version,\n id: config.id,\n projectConfig: unprocessedConfig,\n shouldCodeSign: shouldCodeSign !== false,\n shouldRelease: false,\n userId: primaryUserId,\n versionControlInfo: await getVersionControlInfo(config.appPath),\n });\n buildId = prepareResult.appData.meta.currentBuildProgress.id;\n\n const firebaseUnsubscribe = await subscribeToBuild({\n appId,\n buildId,\n onDataReceived: (data) => onEvent(\"progress\", { build: data }),\n userId: prepareResult.userId,\n });\n\n onEvent(\"firebase-subscribed\", { firebaseUnsubscribe });\n } catch (e) {\n e.message = `Failed while preparing new build; ${e.message}`;\n throw e;\n }\n\n onEvent(\"progress\", {\n preparationProgress: 0.05,\n preparationStageLabel: \"Uploading\",\n });\n\n logForCI(\"Uploading...\");\n\n let sourceArchiveDetails;\n try {\n const uploadAppSourceResult = await uploadApplicationSource({\n appId,\n appPkgJson,\n buildId,\n config,\n onProgress(progress, uploadedSize) {\n // Upload is treated as 95% of preparation\n const dataToEmit = {\n preparationProgress: 0.05 + (progress / 100) * 0.95,\n preparationUploadedSize: \"\",\n };\n\n if (uploadedSize) {\n dataToEmit.preparationUploadedSize = prettyBytes(uploadedSize);\n }\n\n onEvent(\"progress\", dataToEmit);\n },\n });\n\n sourceArchiveDetails = uploadAppSourceResult;\n } catch (e) {\n e.message = `Failed while uploading application source; ${e.message}`;\n throw e;\n }\n\n onEvent(\"progress\", { isPreparationComplete: true });\n logForCI(\"Kicking off build...\");\n\n try {\n await postToFirebaseFunction(\"kickOffBuild\", {\n appId,\n appPkgName: appPkgJson.name,\n appVersion: appPkgJson.version,\n buildId,\n userId: primaryUserId,\n sourceArchiveDetails,\n });\n } catch (e) {\n e.message = `Failed while kicking off build; ${e.message}`;\n throw e;\n }\n};\n", "import * as gitRevSync from \"git-rev-sync\";\n\nexport default async (directory) => {\n let result = {};\n\n try {\n const gitCommitHash = gitRevSync.long(directory);\n\n if (gitCommitHash) {\n result = {\n branchName: gitRevSync.branch(directory),\n commitDate: gitRevSync.date().toISOString(),\n commitId: gitCommitHash,\n commitMessage: gitRevSync.message(),\n hasUncommittedChanges: gitRevSync.isDirty(),\n repositoryRemoteUrl: gitRevSync.remoteUrl(),\n versionControlSystemName: \"git\",\n };\n }\n } catch (e) {\n // Ignore\n }\n\n return result;\n};\n", "import { dirname, resolve } from \"path\";\nimport { existsSync } from \"fs\";\nimport findUp from \"find-up\";\nimport { ProjectConfig } from \"../../types\";\nimport loadConfig from \"./loadConfig\";\nimport resolveConfigPaths from \"./resolveConfigPaths\";\nimport validateConfig from \"./validateConfig\";\nimport logger from \"../logger\";\nimport computeFullProjectConfig from \"./computeFullProjectConfig\";\n\nexport default function getProjectConfig(configPath: string = null): {\n config: ProjectConfig;\n unprocessedConfig: ProjectConfig;\n projectRoot: string;\n} {\n // If no config path is provided, we'll try to find one\n if (configPath === null) {\n logger.debug(\"No config path provided, searching for one\");\n configPath = findUp.sync(\"todesktop.json\");\n if (!configPath) {\n throw new Error(\n \"Can not find todesktop.json in this folder or any parent folders\"\n );\n }\n } else {\n if (typeof configPath === \"undefined\" || configPath === \"\") {\n logger.error(\"Provided config path is empty\");\n throw new Error(\"No config path provided\");\n }\n\n configPath = resolve(process.cwd(), configPath);\n\n // If the config path is provided\n if (!existsSync(configPath)) {\n logger.error(\"Provided config path does not exist\");\n throw new Error(`Config file not found at ${configPath}`);\n }\n }\n\n const projectRoot = dirname(configPath);\n\n // This will throw if it's not valid JSON\n const partialConfig = loadConfig(configPath);\n partialConfig.appPath = partialConfig.appPath || \".\";\n\n // compute the full project config\n const config = computeFullProjectConfig(partialConfig, projectRoot);\n\n // This will throw if invalid\n validateConfig({ config, projectRoot });\n\n const result = resolveConfigPaths({ config, projectRoot });\n\n return { config: result, unprocessedConfig: config, projectRoot };\n}\n", "// This is its own file just so we can mock it more easily\nimport { PartialProjectConfig } from \"../../types\";\n\nexport default function loadConfig(configPath: string): PartialProjectConfig {\n return require(configPath);\n}\n", "import * as path from \"path\";\nimport { ProjectConfig } from \"../../types\";\n\nexport default function resolveConfigPaths({\n config,\n projectRoot,\n}: {\n config: ProjectConfig;\n projectRoot: string;\n}): ProjectConfig {\n const appRoot = config.appPath\n ? path.isAbsolute(config.appPath)\n ? config.appPath\n : path.join(projectRoot, config.appPath)\n : projectRoot;\n\n const transformIfExists = (value, transformer) =>\n value ? transformer(value) : undefined;\n const resolvePath = (filePath) =>\n path.isAbsolute(filePath) ? filePath : path.join(projectRoot, filePath);\n\n const result = {\n ...config,\n appPath: appRoot,\n icon: resolvePath(config.icon),\n };\n\n if (config.extraContentFiles) {\n result.extraContentFiles = transformIfExists(\n config.extraContentFiles,\n (extraContentFiles) =>\n extraContentFiles.map((extraContentFile) => ({\n ...extraContentFile,\n from: resolvePath(extraContentFile.from),\n }))\n );\n }\n\n if (config.extraResources) {\n result.extraResources = transformIfExists(\n config.extraResources,\n (extraResources) =>\n extraResources.map((extraResource) => ({\n ...extraResource,\n from: resolvePath(extraResource.from),\n }))\n );\n }\n\n if (config.linux) {\n result.linux = { ...config.linux };\n\n if (config.linux.icon) {\n result.linux.icon = resolvePath(config.linux.icon);\n }\n }\n\n if (config.mac) {\n result.mac = { ...config.mac };\n\n if (config.mac.entitlements) {\n result.mac.entitlements = resolvePath(config.mac.entitlements);\n }\n\n if (config.mac.icon) {\n result.mac.icon = resolvePath(config.mac.icon);\n }\n }\n\n if (config.dmg) {\n if (config.dmg.background) {\n result.dmg.background = resolvePath(config.dmg.background);\n }\n }\n\n if (config.windows) {\n result.windows = { ...config.windows };\n\n if (config.windows.icon) {\n result.windows.icon = resolvePath(config.windows.icon);\n }\n }\n\n return result;\n}\n", "import Ajv from \"ajv\";\nimport addFormats from \"ajv-formats\";\nimport betterAjvErrors from \"better-ajv-errors\";\nimport { ProjectConfig } from \"../../types\";\nimport addCustomKeywords from \"./addCustomKeywords\";\nimport getFullSchema from \"./schema/full\";\n\nexport default function validateConfig({\n config,\n projectRoot,\n}: {\n config: ProjectConfig;\n projectRoot: string;\n}) {\n const context = { projectRoot };\n const schema = getFullSchema(context);\n\n const ajv = new Ajv({ allErrors: true });\n addFormats(ajv);\n addCustomKeywords(ajv, context);\n const validate = ajv.compile(schema);\n\n if (!validate(config)) {\n const output = betterAjvErrors(schema, config, validate.errors, {\n indent: 2,\n });\n\n throw new Error(\n `todesktop.json invalid. \\nLearn more here: https://www.npmjs.com/package/@todesktop/cli#project-configuration-todesktopjson \\n\\n${output}`\n );\n }\n\n if (config.productName) {\n throw new Error(\n `todesktop.json invalid.\n\nThe \"productName\" property is no longer supported in todesktop.json. Please remove it and add it to your app's package.json instead.\n\nWe made this change because Electron also uses the \"productName\" if it exists in your app's package.json. If you do not add it to your package.json, your app name will default to the value of the \"name\" property in your package.json.`\n );\n }\n}\n", "/*\n See https://ajv.js.org/keywords.html\n*/\nimport Ajv, {\n FuncKeywordDefinition,\n SchemaValidateFunction,\n ValidationError,\n} from \"ajv\";\nimport emailRegex from \"email-regex\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport parseAuthor from \"parse-author\";\nimport * as semver from \"semver\";\nimport validatePackageJSON from \"./validatePackageJSON\";\n\nexport default (ajv: Ajv, context) => {\n const addKeyword = (def: FuncKeywordDefinition) => {\n const validate: SchemaValidateFunction = (schema, data) => {\n try {\n return (def.validate as SchemaValidateFunction)(schema, data);\n } catch (e) {\n if (e instanceof ValidationError) {\n validate.errors = e.errors;\n return false;\n }\n\n throw e;\n }\n };\n\n ajv.addKeyword({ ...def, validate });\n };\n\n // validate that dependencies object doesn't contain packageNames in the blacklist\n addKeyword({\n keyword: \"excludedDependencies\",\n validate: (schema, data) => {\n const matchingPackages = schema.blacklist.filter(\n (packageName) => data[packageName]\n );\n\n if (matchingPackages.length) {\n throw new ValidationError([\n {\n keyword: \"Dependency\",\n message: `${matchingPackages.join(\", \")} should not be in ${\n schema.dependencyKey\n }`,\n instancePath: `/${schema.dependencyKey}`,\n },\n ]);\n }\n\n return true;\n },\n });\n\n // TODO: Remove if isn't used\n addKeyword({\n keyword: \"email\",\n type: \"string\",\n validate: (schema, data) => {\n if (!emailRegex({ exact: true }).test(data)) {\n throw new ValidationError([\n {\n keyword: \"email\",\n message: \"invalid\",\n },\n ]);\n }\n return true;\n },\n });\n\n addKeyword({\n keyword: \"file\",\n type: \"string\",\n validate: (schema, data) => {\n const mustBeDirectory =\n schema.mustBeDirectory || schema.mustBeElectronApp;\n\n // Value is empty\n if (!data.trim().length) {\n if (schema.isOptional) {\n return true;\n }\n\n throw new ValidationError([\n {\n keyword: schema.mustBeDirectory ? \"Directory\" : \"File\",\n message: \"is empty\",\n },\n ]);\n }\n\n const filePath = path.isAbsolute(data)\n ? data\n : path.join(schema.from, data);\n\n // Isn't in project\n if (path.relative(schema.from, filePath).startsWith(\"..\")) {\n throw new ValidationError([\n {\n keyword: mustBeDirectory ? \"Directory\" : \"File\",\n message: `is not in project (${filePath})`,\n },\n ]);\n }\n\n // Extension isn't allowed\n if (\n schema.extensions &&\n !schema.extensions.includes(path.extname(filePath).substr(1))\n ) {\n throw new ValidationError([\n {\n keyword: \"File extension\",\n message: `invalid. ${path.extname(data)} Must be${\n schema.extensions > 1 ? \"one of the following:\" : \"\"\n } \"${schema.extensions.join('\", \"')}\"`,\n },\n ]);\n }\n\n // Doesn't exist\n if (!fs.existsSync(filePath)) {\n throw new ValidationError([\n {\n keyword: mustBeDirectory ? \"Directory\" : \"File\",\n message: `does not exist (${filePath})`,\n },\n ]);\n }\n\n const stats = fs.statSync(filePath);\n\n if (mustBeDirectory && stats.isFile()) {\n throw new ValidationError([\n {\n keyword: \"Directory\",\n message: `must be a directory, not a file (${filePath})`,\n },\n ]);\n } else if (schema.mustBeFile && stats.isDirectory()) {\n throw new ValidationError([\n {\n keyword: \"File\",\n message: `must be a file, not a directory (${filePath})`,\n },\n ]);\n }\n\n if (schema.mustBeElectronApp) {\n const appRoot = path.resolve(filePath);\n const pkgPath = path.join(appRoot, \"package.json\");\n\n if (!fs.existsSync(pkgPath)) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. There is no package.json at ${pkgPath}`,\n },\n ]);\n }\n\n let pkg;\n try {\n pkg = require(pkgPath);\n } catch (e) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. Invalid JSON in package.json (${pkgPath})`,\n },\n ]);\n }\n\n context.projectRoot = appRoot;\n // This throws and bubbles all the way up to the user\n validatePackageJSON(pkg, pkgPath, context);\n\n // Validate that either an index.js or valid \"main\" property exists\n const mainFilePath = pkg.main;\n if (mainFilePath) {\n const resolvedMainFilePath = path.join(appRoot, mainFilePath);\n if (!fs.existsSync(resolvedMainFilePath)) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message: `invalid. The \"main\" file specified in your package.json (${mainFilePath}) does not exist (${resolvedMainFilePath})`,\n },\n ]);\n }\n } else {\n if (!fs.existsSync(path.join(appRoot, \"index.js\"))) {\n throw new ValidationError([\n {\n keyword: \"App\",\n message:\n 'invalid. There is neither a \"main\" property in your package.json nor an index.js at the root of your app',\n },\n ]);\n }\n }\n }\n\n return true;\n },\n errors: true,\n });\n\n addKeyword({\n keyword: \"npmAuthor\",\n validate: (schema, data) => {\n const dataType = typeof data;\n if (dataType === \"undefined\") {\n return true;\n } else if (dataType === \"string\") {\n const parsedAuthor = parseAuthor(data);\n if (!parsedAuthor || !parsedAuthor.email) {\n throw new ValidationError([\n {\n keyword: \"author\",\n message:\n 'invalid. If you\\'re using a string, it must look something like \"Barney Rubble <b@rubble.com>\", see https://docs.npmjs.com/files/package.json#people-fields-author-contributors',\n },\n ]);\n }\n } else if (dataType === \"object\") {\n if (typeof data.name === \"undefined\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `invalid. \"name\" property is missing.`,\n },\n ]);\n } else {\n if (typeof data.name !== \"string\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.name invalid. It must be a string`,\n },\n ]);\n }\n\n if (typeof data.email === \"undefined\") {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `invalid. \"email\" property is missing.`,\n },\n ]);\n } else {\n if (typeof data.email === \"string\") {\n if (!emailRegex({ exact: true }).test(data.email)) {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.email invalid. It does not look like an email.`,\n },\n ]);\n }\n } else {\n throw new ValidationError([\n {\n keyword: \"author\",\n message: `.email invalid. It must be a string.`,\n },\n ]);\n }\n }\n }\n } else {\n // Neither object nor string\n throw new ValidationError([\n {\n keyword: \"author\",\n message:\n \"invalid. It must either be an object or string. See https://docs.npmjs.com/files/package.json#people-fields-author-contributors\",\n },\n ]);\n }\n\n return true;\n },\n errors: true,\n });\n\n addKeyword({\n keyword: \"semanticVersion\",\n type: \"string\",\n validate: (schema, data) => {\n const keyword =\n (schema.packageName ? `${schema.packageName} ` : \"\") + \"version\";\n\n if (!(semver.valid(data) || semver.validRange(data))) {\n throw new ValidationError([\n {\n keyword,\n message:\n \"invalid. It must be a semantic version (see https://semver.org/)\",\n },\n ]);\n }\n\n if (\n schema.mustBeExact &&\n (data.startsWith(\"~\") || data.startsWith(\"^\"))\n ) {\n throw new ValidationError([\n {\n keyword,\n message:\n \"invalid. It must be an exact version. Good: 9.0.0. Bad: ^9.0.0\",\n },\n ]);\n }\n return true;\n },\n });\n};\n", "import Ajv from \"ajv\";\nimport addFormats from \"ajv-formats\";\nimport betterAjvErrors from \"better-ajv-errors\";\nimport addCustomKeywords from \"./addCustomKeywords\";\nimport getPackageJsonSchema from \"./schema/packageJSON\";\n\nexport default (pkg, pkgPath, context) => {\n const ajv = new Ajv({ allErrors: true });\n addFormats(ajv);\n addCustomKeywords(ajv, context);\n const schema = getPackageJsonSchema(context);\n const validate = ajv.compile(schema);\n if (!validate(pkg)) {\n const output = betterAjvErrors(schema, pkg, validate.errors, {\n indent: 2,\n });\n\n const error = new Error(`package.json invalid (${pkgPath}); \\n${output}`);\n (error as any).isValidationError = true;\n // This throws and bubbles all the way up to the user\n throw error;\n }\n};\n", "export default (context) => {\n return {\n type: \"object\",\n required: [\n \"author\",\n \"dependencies\",\n \"devDependencies\",\n \"homepage\",\n \"name\",\n \"version\",\n ],\n properties: {\n author: {\n npmAuthor: {},\n },\n dependencies: {\n type: \"object\",\n required: [\"@todesktop/runtime\"],\n // custom keyword that checks package names aren't included in dependencies\n excludedDependencies: {\n dependencyKey: \"dependencies\",\n blacklist: [\"@todesktop/cli\"],\n },\n properties: {\n \"@todesktop/runtime\": {\n type: \"string\",\n },\n },\n },\n devDependencies: {\n type: \"object\",\n required: [\"electron\"],\n properties: {\n electron: {\n type: \"string\",\n semanticVersion: {\n packageName: \"electron\",\n mustBeExact: true,\n },\n },\n },\n },\n name: {\n type: \"string\",\n minLength: 1,\n },\n scripts: {\n type: \"object\",\n properties: {\n \"todesktop:beforeInstall\": {\n type: \"string\",\n file: {\n from: context.projectRoot,\n mustBeFile: true,\n },\n },\n \"todesktop:afterPack\": {\n type: \"string\",\n file: {\n from: context.projectRoot,\n mustBeFile: true,\n },\n },\n },\n },\n version: {\n type: \"string\",\n semanticVersion: {},\n },\n },\n };\n};\n", "const getItemOrArrayOfItemsSchema = (itemSchema) => {\n return {\n oneOf: [\n itemSchema,\n {\n type: \"array\",\n items: itemSchema,\n },\n ],\n };\n};\n\nexport default (context) => {\n const getIconSchema = (additionalAllowedExtensions = []) => {\n return {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"icns\", \"png\", ...additionalAllowedExtensions],\n mustBeFile: true,\n },\n minLength: 3,\n };\n };\n\n return {\n type: \"object\",\n required: [\"id\", \"icon\", \"schemaVersion\"],\n properties: {\n appId: { type: \"string\", minLength: 1 },\n appFiles: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n appProtocolScheme: { type: \"string\", minLength: 1 },\n appPath: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n isOptional: true,\n mustBeElectronApp: true,\n },\n },\n asarUnpack: {\n oneOf: [\n { type: \"boolean\" },\n {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n ],\n },\n copyright: { type: \"string\", minLength: 1 },\n electronMirror: {\n type: \"string\",\n format: \"uri\",\n },\n electronVersion: {\n type: \"string\",\n minLength: 1,\n },\n extraContentFiles: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"from\"],\n properties: {\n from: {\n type: \"string\",\n file: { from: context.projectRoot },\n },\n to: { type: \"string\" },\n },\n },\n },\n extraResources: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"from\"],\n properties: {\n from: {\n type: \"string\",\n file: { from: context.projectRoot },\n },\n to: { type: \"string\" },\n },\n },\n },\n fileAssociations: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"ext\"],\n properties: {\n ext: getItemOrArrayOfItemsSchema({\n type: \"string\",\n minLength: 1,\n }),\n description: {\n type: \"string\",\n minLength: 1,\n },\n name: {\n type: \"string\",\n minLength: 1,\n },\n mimeType: {\n type: \"string\",\n minLength: 1,\n },\n icon: {\n type: \"string\",\n minLength: 1,\n },\n role: {\n type: \"string\",\n minLength: 1,\n },\n isPackage: {\n type: \"boolean\",\n },\n rank: {\n type: \"string\",\n minLength: 1,\n },\n },\n },\n minItems: 1,\n },\n filesForDistribution: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n minItems: 1,\n },\n icon: getIconSchema(),\n linux: {\n type: \"object\",\n properties: {\n category: { type: \"string\", minLength: 1 },\n icon: getIconSchema(),\n noSandbox: { type: \"boolean\" },\n },\n },\n id: { type: \"string\", minLength: 1 },\n mac: {\n type: \"object\",\n properties: {\n category: { type: \"string\", minLength: 1 },\n additionalBinariesToSign: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n entitlements: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"plist\"],\n mustBeFile: true,\n },\n minLength: 1,\n },\n extendInfo: {\n type: \"object\",\n },\n icon: getIconSchema(),\n },\n },\n dmg: {\n type: \"object\",\n properties: {\n background: {\n type: \"string\",\n file: {\n from: context.projectRoot,\n extensions: [\"tiff\"],\n mustBeFile: true,\n },\n minLength: 1,\n },\n artifactName: { type: \"string\", minLength: 1 },\n backgroundColor: { type: \"string\", minLength: 1 },\n iconSize: { type: \"number\" },\n iconTextSize: { type: \"number\" },\n title: { type: \"string\", minLength: 1 },\n contents: {\n type: \"array\",\n items: {\n type: \"object\",\n properties: {\n x: { type: \"number\" },\n y: { type: \"number\" },\n },\n },\n },\n window: {\n type: \"object\",\n properties: {\n x: { type: \"number\" },\n y: { type: \"number\" },\n width: { type: \"number\" },\n height: { type: \"number\" },\n },\n },\n },\n },\n packageManager: {\n type: \"string\",\n enum: [\"npm\", \"yarn\", \"pnpm\"],\n },\n schemaVersion: { type: \"number\", minimum: 1, maximum: 1 },\n snap: {\n type: \"object\",\n properties: {\n after: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n appPartStage: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n assumes: getItemOrArrayOfItemsSchema({\n type: \"string\",\n minLength: 1,\n }),\n autoStart: {\n type: \"boolean\",\n },\n buildPackages: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n confinement: {\n type: \"string\",\n enum: [\"classic\", \"devmode\", \"strict\"],\n },\n environment: {\n type: \"object\",\n },\n grade: {\n type: \"string\",\n enum: [\"devel\", \"stable\"],\n },\n layout: {\n type: \"object\",\n },\n plugs: {\n type: \"array\",\n items: {\n anyOf: [\n {\n type: \"string\",\n minLength: 1,\n },\n {\n type: \"object\",\n },\n ],\n },\n },\n stagePackages: {\n type: \"array\",\n items: {\n type: \"string\",\n minLength: 1,\n },\n },\n summary: {\n type: \"string\",\n maxLength: 78,\n },\n useTemplateApp: {\n type: \"boolean\",\n },\n },\n },\n uploadSizeLimit: {\n type: \"number\",\n },\n windows: {\n type: \"object\",\n properties: {\n icon: getIconSchema([\"ico\"]),\n },\n },\n },\n };\n};\n", "import { PartialProjectConfig, ProjectConfig } from \"../../types\";\nimport logger from \"../logger\";\nimport loadConfig from \"./loadConfig\";\nimport { resolve } from \"path\";\nimport merge from \"lodash.merge\";\n\nexport default function computeFullProjectConfig(\n partialConfig: PartialProjectConfig,\n projectRoot: string\n): ProjectConfig {\n if (!partialConfig.extends) {\n logger.debug(\"No extends field, returning partial config\");\n return partialConfig as ProjectConfig;\n } else {\n logger.debug(\"Extends field found, resolving\");\n const parentConfigPath = resolve(projectRoot, partialConfig.extends);\n const parentConfig = loadConfig(parentConfigPath);\n const parentFullConfig = computeFullProjectConfig(\n parentConfig,\n projectRoot\n );\n\n const result = merge({}, parentFullConfig, partialConfig);\n\n delete result.extends;\n return result;\n }\n}\n", "import axios from \"axios\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport logger from \"./logger\";\n\nconst { TODESKTOP_CLI_FIREBASE_FUNCTIONS_BASE } = getEnvironmentVariables();\n\nexport default async function (functionName, body = {}, config = {}) {\n logger.debug({ functionName, body, config }, \"postToFirebaseFunction\");\n\n try {\n const response = await axios.post(\n `${TODESKTOP_CLI_FIREBASE_FUNCTIONS_BASE}${functionName}`,\n body,\n config\n );\n\n logger.debug(\n { responseData: response.data },\n \"postToFirebaseFunction: success\"\n );\n return response.data;\n } catch (e) {\n logger.error({ error: e }, \"postToFirebaseFunction: error\");\n throw e;\n }\n}\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async (key, receiver) => {\n const hasResolved = false;\n\n return new Promise<void>((resolve, reject) => {\n logger.debug({ key }, \"subscribeToFirebaseDoc\");\n firestore.doc(key).onSnapshot(\n (snapshot) => {\n receiver({\n snapshot,\n data: snapshot.exists ? snapshot.data() : undefined,\n });\n if (!hasResolved) {\n resolve();\n }\n },\n (err) => {\n reject(err);\n }\n );\n });\n};\n", "import subscribeToFirebaseDoc from \"./subscribeToFirebaseDoc\";\n\nexport default async ({ appId, buildId, onDataReceived, userId }) => {\n try {\n return await subscribeToFirebaseDoc(\n `users/${userId}/applications/${appId}/builds/${buildId}`,\n async ({ data }) => {\n onDataReceived(data);\n }\n );\n } catch (e) {\n e.message = `Failed while subscribing to build; ${e.message}`;\n throw e;\n }\n};\n", "import fastGlob from \"fast-glob\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport generateS3Key from \"./generateS3Key\";\nimport logger from \"./logger\";\nimport uploadToS3 from \"./uploadToS3\";\nimport zip from \"./zip\";\n\nconst getAppFiles = async (globsInput, appPath, appPkgJson) => {\n const globs = [\"!node_modules\", \"!**/node_modules\", \"!.git\", \"!**/.git\"];\n\n if (globsInput && globsInput.length) {\n globs.push(\n ...globsInput,\n path.join(appPath, \"package.json\"),\n path.join(appPath, \"package-lock.json\"),\n path.join(appPath, \"yarn.lock\"),\n path.join(appPath, \"pnpm-lock.yaml\"),\n path.join(appPath, \"shrinkwrap.yaml\")\n );\n } else {\n globs.push(\"**\");\n }\n\n // automatically add hooks to `appFiles` if they exist\n for (const hookName of [\"todesktop:beforeInstall\", \"todesktop:afterPack\"]) {\n if (appPkgJson.scripts && appPkgJson.scripts[hookName]) {\n globs.push(path.join(appPath, appPkgJson.scripts[hookName]));\n }\n }\n\n const normalizedGlobs = globs\n .map((glob) => {\n // Make relative if it's not\n const globToUse = path.isAbsolute(glob)\n ? path.relative(appPath, glob)\n : glob;\n\n return (\n globToUse\n // Globs must always have forward slashes\n .replace(/\\\\/g, \"/\")\n // Remove trailing slash\n .replace(/\\/+$/, \"\")\n );\n })\n .filter((glob) => !glob.startsWith(\"..\") && !glob.startsWith(\"!..\"));\n\n let absolutePaths = await fastGlob(normalizedGlobs, {\n absolute: true,\n cwd: appPath,\n dot: true,\n followSymbolicLinks: false,\n onlyDirectories: false,\n onlyFiles: true,\n globstar: true,\n unique: true,\n });\n\n if (process.platform === \"win32\") {\n absolutePaths = absolutePaths.map((absolutePath) =>\n absolutePath.replace(/\\//g, path.sep)\n );\n }\n\n if (!absolutePaths || !absolutePaths.length) {\n throw new Error(\"No files found to upload\");\n } else if (\n !absolutePaths.filter((absolutePath) => absolutePath.endsWith(\".js\")).length\n ) {\n throw new Error(\n `No .js files found to upload (${absolutePaths[0]}). There's likely an issue with the appFiles option. Learn more at https://www.npmjs.com/package/@todesktop/cli#appfiles----optional-array-of-glob-patterns. If this is not the case, please contact us.`\n );\n } else {\n let mainFilePath = appPath;\n if (appPkgJson.main) {\n mainFilePath = path.join(mainFilePath, appPkgJson.main);\n }\n\n if (fs.statSync(mainFilePath).isDirectory()) {\n mainFilePath = path.join(mainFilePath, \"index.js\");\n }\n\n // Make sure the \"main\" file is included\n if (!absolutePaths.includes(mainFilePath)) {\n throw new Error(\n `The \"main\" file specified in your package.json (${\n appPkgJson.main\n ? path.relative(appPath, mainFilePath)\n : \"defaults to index.js\"\n }) is not set to be uploaded to our servers. This is likely due to how you have configured the \\`appFiles\\` option. Learn more at https://www.npmjs.com/package/@todesktop/cli#appfiles----optional-array-of-glob-patterns. If this is not the case, please contact us.`\n );\n }\n }\n\n return absolutePaths.map((absolutePath) => {\n return {\n from: absolutePath,\n to: path.join(\"app\", path.relative(appPath, absolutePath)),\n };\n });\n};\n\nexport default async ({ appId, appPkgJson, buildId, config, onProgress }) => {\n logger.debug(\n {\n appId,\n appPkgJson,\n buildId,\n config,\n onProgress,\n },\n \"uploadApplicationSource\"\n );\n // eslint-disable-next-line no-unused-vars,@typescript-eslint/no-unused-vars\n let totalBytes = 0;\n\n const files = [\n /*\n App files (stored in app/ in the ZIP)\n */\n ...(await getAppFiles(config.appFiles, config.appPath, appPkgJson)),\n\n /*\n Optional extra content files (stored in extraContentFiles/ in the ZIP). Their\n paths within is the their relative path from the project root so\n there will be no issues with clashing filenames. We also don't\n also any file paths in our todesktop.json that are outside of the\n project directory\n */\n ...(config.extraContentFiles || []).map(({ from, to = \".\" }) => {\n return {\n from,\n to: path.join(\"extraContentFiles\", to, path.basename(from)),\n };\n }),\n\n /*\n Optional extra resources (stored in extraResources/ in the ZIP).\n Similar to extra content files above\n */\n ...(config.extraResources || []).map(({ from, to = \".\" }) => {\n return {\n from,\n to: path.join(\"extraResources\", to, path.basename(from)),\n };\n }),\n\n /*\n Icons (more may be added below)\n */\n {\n from: config.icon,\n to: path.join(\"icons\", \"appIcon\" + path.extname(config.icon)),\n },\n ];\n\n if (config.linux) {\n if (config.linux.icon) {\n files.push({\n from: config.linux.icon,\n to: path.join(\n \"icons\",\n \"appIcon-linux\" + path.extname(config.linux.icon)\n ),\n });\n }\n }\n\n if (config.mac) {\n if (config.mac.entitlements) {\n files.push({\n from: config.mac.entitlements,\n to: path.join(\"other\", \"mac\", \"entitlements.mac.plist\"),\n });\n }\n\n if (config.mac.icon) {\n files.push({\n from: config.mac.icon,\n to: path.join(\"icons\", \"appIcon-mac\" + path.extname(config.mac.icon)),\n });\n }\n }\n\n if (config.dmg) {\n if (config.dmg.background) {\n files.push({\n from: config.dmg.background,\n to: path.join(\"other\", \"mac\", \"dmg-background.tiff\"),\n });\n }\n }\n\n if (config.windows) {\n if (config.windows.icon) {\n files.push({\n from: config.windows.icon,\n to: path.join(\n \"icons\",\n \"appIcon-windows\" + path.extname(config.windows.icon)\n ),\n });\n }\n }\n\n return uploadToS3({\n bucket: config.bucket || undefined,\n inputStream: await zip({\n files,\n fileSizeLimit: config.uploadSizeLimit,\n onError: (e) => {\n throw e;\n },\n onProgress({ fs }) {\n totalBytes = fs.totalBytes;\n },\n appPkgJson,\n }),\n key: generateS3Key({\n appId,\n buildId,\n filenameSuffix: `${appPkgJson.name}.zip`,\n }),\n onProgress({ loaded, total }) {\n onProgress((loaded / total) * 100, loaded);\n },\n });\n};\n", "export default ({ appId, buildId, filenameSuffix }) =>\n `${appId}/sourceArchives/${buildId}--${filenameSuffix}`;\n", "import superagent from \"superagent\";\nimport util from \"util\";\nimport streamToArray from \"stream-to-array\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\nimport logger from \"./logger\";\nimport getCallableFirebaseFunction from \"./getCallableFirebaseFunction\";\n\nconst { TODESKTOP_CLI_S3_BUCKET } = getEnvironmentVariables();\n\nexport default async ({\n bucket = TODESKTOP_CLI_S3_BUCKET,\n inputStream,\n key,\n onProgress = () => {},\n}: {\n bucket?: string;\n inputStream;\n key: string;\n onProgress: (event: { loaded: number; total: number }) => void;\n}) => {\n const { data } = await getCallableFirebaseFunction(\"getSignedURL\")({\n key,\n });\n const body = await new Promise((resolve) => {\n streamToArray(inputStream).then(function (parts) {\n const buffers = parts.map((part) =>\n util.isBuffer(part) ? part : Buffer.from(part)\n );\n return resolve(Buffer.concat(buffers));\n });\n });\n\n return new Promise((resolve) => {\n superagent\n .put(data.signedURL)\n .send(body)\n .set(\"content-type\", \"application/zip\")\n .on(\"progress\", (event) => onProgress(event))\n .end(() => {\n logger.debug({ bucket, key, url: data.uploadURL }, \"uploadToS3\");\n resolve({ bucket, key, url: data.uploadURL });\n });\n\n return { bucket, key, url: data.uploadURL };\n });\n};\n", "import archiver from \"archiver\";\nimport du from \"du\";\nimport fs from \"fs\";\nimport chalk from \"chalk\";\nimport logger from \"./logger\";\nimport path from \"path\";\n\nexport default async function ({\n files,\n fileSizeLimit = 20,\n onError,\n onProgress,\n appPkgJson,\n}) {\n logger.debug({ files }, \"zip\");\n const stream = archiver(\"zip\");\n\n // good practice to catch warnings (ie stat failures and other non-blocking errors)\n stream.on(\"warning\", function (err) {\n if (err.code === \"ENOENT\") {\n console.warn(err);\n logger.warn({ err }, \"zip: stream warning ENOENT\");\n } else {\n // throw error\n onError(err);\n }\n });\n\n // good practice to catch this error explicitly\n stream.on(\"error\", function (err) {\n onError(err);\n });\n\n // Grab the file size and more\n const processedFiles = await Promise.all(\n files.map(async (file) => {\n const stats = fs.lstatSync(file.from);\n const isDirectory = stats.isDirectory();\n\n return {\n ...file,\n isDirectory,\n stats,\n size: isDirectory ? await du(file.from) : stats.size,\n };\n })\n );\n\n const totalFileSize = processedFiles.reduce((sum, b) => sum + b.size, 0);\n // Does file size sum exceed limit?\n if (totalFileSize > fileSizeLimit * 1000000) {\n onError(\n new Error(\n [\n `\\n\\nYour app is larger than ${fileSizeLimit}MB. Your app is ${chalk.bold.red.underline(\n (totalFileSize / 1000000).toFixed(1) + \"MB\"\n )}.\\n`,\n `You may be including unnecessary files in your app(see the \\`appPath\\` and \\`appFiles\\` options).`,\n `If not, this limit can be raised by setting the \\`uploadSizeLimit\\` option.`,\n `Learn more at https://www.npmjs.com/package/@todesktop/cli#uploadsizelimit---optional-number`,\n ].join(\"\\n\")\n )\n );\n return stream;\n }\n\n // Add the files to the ZIP\n processedFiles.forEach(({ from, isDirectory, stats, to }) => {\n if (isDirectory) {\n stream.directory(from, to);\n } else if (appPkgJson && to === path.join(\"app\", \"package.json\")) {\n stream.append(JSON.stringify(appPkgJson), {\n name: to,\n });\n } else {\n stream.file(from, { name: to, mode: stats.mode });\n }\n });\n\n // finalize the archive (ie we are done appending files but streams have to finish yet)\n // 'close', 'end' or 'finish' may be fired right after calling this method so register to them beforehand\n stream.finalize();\n\n stream.on(\"progress\", (progress) =>\n onProgress({\n ...progress,\n percentage: (progress.entries.processed / progress.entries.total) * 100,\n })\n );\n\n return stream;\n}\n", "import merge from \"lodash.merge\";\nimport path from \"path\";\nimport readJson from \"./readJson\";\n\nfunction deleteNullDeps(dep) {\n Object.keys(dep).forEach((key) => {\n if (dep[key] === null) {\n delete dep[key];\n }\n });\n return dep;\n}\n\n/**\n * Remove any dependencies or devDependencies that have a version of null.\n * This is useful for removing dependencies that are not to be used when building\n * in ToDesktop. For example this will remove the `electron-builder` dev dependency\n * from the package.json file when building in ToDesktop:\n * {\n * \"devDependencies\": {\n * \"electron-builder\": null\n * }\n * }\n */\nfunction removeNullDependencies(pkgJson) {\n const { dependencies, devDependencies } = pkgJson;\n\n if (dependencies) {\n pkgJson.dependencies = deleteNullDeps(dependencies);\n }\n\n if (devDependencies) {\n pkgJson.devDependencies = deleteNullDeps(devDependencies);\n }\n\n return pkgJson;\n}\n\nfunction getAppPkgJson({ config }) {\n const packageJsonFromConfig = config.packageJson || {};\n const extendsFrom = packageJsonFromConfig.extends || \"package.json\";\n const packageJsonFromFile = readJson(path.join(config.appPath, extendsFrom));\n\n return removeNullDependencies(\n merge({}, packageJsonFromFile, packageJsonFromConfig)\n );\n}\n\nexport default getAppPkgJson;\n", "// X build has failed, should we exit? I.e. is it settled?\nexport default (build) => {\n const hasBuildSettled = [\"linux\", \"mac\", \"windows\"].every(\n (platform) =>\n build[platform].shouldSkip ||\n \"succeeded\" === build[platform].status ||\n (\"failed\" === build[platform].status &&\n build[platform].numberOfAttemptedBuilds === 2)\n );\n\n const hasSettledWithError = [\"linux\", \"mac\", \"windows\"].some(\n (platform) => \"failed\" === build[platform].status\n );\n\n return hasBuildSettled && hasSettledWithError;\n};\n", "import { useState } from \"react\";\n\n/*\n This should be called at the top of all commands to test if React\n is OK and if not, to exit cleanly.\n\n If React throws an error (e.g. when there are multiple versions of\n React in the customer's dependency tree), then we need to exit with\n a non-zero error code and not with an uncaught exception somewhere.\n\n These parameters exist only to make things more testable\n*/\nexport default ({ cons = console, proc = process } = {}) => {\n try {\n useState(null);\n } catch (e) {\n cons.error(e);\n proc.exit(1);\n }\n};\n", "import { Text, useStdin, useStdout } from \"ink\";\nimport { useState, useEffect } from \"react\";\nimport PropTypes from \"prop-types\";\nimport isCi from \"is-ci\";\n\n// components\nimport Login from \"./Login\";\n\n// logic\nimport { signInWithCustomToken } from \"../utilities/firestore\";\nimport { getAuthConfig, setAuthConfig } from \"../utilities/configStore\";\nimport postToFirebaseFunction from \"../utilities/postToFirebaseFunction\";\nimport getEnvironmentVariables from \"../utilities/getEnvironmentVariables\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport LoadingText from \"./LoadingText\";\n\nconst LoginHOC = ({ children, isInteractive = true }) => {\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n const [isEffectDone, setEffectDone] = useState(false);\n const [error, setError] = useState(null);\n const { isRawModeSupported } = useStdin();\n const { stdout } = useStdout();\n const stdOutRedirected = !stdout.isTTY;\n\n const onFailure = (message, err = {}) => {\n setError({\n ...err,\n message,\n });\n };\n\n // use effect for determining if tokens exist and are valid\n useEffect(() => {\n async function isAccessTokenValid() {\n const { accessToken, email, jwtToken } = getAuthConfig();\n let userCreds = null;\n\n const { TODESKTOP_ACCESS_TOKEN, TODESKTOP_EMAIL } =\n getEnvironmentVariables();\n\n // 1. attempt log in with environment variables if present\n try {\n if (TODESKTOP_ACCESS_TOKEN && TODESKTOP_EMAIL) {\n const newJwtToken = await postToFirebaseFunction(\n \"loginWithAccessToken\",\n {\n email: TODESKTOP_EMAIL,\n accessToken: TODESKTOP_ACCESS_TOKEN,\n }\n );\n\n if (newJwtToken) {\n userCreds = await signInWithCustomToken(newJwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n // if no environment variables set and is in a CI, set alert message and exit\n } else if (!isRawModeSupported || isCi) {\n onFailure(\n \"ToDesktop environment variables not found. When automating builds with your CI provider, you need to specify environment variables for TODESKTOP_EMAIL and TODESKTOP_ACCESS_TOKEN.\"\n );\n }\n } catch (err) {\n // print error and stop the app execution if env variables attempted\n onFailure(\"Log in with environment variables failed.\", err);\n }\n\n // 2. attempt log in with jwtToken if present\n try {\n if (!userCreds && jwtToken) {\n userCreds = await signInWithCustomToken(jwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n } catch (err) {\n // do nothing, attempt login with accessToken and email\n }\n\n // 3. attempt log in with accessToken and email on disk\n try {\n if (!userCreds && accessToken && email) {\n const newJwtToken = await postToFirebaseFunction(\n \"loginWithAccessToken\",\n { email, accessToken }\n );\n\n if (newJwtToken) {\n userCreds = await signInWithCustomToken(newJwtToken);\n setAuthConfig(email, accessToken, newJwtToken);\n if (userCreds.user) setIsLoggedIn(true);\n }\n }\n } catch (err) {\n // do nothing: no error state and not logged in state means render login\n }\n\n setEffectDone(true);\n }\n\n isAccessTokenValid();\n }, []);\n\n if (error && isInteractive) {\n return <ErrorDisplay error={error} />;\n }\n\n if (!isEffectDone) {\n return <LoadingText />;\n }\n\n if (!isLoggedIn && isInteractive) {\n return <Login setIsLoggedIn={setIsLoggedIn} />;\n }\n\n return <>{children}</>;\n};\n\nLoginHOC.propTypes = {\n children: PropTypes.object,\n isInteractive: PropTypes.bool,\n};\n\nexport default LoginHOC;\n", "// modules\nimport { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useState } from \"react\";\nimport { Form, Field } from \"react-final-form\";\n\n// components\nimport TextInput from \"./TextInput\";\nimport ErrorDisplay from \"./ErrorDisplay\";\n\n// logic\nimport postToFirebaseFunction from \"../utilities/postToFirebaseFunction\";\nimport { signInWithCustomToken } from \"../utilities/firestore\";\nimport { setAuthConfig } from \"../utilities/configStore\";\n\nconst loginFields = [\n {\n name: \"email\",\n label: \"Your email\",\n placeholder: \"name@email.com\",\n Input: TextInput,\n validate: (value) => {\n if (!value) return \"Required\";\n },\n },\n {\n name: \"accessToken\",\n label: \"Your access token\",\n placeholder: \"********\",\n Input: TextInput,\n validate: (value) => {\n if (!value) return \"Required\";\n },\n mask: \"*\",\n },\n];\n\nconst Login = ({ setIsLoggedIn }) => {\n const [activeField, setActiveField] = useState(0);\n const [error, setError] = useState(null);\n const [failureMessage, setFailureMessage] = useState(null);\n const [isSubmittingForm, setIsSubmittingForm] = useState(false);\n\n const onFailure = (message) => {\n setIsSubmittingForm(false);\n setFailureMessage(message);\n setActiveField(0);\n };\n\n // login handler that verifies accessToken and email with that in firebase\n const onSubmitLogin = async ({ email, accessToken }) => {\n setFailureMessage(null);\n setIsSubmittingForm(true);\n\n try {\n const jwtToken = await postToFirebaseFunction(\"loginWithAccessToken\", {\n email,\n accessToken,\n });\n\n if (jwtToken) {\n await signInWithCustomToken(jwtToken);\n setAuthConfig(email, accessToken, jwtToken);\n setIsLoggedIn(true);\n } else {\n onFailure(\"Incorrrect credentials. Try again\");\n }\n } catch (err) {\n if (err.code === 500) {\n setError(err);\n } else {\n onFailure(`Login unsuccessful: ${err.message}`);\n }\n }\n };\n\n if (error) return <ErrorDisplay error={error} />;\n\n return (\n <>\n <Text>You are not currently logged in.</Text>\n <Text>Log in below:</Text>\n <Box marginBottom={1} />\n <Form onSubmit={onSubmitLogin}>\n {({ handleSubmit, validating }) => (\n <Box flexDirection=\"column\">\n {loginFields.map(\n ({ name, label, placeholder, validate, Input, mask }, index) => (\n <Field name={name} key={name} validate={validate}>\n {({ input, meta }) => (\n <Box flexDirection=\"column\">\n {activeField >= index ? (\n <Box>\n <Text bold={activeField === index}>{label}: </Text>\n {activeField === index ? (\n <Input\n {...input}\n mask={mask}\n placeholder={placeholder}\n onSubmit={() => {\n if (meta.valid && !validating) {\n setActiveField((value) => value + 1); // go to next field\n if (activeField === loginFields.length - 1) {\n // last field, so submit\n handleSubmit();\n }\n } else {\n input.onBlur(); // mark as touched to show error\n }\n }}\n />\n ) : (\n (input.value && (\n <Text>\n {name === \"accessToken\"\n ? input.value.replace(/./gi, \"*\")\n : input.value}\n </Text>\n )) ||\n (placeholder && (\n <Text color=\"gray\">{placeholder}</Text>\n ))\n )}\n {meta.invalid && meta.touched && (\n <Box marginLeft={2} marginRight={1}>\n <Text color=\"red\">\u2716</Text>\n </Box>\n )}\n {meta.error && meta.touched && (\n <Error errorMessage={meta.error} />\n )}\n </Box>\n ) : null}\n </Box>\n )}\n </Field>\n )\n )}\n </Box>\n )}\n </Form>\n\n {isSubmittingForm && (\n <Box marginTop={1}>\n <Text>Logging in...</Text>\n </Box>\n )}\n\n {failureMessage && <Error errorMessage={failureMessage} marginTop />}\n </>\n );\n};\n\nconst Error = ({ errorMessage, marginTop }) => (\n <Box marginTop={marginTop ? 1 : 0}>\n <Text color=\"red\">{errorMessage}</Text>\n </Box>\n);\n\nError.propTypes = {\n errorMessage: PropTypes.string.isRequired,\n marginTop: PropTypes.bool,\n};\n\nLogin.propTypes = {\n setIsLoggedIn: PropTypes.func.isRequired,\n};\n\nexport default Login;\n", "import InkTextInput from \"ink-text-input\";\nimport React from \"react\";\n\nconst TextInput = ({ onBlur, onFocus, ...props }: TextInputProps) => {\n React.useEffect(() => {\n onFocus();\n return onBlur;\n }, [onFocus, onBlur]);\n return <InkTextInput {...props} showCursor />;\n};\n\nexport default TextInput;\n\ntype InkTextInputProps = React.ComponentProps<typeof InkTextInput>;\ninterface TextInputProps extends InkTextInputProps {\n onBlur: () => void;\n onFocus: () => void;\n}\n", "import { Text, useStdout } from \"ink\";\n\nconst LoadingText = () => {\n const { stdout } = useStdout();\n const stdOutRedirected = !stdout.isTTY;\n if (stdOutRedirected) {\n // Don't write Loading text if we're not in a TTY (e.g... redirected to a file)\n return null;\n }\n\n return <Text>Loading...</Text>;\n};\n\nexport default LoadingText;\n", "import React, { ReactNode } from \"react\";\nimport * as Sentry from \"@sentry/node\";\n\nclass ErrorBoundary extends React.Component<\n { children: ReactNode },\n { error?: Error; eventId?: string }\n> {\n constructor(props) {\n super(props);\n this.state = { eventId: null, error: null };\n }\n\n static getDerivedStateFromError(error) {\n return { error };\n }\n\n componentDidCatch(error, errorInfo) {\n Sentry.withScope((scope) => {\n scope.setExtras(errorInfo);\n const eventId = Sentry.captureException(error);\n this.setState({ eventId });\n });\n }\n\n render() {\n if (this.state.error) {\n throw this.state.error;\n }\n return this.props.children;\n }\n}\n\nexport default ErrorBoundary;\n", "import { Box, Text, useStdin } from \"ink\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport CancelBuild from \"./CancelBuild\";\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport CustomSelectInputItem from \"./CustomSelectInputItem\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport ViewBuild from \"./ViewBuild\";\nimport { isBuildCancellable, isBuildRunning } from \"../utilities/buildStatus\";\nimport firestore from \"../utilities/firestore\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logger from \"../utilities/logger\";\nimport useInput from \"../utilities/useInput\";\nimport useExit from \"../utilities/useExit\";\nimport isCi from \"is-ci\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst OngoingBuildGuard = ({ children, commandUsed, configPath }) => {\n const { isRawModeSupported } = useStdin();\n const onInput = useInput();\n const exit = useExit();\n const [{ appId, builds, error, isLoading, itemChosen }, setState] = useState({\n appId: null,\n builds: [],\n error: null,\n isLoading: true,\n itemChosen: null,\n });\n\n useEffect(() => {\n if (!isLoading) {\n return;\n }\n\n (async () => {\n try {\n const applicationId = getProjectConfig(configPath).config.id;\n const { id } = await findAppUserId(applicationId);\n\n const buildsResult = await firestore\n .doc(`users/${id}/applications/${applicationId}`)\n .collection(\"builds\")\n .orderBy(\"createdAt\", \"desc\")\n .limit(10)\n .get();\n\n const stateUpdates = {\n appId: applicationId,\n isLoading: false,\n builds: [],\n };\n\n if (!buildsResult.empty) {\n const latestBuild = buildsResult.docs[0].data();\n const isRunning =\n isBuildRunning(latestBuild) && latestBuild.status !== \"preparation\";\n logger.debug(\n { isRunning },\n \"OngoingBuildGuard component: got latest build\"\n );\n\n stateUpdates.builds = buildsResult.docs\n .map((doc) => doc.data())\n .filter((build) => {\n if (isBuildRunning(build) && build.status !== \"preparation\") {\n return true;\n }\n return false;\n });\n }\n\n setState((previousState) => ({\n ...previousState,\n ...stateUpdates,\n }));\n } catch (e) {\n setState((previousState) => ({\n ...previousState,\n error: e,\n }));\n }\n })();\n }, [builds, itemChosen, isLoading, isRawModeSupported]);\n\n /*\n Because we're using <SelectInput/>, we need to explicitly handle when\n ctrl+c is pressed. `onInput` takes care of that.\n See https://github.com/vadimdemedes/pastel/issues/38\n */\n if (isRawModeSupported) {\n // Input causes an error on if stdin does not support raw mode\n onInput(() => {});\n }\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (isLoading) {\n return <Text>...</Text>;\n }\n\n if (itemChosen) {\n logger.debug({ itemChosen }, \"OngoingBuildGuard component: item chosen\");\n const build = builds.find(Boolean);\n\n if (itemChosen.value === \"view\") {\n return <ViewBuild commandUsed={commandUsed} id={build.id} />;\n } else if (itemChosen.value === \"cancel\") {\n return (\n <CancelBuild appId={appId} commandUsed={commandUsed} id={build.id}>\n {children}\n </CancelBuild>\n );\n } else if (itemChosen.value === \"concurrent\") {\n return <>{children}</>;\n } else {\n setTimeout(exit, 10);\n }\n }\n\n if (builds.length && isCi === false && isRawModeSupported) {\n const latestBuild = builds.find(Boolean);\n const multiple = builds.length > 1;\n\n const items = [\n {\n label: `View ${multiple ? \"latest\" : \"it\"}`,\n value: \"view\",\n },\n ];\n\n if (builds.some((build) => isBuildCancellable(build))) {\n items.push({\n label: `Cancel ${multiple ? \"latest\" : \"it\"} and start a new build`,\n value: \"cancel\",\n });\n\n items.push({\n label: \"Start a concurrent build\",\n value: \"concurrent\",\n });\n }\n\n items.push({\n label: \"Exit\",\n value: \"exit\",\n });\n const handleSelect = (itemChosen) =>\n setState((previousState) => ({ ...previousState, itemChosen }));\n\n return (\n <>\n <Box marginBottom={1}>\n <Text bold>\n {multiple\n ? \"There are ongoing builds \"\n : \"There is an ongoing build \"}\n </Text>\n <Text>\n ({latestBuild.appName}\n {latestBuild.appVersion ? ` v${latestBuild.appVersion}` : \"\"})\n </Text>\n </Box>\n <SelectInput\n indicatorComponent={CustomSelectInputIndicator}\n itemComponent={CustomSelectInputItem}\n items={items}\n onSelect={handleSelect}\n />\n </>\n );\n } else {\n return <>{children}</>;\n }\n};\n\nOngoingBuildGuard.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n children: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n configPath: PropTypes.string,\n};\n\nexport default OngoingBuildGuard;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst CustomSelectInputIndicator = ({ isSelected, ...props }) => (\n <Box marginRight={1} {...props}>\n <Text>{isSelected ? (process.platform === \"win32\" ? \">\" : \"\u276F\") : \" \"}</Text>\n </Box>\n);\n\nCustomSelectInputIndicator.propTypes = {\n isSelected: PropTypes.bool.isRequired,\n};\n\nexport default CustomSelectInputIndicator;\n", "import { Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\nconst CustomSelectInputItem = ({ isSelected, label, ...props }) => (\n <Text bold={isSelected} color={isSelected ? undefined : \"gray\"} {...props}>\n {label}\n </Text>\n);\n\nCustomSelectInputItem.propTypes = {\n isSelected: PropTypes.bool.isRequired,\n label: PropTypes.string.isRequired,\n};\n\nexport default CustomSelectInputItem;\n", "// libs\nimport { Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\n\n// components\nimport BuildProgress from \"./BuildProgress\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport MainLayout from \"./MainLayout\";\n\n// utils\nimport getLatestBuildId from \"../utilities/getLatestBuildId\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logForCI from \"../utilities/logForCI\";\nimport shouldExitOnBuildFailure from \"../utilities/shouldExitOnBuildFailure\";\nimport subscribeToBuild from \"../utilities/subscribeToBuild\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\nimport LoadingText from \"./LoadingText\";\n\nconst ViewBuild = ({ commandUsed, id, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n arbitraryMessageComponent,\n build,\n error,\n hasBuildEverFailed,\n isLoading,\n },\n setState,\n ] = useState({\n appId: null,\n arbitraryMessageComponent: null,\n build: null,\n error: null,\n hasBuildEverFailed: false,\n isLoading: true,\n });\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n let firebaseUnsubscribe;\n\n async function viewBuild() {\n let config;\n try {\n // This will throw if validation fails:\n config = getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const { id: userId } = await findAppUserId(config.id);\n\n const subscribe = (buildId) => {\n subscribeToBuild({\n appId: config.id,\n buildId,\n onDataReceived: (data) => {\n if (!data) {\n onError(\n new Error(\n `No such build exists (${buildId}). Please contact us if this is an error`\n )\n );\n }\n setState((prevState) => ({\n ...prevState,\n appId: config.id,\n build: data,\n isLoading: false,\n }));\n },\n userId,\n })\n .then((firebaseUnsubscribeResult) => {\n firebaseUnsubscribe = firebaseUnsubscribeResult;\n })\n .catch(onError);\n };\n\n if (id) {\n subscribe(id);\n } else {\n getLatestBuildId({ appId: config.id, userId })\n .catch(onError)\n .then((latestBuildId) => {\n if (!latestBuildId) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: <Text>There are no builds yet</Text>,\n }));\n return;\n }\n return subscribe(latestBuildId);\n });\n }\n }\n\n viewBuild();\n\n return () => {\n if (firebaseUnsubscribe) {\n firebaseUnsubscribe();\n }\n };\n }, [id]);\n\n // Exit if the build has errored and settled\n useEffect(() => {\n if (hasBuildEverFailed && shouldExitOnBuildFailure(build)) {\n setTimeout(() => exit(new Error(\"Build has failed\")), 10);\n }\n }, [build, exit, hasBuildEverFailed]);\n\n // Exit once an arbitrary message exists\n useEffect(() => {\n if (arbitraryMessageComponent) {\n setTimeout(() => exit(new Error(\"Validation failed\")), 10);\n }\n }, [arbitraryMessageComponent, exit]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (isLoading) {\n return <LoadingText />;\n }\n\n const onBuildFailure = () => {\n if (hasBuildEverFailed) {\n return;\n }\n setState((prevState) => ({\n ...prevState,\n hasBuildEverFailed: true,\n }));\n };\n\n return (\n <MainLayout\n appId={appId}\n appName={build.appName}\n appVersion={build.appVersion}\n build={build}\n commandUsed={commandUsed}\n hasBuildEverFailed={hasBuildEverFailed}\n >\n <BuildProgress build={build} onBuildFailure={onBuildFailure} />\n </MainLayout>\n );\n};\n\nViewBuild.propTypes = {\n id: (props, propName, componentName) => {\n if ([props.id, props.shouldViewLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldViewLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.id;\n if (![\"string\", \"undefined\"].includes(type)) {\n return new Error(\n `'id' is a '${type}', not a string, in '${componentName}'.`\n );\n }\n },\n commandUsed: PropTypes.string.isRequired,\n shouldViewLatest: (props, propName, componentName) => {\n if ([props.id, props.shouldViewLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldViewLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.shouldViewLatest;\n if (![\"boolean\", \"undefined\"].includes(type)) {\n return new Error(\n `'shouldViewLatest' is a '${type}', not a boolean, in '${componentName}'.`\n );\n }\n },\n configPath: PropTypes.string,\n};\n\nexport default ViewBuild;\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({ appId, userId }) => {\n logger.debug({ appId }, \"getLatestBuildId\");\n const appRef = firestore.doc(`users/${userId}/applications/${appId}`);\n const appSnapshot = await appRef.get();\n\n if (!appSnapshot.exists) {\n throw new Error(`Application with ID of ${appId} doesn't exist.`);\n }\n\n const buildsResult = await appRef\n .collection(\"builds\")\n .orderBy(\"createdAt\", \"desc\")\n .limit(1)\n .get();\n\n if (buildsResult.empty) {\n return null;\n } else {\n return buildsResult.docs[0].id;\n }\n};\n", "import firestore, { currentUser } from \"./firestore\";\n\nconst getCollection = (collectionRef) => {\n return collectionRef.get().then((resp) => {\n const result = [];\n resp.forEach((doc) => result.push(doc.data()));\n return result;\n });\n};\n\nconst acceptedUsersCollection = (id) =>\n firestore.collection(`users/${id}/acceptedUsers`);\n\nconst findAppUserId = async (appId) => {\n const { uid, email } = currentUser();\n const acceptedUsers = await getCollection(acceptedUsersCollection(uid));\n const primaryUser = { id: uid, label: email };\n\n const users = [\n primaryUser,\n ...acceptedUsers.map((user) => ({ id: user.id, label: user.email })),\n ];\n\n for (const user of users) {\n try {\n const doc = await firestore\n .doc(`users/${user.id}/applications/${appId}`)\n .get();\n\n if (doc.exists) return user;\n } catch (err) {\n // will throw an error if user doesn't have access\n }\n }\n\n return primaryUser;\n};\n\nexport default findAppUserId;\n", "import { useEffect, useState } from \"react\";\n\nimport { onUserAuth } from \"./firestore\";\nimport { identify, track, ANALYTICS_EVENT } from \"./analytics\";\nimport logger from \"./logger\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\n\nexport const useAnalyticsCommand = (\n command,\n flags: any = {},\n properties = {}\n) => {\n const [hasAttemptedTracking, setTrackingAttempt] = useState(false);\n\n logger.info({ command, flags, properties }, \"useAnalyticsCommand\");\n\n try {\n if (flags.projectPath) {\n properties = {\n ...properties,\n ...getProjectConfig(),\n };\n }\n } catch (err) {\n // do nothing\n }\n\n useEffect(() => {\n const authUnsubscribe = onUserAuth(async (user) => {\n /**\n * Only identify if there's a user id (stops use of anon id).\n * Subsequent track callback will thus always be tied to a user.\n */\n if (user.uid) {\n identify(\n user.uid,\n {\n email: user.email,\n displayName: user.displayName,\n },\n () => {\n track(\n ANALYTICS_EVENT.CLI_COMMAND,\n {\n ...properties,\n flags,\n command,\n },\n () => setTrackingAttempt(true)\n );\n authUnsubscribe && authUnsubscribe();\n }\n );\n }\n });\n\n // if it takes longer than 5 secs to identify a user, just set the\n // tracking attempt to true so that other commands aren't waiting\n // forever to terminate (see whoami component)\n setTimeout(() => setTrackingAttempt(true), 5000);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); // leave empty - this should only ever execute once (on mount)\n\n return { hasAttemptedTracking };\n};\n", "import Build from \"../components/Build\";\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport OngoingBuildGuard from \"../components/OngoingBuildGuard\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst BuildCommand = ({\n shouldCodeSign = true,\n configPath = null,\n}: {\n shouldCodeSign?: boolean;\n configPath?: string;\n}) => {\n checkIfReactIsUsable();\n\n useAnalyticsCommand(\"build\", {\n codeSign: shouldCodeSign,\n config: configPath,\n });\n\n const commandUsed = \"todesktop build\";\n\n return (\n <ErrorBoundary>\n <LoginHOC>\n <OngoingBuildGuard configPath={configPath} commandUsed={commandUsed}>\n <Build\n commandUsed={commandUsed}\n shouldCodeSign={shouldCodeSign}\n configPath={configPath}\n />\n </OngoingBuildGuard>\n </LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default BuildCommand;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport Table from \"./Table\";\nimport capitalize from \"../utilities/capitalize\";\nimport getBuilds from \"../utilities/getBuilds\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport getRelativeDateFromDateString from \"../utilities/getRelativeDateFromDateString\";\nimport logForCI from \"../utilities/logForCI\";\nimport useInput from \"../utilities/useInput\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\nimport SyntaxHighlight from \"./SyntaxHighlight\";\nimport LoadingText from \"./LoadingText\";\n\nconst ViewBuilds = ({\n commandUsed,\n configPath,\n count,\n format,\n exit: shouldExitAfterViewingBuilds = false,\n}) => {\n const exit = useExit();\n const [\n {\n builds,\n error,\n hasMoreToLoad,\n isInitialLoadComplete,\n isLoading,\n projectConfig,\n startAfter,\n user,\n },\n setState,\n ] = useState({\n builds: [],\n error: null,\n hasMoreToLoad: true,\n isInitialLoadComplete: false,\n isLoading: false,\n projectConfig: null,\n startAfter: null,\n user: null,\n });\n\n const onInput = useInput();\n\n onInput((input, key) => {\n if (key.escape) {\n exit();\n }\n\n if (input === \" \" || key.downArrow || key.pageDown || key.return) {\n if (!isInitialLoadComplete || !hasMoreToLoad) {\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n startAfter: builds[builds.length - 1].createdAt,\n }));\n }\n });\n\n useEffect(() => {\n async function viewBuilds() {\n if (\n error ||\n isLoading ||\n (isInitialLoadComplete && (!hasMoreToLoad || !startAfter))\n ) {\n return;\n }\n\n if (![\"table\", \"json\"].includes(format)) {\n setState((previousState) => ({\n ...previousState,\n error: new Error(\n `Invalid output format \"${format}\". Valid formats are \"table\" and \"json\".`\n ),\n }));\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n isLoading: true,\n }));\n\n let config;\n try {\n // This will throw if validation fails:\n config = projectConfig || getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const pageSize = count || 5;\n const user = await findAppUserId(config.id);\n\n getBuilds({\n appId: config.id,\n limit: pageSize + 1,\n startAfter,\n userId: user.id,\n })\n .then((buildsResult) => {\n setState((previousState) => {\n const stateUpdates = {\n builds: [],\n hasMoreToLoad: buildsResult.length > pageSize,\n isInitialLoadComplete: true,\n isLoading: false,\n projectConfig: config,\n startAfter: null,\n user,\n };\n\n if (buildsResult.length) {\n stateUpdates.builds = [\n ...previousState.builds,\n ...buildsResult.slice(0, pageSize),\n ];\n }\n return {\n ...previousState,\n ...stateUpdates,\n };\n });\n })\n .catch((e) => {\n logForCI(e);\n setState((previousState) => ({\n ...previousState,\n error: e,\n isLoading: false,\n }));\n });\n }\n\n viewBuilds();\n }, [\n error,\n hasMoreToLoad,\n isInitialLoadComplete,\n isLoading,\n projectConfig,\n startAfter,\n ]);\n\n // Exit once all are loaded\n useEffect(() => {\n if (!hasMoreToLoad) {\n setTimeout(exit, 10);\n }\n }, [exit, hasMoreToLoad]);\n\n // Exit the process once the initial build data has been displayed if user has set the `--exit` flag\n useEffect(() => {\n if (!isLoading && isInitialLoadComplete && shouldExitAfterViewingBuilds) {\n setTimeout(exit, 10);\n }\n }, [exit, isLoading, shouldExitAfterViewingBuilds, isInitialLoadComplete]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (!isInitialLoadComplete) {\n return <LoadingText />;\n }\n\n if (builds.length) {\n const formatData = (builds) =>\n builds.map((build) => ({\n ID: build.id,\n Version: build.appVersion || \"n/a\",\n \"Creation date\": getRelativeDateFromDateString(build.createdAt),\n Status: capitalize(build.status),\n \"Release date\": build.releasedAt\n ? getRelativeDateFromDateString(build.releasedAt)\n : \"Unreleased\",\n Owner: user ? user.label : \"unknown\",\n }));\n\n const getCellTextProps = ({ key, props, value }) => {\n const result = { ...props };\n\n if (key === \"Status\") {\n const status = value.toLowerCase();\n if (status === \"succeeded\") {\n result.color = \"green\";\n } else if (status === \"failed\") {\n result.color = \"red\";\n } else if (status === \"cancelled\") {\n result.dimColor = true;\n }\n } else if (key === \"Version\" && value.toLowerCase() === \"n/a\") {\n result.dimColor = true;\n } else if (\n key === \"Release date\" &&\n value.toLowerCase() === \"unreleased\"\n ) {\n result.dimColor = true;\n }\n\n return result;\n };\n\n return (\n <>\n {format === \"table\" ? (\n <Table\n getCellTextProps={getCellTextProps}\n data={formatData(builds)}\n />\n ) : null}\n {format === \"json\" ? (\n <SyntaxHighlight object={removeAppBuilderLibConfig(builds)} />\n ) : null}\n {!shouldExitAfterViewingBuilds && builds.length > 0 ? (\n <Box>\n <Text color=\"gray\" dimColor>\n {isLoading\n ? \"Loading more...\"\n : hasMoreToLoad\n ? `Showing the latest ${builds.length} builds. Press space/down to load more.`\n : `Showing all (${builds.length}) builds`}\n </Text>\n </Box>\n ) : null}\n </>\n );\n } else {\n return <Text>There are no builds yet</Text>;\n }\n};\n\nconst removeAppBuilderLibConfig = (builds) => {\n // Remove the appBuilderLib config from the builds because it's difficult to display\n // and not very useful to the user.\n return builds.map((build) => {\n if (build.mac && build.mac.appBuilderLibConfig) {\n delete build.mac.appBuilderLibConfig;\n }\n if (build.windows && build.windows.appBuilderLibConfig) {\n delete build.windows.appBuilderLibConfig;\n }\n if (build.linux && build.linux.appBuilderLibConfig) {\n delete build.linux.appBuilderLibConfig;\n }\n return build;\n });\n};\n\nViewBuilds.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n configPath: PropTypes.string,\n count: PropTypes.number,\n format: PropTypes.string,\n exit: PropTypes.bool,\n};\n\nexport default ViewBuilds;\n", "import { Box } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport TableEnd from \"./TableEnd\";\nimport TableHead from \"./TableHead\";\nimport TableBody from \"./TableBody\";\nimport getKeyDetails from \"../utilities/getKeyDetails\";\n\n/*\n This component prints (the array of objects given) in a table.\n The array must not be empty.\n The keys are used as headers.\n Column widths are based on the longest value (object key or value).\n It is assumed that the same keys exist in all items.\n*/\nconst Table = ({ data, getCellTextProps }) => {\n const keyDetails = getKeyDetails(data);\n\n return (\n <Box flexDirection=\"column\">\n <TableHead keyDetails={keyDetails} />\n <TableBody\n data={data}\n getCellTextProps={getCellTextProps}\n keyDetails={keyDetails}\n />\n <TableEnd keyDetails={keyDetails} />\n </Box>\n );\n};\n\nTable.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n getCellTextProps: PropTypes.func,\n};\n\nexport default Table;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\n/*\n See Table component\n*/\nconst TableEnd = ({ keyDetails, ...props }) => {\n let content = \"\u2514\";\n content += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u2534\");\n content += \"\u2518\";\n\n return (\n <Box {...props}>\n <Text>{content}</Text>\n </Box>\n );\n};\n\nTableEnd.propTypes = {\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableEnd;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { Fragment } from \"react\";\n\n/*\n See Table component\n*/\nconst TableHead = ({ keyDetails, ...props }) => {\n let topLine = \"\u250C\";\n topLine += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u252C\");\n topLine += \"\u2510\";\n\n const contentLineElements = Object.values(keyDetails).map(\n ({ key, width }, index) => {\n return (\n <Fragment key={key}>\n {index > 0 ? <Text> \u2502 </Text> : null}\n <Box width={width}>\n <Text bold>{key}</Text>\n </Box>\n </Fragment>\n );\n }\n );\n\n return (\n <Box flexDirection=\"column\" {...props}>\n <Box>\n <Text>{topLine}</Text>\n </Box>\n <Box>\n <Box>\n <Text>\u2502 </Text>\n {contentLineElements}\n <Text> \u2502</Text>\n </Box>\n </Box>\n </Box>\n );\n};\n\nTableHead.propTypes = {\n bottomLinePrefix: PropTypes.string,\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableHead;\n", "import PropTypes from \"prop-types\";\nimport TableRow from \"./TableRow\";\n\n/*\n See Table component\n*/\nconst TableBody = ({ data, getCellTextProps, keyDetails }) => {\n return (\n <>\n {data.map((rowData, index) => (\n <TableRow\n data={rowData}\n getCellTextProps={getCellTextProps}\n key={index}\n keyDetails={keyDetails}\n />\n ))}\n </>\n );\n};\n\nTableBody.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n getCellTextProps: PropTypes.func,\n keyDetails: PropTypes.object.isRequired,\n};\n\nexport default TableBody;\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\n\n/*\n See Table component\n*/\nconst TableRow = ({\n data,\n getCellTextProps = ({ props }) => props,\n keyDetails,\n textProps = {},\n}: {\n data: object;\n getCellTextProps?: (...args: any[]) => any;\n keyDetails: object;\n textProps?: object;\n}) => {\n let topLine = \"\u251C\";\n topLine += Object.values(keyDetails)\n .map(({ width }) => \"\u2500\".repeat(width + 2))\n .join(\"\u253C\");\n topLine += \"\u2524\";\n\n const content = (\n <>\n <Text>\u2502 </Text>\n {Object.entries(data).map(([key, value], index) => {\n return (\n <Box key={key}>\n {index > 0 ? <Text> \u2502 </Text> : null}\n <Box width={keyDetails[key].width}>\n <Text\n {...getCellTextProps({\n key,\n props: textProps,\n rowData: data,\n value,\n })}\n >\n {value}\n </Text>\n </Box>\n </Box>\n );\n })}\n <Text> \u2502</Text>\n </>\n );\n\n return (\n <>\n <Box flexDirection=\"column\">\n <Text>{topLine}</Text>\n <Box>{content}</Box>\n </Box>\n </>\n );\n};\n\nTableRow.propTypes = {\n data: PropTypes.object.isRequired,\n getCellTextProps: PropTypes.func,\n keyDetails: PropTypes.object.isRequired,\n textProps: PropTypes.object,\n};\n\nexport default TableRow;\n", "// This is used to get the column widths for tables\nexport default (data) => {\n const result = {};\n Object.keys(data[0]).forEach((key) => {\n result[key] = {\n key,\n width: Math.max(\n key.length,\n data.map((item) => item[key].toString().length).sort((a, b) => b - a)[0]\n ),\n };\n });\n return result;\n};\n", "export default (input) => {\n if (typeof input !== \"string\") {\n return \"\";\n }\n return input.charAt(0).toUpperCase() + input.slice(1);\n};\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({\n addWhereClauses = (query) => query,\n userId,\n appId,\n limit = 5,\n startAfter = null,\n}) => {\n logger.debug({ appId, limit, startAfter }, \"getBuilds\");\n const appRef = firestore.doc(`users/${userId}/applications/${appId}`);\n const appSnapshot = await appRef.get();\n\n if (!appSnapshot.exists) {\n throw new Error(`Application with ID of ${appId} doesn't exist.`);\n }\n\n let query = addWhereClauses(appRef.collection(\"builds\")).orderBy(\n \"createdAt\",\n \"desc\"\n );\n\n if (startAfter) {\n query = query.startAfter(startAfter);\n }\n\n const buildsResult = await query.limit(limit).get();\n\n if (buildsResult.empty) {\n return [];\n }\n\n return buildsResult.docs.map((doc) => doc.data());\n};\n", "import * as dateFns from \"date-fns\";\n\nexport default (input) =>\n dateFns.formatDistance(new Date(input), new Date()) + \" ago\";\n", "import chalk, { ColorSupport } from \"chalk\";\nimport * as React from \"react\";\nimport { Text, useStdout } from \"ink\";\nimport util from \"util\";\n\nconst supportsColor = chalk.stderr.supportsColor as ColorSupport;\n\nconst SyntaxHighlight = ({\n object,\n colors = supportsColor?.hasBasic,\n}: {\n object: object;\n colors?: boolean;\n}) => {\n const { stdout } = useStdout();\n\n const highlightedCode = React.useMemo(() => {\n return stdout.isTTY\n ? util.inspect(object, { colors, depth: 6 })\n : JSON.stringify(object, null, 2);\n }, [colors, object, stdout.isTTY]);\n\n return <Text wrap=\"end\">{highlightedCode}</Text>;\n};\n\nexport default SyntaxHighlight;\n", "import checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport ViewBuild from \"../components/ViewBuild\";\nimport ViewBuilds from \"../components/ViewBuilds\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst BuildsCommand = ({\n id,\n shouldViewLatest,\n configPath = null,\n count,\n format = \"table\",\n exit,\n}: {\n id?: string;\n shouldViewLatest?: boolean;\n configPath?: string;\n count?: number;\n format?: \"table\" | \"json\";\n exit?: boolean;\n}) => {\n checkIfReactIsUsable();\n useAnalyticsCommand(\"builds\", {\n id,\n shouldViewLatest,\n configPath,\n count,\n format,\n exit,\n });\n\n const getContents = () => {\n let commandUsed = \"todesktop builds\";\n if (id) {\n commandUsed += \" <id>\";\n return (\n <ViewBuild commandUsed={commandUsed} id={id} configPath={configPath} />\n );\n } else if (shouldViewLatest) {\n commandUsed += \" --latest\";\n return (\n <ViewBuild\n commandUsed={commandUsed}\n shouldViewLatest={true}\n configPath={configPath}\n />\n );\n } else {\n return (\n <ViewBuilds\n commandUsed={commandUsed}\n configPath={configPath}\n count={count}\n format={format}\n exit={exit}\n />\n );\n }\n };\n\n return (\n <ErrorBoundary>\n <LoginHOC>{getContents()}</LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default BuildsCommand;\n", "import { useEffect } from \"react\";\nimport { Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport { deleteAuthConfig } from \"../utilities/configStore\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\nimport useExit from \"../utilities/useExit\";\n\nconst Logout = () => {\n const exit = useExit();\n const { hasAttemptedTracking } = useAnalyticsCommand(\"logout\");\n\n checkIfReactIsUsable();\n // delete auth config deletes the credentials stored on disk\n deleteAuthConfig();\n\n // exits the program once tracking of the \"logout\" command has been attempted\n useEffect(() => {\n if (hasAttemptedTracking) {\n exit();\n }\n }, [exit, hasAttemptedTracking]);\n\n return <Text>Log out successful</Text>;\n};\n\nconst LogoutWrapper = () => {\n return (\n <ErrorBoundary>\n <LoginHOC isInteractive={false}>\n <Logout />\n </LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default LogoutWrapper;\n", "import { Box, Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport ReleaseBuild from \"../components/ReleaseBuild\";\nimport PickBuildForRelease from \"../components/PickBuildForRelease\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\n\nconst ReleaseCommand = ({\n id,\n force,\n shouldReleaseLatest,\n configPath,\n}: {\n id?: string;\n force?: boolean;\n shouldReleaseLatest?: boolean;\n configPath?: string;\n}) => {\n checkIfReactIsUsable();\n useAnalyticsCommand(\"release\", {\n id,\n force,\n shouldReleaseLatest,\n config: configPath,\n });\n\n // TODO: remove some time in the future\n if (id && id.startsWith(\".\")) {\n return (\n <>\n <Box>\n <Text bold color=\"red\">\n todesktop release <project-path>\n </Text>\n <Text> is no longer supported. Run this instead:</Text>\n </Box>\n <Text bold color=\"greenBright\">\n todesktop build && todesktop release --latest --force\n </Text>\n </>\n );\n }\n\n const getContents = () => {\n if (id) {\n return (\n <ReleaseBuild\n configPath={configPath}\n commandUsed=\"todesktop release <id>\"\n id={id}\n shouldConfirm={!force}\n />\n );\n } else if (shouldReleaseLatest) {\n return (\n <ReleaseBuild\n configPath={configPath}\n commandUsed=\"todesktop release --latest\"\n shouldReleaseLatest={true}\n shouldConfirm={!force}\n />\n );\n } else {\n return (\n <PickBuildForRelease\n configPath={configPath}\n commandUsed=\"todesktop builds\"\n shouldConfirm={!force}\n />\n );\n }\n };\n\n return (\n <ErrorBoundary>\n <LoginHOC>{getContents()}</LoginHOC>\n </ErrorBoundary>\n );\n};\n\nexport default ReleaseCommand;\n", "import { Box, Text } from \"ink\";\nimport Link from \"ink-link\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\n\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport CustomSelectInputItem from \"./CustomSelectInputItem\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport getBuildById from \"../utilities/getBuildById\";\nimport getCallableFirebaseFunction from \"../utilities/getCallableFirebaseFunction\";\nimport getLatestBuildId from \"../utilities/getLatestBuildId\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport findAppUserId from \"../utilities/findAppUserId\";\n\nconst getValidationErrorMessageDisplay = (build, validationMessage) => {\n return (\n <Box flexDirection=\"column\">\n <Text bold color=\"red\">\n Can't release {build.appName} v{build.appVersion}\n </Text>\n\n <Box marginBottom={1} marginTop={1}>\n <Text>{validationMessage}</Text>\n </Box>\n\n <Text bold>See web UI for more information: </Text>\n <Text>\n <Link fallback={false} url={build.url}>\n {build.url}\n </Link>\n </Text>\n </Box>\n );\n};\n\nconst ReleaseBuild = ({ commandUsed, id, shouldConfirm, configPath }) => {\n const exit = useExit();\n const [\n {\n appId,\n arbitraryMessageComponent,\n build,\n error,\n hasConfirmed,\n hasBeenValidatedSuccesfully,\n isComplete,\n isReleasing,\n },\n setState,\n ] = useState({\n appId: null,\n build: null,\n error: null,\n hasConfirmed: false,\n hasBeenValidatedSuccesfully: false,\n isComplete: false,\n isReleasing: false,\n arbitraryMessageComponent: null,\n });\n\n const onError = (e) => {\n const error = e.response ? e.response.data : e;\n logForCI(error);\n setState((prevState) => ({\n ...prevState,\n error,\n }));\n };\n\n useEffect(() => {\n async function releaseBuild() {\n if (build) {\n return;\n }\n\n // This will throw if validation fails:\n const config = getProjectConfig(configPath).config;\n const appId = config.id;\n\n const { id: userId } = await findAppUserId(appId);\n\n const loadBuild = (buildId) => {\n getBuildById({ appId, buildId, userId })\n .then((buildResult) => {\n if (!buildResult) {\n throw new Error(\n `No such build ${buildId} for application ${appId}`\n );\n }\n\n setState((previousState) => ({\n ...previousState,\n appId,\n build: buildResult,\n }));\n })\n .catch(onError);\n };\n\n if (id) {\n loadBuild(id);\n } else {\n getLatestBuildId({ appId, userId })\n .catch(onError)\n .then((buildId) => {\n if (!buildId) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: <Text>There are no builds yet</Text>,\n }));\n return;\n }\n return loadBuild(buildId);\n });\n }\n }\n\n releaseBuild();\n }, [build, id]);\n\n useEffect(() => {\n if (!build || hasBeenValidatedSuccesfully || arbitraryMessageComponent) {\n return;\n }\n\n let validationMessage;\n if (build.releasedAt) {\n validationMessage = `It has already been released.`;\n } else if (build.status !== \"succeeded\") {\n validationMessage = `The build must have completed successfully. Actual build status: ${build.status}`;\n }\n\n if (validationMessage) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: getValidationErrorMessageDisplay(\n build,\n validationMessage\n ),\n hasBeenValidatedSuccesfully: false,\n }));\n } else {\n setState((previousState) => ({\n ...previousState,\n hasBeenValidatedSuccesfully: true,\n }));\n }\n }, [arbitraryMessageComponent, build, hasBeenValidatedSuccesfully]);\n\n useEffect(() => {\n if (\n !hasBeenValidatedSuccesfully ||\n (shouldConfirm && !hasConfirmed) ||\n isReleasing ||\n isComplete\n ) {\n return;\n }\n\n setState((previousState) => ({\n ...previousState,\n isReleasing: true,\n }));\n\n getCallableFirebaseFunction(\"releaseBuild\")({\n appId,\n buildId: build.id,\n })\n .then(() => {\n logForCI(\"Released!\");\n setState((previousState) => ({\n ...previousState,\n isReleasing: false,\n isComplete: true,\n }));\n })\n .catch((e) => {\n if ([\"failed-precondition\", \"not-found\"].includes(e.code)) {\n setState((previousState) => ({\n ...previousState,\n arbitraryMessageComponent: getValidationErrorMessageDisplay(\n build,\n e.message\n ),\n isReleasing: false,\n }));\n } else {\n onError(new Error(\"Unexpected internal error while releasing build\"));\n }\n });\n }, [\n appId,\n build,\n hasConfirmed,\n hasBeenValidatedSuccesfully,\n id,\n isComplete,\n isReleasing,\n shouldConfirm,\n ]);\n\n // Exit once complete\n useEffect(() => {\n if (isComplete) {\n setTimeout(exit, 10);\n return;\n }\n if (arbitraryMessageComponent) {\n setTimeout(() => exit(new Error(\"Validation failed\")), 10);\n }\n }, [arbitraryMessageComponent, exit, isComplete]);\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (arbitraryMessageComponent) {\n return arbitraryMessageComponent;\n }\n\n if (hasBeenValidatedSuccesfully && shouldConfirm && !hasConfirmed) {\n const items = [\n {\n label: \"Yes\",\n value: \"yes\",\n },\n {\n label: \"No\",\n value: \"no\",\n },\n ];\n const onSubmit = (item) => {\n if (item.value === \"no\") {\n setTimeout(exit, 10);\n return;\n }\n setState((previousState) => ({\n ...previousState,\n hasConfirmed: true,\n }));\n };\n return (\n <Box flexDirection=\"column\">\n <Box>\n <Text>This will release build {build.id} as </Text>\n <Text bold>\n {build.appName} v{build.appVersion}\n </Text>\n <Text>, are you sure?</Text>\n </Box>\n\n <Box marginBottom={1} marginTop={1}>\n <SelectInput\n indicatorComponent={CustomSelectInputIndicator}\n initialIndex={1}\n itemComponent={CustomSelectInputItem}\n items={items}\n onSelect={onSubmit}\n />\n </Box>\n\n <Text dimColor>\n Your users will be auto-updated to this version. You can use --force\n to bypass this confirmation in future\n </Text>\n </Box>\n );\n }\n\n if (isReleasing) {\n return <Text>Releasing...</Text>;\n }\n\n if (isComplete) {\n return (\n <Text bold color=\"greenBright\">\n Released!\n </Text>\n );\n }\n\n return <Text>...</Text>;\n};\n\nReleaseBuild.propTypes = {\n id: (props, propName, componentName) => {\n if ([props.id, props.shouldReleaseLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldReleaseLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.id;\n if (![\"string\", \"undefined\"].includes(type)) {\n return new Error(\n `'id' is a '${type}', not a string, in '${componentName}'.`\n );\n }\n },\n commandUsed: PropTypes.string.isRequired,\n shouldReleaseLatest: (props, propName, componentName) => {\n if ([props.id, props.shouldReleaseLatest].filter(Boolean).length !== 1) {\n return new Error(\n `Exactly one of 'id' and 'shouldReleaseLatest' must be specified in '${componentName}'`\n );\n }\n\n const type = typeof props.shouldReleaseLatest;\n if (![\"boolean\", \"undefined\"].includes(type)) {\n return new Error(\n `'shouldReleaseLatest' is a '${type}', not a boolean, in '${componentName}'.`\n );\n }\n },\n shouldConfirm: PropTypes.bool.isRequired,\n configPath: PropTypes.string,\n};\n\nexport default ReleaseBuild;\n", "import firestore from \"./firestore\";\nimport logger from \"./logger\";\n\nexport default async ({ appId, buildId, userId }) => {\n logger.debug({ appId, buildId }, \"getBuildById\");\n const snapshot = await firestore\n .doc(`users/${userId}/applications/${appId}/builds/${buildId}`)\n .get();\n\n if (!snapshot.exists) {\n return null;\n }\n\n return snapshot.data();\n};\n", "import { Box, Text } from \"ink\";\nimport PropTypes from \"prop-types\";\nimport { useEffect, useState } from \"react\";\nimport ErrorDisplay from \"./ErrorDisplay\";\nimport ReleaseBuild from \"./ReleaseBuild\";\nimport SelectTable from \"./SelectTable\";\nimport getBuilds from \"../utilities/getBuilds\";\nimport getProjectConfig from \"../utilities/projectConfig/getProjectConfig\";\nimport getRelativeDateFromDateString from \"../utilities/getRelativeDateFromDateString\";\nimport logForCI from \"../utilities/logForCI\";\nimport useExit from \"../utilities/useExit\";\nimport useInput from \"../utilities/useInput\";\nimport findAppUserId from \"../utilities/findAppUserId\";\nimport LoadingText from \"./LoadingText\";\n\nconst PickBuildForRelease = ({ commandUsed, shouldConfirm, configPath }) => {\n const exit = useExit();\n const [{ error, builds, chosenBuildId, isLoading, user }, setState] =\n useState({\n error: null,\n builds: null,\n chosenBuildId: null,\n isLoading: true,\n user: null,\n });\n\n const onInput = useInput();\n\n useEffect(() => {\n async function pickBuildForRelease() {\n if (builds) {\n return;\n }\n\n let config;\n try {\n // This will throw if validation fails:\n config = getProjectConfig(configPath).config;\n } catch (e) {\n setState((previousState) => ({ ...previousState, error: e }));\n return;\n }\n\n const user = await findAppUserId(config.id);\n\n getBuilds({\n addWhereClauses: (query) => query.where(\"status\", \"==\", \"succeeded\"),\n appId: config.id,\n limit: 50,\n userId: user.id,\n })\n .then((buildsResult) => {\n setState((previousState) => ({\n ...previousState,\n user,\n builds: buildsResult\n .filter((buildResult) => !buildResult.releasedAt)\n .slice(0, 5),\n isLoading: false,\n }));\n })\n .catch((e) => {\n logForCI(e);\n setState((previousState) => ({\n ...previousState,\n error: e,\n isLoading: false,\n }));\n });\n }\n\n pickBuildForRelease();\n }, [builds]);\n\n onInput((input, key) => {\n if (!builds || !builds.length || chosenBuildId) {\n return;\n }\n\n if (key.escape) {\n exit();\n }\n });\n\n if (error) {\n return <ErrorDisplay commandUsed={commandUsed} error={error} />;\n }\n\n if (isLoading) {\n return <LoadingText />;\n }\n\n if (chosenBuildId) {\n return (\n <ReleaseBuild\n commandUsed={commandUsed}\n id={chosenBuildId}\n shouldConfirm={shouldConfirm}\n />\n );\n }\n\n if (builds.length) {\n const data = builds.map((build) => ({\n ID: build.id,\n Version: build.appVersion || \"unknown\",\n \"Creation date\": getRelativeDateFromDateString(build.createdAt),\n Owner: user ? user.label : \"unknown\",\n }));\n\n const onSelect = (item) =>\n setState((previousState) => ({\n ...previousState,\n chosenBuildId: item.value.ID,\n }));\n\n return (\n <>\n <Box>\n <Text>Which build would you like to release?</Text>\n </Box>\n <SelectTable data={data} onSelect={onSelect} />\n <Box>\n <Text dimColor>\n Showing the latest {builds.length} unreleased successful builds\n </Text>\n </Box>\n </>\n );\n } else {\n return (\n <Box>\n <Text>No elligible builds found </Text>\n <Text dimColor>(i.e. unreleased and successful)</Text>\n </Box>\n );\n }\n};\n\nPickBuildForRelease.propTypes = {\n commandUsed: PropTypes.string.isRequired,\n shouldConfirm: PropTypes.bool.isRequired,\n configPath: PropTypes.string,\n};\n\nexport default PickBuildForRelease;\n", "import { Box } from \"ink\";\nimport SelectInput from \"ink-select-input\";\nimport PropTypes from \"prop-types\";\nimport CustomSelectInputIndicator from \"./CustomSelectInputIndicator\";\nimport TableEnd from \"./TableEnd\";\nimport TableHead from \"./TableHead\";\nimport TableRow from \"./TableRow\";\nimport getKeyDetails from \"../utilities/getKeyDetails\";\n\nconst CustomIndicator = (props) => (\n <CustomSelectInputIndicator marginTop={1} {...props} />\n);\n\n/*\n This is like if <Table/> and ink-select-input had a baby.\n Read the block comment at the top of <Table/> first.\n*/\nconst SelectTable = ({ data, onSelect }) => {\n const keyDetails = getKeyDetails(data);\n\n const getSelectItems = () => {\n return data.map((rowData, index) => {\n return {\n index,\n key: index,\n value: rowData,\n };\n });\n };\n\n const ItemComponent = ({\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n label, // Make it compatible to SelectInput type, not used actually\n index,\n isSelected,\n }: {\n label: string;\n index?: number;\n isSelected?: boolean;\n }) => {\n return (\n <TableRow\n data={data[index]}\n key={index}\n keyDetails={keyDetails}\n textProps={{ bold: isSelected, color: isSelected ? undefined : \"gray\" }}\n />\n );\n };\n\n return (\n <Box flexDirection=\"column\">\n <TableHead keyDetails={keyDetails} marginLeft={2} />\n <SelectInput\n indicatorComponent={CustomIndicator}\n itemComponent={ItemComponent}\n items={getSelectItems()}\n onSelect={onSelect}\n />\n <TableEnd keyDetails={keyDetails} marginLeft={2} />\n </Box>\n );\n};\n\nSelectTable.propTypes = {\n data: (props, propName, componentName) => {\n const type = typeof props.data;\n if (Array.isArray(\"array\")) {\n return new Error(\n `'data' prop must be an array ('${type}' given) in ${componentName} component`\n );\n }\n\n if (props.data.length === 0) {\n return new Error(\n `'data' prop must not be empty, in ${componentName} component`\n );\n }\n },\n onSelect: PropTypes.func,\n};\n\nexport default SelectTable;\n", "import { useEffect } from \"react\";\nimport { Text } from \"ink\";\n\nimport checkIfReactIsUsable from \"../utilities/checkIfReactIsUsable\";\nimport { getAuthConfig } from \"../utilities/configStore\";\nimport ErrorBoundary from \"../components/ErrorBoundary\";\nimport LoginHOC from \"../components/LoginHOC\";\nimport { useAnalyticsCommand } from \"../utilities/useAnalytics\";\nimport useExit from \"../utilities/useExit\";\n\nconst WhoAmI = () => {\n const exit = useExit();\n checkIfReactIsUsable();\n const auth = getAuthConfig();\n const { hasAttemptedTracking } = useAnalyticsCommand(\"whoami\", {}, {});\n\n // exits the program once tracking of the \"whoami\" command has been attempted\n useEffect(() => {\n if (hasAttemptedTracking) {\n exit();\n }\n }, [exit, hasAttemptedTracking]);\n\n if (!auth || !auth.email) {\n return <Text>{\"You're not signed in\"}</Text>;\n }\n return <Text>{auth.email}</Text>;\n};\n\nconst WhoAmIWrapper = () => (\n <ErrorBoundary>\n <LoginHOC isInteractive={false}>\n <WhoAmI />\n </LoginHOC>\n </ErrorBoundary>\n);\n\nexport default WhoAmIWrapper;\n", "import chalk from \"chalk\";\nimport isInstalledGlobally from \"is-installed-globally\";\nimport latestVersion from \"latest-version\";\nimport semver from \"semver\";\nimport getToDesktopPackageJson from \"./getToDesktopPackageJson\";\n\nexport default () => {\n // Ignore during tests\n if (process.env.AVA_PATH) {\n return;\n }\n\n const pkg = getToDesktopPackageJson();\n latestVersion(pkg.name).then((latest) => {\n if (semver.gt(latest, pkg.version)) {\n const commandToUpdate = chalk.greenBright(\n `npm install ${\n isInstalledGlobally ? \"--location=global\" : \"--save-dev\"\n } @todesktop/cli`\n );\n console.log(\n `Your version of @todesktop/cli is out of date.\\nRun ${commandToUpdate} to update to v${latest}.`\n );\n if (!semver.satisfies(latest, `^${pkg.version}`)) {\n console.log(`CLI is exiting because it is out out of date.`);\n process.exit(1);\n }\n }\n });\n};\n", "import * as Sentry from \"@sentry/node\";\nimport os from \"os\";\nimport pkgJson from \"../../package.json\";\nimport { getAuthConfig } from \"./configStore\";\nimport getProjectConfig from \"./projectConfig/getProjectConfig\";\nimport getEnvironmentVariables from \"./getEnvironmentVariables\";\n\nexport default () => {\n const { TODESKTOP_CLI_SENTRY_DSN } = getEnvironmentVariables();\n if (!TODESKTOP_CLI_SENTRY_DSN) {\n // Don't initialise Sentry\n return;\n }\n Sentry.init({\n dsn: TODESKTOP_CLI_SENTRY_DSN,\n });\n Sentry.configureScope((scope) => {\n try {\n scope.setUser({ email: getAuthConfig().email as string });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"os\", {\n name: os.platform(),\n version: os.release(),\n });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"runtime\", {\n name: \"Node.js\",\n version: process.version,\n });\n } catch (err) {\n // nothing\n }\n try {\n scope.setContext(\"app\", {\n app_name: pkgJson.name,\n app_version: pkgJson.version,\n });\n } catch (err) {\n // nothing\n }\n try {\n const configResult = getProjectConfig();\n scope.setExtra(\"config\", configResult);\n } catch (err) {\n // nothing\n }\n });\n};\n", "import exitIfCLIOutOfDate from \"./exitIfCLIOutOfDate\";\nimport initSentry from \"./initSentry\";\n\nexport default ({ sentry = true, exitIfOutOfDate = true } = {}) => {\n if (sentry) {\n initSentry();\n }\n\n if (exitIfOutOfDate) {\n exitIfCLIOutOfDate();\n }\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_ink", "import_react", "import_react", "import_prop_types", "import_ink", "import_prop_types", "import_react", "import_ink", "bunyan", "args", "isCi", "dotenv", "path", "firebase", "fs", "Conf", "xdgBasedir", "del", "pkgUp", "environmentVariables", "Analytics", "os", "uuidv4", "resolve", "import_path", "path", "Link", "PropTypes", "import_prop_types", "import_ink", "import_ink_link", "import_path", "import_jsx_runtime", "path", "Link", "PropTypes", "import_jsx_runtime", "throttle", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_ink", "import_jsx_runtime", "import_jsx_runtime", "Gradient", "PropTypes", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_jsx_runtime", "import_ink", "import_is_ci", "import_react", "import_ink", "import_react", "firebase", "import_jsx_runtime", "import_ink", "import_ink_link", "import_prop_types", "import_jsx_runtime", "Link", "PropTypes", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_is_ci", "import_ink", "isCi", "import_jsx_runtime", "isCi", "import_path", "path", "config", "import_ajv", "import_ajv_formats", "import_better_ajv_errors", "import_ajv", "fs", "path", "Ajv", "addFormats", "betterAjvErrors", "emailRegex", "parseAuthor", "config", "Ajv", "addFormats", "betterAjvErrors", "import_path", "import_lodash", "merge", "findUp", "config", "config", "axios", "resolve", "fs", "path", "resolve", "streamToArray", "util", "superagent", "import_fs", "import_path", "archiver", "fs", "du", "chalk", "path", "fastGlob", "config", "fs", "import_lodash", "import_path", "config", "path", "merge", "config", "prettyBytes", "import_jsx_runtime", "error", "PropTypes", "import_react", "import_ink", "import_react", "import_prop_types", "import_is_ci", "import_ink", "import_prop_types", "import_react", "import_react", "import_jsx_runtime", "React", "InkTextInput", "import_jsx_runtime", "message", "Error", "PropTypes", "import_ink", "import_jsx_runtime", "import_jsx_runtime", "message", "isCi", "PropTypes", "import_react", "Sentry", "React", "import_ink", "import_prop_types", "import_react", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "error", "config", "PropTypes", "import_is_ci", "import_jsx_runtime", "isCi", "itemChosen", "SelectInput", "PropTypes", "import_react", "import_jsx_runtime", "import_ink", "import_prop_types", "import_react", "import_ink", "import_prop_types", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_jsx_runtime", "PropTypes", "import_prop_types", "import_ink", "import_prop_types", "import_jsx_runtime", "PropTypes", "import_jsx_runtime", "PropTypes", "import_jsx_runtime", "PropTypes", "import_chalk", "React", "import_ink", "import_util", "import_jsx_runtime", "chalk", "util", "import_jsx_runtime", "config", "user", "builds", "PropTypes", "import_jsx_runtime", "import_react", "import_ink", "import_jsx_runtime", "import_ink", "import_ink", "import_ink_link", "import_ink_select_input", "import_prop_types", "import_react", "import_jsx_runtime", "Link", "error", "config", "appId", "SelectInput", "PropTypes", "import_ink", "import_prop_types", "import_react", "import_ink", "import_ink_select_input", "import_prop_types", "import_jsx_runtime", "SelectInput", "PropTypes", "import_jsx_runtime", "config", "user", "PropTypes", "import_jsx_runtime", "import_react", "import_ink", "import_jsx_runtime", "import_chalk", "latestVersion", "semver", "chalk", "isInstalledGlobally", "Sentry", "import_os", "os", "config"]
|
|
7
7
|
}
|