|
| 1 | +FROM ruby:3.2-slim-bookworm@sha256:6ff55a14560f94d6c199033e4aa90cc7f0b7afaea5a50bc91cfbc4905f366f39 as base |
| 2 | + |
| 3 | +ENV DEBIAN_FRONTEND=noninteractive |
| 4 | +ENV TZ=US/Pacific |
| 5 | +RUN apt update && apt install -yq --no-install-recommends \ |
| 6 | + build-essential \ |
| 7 | + ca-certificates \ |
| 8 | + curl \ |
| 9 | + git \ |
| 10 | + gnupg \ |
| 11 | + lsof \ |
| 12 | + make \ |
| 13 | + unzip \ |
| 14 | + vim-nox \ |
| 15 | + && rm -rf /var/lib/apt/lists/* |
| 16 | + |
| 17 | +RUN echo "alias lla='ls -lAhG --color=auto'" >> ~/.bashrc |
| 18 | +WORKDIR /root |
| 19 | + |
| 20 | + |
| 21 | +# google-chrome-stable |
| 22 | + |
| 23 | + |
| 24 | +# ============== DART ============== |
| 25 | +# See https://github.com/dart-lang/dart-docker |
| 26 | +# See https://github.com/dart-lang/setup-dart/blob/main/setup.sh |
| 27 | +FROM base as dart |
| 28 | +ARG DART_VERSION=latest |
| 29 | +ARG DART_CHANNEL=stable |
| 30 | +ENV DART_VERSION=$DART_VERSION |
| 31 | +ENV DART_CHANNEL=$DART_CHANNEL |
| 32 | +ENV DART_SDK=/usr/lib/dart |
| 33 | +ENV PATH=$DART_SDK/bin:$PATH |
| 34 | +RUN set -eu; \ |
| 35 | + case "$(dpkg --print-architecture)_${DART_CHANNEL}" in \ |
| 36 | + # BEGIN dart-sha |
| 37 | + amd64_stable) \ |
| 38 | + DART_SHA256="be679ccef3a0b28f19e296dd5b6374ac60dd0deb06d4d663da9905190489d48b"; \ |
| 39 | + SDK_ARCH="x64";; \ |
| 40 | + arm64_stable) \ |
| 41 | + DART_SHA256="395180693ccc758e4e830d3b13c4879e6e96b6869763a56e91721bf9d4228250"; \ |
| 42 | + SDK_ARCH="arm64";; \ |
| 43 | + amd64_beta) \ |
| 44 | + DART_SHA256="bd0311f604def7e49215c6fbed823dc01284586f83963b6891cc6dee36da2488"; \ |
| 45 | + SDK_ARCH="x64";; \ |
| 46 | + arm64_beta) \ |
| 47 | + DART_SHA256="02de2c59d14fe4fcbcc6da756457be6966cd399bee507b2980d0e3c76fa4a2e3"; \ |
| 48 | + SDK_ARCH="arm64";; \ |
| 49 | + amd64_dev) \ |
| 50 | + DART_SHA256="4b411a63f3b20dcb2fa8ad81d7ec0caf3fa19deb13b7ae5fbd66acce99cb992b"; \ |
| 51 | + SDK_ARCH="x64";; \ |
| 52 | + arm64_dev) \ |
| 53 | + DART_SHA256="df63b26de4699be1738ddec36fcb98b98ac880e2223d1137caf40a529e8c0799"; \ |
| 54 | + SDK_ARCH="arm64";; \ |
| 55 | + # END dart-sha |
| 56 | + esac; \ |
| 57 | + SDK="dartsdk-linux-${SDK_ARCH}-release.zip"; \ |
| 58 | + BASEURL="https://storage.googleapis.com/dart-archive/channels"; \ |
| 59 | + URL="$BASEURL/$DART_CHANNEL/release/$DART_VERSION/sdk/$SDK"; \ |
| 60 | + curl -fsSLO "$URL"; \ |
| 61 | + echo "$DART_SHA256 *$SDK" | sha256sum --check --status --strict - || (\ |
| 62 | + echo -e "\n\nDART CHECKSUM FAILED! Run 'make fetch-sums' for updated values.\n\n" && \ |
| 63 | + rm "$SDK" && \ |
| 64 | + exit 1 \ |
| 65 | + ); \ |
| 66 | + unzip "$SDK" > /dev/null && mv dart-sdk "$DART_SDK" && rm "$SDK"; |
| 67 | +ENV PUB_CACHE="${HOME}/.pub-cache" |
| 68 | +RUN dart --disable-analytics |
| 69 | +RUN echo -e "Successfully installed Dart SDK:" && dart --version |
| 70 | + |
| 71 | + |
| 72 | +# ============== DART-TESTS ============== |
| 73 | +from dart as dart-tests |
| 74 | +WORKDIR /app |
| 75 | +COPY ./ ./ |
| 76 | +RUN dart pub get |
| 77 | +ENV BASE_DIR=/app |
| 78 | +ENV TOOL_DIR=$BASE_DIR/tool |
| 79 | +CMD ["./tool/test.sh"] |
| 80 | + |
| 81 | + |
| 82 | +# ============== NODEJS INSTALL ============== |
| 83 | +FROM dart as node |
| 84 | + |
| 85 | +RUN mkdir -p /etc/apt/keyrings \ |
| 86 | + && curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg \ |
| 87 | + && echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_18.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list \ |
| 88 | + && apt-get update -yq \ |
| 89 | + && apt-get install nodejs -yq \ |
| 90 | + && npm install -g npm # Ensure latest npm |
| 91 | + |
| 92 | + |
| 93 | +# ============== DEV/JEKYLL SETUP ============== |
| 94 | +FROM node as dev |
| 95 | +WORKDIR /app |
| 96 | + |
| 97 | +ENV JEKYLL_ENV=development |
| 98 | +COPY Gemfile Gemfile.lock ./ |
| 99 | +RUN gem update --system && gem install bundler |
| 100 | +RUN BUNDLE_WITHOUT="test production" bundle install --jobs=4 --retry=2 |
| 101 | + |
| 102 | +ENV NODE_ENV=development |
| 103 | +COPY package.json package-lock.json ./ |
| 104 | +RUN npm install -g firebase-tools@12.4.0 |
| 105 | +RUN npm install |
| 106 | + |
| 107 | +COPY ./ ./ |
| 108 | + |
| 109 | +# Ensure packages are still up-to-date if anything has changed |
| 110 | +# RUN dart pub get --offline |
| 111 | +RUN dart pub get |
| 112 | + |
| 113 | +# Let's not play "which dir is this" |
| 114 | +ENV BASE_DIR=/app |
| 115 | +ENV TOOL_DIR=$BASE_DIR/tool |
| 116 | + |
| 117 | +# Jekyl |
| 118 | +EXPOSE 4000 |
| 119 | +EXPOSE 35729 |
| 120 | + |
| 121 | +# Firebase emulator port |
| 122 | +# Airplay runs on :5000 by default now |
| 123 | +EXPOSE 5500 |
| 124 | + |
| 125 | +# re-enable defult in case we want to test packages |
| 126 | +ENV DEBIAN_FRONTEND=dialog |
| 127 | + |
| 128 | + |
| 129 | +# ============== FIREBASE EMULATE ============== |
| 130 | +FROM dev as emulate |
| 131 | +RUN bundle exec jekyll build --config _config.yml,_config_test.yml |
| 132 | +CMD ["make", "emulate"] |
| 133 | + |
| 134 | + |
| 135 | +# ============== BUILD PROD JEKYLL SITE ============== |
| 136 | +FROM node AS build |
| 137 | +WORKDIR /app |
| 138 | + |
| 139 | +ENV JEKYLL_ENV=production |
| 140 | +COPY Gemfile Gemfile.lock ./ |
| 141 | +RUN gem update --system && gem install bundler |
| 142 | +RUN BUNDLE_WITHOUT="test development" bundle install --jobs=4 --retry=2 --quiet |
| 143 | + |
| 144 | +ENV NODE_ENV=production |
| 145 | +COPY package.json package-lock.json ./ |
| 146 | +RUN npm install |
| 147 | + |
| 148 | +COPY ./ ./ |
| 149 | + |
| 150 | +RUN dart pub get |
| 151 | + |
| 152 | +ENV BASE_DIR=/app |
| 153 | +ENV TOOL_DIR=$BASE_DIR/tool |
| 154 | + |
| 155 | +ARG BUILD_CONFIGS=_config.yml |
| 156 | +ENV BUILD_CONFIGS=$BUILD_CONFIGS |
| 157 | +RUN bundle exec jekyll build --config $BUILD_CONFIGS |
| 158 | + |
| 159 | + |
| 160 | +# ============== DEPLOY to FIREBASE ============== |
| 161 | +FROM build as deploy |
| 162 | +RUN npm install -g firebase-tools@12.4.0 |
| 163 | +ARG FIREBASE_TOKEN |
| 164 | +ENV FIREBASE_TOKEN=$FIREBASE_TOKEN |
| 165 | +ARG FIREBASE_PROJECT=default |
| 166 | +ENV FIREBASE_PROJECT=$FIREBASE_PROJECT |
| 167 | +RUN [[ -z "$FIREBASE_TOKEN" ]] && echo "FIREBASE_TOKEN is required for container deploy!" |
| 168 | +RUN make deploy-ci |
0 commit comments