mirror of
https://github.com/matrix-org/matrix-hookshot.git
synced 2025-03-10 13:17:08 +00:00
Get ARM64 builds working (#339)
* Use node:16-slim for final image build * changelog * Add ignore scripts to final install step * Copy matrix-sdk-crypto-nodejs built files * Add workaround to build images foo crypto-nodejs * chmod +x * require bash for builds * Add apt install to hopefully make the rust bits build for arm * Fix missing multilib (#349) * Update and rename 336.misc to 339.bugfix Co-authored-by: Paul Tötterman <ptman@users.noreply.github.com>
This commit is contained in:
parent
e9c6afdc44
commit
c02d4349a3
@ -10,11 +10,16 @@ WORKDIR /src
|
||||
RUN curl https://sh.rustup.rs -sSf | sh -s -- -y --profile minimal
|
||||
ENV PATH="/root/.cargo/bin:${PATH}"
|
||||
|
||||
# Needed to build rust things for matrix-sdk-crypto-nodejs
|
||||
# See https://github.com/matrix-org/matrix-rust-sdk-bindings/blob/main/crates/matrix-sdk-crypto-nodejs/release/Dockerfile.linux#L5-L6
|
||||
RUN apt-get update && apt-get install -y build-essential cmake
|
||||
|
||||
# Workaround: Need to install esbuild manually https://github.com/evanw/esbuild/issues/462#issuecomment-771328459
|
||||
RUN yarn --ignore-scripts
|
||||
RUN node node_modules/esbuild/install.js
|
||||
RUN yarn build --pure-lockfile
|
||||
|
||||
|
||||
# Stage 1: The actual container
|
||||
FROM node:16-slim
|
||||
|
||||
@ -23,9 +28,13 @@ COPY --from=builder /src/public/ /bin/matrix-hookshot/public/
|
||||
COPY --from=builder /src/package.json /bin/matrix-hookshot/
|
||||
COPY --from=builder /src/yarn.lock /bin/matrix-hookshot/
|
||||
WORKDIR /bin/matrix-hookshot
|
||||
|
||||
# --ignore-scripts so we don't try to build
|
||||
RUN yarn --ignore-scripts --production --pure-lockfile && yarn cache clean
|
||||
|
||||
# Copy rust bindings for crypto, since we built them in the previous step.
|
||||
COPY --from=builder /src/node_modules/@turt2live/matrix-sdk-crypto-nodejs /bin/matrix-hookshot/node_modules/@turt2live/matrix-sdk-crypto-nodejs
|
||||
|
||||
VOLUME /data
|
||||
EXPOSE 9993
|
||||
EXPOSE 7775
|
||||
|
1
changelog.d/339.bugfix
Normal file
1
changelog.d/339.bugfix
Normal file
@ -0,0 +1 @@
|
||||
Docker images can now be built cross-platform. Thanks @ptman for getting arm64 builds going!
|
@ -1,8 +1,14 @@
|
||||
#!/bin/sh
|
||||
#!/bin/bash
|
||||
|
||||
# exit when any command fails
|
||||
set -e
|
||||
|
||||
# Workaround for non-x64 / ia32 targets
|
||||
pushd node_modules/@turt2live/matrix-sdk-crypto-nodejs
|
||||
echo "Checking matrix-sdk-crypto-nodejs bindings (and building if required)"
|
||||
node check-exists.js
|
||||
popd
|
||||
|
||||
echo "Building Rust layer"
|
||||
yarn run build:app:rs
|
||||
echo "Running rust-typescript definitions fix"
|
||||
|
Loading…
x
Reference in New Issue
Block a user