@expo/cli 54.1.0-canary-20251009-9919e08 → 54.1.0-canary-20251013-623c5a6

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/build/bin/cli CHANGED
@@ -123,7 +123,7 @@ const args = (0, _arg().default)({
123
123
  });
124
124
  if (args['--version']) {
125
125
  // Version is added in the build script.
126
- console.log("54.1.0-canary-20251009-9919e08");
126
+ console.log("54.1.0-canary-20251013-623c5a6");
127
127
  process.exit(0);
128
128
  }
129
129
  if (args['--non-interactive']) {
@@ -98,11 +98,23 @@ function injectScriptTags(html, scriptTags) {
98
98
  var _name_match;
99
99
  return (_name_match = name.match(/^\(([^/]+?)\)$/)) == null ? void 0 : _name_match[1];
100
100
  }
101
- async function getFilesToExportFromServerAsync(projectRoot, { manifest, renderAsync, // Servers can handle group routes automatically and therefore
101
+ async function getFilesToExportFromServerAsync(projectRoot, { manifest, serverManifest, renderAsync, // Servers can handle group routes automatically and therefore
102
102
  // don't require the build-time generation of every possible group
103
103
  // variation.
104
104
  exportServer, // name : contents
105
105
  files = new Map() }) {
106
+ if (!exportServer && serverManifest) {
107
+ // When we're not exporting a `server` output, we provide a `_expo/.routes.json` for
108
+ // EAS Hosting to recognize the `headers` and `redirects` configs
109
+ const subsetServerManifest = {
110
+ headers: serverManifest.headers,
111
+ redirects: serverManifest.redirects
112
+ };
113
+ files.set('_expo/.routes.json', {
114
+ contents: JSON.stringify(subsetServerManifest, null, 2),
115
+ targetDomain: 'client'
116
+ });
117
+ }
106
118
  await Promise.all(getHtmlFiles({
107
119
  manifest,
108
120
  includeGroupVariations: !exportServer
@@ -192,6 +204,7 @@ async function exportFromServerAsync(projectRoot, devServer, { outputDir, baseUr
192
204
  await getFilesToExportFromServerAsync(projectRoot, {
193
205
  files,
194
206
  manifest,
207
+ serverManifest,
195
208
  exportServer,
196
209
  async renderAsync ({ pathname, route }) {
197
210
  const template = await renderAsync(pathname);
@@ -388,6 +401,7 @@ async function exportApiRoutesStandaloneAsync(devServer, { files = new Map(), pl
388
401
  // TODO: Export an HTML entry for each file. This is a temporary solution until we have SSR/SSG for RSC.
389
402
  await getFilesToExportFromServerAsync(devServer.projectRoot, {
390
403
  manifest: htmlManifest,
404
+ serverManifest,
391
405
  exportServer: true,
392
406
  files,
393
407
  renderAsync: async ({ pathname, filePath })=>{
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/export/exportStaticAsync.ts"],"sourcesContent":["/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { ExpoConfig } from '@expo/config';\nimport chalk from 'chalk';\nimport { RouteNode } from 'expo-router/build/Route';\nimport { stripGroupSegmentsFromPath } from 'expo-router/build/matchers';\nimport { shouldLinkExternally } from 'expo-router/build/utils/url';\nimport path from 'path';\nimport resolveFrom from 'resolve-from';\nimport { inspect } from 'util';\n\nimport { getVirtualFaviconAssetsAsync } from './favicon';\nimport { persistMetroAssetsAsync } from './persistMetroAssets';\nimport { ExportAssetMap, getFilesFromSerialAssets } from './saveAssets';\nimport { Log } from '../log';\nimport {\n ExpoRouterRuntimeManifest,\n MetroBundlerDevServer,\n} from '../start/server/metro/MetroBundlerDevServer';\nimport { ExpoRouterServerManifestV1 } from '../start/server/metro/fetchRouterManifest';\nimport { logMetroErrorAsync } from '../start/server/metro/metroErrorInterface';\nimport { getApiRoutesForDirectory, getMiddlewareForDirectory } from '../start/server/metro/router';\nimport { serializeHtmlWithAssets } from '../start/server/metro/serializeHtml';\nimport { learnMore } from '../utils/link';\n\nconst debug = require('debug')('expo:export:generateStaticRoutes') as typeof console.log;\n\ntype ExtraScriptTag = {\n platform: string;\n src: string;\n};\n\ntype Options = {\n mode: 'production' | 'development';\n files?: ExportAssetMap;\n outputDir: string;\n minify: boolean;\n exportServer: boolean;\n baseUrl: string;\n includeSourceMaps: boolean;\n entryPoint?: string;\n clear: boolean;\n routerRoot: string;\n reactCompiler: boolean;\n maxWorkers?: number;\n isExporting: boolean;\n exp?: ExpoConfig;\n // <script type=\"type/expo\" data-platform=\"ios\" src=\"...\" />\n scriptTags?: ExtraScriptTag[];\n};\n\ntype HtmlRequestLocation = {\n /** The output file path name to use relative to the static folder. */\n filePath: string;\n /** The pathname to make requests to in order to fetch the HTML. */\n pathname: string;\n /** The runtime route node object, used to associate async modules with the static HTML. */\n route: RouteNode;\n};\n\nexport function injectScriptTags(html: string, scriptTags: ExtraScriptTag[]): string {\n const scriptTagsHtml = scriptTags\n .map((tag) =>\n tag.platform === 'web'\n ? `<script src=\"${tag.src}\"></script>`\n : `<script type=\"type/expo\" src=\"${tag.src}\" data-platform=\"${tag.platform}\"></script>`\n )\n .join('\\n');\n html = html.replace('</head>', `${scriptTagsHtml}\\n</head>`);\n return html;\n}\n\n/** Match `(page)` -> `page` */\nfunction matchGroupName(name: string): string | undefined {\n return name.match(/^\\(([^/]+?)\\)$/)?.[1];\n}\n\nexport async function getFilesToExportFromServerAsync(\n projectRoot: string,\n {\n manifest,\n renderAsync,\n // Servers can handle group routes automatically and therefore\n // don't require the build-time generation of every possible group\n // variation.\n exportServer,\n // name : contents\n files = new Map(),\n }: {\n manifest: ExpoRouterRuntimeManifest;\n renderAsync: (requestLocation: HtmlRequestLocation) => Promise<string>;\n exportServer?: boolean;\n files?: ExportAssetMap;\n }\n): Promise<ExportAssetMap> {\n await Promise.all(\n getHtmlFiles({ manifest, includeGroupVariations: !exportServer }).map(\n async ({ route, filePath, pathname }) => {\n // Rewrite routes should not be statically generated\n if (route.type === 'rewrite') {\n return;\n }\n\n try {\n const targetDomain = exportServer ? 'server' : 'client';\n files.set(filePath, { contents: '', targetDomain });\n const data = await renderAsync({ route, filePath, pathname });\n files.set(filePath, {\n contents: data,\n routeId: pathname,\n targetDomain,\n });\n } catch (e: any) {\n await logMetroErrorAsync({ error: e, projectRoot });\n throw new Error('Failed to statically export route: ' + pathname);\n }\n }\n )\n );\n\n return files;\n}\n\nfunction modifyRouteNodeInRuntimeManifest(\n manifest: ExpoRouterRuntimeManifest,\n callback: (route: RouteNode) => any\n) {\n const iterateScreens = (screens: ExpoRouterRuntimeManifest['screens']) => {\n Object.values(screens).map((value) => {\n if (typeof value !== 'string') {\n if (value._route) callback(value._route);\n iterateScreens(value.screens);\n }\n });\n };\n\n iterateScreens(manifest.screens);\n}\n\n// TODO: Do this earlier in the process.\nfunction makeRuntimeEntryPointsAbsolute(manifest: ExpoRouterRuntimeManifest, appDir: string) {\n modifyRouteNodeInRuntimeManifest(manifest, (route) => {\n if (Array.isArray(route.entryPoints)) {\n route.entryPoints = route.entryPoints.map((entryPoint) => {\n // TODO(@hassankhan): ENG-16577\n if (shouldLinkExternally(entryPoint)) {\n return entryPoint;\n }\n\n if (entryPoint.startsWith('.')) {\n return path.resolve(appDir, entryPoint);\n } else if (!path.isAbsolute(entryPoint)) {\n return resolveFrom(appDir, entryPoint);\n }\n return entryPoint;\n });\n }\n });\n}\n\n/** Perform all fs commits */\nexport async function exportFromServerAsync(\n projectRoot: string,\n devServer: MetroBundlerDevServer,\n {\n outputDir,\n baseUrl,\n exportServer,\n includeSourceMaps,\n routerRoot,\n files = new Map(),\n exp,\n scriptTags,\n }: Options\n): Promise<ExportAssetMap> {\n Log.log(\n `Static rendering is enabled. ` +\n learnMore('https://docs.expo.dev/router/reference/static-rendering/')\n );\n\n const platform = 'web';\n const isExporting = true;\n const appDir = path.join(projectRoot, routerRoot);\n const injectFaviconTag = await getVirtualFaviconAssetsAsync(projectRoot, {\n outputDir,\n baseUrl,\n files,\n exp,\n });\n\n const [resources, { manifest, serverManifest, renderAsync }] = await Promise.all([\n devServer.getStaticResourcesAsync({\n includeSourceMaps,\n }),\n devServer.getStaticRenderFunctionAsync(),\n ]);\n\n makeRuntimeEntryPointsAbsolute(manifest, appDir);\n\n debug('Routes:\\n', inspect(manifest, { colors: true, depth: null }));\n\n await getFilesToExportFromServerAsync(projectRoot, {\n files,\n manifest,\n exportServer,\n async renderAsync({ pathname, route }) {\n const template = await renderAsync(pathname);\n let html = await serializeHtmlWithAssets({\n isExporting,\n resources: resources.artifacts,\n template,\n baseUrl,\n route,\n hydrate: true,\n });\n\n if (injectFaviconTag) {\n html = injectFaviconTag(html);\n }\n\n if (scriptTags) {\n // Inject script tags into the HTML.\n // <script type=\"type/expo\" data-platform=\"ios\" src=\"...\" />\n html = injectScriptTags(html, scriptTags);\n }\n\n return html;\n },\n });\n\n getFilesFromSerialAssets(resources.artifacts, {\n platform,\n includeSourceMaps,\n files,\n isServerHosted: true,\n });\n\n if (resources.assets) {\n // TODO: Collect files without writing to disk.\n // NOTE(kitten): Re. above, this is now using `files` except for iOS catalog output, which isn't used here\n await persistMetroAssetsAsync(projectRoot, resources.assets, {\n files,\n platform,\n outputDirectory: outputDir,\n baseUrl,\n });\n }\n\n if (exportServer) {\n const apiRoutes = await exportApiRoutesAsync({\n platform: 'web',\n server: devServer,\n manifest: serverManifest,\n // NOTE(kitten): For now, we always output source maps for API route exports\n includeSourceMaps: true,\n });\n\n // Add the api routes to the files to export.\n for (const [route, contents] of apiRoutes) {\n files.set(route, contents);\n }\n } else {\n warnPossibleInvalidExportType(appDir);\n }\n\n return files;\n}\n\nexport function getHtmlFiles({\n manifest,\n includeGroupVariations,\n}: {\n manifest: ExpoRouterRuntimeManifest;\n includeGroupVariations?: boolean;\n}): HtmlRequestLocation[] {\n const htmlFiles = new Set<Omit<HtmlRequestLocation, 'pathname'>>();\n\n function traverseScreens(\n screens: ExpoRouterRuntimeManifest['screens'],\n route: RouteNode | null,\n baseUrl = ''\n ) {\n for (const [key, value] of Object.entries(screens)) {\n let leaf: string | null = null;\n if (typeof value === 'string') {\n leaf = value;\n } else if (value.screens && Object.keys(value.screens).length === 0) {\n // Ensure the trailing index is accounted for.\n if (key === value.path + '/index') {\n leaf = key;\n } else {\n leaf = value.path;\n }\n\n route = value._route ?? null;\n }\n\n if (leaf != null) {\n let filePath = baseUrl + leaf;\n\n if (leaf === '') {\n filePath =\n baseUrl === ''\n ? 'index'\n : baseUrl.endsWith('/')\n ? baseUrl + 'index'\n : baseUrl.slice(0, -1);\n } else if (\n // If the path is a collection of group segments leading to an index route, append `/index`.\n stripGroupSegmentsFromPath(filePath) === ''\n ) {\n filePath += '/index';\n }\n\n // This should never happen, the type of `string | object` originally comes from React Navigation.\n if (!route) {\n throw new Error(\n `Internal error: Route not found for \"${filePath}\" while collecting static export paths.`\n );\n }\n\n if (includeGroupVariations) {\n // TODO: Dedupe requests for alias routes.\n addOptionalGroups(filePath, route);\n } else {\n htmlFiles.add({\n filePath,\n route,\n });\n }\n } else if (typeof value === 'object' && value?.screens) {\n // The __root slot has no path.\n const newPath = value.path ? baseUrl + value.path + '/' : baseUrl;\n traverseScreens(value.screens, value._route ?? null, newPath);\n }\n }\n }\n\n function addOptionalGroups(path: string, route: RouteNode) {\n const variations = getPathVariations(path);\n for (const variation of variations) {\n htmlFiles.add({ filePath: variation, route });\n }\n }\n\n traverseScreens(manifest.screens, null);\n\n return uniqueBy(Array.from(htmlFiles), (value) => value.filePath).map((value) => {\n const parts = value.filePath.split('/');\n // Replace `:foo` with `[foo]` and `*foo` with `[...foo]`\n const partsWithGroups = parts.map((part) => {\n if (part === '*not-found') {\n return `+not-found`;\n } else if (part.startsWith(':')) {\n return `[${part.slice(1)}]`;\n } else if (part.startsWith('*')) {\n return `[...${part.slice(1)}]`;\n }\n return part;\n });\n const filePathLocation = partsWithGroups.join('/');\n const filePath = filePathLocation + '.html';\n return {\n ...value,\n filePath,\n pathname: filePathLocation.replace(/(\\/?index)?$/, ''),\n };\n });\n}\n\nfunction uniqueBy<T>(array: T[], key: (value: T) => string): T[] {\n const seen = new Set<string>();\n const result: T[] = [];\n for (const value of array) {\n const id = key(value);\n if (!seen.has(id)) {\n seen.add(id);\n result.push(value);\n }\n }\n return result;\n}\n\n// Given a route like `(foo)/bar/(baz)`, return all possible variations of the route.\n// e.g. `(foo)/bar/(baz)`, `(foo)/bar/baz`, `foo/bar/(baz)`, `foo/bar/baz`,\nexport function getPathVariations(routePath: string): string[] {\n const variations = new Set<string>();\n const segments = routePath.split('/');\n\n function generateVariations(segments: string[], current = ''): void {\n if (segments.length === 0) {\n if (current) variations.add(current);\n return;\n }\n\n const [head, ...rest] = segments;\n\n if (matchGroupName(head)) {\n const groups = head.slice(1, -1).split(',');\n\n if (groups.length > 1) {\n for (const group of groups) {\n // If there are multiple groups, recurse on each group.\n generateVariations([`(${group.trim()})`, ...rest], current);\n }\n return;\n } else {\n // Start a fork where this group is included\n generateVariations(rest, current ? `${current}/(${groups[0]})` : `(${groups[0]})`);\n // This code will continue and add paths without this group included`\n }\n } else if (current) {\n current = `${current}/${head}`;\n } else {\n current = head;\n }\n\n generateVariations(rest, current);\n }\n\n generateVariations(segments);\n\n return Array.from(variations);\n}\n\nexport async function exportApiRoutesStandaloneAsync(\n devServer: MetroBundlerDevServer,\n {\n files = new Map(),\n platform,\n apiRoutesOnly,\n templateHtml,\n }: {\n files?: ExportAssetMap;\n platform: string;\n apiRoutesOnly: boolean;\n templateHtml?: string;\n }\n) {\n const { serverManifest, htmlManifest } = await devServer.getServerManifestAsync();\n\n const apiRoutes = await exportApiRoutesAsync({\n server: devServer,\n manifest: serverManifest,\n // NOTE(kitten): For now, we always output source maps for API route exports\n includeSourceMaps: true,\n platform,\n apiRoutesOnly,\n });\n\n // Add the api routes to the files to export.\n for (const [route, contents] of apiRoutes) {\n files.set(route, contents);\n }\n\n if (templateHtml && devServer.isReactServerComponentsEnabled) {\n // TODO: Export an HTML entry for each file. This is a temporary solution until we have SSR/SSG for RSC.\n await getFilesToExportFromServerAsync(devServer.projectRoot, {\n manifest: htmlManifest,\n exportServer: true,\n files,\n renderAsync: async ({ pathname, filePath }) => {\n files.set(filePath, {\n contents: templateHtml!,\n routeId: pathname,\n targetDomain: 'server',\n });\n return templateHtml!;\n },\n });\n }\n\n return files;\n}\n\nasync function exportApiRoutesAsync({\n includeSourceMaps,\n server,\n platform,\n apiRoutesOnly,\n ...props\n}: Pick<Options, 'includeSourceMaps'> & {\n server: MetroBundlerDevServer;\n manifest: ExpoRouterServerManifestV1;\n platform: string;\n apiRoutesOnly?: boolean;\n}): Promise<ExportAssetMap> {\n const { manifest, files } = await server.exportExpoRouterApiRoutesAsync({\n outputDir: '_expo/functions',\n prerenderManifest: props.manifest,\n includeSourceMaps,\n platform,\n });\n\n // HACK: Clear out the HTML and 404 routes if we're only exporting API routes. This is used for native apps that are using API routes but haven't implemented web support yet.\n if (apiRoutesOnly) {\n manifest.htmlRoutes = [];\n manifest.notFoundRoutes = [];\n }\n\n files.set('_expo/routes.json', {\n contents: JSON.stringify(manifest, null, 2),\n targetDomain: 'server',\n });\n\n return files;\n}\n\nfunction warnPossibleInvalidExportType(appDir: string) {\n const apiRoutes = getApiRoutesForDirectory(appDir);\n if (apiRoutes.length) {\n // TODO: Allow API Routes for native-only.\n Log.warn(\n chalk.yellow`Skipping export for API routes because \\`web.output\\` is not \"server\". You may want to remove the routes: ${apiRoutes\n .map((v) => path.relative(appDir, v))\n .join(', ')}`\n );\n }\n\n const middlewareFile = getMiddlewareForDirectory(appDir);\n if (middlewareFile) {\n Log.warn(\n chalk.yellow`Skipping export for middleware because \\`web.output\\` is not \"server\". You may want to remove ${path.relative(appDir, middlewareFile)}`\n );\n }\n}\n"],"names":["exportApiRoutesStandaloneAsync","exportFromServerAsync","getFilesToExportFromServerAsync","getHtmlFiles","getPathVariations","injectScriptTags","debug","require","html","scriptTags","scriptTagsHtml","map","tag","platform","src","join","replace","matchGroupName","name","match","projectRoot","manifest","renderAsync","exportServer","files","Map","Promise","all","includeGroupVariations","route","filePath","pathname","type","targetDomain","set","contents","data","routeId","e","logMetroErrorAsync","error","Error","modifyRouteNodeInRuntimeManifest","callback","iterateScreens","screens","Object","values","value","_route","makeRuntimeEntryPointsAbsolute","appDir","Array","isArray","entryPoints","entryPoint","shouldLinkExternally","startsWith","path","resolve","isAbsolute","resolveFrom","devServer","outputDir","baseUrl","includeSourceMaps","routerRoot","exp","Log","log","learnMore","isExporting","injectFaviconTag","getVirtualFaviconAssetsAsync","resources","serverManifest","getStaticResourcesAsync","getStaticRenderFunctionAsync","inspect","colors","depth","template","serializeHtmlWithAssets","artifacts","hydrate","getFilesFromSerialAssets","isServerHosted","assets","persistMetroAssetsAsync","outputDirectory","apiRoutes","exportApiRoutesAsync","server","warnPossibleInvalidExportType","htmlFiles","Set","traverseScreens","key","entries","leaf","keys","length","endsWith","slice","stripGroupSegmentsFromPath","addOptionalGroups","add","newPath","variations","variation","uniqueBy","from","parts","split","partsWithGroups","part","filePathLocation","array","seen","result","id","has","push","routePath","segments","generateVariations","current","head","rest","groups","group","trim","apiRoutesOnly","templateHtml","htmlManifest","getServerManifestAsync","isReactServerComponentsEnabled","props","exportExpoRouterApiRoutesAsync","prerenderManifest","htmlRoutes","notFoundRoutes","JSON","stringify","getApiRoutesForDirectory","warn","chalk","yellow","v","relative","middlewareFile","getMiddlewareForDirectory"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/export/exportStaticAsync.ts"],"sourcesContent":["/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { ExpoConfig } from '@expo/config';\nimport chalk from 'chalk';\nimport { RouteNode } from 'expo-router/build/Route';\nimport { stripGroupSegmentsFromPath } from 'expo-router/build/matchers';\nimport { shouldLinkExternally } from 'expo-router/build/utils/url';\nimport path from 'path';\nimport resolveFrom from 'resolve-from';\nimport { inspect } from 'util';\n\nimport { getVirtualFaviconAssetsAsync } from './favicon';\nimport { persistMetroAssetsAsync } from './persistMetroAssets';\nimport { ExportAssetMap, getFilesFromSerialAssets } from './saveAssets';\nimport { Log } from '../log';\nimport {\n ExpoRouterRuntimeManifest,\n MetroBundlerDevServer,\n} from '../start/server/metro/MetroBundlerDevServer';\nimport { ExpoRouterServerManifestV1 } from '../start/server/metro/fetchRouterManifest';\nimport { logMetroErrorAsync } from '../start/server/metro/metroErrorInterface';\nimport { getApiRoutesForDirectory, getMiddlewareForDirectory } from '../start/server/metro/router';\nimport { serializeHtmlWithAssets } from '../start/server/metro/serializeHtml';\nimport { learnMore } from '../utils/link';\n\nconst debug = require('debug')('expo:export:generateStaticRoutes') as typeof console.log;\n\ntype ExtraScriptTag = {\n platform: string;\n src: string;\n};\n\ntype Options = {\n mode: 'production' | 'development';\n files?: ExportAssetMap;\n outputDir: string;\n minify: boolean;\n exportServer: boolean;\n baseUrl: string;\n includeSourceMaps: boolean;\n entryPoint?: string;\n clear: boolean;\n routerRoot: string;\n reactCompiler: boolean;\n maxWorkers?: number;\n isExporting: boolean;\n exp?: ExpoConfig;\n // <script type=\"type/expo\" data-platform=\"ios\" src=\"...\" />\n scriptTags?: ExtraScriptTag[];\n};\n\ntype HtmlRequestLocation = {\n /** The output file path name to use relative to the static folder. */\n filePath: string;\n /** The pathname to make requests to in order to fetch the HTML. */\n pathname: string;\n /** The runtime route node object, used to associate async modules with the static HTML. */\n route: RouteNode;\n};\n\nexport function injectScriptTags(html: string, scriptTags: ExtraScriptTag[]): string {\n const scriptTagsHtml = scriptTags\n .map((tag) =>\n tag.platform === 'web'\n ? `<script src=\"${tag.src}\"></script>`\n : `<script type=\"type/expo\" src=\"${tag.src}\" data-platform=\"${tag.platform}\"></script>`\n )\n .join('\\n');\n html = html.replace('</head>', `${scriptTagsHtml}\\n</head>`);\n return html;\n}\n\n/** Match `(page)` -> `page` */\nfunction matchGroupName(name: string): string | undefined {\n return name.match(/^\\(([^/]+?)\\)$/)?.[1];\n}\n\nexport async function getFilesToExportFromServerAsync(\n projectRoot: string,\n {\n manifest,\n serverManifest,\n renderAsync,\n // Servers can handle group routes automatically and therefore\n // don't require the build-time generation of every possible group\n // variation.\n exportServer,\n // name : contents\n files = new Map(),\n }: {\n manifest: ExpoRouterRuntimeManifest;\n serverManifest: ExpoRouterServerManifestV1;\n renderAsync: (requestLocation: HtmlRequestLocation) => Promise<string>;\n exportServer?: boolean;\n files?: ExportAssetMap;\n }\n): Promise<ExportAssetMap> {\n if (!exportServer && serverManifest) {\n // When we're not exporting a `server` output, we provide a `_expo/.routes.json` for\n // EAS Hosting to recognize the `headers` and `redirects` configs\n const subsetServerManifest = {\n headers: serverManifest.headers,\n redirects: serverManifest.redirects,\n };\n files.set('_expo/.routes.json', {\n contents: JSON.stringify(subsetServerManifest, null, 2),\n targetDomain: 'client',\n });\n }\n\n await Promise.all(\n getHtmlFiles({ manifest, includeGroupVariations: !exportServer }).map(\n async ({ route, filePath, pathname }) => {\n // Rewrite routes should not be statically generated\n if (route.type === 'rewrite') {\n return;\n }\n\n try {\n const targetDomain = exportServer ? 'server' : 'client';\n files.set(filePath, { contents: '', targetDomain });\n const data = await renderAsync({ route, filePath, pathname });\n files.set(filePath, {\n contents: data,\n routeId: pathname,\n targetDomain,\n });\n } catch (e: any) {\n await logMetroErrorAsync({ error: e, projectRoot });\n throw new Error('Failed to statically export route: ' + pathname);\n }\n }\n )\n );\n\n return files;\n}\n\nfunction modifyRouteNodeInRuntimeManifest(\n manifest: ExpoRouterRuntimeManifest,\n callback: (route: RouteNode) => any\n) {\n const iterateScreens = (screens: ExpoRouterRuntimeManifest['screens']) => {\n Object.values(screens).map((value) => {\n if (typeof value !== 'string') {\n if (value._route) callback(value._route);\n iterateScreens(value.screens);\n }\n });\n };\n\n iterateScreens(manifest.screens);\n}\n\n// TODO: Do this earlier in the process.\nfunction makeRuntimeEntryPointsAbsolute(manifest: ExpoRouterRuntimeManifest, appDir: string) {\n modifyRouteNodeInRuntimeManifest(manifest, (route) => {\n if (Array.isArray(route.entryPoints)) {\n route.entryPoints = route.entryPoints.map((entryPoint) => {\n // TODO(@hassankhan): ENG-16577\n if (shouldLinkExternally(entryPoint)) {\n return entryPoint;\n }\n\n if (entryPoint.startsWith('.')) {\n return path.resolve(appDir, entryPoint);\n } else if (!path.isAbsolute(entryPoint)) {\n return resolveFrom(appDir, entryPoint);\n }\n return entryPoint;\n });\n }\n });\n}\n\n/** Perform all fs commits */\nexport async function exportFromServerAsync(\n projectRoot: string,\n devServer: MetroBundlerDevServer,\n {\n outputDir,\n baseUrl,\n exportServer,\n includeSourceMaps,\n routerRoot,\n files = new Map(),\n exp,\n scriptTags,\n }: Options\n): Promise<ExportAssetMap> {\n Log.log(\n `Static rendering is enabled. ` +\n learnMore('https://docs.expo.dev/router/reference/static-rendering/')\n );\n\n const platform = 'web';\n const isExporting = true;\n const appDir = path.join(projectRoot, routerRoot);\n const injectFaviconTag = await getVirtualFaviconAssetsAsync(projectRoot, {\n outputDir,\n baseUrl,\n files,\n exp,\n });\n\n const [resources, { manifest, serverManifest, renderAsync }] = await Promise.all([\n devServer.getStaticResourcesAsync({\n includeSourceMaps,\n }),\n devServer.getStaticRenderFunctionAsync(),\n ]);\n\n makeRuntimeEntryPointsAbsolute(manifest, appDir);\n\n debug('Routes:\\n', inspect(manifest, { colors: true, depth: null }));\n\n await getFilesToExportFromServerAsync(projectRoot, {\n files,\n manifest,\n serverManifest,\n exportServer,\n async renderAsync({ pathname, route }) {\n const template = await renderAsync(pathname);\n let html = await serializeHtmlWithAssets({\n isExporting,\n resources: resources.artifacts,\n template,\n baseUrl,\n route,\n hydrate: true,\n });\n\n if (injectFaviconTag) {\n html = injectFaviconTag(html);\n }\n\n if (scriptTags) {\n // Inject script tags into the HTML.\n // <script type=\"type/expo\" data-platform=\"ios\" src=\"...\" />\n html = injectScriptTags(html, scriptTags);\n }\n\n return html;\n },\n });\n\n getFilesFromSerialAssets(resources.artifacts, {\n platform,\n includeSourceMaps,\n files,\n isServerHosted: true,\n });\n\n if (resources.assets) {\n // TODO: Collect files without writing to disk.\n // NOTE(kitten): Re. above, this is now using `files` except for iOS catalog output, which isn't used here\n await persistMetroAssetsAsync(projectRoot, resources.assets, {\n files,\n platform,\n outputDirectory: outputDir,\n baseUrl,\n });\n }\n\n if (exportServer) {\n const apiRoutes = await exportApiRoutesAsync({\n platform: 'web',\n server: devServer,\n manifest: serverManifest,\n // NOTE(kitten): For now, we always output source maps for API route exports\n includeSourceMaps: true,\n });\n\n // Add the api routes to the files to export.\n for (const [route, contents] of apiRoutes) {\n files.set(route, contents);\n }\n } else {\n warnPossibleInvalidExportType(appDir);\n }\n\n return files;\n}\n\nexport function getHtmlFiles({\n manifest,\n includeGroupVariations,\n}: {\n manifest: ExpoRouterRuntimeManifest;\n includeGroupVariations?: boolean;\n}): HtmlRequestLocation[] {\n const htmlFiles = new Set<Omit<HtmlRequestLocation, 'pathname'>>();\n\n function traverseScreens(\n screens: ExpoRouterRuntimeManifest['screens'],\n route: RouteNode | null,\n baseUrl = ''\n ) {\n for (const [key, value] of Object.entries(screens)) {\n let leaf: string | null = null;\n if (typeof value === 'string') {\n leaf = value;\n } else if (value.screens && Object.keys(value.screens).length === 0) {\n // Ensure the trailing index is accounted for.\n if (key === value.path + '/index') {\n leaf = key;\n } else {\n leaf = value.path;\n }\n\n route = value._route ?? null;\n }\n\n if (leaf != null) {\n let filePath = baseUrl + leaf;\n\n if (leaf === '') {\n filePath =\n baseUrl === ''\n ? 'index'\n : baseUrl.endsWith('/')\n ? baseUrl + 'index'\n : baseUrl.slice(0, -1);\n } else if (\n // If the path is a collection of group segments leading to an index route, append `/index`.\n stripGroupSegmentsFromPath(filePath) === ''\n ) {\n filePath += '/index';\n }\n\n // This should never happen, the type of `string | object` originally comes from React Navigation.\n if (!route) {\n throw new Error(\n `Internal error: Route not found for \"${filePath}\" while collecting static export paths.`\n );\n }\n\n if (includeGroupVariations) {\n // TODO: Dedupe requests for alias routes.\n addOptionalGroups(filePath, route);\n } else {\n htmlFiles.add({\n filePath,\n route,\n });\n }\n } else if (typeof value === 'object' && value?.screens) {\n // The __root slot has no path.\n const newPath = value.path ? baseUrl + value.path + '/' : baseUrl;\n traverseScreens(value.screens, value._route ?? null, newPath);\n }\n }\n }\n\n function addOptionalGroups(path: string, route: RouteNode) {\n const variations = getPathVariations(path);\n for (const variation of variations) {\n htmlFiles.add({ filePath: variation, route });\n }\n }\n\n traverseScreens(manifest.screens, null);\n\n return uniqueBy(Array.from(htmlFiles), (value) => value.filePath).map((value) => {\n const parts = value.filePath.split('/');\n // Replace `:foo` with `[foo]` and `*foo` with `[...foo]`\n const partsWithGroups = parts.map((part) => {\n if (part === '*not-found') {\n return `+not-found`;\n } else if (part.startsWith(':')) {\n return `[${part.slice(1)}]`;\n } else if (part.startsWith('*')) {\n return `[...${part.slice(1)}]`;\n }\n return part;\n });\n const filePathLocation = partsWithGroups.join('/');\n const filePath = filePathLocation + '.html';\n return {\n ...value,\n filePath,\n pathname: filePathLocation.replace(/(\\/?index)?$/, ''),\n };\n });\n}\n\nfunction uniqueBy<T>(array: T[], key: (value: T) => string): T[] {\n const seen = new Set<string>();\n const result: T[] = [];\n for (const value of array) {\n const id = key(value);\n if (!seen.has(id)) {\n seen.add(id);\n result.push(value);\n }\n }\n return result;\n}\n\n// Given a route like `(foo)/bar/(baz)`, return all possible variations of the route.\n// e.g. `(foo)/bar/(baz)`, `(foo)/bar/baz`, `foo/bar/(baz)`, `foo/bar/baz`,\nexport function getPathVariations(routePath: string): string[] {\n const variations = new Set<string>();\n const segments = routePath.split('/');\n\n function generateVariations(segments: string[], current = ''): void {\n if (segments.length === 0) {\n if (current) variations.add(current);\n return;\n }\n\n const [head, ...rest] = segments;\n\n if (matchGroupName(head)) {\n const groups = head.slice(1, -1).split(',');\n\n if (groups.length > 1) {\n for (const group of groups) {\n // If there are multiple groups, recurse on each group.\n generateVariations([`(${group.trim()})`, ...rest], current);\n }\n return;\n } else {\n // Start a fork where this group is included\n generateVariations(rest, current ? `${current}/(${groups[0]})` : `(${groups[0]})`);\n // This code will continue and add paths without this group included`\n }\n } else if (current) {\n current = `${current}/${head}`;\n } else {\n current = head;\n }\n\n generateVariations(rest, current);\n }\n\n generateVariations(segments);\n\n return Array.from(variations);\n}\n\nexport async function exportApiRoutesStandaloneAsync(\n devServer: MetroBundlerDevServer,\n {\n files = new Map(),\n platform,\n apiRoutesOnly,\n templateHtml,\n }: {\n files?: ExportAssetMap;\n platform: string;\n apiRoutesOnly: boolean;\n templateHtml?: string;\n }\n) {\n const { serverManifest, htmlManifest } = await devServer.getServerManifestAsync();\n\n const apiRoutes = await exportApiRoutesAsync({\n server: devServer,\n manifest: serverManifest,\n // NOTE(kitten): For now, we always output source maps for API route exports\n includeSourceMaps: true,\n platform,\n apiRoutesOnly,\n });\n\n // Add the api routes to the files to export.\n for (const [route, contents] of apiRoutes) {\n files.set(route, contents);\n }\n\n if (templateHtml && devServer.isReactServerComponentsEnabled) {\n // TODO: Export an HTML entry for each file. This is a temporary solution until we have SSR/SSG for RSC.\n await getFilesToExportFromServerAsync(devServer.projectRoot, {\n manifest: htmlManifest,\n serverManifest,\n exportServer: true,\n files,\n renderAsync: async ({ pathname, filePath }) => {\n files.set(filePath, {\n contents: templateHtml!,\n routeId: pathname,\n targetDomain: 'server',\n });\n return templateHtml!;\n },\n });\n }\n\n return files;\n}\n\nasync function exportApiRoutesAsync({\n includeSourceMaps,\n server,\n platform,\n apiRoutesOnly,\n ...props\n}: Pick<Options, 'includeSourceMaps'> & {\n server: MetroBundlerDevServer;\n manifest: ExpoRouterServerManifestV1;\n platform: string;\n apiRoutesOnly?: boolean;\n}): Promise<ExportAssetMap> {\n const { manifest, files } = await server.exportExpoRouterApiRoutesAsync({\n outputDir: '_expo/functions',\n prerenderManifest: props.manifest,\n includeSourceMaps,\n platform,\n });\n\n // HACK: Clear out the HTML and 404 routes if we're only exporting API routes. This is used for native apps that are using API routes but haven't implemented web support yet.\n if (apiRoutesOnly) {\n manifest.htmlRoutes = [];\n manifest.notFoundRoutes = [];\n }\n\n files.set('_expo/routes.json', {\n contents: JSON.stringify(manifest, null, 2),\n targetDomain: 'server',\n });\n\n return files;\n}\n\nfunction warnPossibleInvalidExportType(appDir: string) {\n const apiRoutes = getApiRoutesForDirectory(appDir);\n if (apiRoutes.length) {\n // TODO: Allow API Routes for native-only.\n Log.warn(\n chalk.yellow`Skipping export for API routes because \\`web.output\\` is not \"server\". You may want to remove the routes: ${apiRoutes\n .map((v) => path.relative(appDir, v))\n .join(', ')}`\n );\n }\n\n const middlewareFile = getMiddlewareForDirectory(appDir);\n if (middlewareFile) {\n Log.warn(\n chalk.yellow`Skipping export for middleware because \\`web.output\\` is not \"server\". You may want to remove ${path.relative(appDir, middlewareFile)}`\n );\n }\n}\n"],"names":["exportApiRoutesStandaloneAsync","exportFromServerAsync","getFilesToExportFromServerAsync","getHtmlFiles","getPathVariations","injectScriptTags","debug","require","html","scriptTags","scriptTagsHtml","map","tag","platform","src","join","replace","matchGroupName","name","match","projectRoot","manifest","serverManifest","renderAsync","exportServer","files","Map","subsetServerManifest","headers","redirects","set","contents","JSON","stringify","targetDomain","Promise","all","includeGroupVariations","route","filePath","pathname","type","data","routeId","e","logMetroErrorAsync","error","Error","modifyRouteNodeInRuntimeManifest","callback","iterateScreens","screens","Object","values","value","_route","makeRuntimeEntryPointsAbsolute","appDir","Array","isArray","entryPoints","entryPoint","shouldLinkExternally","startsWith","path","resolve","isAbsolute","resolveFrom","devServer","outputDir","baseUrl","includeSourceMaps","routerRoot","exp","Log","log","learnMore","isExporting","injectFaviconTag","getVirtualFaviconAssetsAsync","resources","getStaticResourcesAsync","getStaticRenderFunctionAsync","inspect","colors","depth","template","serializeHtmlWithAssets","artifacts","hydrate","getFilesFromSerialAssets","isServerHosted","assets","persistMetroAssetsAsync","outputDirectory","apiRoutes","exportApiRoutesAsync","server","warnPossibleInvalidExportType","htmlFiles","Set","traverseScreens","key","entries","leaf","keys","length","endsWith","slice","stripGroupSegmentsFromPath","addOptionalGroups","add","newPath","variations","variation","uniqueBy","from","parts","split","partsWithGroups","part","filePathLocation","array","seen","result","id","has","push","routePath","segments","generateVariations","current","head","rest","groups","group","trim","apiRoutesOnly","templateHtml","htmlManifest","getServerManifestAsync","isReactServerComponentsEnabled","props","exportExpoRouterApiRoutesAsync","prerenderManifest","htmlRoutes","notFoundRoutes","getApiRoutesForDirectory","warn","chalk","yellow","v","relative","middlewareFile","getMiddlewareForDirectory"],"mappings":"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"}
@@ -33,7 +33,7 @@ class FetchClient {
33
33
  this.headers = {
34
34
  accept: 'application/json',
35
35
  'content-type': 'application/json',
36
- 'user-agent': `expo-cli/${"54.1.0-canary-20251009-9919e08"}`,
36
+ 'user-agent': `expo-cli/${"54.1.0-canary-20251013-623c5a6"}`,
37
37
  authorization: 'Basic ' + _nodebuffer().Buffer.from(`${target}:`).toString('base64')
38
38
  };
39
39
  }
@@ -83,7 +83,7 @@ function createContext() {
83
83
  cpu: summarizeCpuInfo(),
84
84
  app: {
85
85
  name: 'expo/cli',
86
- version: "54.1.0-canary-20251009-9919e08"
86
+ version: "54.1.0-canary-20251013-623c5a6"
87
87
  },
88
88
  ci: _ciinfo().isCI ? {
89
89
  name: _ciinfo().name,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@expo/cli",
3
- "version": "54.1.0-canary-20251009-9919e08",
3
+ "version": "54.1.0-canary-20251013-623c5a6",
4
4
  "description": "The Expo CLI",
5
5
  "main": "build/bin/cli",
6
6
  "bin": {
@@ -43,20 +43,20 @@
43
43
  "dependencies": {
44
44
  "@0no-co/graphql.web": "^1.0.8",
45
45
  "@expo/code-signing-certificates": "^0.0.5",
46
- "@expo/config": "12.0.11-canary-20251009-9919e08",
47
- "@expo/config-plugins": "54.0.3-canary-20251009-9919e08",
46
+ "@expo/config": "12.0.11-canary-20251013-623c5a6",
47
+ "@expo/config-plugins": "54.0.3-canary-20251013-623c5a6",
48
48
  "@expo/devcert": "^1.1.2",
49
- "@expo/env": "2.0.8-canary-20251009-9919e08",
50
- "@expo/image-utils": "0.8.8-canary-20251009-9919e08",
51
- "@expo/json-file": "10.0.8-canary-20251009-9919e08",
49
+ "@expo/env": "2.0.8-canary-20251013-623c5a6",
50
+ "@expo/image-utils": "0.8.8-canary-20251013-623c5a6",
51
+ "@expo/json-file": "10.0.8-canary-20251013-623c5a6",
52
52
  "@expo/mcp-tunnel": "~0.0.7",
53
53
  "@expo/metro": "~54.0.0",
54
- "@expo/metro-config": "54.0.7-canary-20251009-9919e08",
55
- "@expo/osascript": "2.3.8-canary-20251009-9919e08",
56
- "@expo/package-manager": "1.9.9-canary-20251009-9919e08",
57
- "@expo/plist": "0.4.8-canary-20251009-9919e08",
58
- "@expo/prebuild-config": "54.0.5-canary-20251009-9919e08",
59
- "@expo/schema-utils": "0.1.8-canary-20251009-9919e08",
54
+ "@expo/metro-config": "54.0.7-canary-20251013-623c5a6",
55
+ "@expo/osascript": "2.3.8-canary-20251013-623c5a6",
56
+ "@expo/package-manager": "1.9.9-canary-20251013-623c5a6",
57
+ "@expo/plist": "0.4.8-canary-20251013-623c5a6",
58
+ "@expo/prebuild-config": "54.0.6-canary-20251013-623c5a6",
59
+ "@expo/schema-utils": "0.1.8-canary-20251013-623c5a6",
60
60
  "@expo/spawn-async": "^1.7.2",
61
61
  "@expo/ws-tunnel": "^1.0.1",
62
62
  "@expo/xcpretty": "^4.3.0",
@@ -74,7 +74,7 @@
74
74
  "connect": "^3.7.0",
75
75
  "debug": "^4.3.4",
76
76
  "env-editor": "^0.4.1",
77
- "expo-server": "1.1.0-canary-20251009-9919e08",
77
+ "expo-server": "1.1.0-canary-20251013-623c5a6",
78
78
  "freeport-async": "^2.0.0",
79
79
  "getenv": "^2.0.0",
80
80
  "glob": "^10.4.2",
@@ -113,8 +113,8 @@
113
113
  ]
114
114
  },
115
115
  "peerDependencies": {
116
- "expo": "55.0.0-canary-20251009-9919e08",
117
- "expo-router": "6.1.0-canary-20251009-9919e08",
116
+ "expo": "55.0.0-canary-20251013-623c5a6",
117
+ "expo-router": "6.1.0-canary-20251013-623c5a6",
118
118
  "react-native": "*"
119
119
  },
120
120
  "peerDependenciesMeta": {
@@ -157,7 +157,7 @@
157
157
  "@types/ws": "^8.5.4",
158
158
  "devtools-protocol": "^0.0.1113120",
159
159
  "expo-atlas": "^0.4.1",
160
- "expo-module-scripts": "5.0.8-canary-20251009-9919e08",
160
+ "expo-module-scripts": "5.0.8-canary-20251013-623c5a6",
161
161
  "find-process": "^1.4.7",
162
162
  "jest-runner-tsd": "^6.0.0",
163
163
  "klaw-sync": "^6.0.0",