mirror of
https://github.com/oven-sh/bun
synced 2026-02-02 15:08:46 +00:00
146 lines
4.0 KiB
YAML
146 lines
4.0 KiB
YAML
name: bun-release-canary
|
|
concurrency: release-canary
|
|
on:
|
|
schedule:
|
|
- cron: "0 14 * * *" # every day at 6am PST
|
|
workflow_dispatch:
|
|
jobs:
|
|
sign:
|
|
name: Sign Release
|
|
runs-on: ubuntu-latest
|
|
if: github.repository_owner == 'oven-sh'
|
|
defaults:
|
|
run:
|
|
working-directory: packages/bun-release
|
|
steps:
|
|
- id: checkout
|
|
name: Checkout
|
|
uses: actions/checkout@v3
|
|
- id: setup-gpg
|
|
name: Setup GPG
|
|
uses: crazy-max/ghaction-import-gpg@v5
|
|
with:
|
|
gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }}
|
|
passphrase: ${{ secrets.GPG_PASSPHRASE }}
|
|
- id: setup-bun
|
|
name: Setup Bun
|
|
uses: oven-sh/setup-bun@v1
|
|
with:
|
|
bun-version: canary
|
|
- id: bun-install
|
|
name: Install Dependencies
|
|
run: bun install
|
|
- id: bun-run
|
|
name: Sign Release
|
|
run: |
|
|
echo "$GPG_PASSPHRASE" | bun upload-assets -- "canary"
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}
|
|
npm:
|
|
name: Release to NPM
|
|
runs-on: ubuntu-latest
|
|
needs: sign
|
|
if: github.repository_owner == 'oven-sh'
|
|
defaults:
|
|
run:
|
|
working-directory: packages/bun-release
|
|
steps:
|
|
- id: checkout
|
|
name: Checkout
|
|
uses: actions/checkout@v3
|
|
- id: setup-bun
|
|
name: Setup Bun
|
|
uses: oven-sh/setup-bun@v1
|
|
with:
|
|
bun-version: canary
|
|
- id: bun-install
|
|
name: Install Dependencies
|
|
run: bun install
|
|
- id: bun-run
|
|
name: Release
|
|
run: bun upload-npm -- canary publish
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
|
|
docker:
|
|
name: Release to Dockerhub (${{ matrix.variant }})
|
|
runs-on: ubuntu-latest
|
|
needs: sign
|
|
if: github.repository_owner == 'oven-sh'
|
|
strategy:
|
|
matrix:
|
|
variant:
|
|
- debian
|
|
- slim
|
|
- alpine
|
|
- distroless
|
|
steps:
|
|
- id: checkout
|
|
name: Checkout
|
|
uses: actions/checkout@v3
|
|
- id: qemu
|
|
name: Setup Docker QEMU
|
|
uses: docker/setup-qemu-action@v2
|
|
- id: buildx
|
|
name: Setup Docker buildx
|
|
uses: docker/setup-buildx-action@v2
|
|
with:
|
|
platforms: linux/amd64,linux/arm64
|
|
- id: metadata
|
|
name: Setup Docker metadata
|
|
uses: docker/metadata-action@v4
|
|
with:
|
|
images: oven/bun
|
|
flavor: |
|
|
latest=${{ matrix.variant == 'debian' }}
|
|
suffix=${{ matrix.variant }}
|
|
tags: canary
|
|
- id: login
|
|
name: Login to Docker
|
|
uses: docker/login-action@v2
|
|
with:
|
|
username: ${{ secrets.DOCKER_USERNAME }}
|
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
|
- id: push
|
|
name: Push to Docker
|
|
uses: docker/build-push-action@v3
|
|
with:
|
|
context: ./dockerhub/${{ matrix.variant }}
|
|
platforms: linux/amd64,linux/arm64
|
|
builder: ${{ steps.buildx.outputs.name }}
|
|
push: true
|
|
tags: ${{ steps.metadata.outputs.tags }}
|
|
labels: ${{ steps.metadata.outputs.labels }}
|
|
build-args: |
|
|
BUN_VERSION=canary
|
|
s3:
|
|
name: Upload to S3
|
|
runs-on: ubuntu-latest
|
|
needs: sign
|
|
if: github.repository_owner == 'oven-sh'
|
|
defaults:
|
|
run:
|
|
working-directory: packages/bun-release
|
|
steps:
|
|
- id: checkout
|
|
name: Checkout
|
|
uses: actions/checkout@v3
|
|
- id: setup-bun
|
|
name: Setup Bun
|
|
uses: oven-sh/setup-bun@v1
|
|
with:
|
|
bun-version: canary
|
|
- id: bun-install
|
|
name: Install Dependencies
|
|
run: bun install
|
|
- id: bun-run
|
|
name: Release
|
|
run: bun upload-s3 -- canary
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY}}
|
|
AWS_ENDPOINT: ${{ secrets.AWS_ENDPOINT }}
|
|
AWS_BUCKET: bun
|