Minimize size of docker image in stack (#7)

Part of https://www.notion.so/Implement-stacks-1b5a6b22d472806a82f5dafed6955138

Reviewed-on: LaconicNetwork/zenith-wallet-web#7
Co-authored-by: Nabarun <nabarun@deepstacksoft.com>
Co-committed-by: Nabarun <nabarun@deepstacksoft.com>
This commit is contained in:
Nabarun 2025-07-30 10:20:47 +00:00 committed by nabarun
parent 49d454dcf7
commit 438db6d5c6
3 changed files with 26 additions and 12 deletions

View File

@ -1,6 +1,6 @@
{ {
"name": "web-wallet", "name": "web-wallet",
"version": "0.1.7-zenith-0.2.0", "version": "0.1.7-zenith-0.2.1",
"private": true, "private": true,
"dependencies": { "dependencies": {
"@laconic-network/cosmjs-util": "^0.1.0", "@laconic-network/cosmjs-util": "^0.1.0",

View File

@ -18,7 +18,7 @@ export REACT_APP_GAS_ADJUSTMENT=$CERC_GAS_ADJUSTMENT
export REACT_APP_ALLOWED_URLS=$CERC_ALLOWED_URLS export REACT_APP_ALLOWED_URLS=$CERC_ALLOWED_URLS
# Set env variables in build # Set env variables in build
yarn set-env import-meta-env -x /app/.env.example -p /app/build/index.html
# Define the directory and file path # Define the directory and file path
FILE_PATH="/app/build/.well-known/walletconnect.txt" FILE_PATH="/app/build/.well-known/walletconnect.txt"

View File

@ -1,7 +1,9 @@
# Originally from: https://github.com/devcontainers/images/blob/main/src/javascript-node/.devcontainer/Dockerfile # Originally from: https://github.com/devcontainers/images/blob/main/src/javascript-node/.devcontainer/Dockerfile
# [Choice] Node.js version (use -bullseye variants on local arm64/Apple Silicon): 18, 16, 14, 18-bullseye, 16-bullseye, 14-bullseye, 18-buster, 16-buster, 14-buster # [Choice] Node.js version (use -bullseye variants on local arm64/Apple Silicon): 18, 16, 14, 18-bullseye, 16-bullseye, 14-bullseye, 18-buster, 16-buster, 14-buster
ARG VARIANT=22-bullseye ARG VARIANT=22-bullseye
FROM node:${VARIANT}
# Build stage
FROM node:${VARIANT} AS builder
ARG USERNAME=node ARG USERNAME=node
ARG NPM_GLOBAL=/usr/local/share/npm-global ARG NPM_GLOBAL=/usr/local/share/npm-global
@ -26,18 +28,30 @@ RUN \
&& su ${USERNAME} -c "umask 0002 && npm install -g eslint" \ && su ${USERNAME} -c "umask 0002 && npm install -g eslint" \
&& npm cache clean --force > /dev/null 2>&1 && npm cache clean --force > /dev/null 2>&1
# Install additional OS packages.
RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
&& apt-get -y install --no-install-recommends jq bash netcat
RUN mkdir -p /scripts
# Install simple web server for now (use nginx perhaps later)
RUN yarn global add serve
WORKDIR /app WORKDIR /app
COPY . . COPY . .
RUN yarn install && yarn build RUN yarn install && yarn build
# Production stage
FROM node:${VARIANT}-slim AS production
# Install additional OS packages for debugging
RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
&& apt-get -y install --no-install-recommends bash netcat \
&& rm -rf /var/lib/apt/lists/*
RUN mkdir -p /scripts
# Install serve package globally
# Install import-meta-env for setting environment variables (check package.json for version)
RUN yarn global add serve@^14.2.4 @import-meta-env/cli@^0.7.3
# Create app directory
WORKDIR /app
# Copy built application and env example from builder stage
COPY --from=builder /app/build ./build
COPY --from=builder /app/.env.example ./.env.example
# Expose port for http # Expose port for http
EXPOSE 80 EXPOSE 80