Compare commits

..

No commits in common. "cb570a7663c8cd49c7b99118edc62029d6bffc99" and "1dab2f7f4e35e5377f46b23352ff7b9c020df31d" have entirely different histories.

3 changed files with 13 additions and 18 deletions

View file

@ -11,10 +11,10 @@ ENV UV_NO_MANAGED_PYTHON=true
ENV VIRTUAL_ENV=/usr/local/share/dooris/venv/ ENV VIRTUAL_ENV=/usr/local/share/dooris/venv/
ENV PNPM_HOME=/usr/local/share/dooris/pnpm/ ENV PNPM_HOME=/usr/local/share/dooris/pnpm/
ENV PATH=$PNPM_HOME:$VIRTUAL_ENV/bin:$PATH ENV PATH=$PNPM_HOME:$VIRTUAL_ENV/bin:$PATH
ENV DOORIS_SERVE_STATIC=/var/www/dooris/static/ ENV DOORIS_STATIC_ROOT=/var/www/dooris/static/
WORKDIR /usr/local/src/dooris/ WORKDIR /usr/local/src/dooris/
RUN apk add --no-cache uv python3 pnpm RUN apk add --no-cache uv nginx python3 pnpm
RUN addgroup -g $APP_GID dooris &&\ RUN addgroup -g $APP_GID dooris &&\
adduser -h /usr/local/src/dooris -u $APP_UID -G dooris -D dooris &&\ adduser -h /usr/local/src/dooris -u $APP_UID -G dooris -D dooris &&\
mkdir -p /var/www/dooris/ /usr/local/share/dooris/ /usr/local/src/dooris/ /var/cache/dooris/ &&\ mkdir -p /var/www/dooris/ /usr/local/share/dooris/ /usr/local/src/dooris/ /var/cache/dooris/ &&\
@ -25,19 +25,25 @@ RUN addgroup -g $APP_GID dooris &&\
FROM base AS deps FROM base AS deps
USER dooris USER dooris
ADD --link --chown=dooris:dooris api/pyproject.toml api/uv.lock api/ ADD --link --chown=dooris:dooris api/pyproject.toml api/uv.lock api/
ADD --link --chown=dooris:dooris app/package.json app/pnpm-lock.yaml app/ # ADD --link --chown=dooris:dooris package.json pnpm-lock.yaml .
RUN uv venv $VIRTUAL_ENV &&\ RUN uv venv $VIRTUAL_ENV &&\
uv sync --active --frozen --no-install-project --no-editable uv sync --active --frozen --no-install-project --no-editable
RUN pnpm --dir=app/ install --frozen-lockfile --package-import-method=copy # RUN pnpm install --frozen-lockfile --package-import-method=copy
FROM deps AS final FROM deps AS final
ADD --chown=dooris:dooris --link . /usr/local/src/dooris/ ADD --chown=dooris:dooris --link . /usr/local/src/dooris/
RUN pnpm --dir=app/ run build --outDir=$DOORIS_SERVE_STATIC # RUN pnpm run build
RUN --mount=type=cache,uid=$APP_UID,gid=$APP_GID,target=$UV_CACHE_DIR \ RUN --mount=type=cache,uid=$APP_UID,gid=$APP_GID,target=$UV_CACHE_DIR \
uv sync --active --frozen uv sync --active --frozen
# RUN export dooris_SECRET_KEY=django-insecure \
# dooris_BASE_URI=http://invalid.invalid \
# dooris_DB_URL=sqlite:///:memory: &&\
# ./manage.py collectstatic --no-input
ENTRYPOINT [ "uv", "run", "--active", "dooris-api" ] # ADD dev/cmd.sh /usr/local/bin/cmd.sh
ENTRYPOINT [ "/usr/local/bin/cmd.sh" ]
CMD [ "0.0.0.0:8000" ]
EXPOSE 8000/tcp EXPOSE 8000/tcp

View file

@ -40,22 +40,12 @@ def main():
default=os.environ.get("DOORIS_BASE_URL", None), default=os.environ.get("DOORIS_BASE_URL", None),
help="The Base-URL that this application is reachable under", help="The Base-URL that this application is reachable under",
) )
argp.add_argument(
"--serve-static",
required=False,
default=os.environ.get("DOORIS_SERVE_STATIC", None),
help="In addition to the API functionality, serve static files from this path",
)
args = argp.parse_args() args = argp.parse_args()
app_config.set(args) app_config.set(args)
import uvicorn import uvicorn
from dooris_api.app import app from dooris_api.app import app
if args.serve_static:
from fastapi.staticfiles import StaticFiles
app.mount("/", StaticFiles(directory=args.serve_static, html=True), name="static")
config = uvicorn.Config(app, port=8000, log_level="debug") config = uvicorn.Config(app, port=8000, log_level="debug")
server = uvicorn.Server(config) server = uvicorn.Server(config)
server.run() server.run()

View file

@ -48,7 +48,6 @@ async def lifespan(app: FastAPI):
app = FastAPI( app = FastAPI(
title="Dooris", title="Dooris",
summary="Server to interact with CCCHH doors via locks over CCUJACK over HomeMatic over WiFi", summary="Server to interact with CCCHH doors via locks over CCUJACK over HomeMatic over WiFi",
openapi_url="/api/openapi.json",
docs_url="/api/docs", docs_url="/api/docs",
lifespan=lifespan, lifespan=lifespan,
) )