mirror of
https://github.com/ThatGuySam/doesitarm.git
synced 2026-05-18 06:44:46 -07:00
The previous route fallback fix worked locally but still failed on production because the Netlify SSR runtime did not have repo-local JSON files available at the paths the helper searched. Switch the fallback helper to raw-import the generated app, game, device, and YouTube JSON inputs so the SSR bundle carries the data it needs at runtime, independent of function working directory or file packaging quirks. Constraint: Netlify SSR bundling does not reliably expose repo-local generated files as runtime-readable filesystem paths Rejected: Rely on Netlify included_files for SSR bundle data | the generated SSR function archive still omitted the fallback files Rejected: Fetch large fallback JSON over HTTP on each request | unnecessary network dependency for a server-side fallback path Confidence: medium Scope-risk: narrow Reversibility: clean Directive: Prefer bundler-native inclusion for SSR-only fallback data when runtime file availability is uncertain on Netlify Tested: vitest ./test/prebuild/config-node.test.js ./test/prebuild/site-listings.test.js; pnpm run netlify-build Not-tested: live production after redeploy
37 lines
1.3 KiB
JavaScript
37 lines
1.3 KiB
JavaScript
import youtubeVideosText from '~/static/api/youtube-videos.json?raw'
|
|
import appListText from '~/static/app-list.json?raw'
|
|
import deviceListText from '~/static/device-list.json?raw'
|
|
import gameListText from '~/static/game-list.json?raw'
|
|
|
|
import {
|
|
buildVideoListingFromFetchedVideo,
|
|
makeVideoSlug
|
|
} from '~/helpers/build-video-list.js'
|
|
const trailingCommaPattern = /,\s*([\]}])/g
|
|
const parsedDeviceList = JSON.parse( deviceListText.replace( trailingCommaPattern, '$1' ) )
|
|
const parsedAppList = JSON.parse( appListText.replace( trailingCommaPattern, '$1' ) )
|
|
const parsedGameList = JSON.parse( gameListText.replace( trailingCommaPattern, '$1' ) )
|
|
const parsedYoutubeVideos = JSON.parse( youtubeVideosText )
|
|
|
|
export function getDeviceListingBySlug ( slug ) {
|
|
return parsedDeviceList.find( device => device.slug === slug ) || null
|
|
}
|
|
|
|
function getAllVideoAppsList () {
|
|
return [
|
|
...parsedAppList,
|
|
...parsedGameList
|
|
]
|
|
}
|
|
|
|
export async function getVideoListingBySlug ( slug ) {
|
|
const allVideoAppsList = getAllVideoAppsList()
|
|
|
|
for ( const [ videoId, fetchedVideo ] of Object.entries( parsedYoutubeVideos ) ) {
|
|
if ( makeVideoSlug( fetchedVideo.title, videoId ) !== slug ) continue
|
|
|
|
return await buildVideoListingFromFetchedVideo( fetchedVideo, videoId, allVideoAppsList )
|
|
}
|
|
|
|
return null
|
|
}
|