9b5cfe5e49
Recipe image upload failed in prod with ENOENT writing the full image. Root cause: the deploy built against the dev .env, whose relative IMAGE_DIR="./imgs/" resolves under the service's dist/ working dir instead of the real served image directory — and `$env/static/private` is inlined at build time, so dev values shipped to prod. - deploy.sh: source .env_prod (overridable via PROD_ENV) into the env before `pnpm build`, so prod values win over .env for the whole build lifecycle; abort if it's missing rather than ship a dev-env build. - .gitignore: ignore .env_* so .env_prod (prod secrets) isn't committed (the existing .env.* dot pattern didn't match the underscore form). - imageProcessing: mkdir -p the full/thumb dirs before writing. The WebP passthrough writes the full image with fs.writeFile, which (unlike sharp's toFile) does not create parent dirs. - recipeFormHelpers: add serializableFormValues() and use it in the add/ edit actions' fail() returns. Returning raw formData (now containing the recipe_image File) crashed the action response with a non-POJO devalue error, masking the real failure with an opaque 500.
60 lines
2.0 KiB
Plaintext
60 lines
2.0 KiB
Plaintext
.DS_Store
|
|
*/.jukit
|
|
*/.jukit/*
|
|
node_modules
|
|
/build
|
|
/.svelte-kit
|
|
/package
|
|
.env
|
|
.env.*
|
|
.env_*
|
|
!.env.example
|
|
vite.config.js.timestamp-*
|
|
vite.config.ts.timestamp-*
|
|
# USDA bulk data downloads (regenerated by scripts/import-usda-nutrition.ts)
|
|
data/usda/
|
|
# Loyalty-card barcodes (regenerated by scripts/generate-loyalty-cards.ts from env)
|
|
static/shopping/supercard.svg
|
|
static/shopping/cumulus.svg
|
|
# Hikes build outputs (regenerated by scripts/build-hikes.ts at prebuild)
|
|
static/hikes/
|
|
hikes-assets/
|
|
src/lib/data/hikes.generated.ts
|
|
# Tile-proxy build artefacts + secrets (the source tree itself is tracked).
|
|
# The binary is dropped next to Cargo.toml by `make build`; its name happens
|
|
# to collide with the directory it lives in, so the path is fully qualified
|
|
# here to avoid the nested-gitignore quirk that previously hid the source.
|
|
/tile-proxy/tile-proxy
|
|
/tile-proxy/target/
|
|
/tile-proxy/.env
|
|
# Private image build outputs (regenerated by scripts/build-private-images.ts).
|
|
# Sources are private + large, so they're ignored too — only the README is kept.
|
|
private-assets/
|
|
src/lib/data/privateImages.generated.ts
|
|
src/lib/assets/private-images/*
|
|
!src/lib/assets/private-images/README.md
|
|
# Build-script disk caches (Swisstopo identify, BRouter responses, ...)
|
|
scripts/.cache/
|
|
# Loose working-tree scratch files (notes, photos, prototypes) that aren't
|
|
# part of the committed source.
|
|
/HIKES_PLAN.md
|
|
/additional_apologetics.md
|
|
/header_jellyfin.html
|
|
/person-hiking.svg
|
|
/PXL_*.jpg
|
|
/PXL_*.MP.jpg
|
|
src-tauri/icons/_safezone_template_*.png
|
|
src-tauri/target/
|
|
src-tauri/*.keystore
|
|
# Android: ignore build output and caches, track source files
|
|
src-tauri/gen/android/.gradle/
|
|
src-tauri/gen/android/app/build/
|
|
src-tauri/gen/android/buildSrc/.gradle/
|
|
src-tauri/gen/android/buildSrc/build/
|
|
|
|
# Hike content: track the writing (index.svx), route (track.gpx) and icons,
|
|
# but not the source photos (huge; re-encoded into static assets at build time).
|
|
src/content/hikes/*/images/
|
|
src/content/hikes/*/private/
|
|
src/content/hikes/*/cover.*
|