Dockerfile.solana 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #syntax=docker/dockerfile:1.2@sha256:e2a8561e419ab1ba6b2fe6cbdf49fd92b95912df1cf7d313c3e2230a333fdbcc
  2. FROM pythfoundation/pyth-client:devnet-v2.10.1 as pyth-oracle-copy
  3. FROM docker.io/library/rust:1.49@sha256:a50165ea96983c21832578afb1c8c028674c965bc1ed43b607871b1f362e06a5 as build
  4. RUN apt-get update && \
  5. apt-get install -y \
  6. clang \
  7. libssl-dev \
  8. libudev-dev \
  9. llvm \
  10. pkg-config \
  11. zlib1g-dev \
  12. && \
  13. rm -rf /var/lib/apt/lists/* && \
  14. rustup component add rustfmt && \
  15. rustup default nightly-2022-01-02
  16. RUN sh -c "$(curl -sSfL https://release.solana.com/v1.9.4/install)"
  17. ENV PATH="/root/.local/share/solana/install/active_release/bin:$PATH"
  18. # Solana does a questionable download at the beginning of a *first* build-bpf call. Trigger and layer-cache it explicitly.
  19. RUN cargo init --lib /tmp/decoy-crate && \
  20. cd /tmp/decoy-crate && cargo build-bpf && \
  21. rm -rf /tmp/decoy-crate
  22. # Add bridge contract sources
  23. WORKDIR /usr/src/bridge
  24. ADD solana solana
  25. ADD third_party/pyth/p2w-sdk/rust third_party/pyth/p2w-sdk/rust
  26. RUN mkdir -p /opt/solana/deps
  27. ENV EMITTER_ADDRESS="11111111111111111111111111111115"
  28. ENV BRIDGE_ADDRESS="Bridge1p5gheXUvJ6jGWGeCsgPKgnE3YgdGKRVCMY9o"
  29. # Build Wormhole Solana programs
  30. RUN --mount=type=cache,target=solana/bridge/target \
  31. --mount=type=cache,target=solana/modules/token_bridge/target \
  32. --mount=type=cache,target=solana/modules/nft_bridge/target \
  33. --mount=type=cache,target=solana/pyth2wormhole/target \
  34. --mount=type=cache,target=solana/migration/target \
  35. cargo build-bpf --manifest-path "solana/bridge/program/Cargo.toml" -- --locked && \
  36. cargo build-bpf --manifest-path "solana/bridge/cpi_poster/Cargo.toml" -- --locked && \
  37. cargo build-bpf --manifest-path "solana/modules/token_bridge/program/Cargo.toml" -- --locked && \
  38. cargo build-bpf --manifest-path "solana/pyth2wormhole/program/Cargo.toml" -- --locked && \
  39. cargo build-bpf --manifest-path "solana/modules/nft_bridge/program/Cargo.toml" -- --locked && \
  40. cargo build-bpf --manifest-path "solana/migration/Cargo.toml" -- --locked && \
  41. cp solana/bridge/target/deploy/bridge.so /opt/solana/deps/bridge.so && \
  42. cp solana/bridge/target/deploy/cpi_poster.so /opt/solana/deps/cpi_poster.so && \
  43. cp solana/migration/target/deploy/wormhole_migration.so /opt/solana/deps/wormhole_migration.so && \
  44. cp solana/modules/token_bridge/target/deploy/token_bridge.so /opt/solana/deps/token_bridge.so && \
  45. cp solana/modules/nft_bridge/target/deploy/nft_bridge.so /opt/solana/deps/nft_bridge.so && \
  46. cp solana/modules/token_bridge/token-metadata/spl_token_metadata.so /opt/solana/deps/spl_token_metadata.so && \
  47. cp solana/pyth2wormhole/target/deploy/pyth2wormhole.so /opt/solana/deps/pyth2wormhole.so
  48. COPY --from=pyth-oracle-copy /home/pyth/pyth-client/target/oracle.so /opt/solana/deps/pyth_oracle.so
  49. ENV RUST_LOG="solana_runtime::system_instruction_processor=trace,solana_runtime::message_processor=trace,solana_bpf_loader=debug,solana_rbpf=debug"
  50. ENV RUST_BACKTRACE=1