Skip to content

docker

docker #88

Workflow file for this run

name: docker
on:
workflow_dispatch: # manually run
env:
CI: true
jobs:
publish:
name: Build & publish docker images
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- uses: SebRollen/[email protected]
id: bootnode_version
with:
file: 'crates/bootnode/Cargo.toml'
field: 'package.version'
- uses: SebRollen/[email protected]
id: keygen_version
with:
file: 'crates/keygen/Cargo.toml'
field: 'package.version'
- uses: SebRollen/[email protected]
id: observer_version
with:
file: 'crates/observer/Cargo.toml'
field: 'package.version'
- name: Docker login
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_LOGIN }}
password: ${{ secrets.DOCKER_TOKEN }}
- name: Build & publish bootnode
uses: docker/build-push-action@v5
env:
VERSION: ${{ steps.bootnode_version.outputs.value }}
with:
context: .
platforms: linux/amd64,linux/arm/v7,linux/arm64/v8,linux/386
target: bootnode
push: true
tags: subsquid/bootnode:${{ env.VERSION }},subsquid/bootnode:latest
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Build & publish keygen
uses: docker/build-push-action@v5
env:
VERSION: ${{ steps.keygen_version.outputs.value }}
with:
context: .
platforms: linux/amd64,linux/arm/v7,linux/arm64/v8,linux/386
target: keygen
push: true
tags: subsquid/keygen:${{ env.VERSION }},subsquid/keygen:latest
cache-from: type=gha
cache-to: type=gha,mode=max
- name: Build & publish observer
uses: docker/build-push-action@v5
env:
VERSION: ${{ steps.observer_version.outputs.value }}
with:
context: .
target: observer
push: true
tags: subsquid/observer:${{ env.VERSION }},subsquid/observer:latest
cache-from: type=gha
cache-to: type=gha,mode=max