[PIE-1] Add initial svelte project #2

Merged
breadone merged 7 commits from PIE-1 into main 2025-08-12 12:27:42 +12:00
5 changed files with 73 additions and 1 deletions
Showing only changes of commit 0c692a62e8 - Show all commits

25
api/Dockerfile Normal file
View File

@ -0,0 +1,25 @@
FROM alpine:latest
ARG PB_VERSION=0.29.2
ENV PB_DATA_DIR=/pb_data
WORKDIR /pb
RUN apk add --no-cache \
unzip \
curl \
ca-certificates \
bash
# download and unzip PocketBase
ADD https://github.com/pocketbase/pocketbase/releases/download/v${PB_VERSION}/pocketbase_${PB_VERSION}_linux_amd64.zip /tmp/pb.zip
RUN unzip /tmp/pb.zip -d /pb/
# copy entrypoint
COPY docker-entrypoint.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/docker-entrypoint.sh
EXPOSE 8080
ENTRYPOINT ["docker-entrypoint.sh"]
CMD ["serve", "--http=0.0.0.0:8080"]

27
api/docker-entrypoint.sh Normal file
View File

@ -0,0 +1,27 @@
#!/usr/bin/env bash
set -e
# Required env-vars
: "${PB_ADMIN_EMAIL:?need PB_ADMIN_EMAIL}"
: "${PB_ADMIN_PASSWORD:?need PB_ADMIN_PASSWORD}"
: "${PB_DATA_DIR:?need PB_DATA_DIR}"
# ensure data dir exists (for embedded SQLite + migrations + files)
mkdir -p "${PB_DATA_DIR}"
export POCKETBASE_DATA_DIR="${PB_DATA_DIR}"
# if there are no users yet, create the superuser
# we check the sqlite file for any existing record in the users table
if [ ! -f "${PB_DATA_DIR}/pb_data.db" ] || ! \
sqlite3 "${PB_DATA_DIR}/pb_data.db" \
"SELECT id FROM users WHERE email='${PB_ADMIN_EMAIL}' LIMIT 1;" \
| grep -q .; then
echo ">>> Creating PocketBase superuser: ${PB_ADMIN_EMAIL}"
/pb/pocketbase superuser create "${PB_ADMIN_EMAIL}" "${PB_ADMIN_PASSWORD}"
else
echo ">>> Superuser ${PB_ADMIN_EMAIL} already exists, skipping creation."
fi
# exec the real pocketbase binary with any passed arguments
exec /pb/pocketbase "$@"

View File

@ -3,4 +3,12 @@ services:
build: .
env_file: .env
ports:
- "4173:4173"
- "4173:4173"
pb:
build: api
env_file: .env
volumes:
- ./data:/pb_data
ports:
- "8080:8080"

9
package-lock.json generated
View File

@ -7,6 +7,9 @@
"": {
"name": "recipie",
"version": "0.0.1",
"dependencies": {
"pocketbase": "^0.26.2"
},
"devDependencies": {
"@sveltejs/adapter-node": "^5.2.12",
"@sveltejs/kit": "^2.22.0",
@ -2084,6 +2087,12 @@
"url": "https://github.com/sponsors/jonschlinkert"
}
},
"node_modules/pocketbase": {
"version": "0.26.2",
"resolved": "https://registry.npmjs.org/pocketbase/-/pocketbase-0.26.2.tgz",
"integrity": "sha512-WA8EOBc3QnSJh8rJ3iYoi9DmmPOMFIgVfAmIGux7wwruUEIzXgvrO4u0W2htfQjGIcyezJkdZOy5Xmh7SxAftw==",
"license": "MIT"
},
"node_modules/postcss": {
"version": "8.5.6",
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.6.tgz",

View File

@ -28,5 +28,8 @@
"tailwindcss": "^4.0.0",
"typescript": "^5.0.0",
"vite": "^7.0.4"
},
"dependencies": {
"pocketbase": "^0.26.2"
}
}