267 lines
10 KiB
YAML
267 lines
10 KiB
YAML
name: publish
|
|
on:
|
|
repository_dispatch:
|
|
types: [trigger-ocelot-build-success]
|
|
push:
|
|
branches:
|
|
- master
|
|
|
|
jobs:
|
|
build_branded:
|
|
name: Docker Build Branded
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
SECRET: ${{ secrets.SECRET }}
|
|
CONFIGURATION: "this"
|
|
GITHUB_OCELOT_REF_JUST_BUILT: ${{ github.event.client_payload.ref }}
|
|
OCELOT_GITHUB_RUN_NUMBER: ${{ github.event.client_payload.GITHUB_RUN_NUMBER }}
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v3
|
|
- name: Decrypt .env
|
|
run: gpg --quiet --batch --yes --decrypt --passphrase="${{ env.SECRET }}" --output .env .env.enc
|
|
- name: Load .env
|
|
uses: aarcangeli/load-dotenv@v1.0.0
|
|
with:
|
|
quiet: true
|
|
- name: Set GITHUB_OCELOT_REF
|
|
run: |
|
|
if [ -z ${GITHUB_OCELOT_REF} ]; then
|
|
echo "GITHUB_OCELOT_REF=${GITHUB_OCELOT_REF_JUST_BUILT}" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Set DOCKERHUB_ORGANISATION
|
|
run: |
|
|
if [ -z ${DOCKERHUB_ORGANISATION} ]; then
|
|
echo "DOCKERHUB_ORGANISATION=ocelotsocialnetwork" >> $GITHUB_ENV
|
|
fi
|
|
- name: Checkout Ocelot code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
repository: 'Ocelot-Social-Community/Ocelot-Social'
|
|
ref: ${{ env.GITHUB_OCELOT_REF }}
|
|
path: 'ocelot/'
|
|
fetch-depth: 0
|
|
- name: Set OCELOT_GITHUB_RUN_NUMBER
|
|
run: |
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=${GITHUB_OCELOT_REF}" >> $GITHUB_ENV
|
|
fi
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=master" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Checkout Branded Repo code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
ref: 'master'
|
|
path: "ocelot/deployment/configurations/${{ env.CONFIGURATION }}"
|
|
fetch-depth: 0
|
|
- name: Build branded images
|
|
run: |
|
|
ocelot/deployment/scripts/branded-images.build.sh
|
|
docker save "${DOCKERHUB_ORGANISATION}/backend-${DOCKERHUB_BRAND_VARRIANT}" > /tmp/backend-branded.tar
|
|
docker save "${DOCKERHUB_ORGANISATION}/webapp-${DOCKERHUB_BRAND_VARRIANT}" > /tmp/webapp-branded.tar
|
|
docker save "${DOCKERHUB_ORGANISATION}/maintenance-${DOCKERHUB_BRAND_VARRIANT}" > /tmp/maintenance-branded.tar
|
|
|
|
- name: Upload Artifact (Backend)
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: docker-backend-branded
|
|
path: /tmp/backend-branded.tar
|
|
|
|
- name: Upload Artifact (Webapp)
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: docker-webapp-branded
|
|
path: /tmp/webapp-branded.tar
|
|
|
|
- name: Upload Artifact (Maintenance)
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: docker-maintenance-branded
|
|
path: /tmp/maintenance-branded.tar
|
|
|
|
upload_to_dockerhub:
|
|
name: Upload to Dockerhub
|
|
runs-on: ubuntu-latest
|
|
needs: [build_branded]
|
|
env:
|
|
SECRET: ${{ secrets.SECRET }}
|
|
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
GITHUB_OCELOT_REF_JUST_BUILT: ${{ github.event.client_payload.ref }}
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v3
|
|
- name: Decrypt .env
|
|
run: gpg --quiet --batch --yes --decrypt --passphrase="${{ env.SECRET }}" --output .env .env.enc
|
|
- name: Load .env
|
|
uses: aarcangeli/load-dotenv@v1.0.0
|
|
with:
|
|
quiet: true
|
|
- name: Set GITHUB_OCELOT_REF
|
|
run: |
|
|
if [ -z ${GITHUB_OCELOT_REF} ]; then
|
|
echo "GITHUB_OCELOT_REF=${GITHUB_OCELOT_REF_JUST_BUILT}" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Checkout Ocelot code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
repository: 'Ocelot-Social-Community/Ocelot-Social'
|
|
ref: ${{ env.GITHUB_OCELOT_REF }}
|
|
path: 'ocelot/'
|
|
fetch-depth: 0
|
|
|
|
- name: Download Docker Image (Backend)
|
|
uses: actions/download-artifact@v2
|
|
with:
|
|
name: docker-backend-branded
|
|
path: /tmp
|
|
- name: Load Docker Image
|
|
run: docker load < /tmp/backend-branded.tar
|
|
|
|
- name: Download Docker Image (Webapp)
|
|
uses: actions/download-artifact@v2
|
|
with:
|
|
name: docker-webapp-branded
|
|
path: /tmp
|
|
- name: Load Docker Image
|
|
run: docker load < /tmp/webapp-branded.tar
|
|
|
|
- name: Download Docker Image (Maintenance)
|
|
uses: actions/download-artifact@v2
|
|
with:
|
|
name: docker-maintenance-branded
|
|
path: /tmp
|
|
- name: Load Docker Image
|
|
run: docker load < /tmp/maintenance-branded.tar
|
|
|
|
- name: Upload to dockerhub
|
|
run: ocelot/deployment/scripts/branded-images.upload.sh
|
|
|
|
github_tag:
|
|
name: Tag latest version on Github
|
|
runs-on: ubuntu-latest
|
|
needs: [upload_to_dockerhub]
|
|
env:
|
|
SECRET: ${{ secrets.SECRET }}
|
|
GITHUB_OCELOT_REF_JUST_BUILT: ${{ github.event.client_payload.ref }}
|
|
OCELOT_GITHUB_RUN_NUMBER: ${{ github.event.client_payload.GITHUB_RUN_NUMBER }}
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v3
|
|
- name: Decrypt .env
|
|
run: gpg --quiet --batch --yes --decrypt --passphrase="${{ env.SECRET }}" --output .env .env.enc
|
|
- name: Load .env
|
|
uses: aarcangeli/load-dotenv@v1.0.0
|
|
with:
|
|
quiet: true
|
|
- name: Set GITHUB_OCELOT_REF
|
|
run: |
|
|
if [ -z ${GITHUB_OCELOT_REF} ]; then
|
|
echo "GITHUB_OCELOT_REF=${GITHUB_OCELOT_REF_JUST_BUILT}" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Checkout Ocelot code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
repository: 'Ocelot-Social-Community/Ocelot-Social'
|
|
ref: ${{ env.GITHUB_OCELOT_REF }}
|
|
path: 'ocelot/'
|
|
fetch-depth: 0
|
|
- name: Set OCELOT_GITHUB_RUN_NUMBER
|
|
run: |
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=${GITHUB_OCELOT_REF}" >> $GITHUB_ENV
|
|
fi
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=master" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Setup env
|
|
run: |
|
|
echo "OCELOT_VERSION=$(node -p -e "require('./ocelot/package.json').version")" >> $GITHUB_ENV
|
|
echo "BRANDED_VERSION=${GITHUB_RUN_NUMBER}" >> $GITHUB_ENV
|
|
echo "BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')" >> $GITHUB_ENV
|
|
echo "BUILD_COMMIT=${GITHUB_SHA}" >> $GITHUB_ENV
|
|
- run: echo "BUILD_VERSION=${BRANDED_VERSION}-ocelot.social${OCELOT_VERSION}-${OCELOT_GITHUB_RUN_NUMBER}" >> $GITHUB_ENV
|
|
- name: package-version-to-git-tag + build number
|
|
uses: pkgdeps/git-tag-action@v2
|
|
with:
|
|
github_token: ${{ github.token }} #${{ secrets.GITHUB_TOKEN }}
|
|
github_repo: ${{ github.repository }}
|
|
version: ${{ env.BUILD_VERSION }}
|
|
git_commit_sha: ${{ github.sha }}
|
|
git_tag_prefix: "b"
|
|
#- name: Generate changelog
|
|
# run: |
|
|
# yarn install
|
|
# yarn auto-changelog --latest-version ${{ env.VERSION }} --unreleased-only
|
|
- name: package-version-to-git-release
|
|
continue-on-error: true # Will fail if tag exists
|
|
id: create_release
|
|
uses: actions/create-release@v1
|
|
env:
|
|
GITHUB_TOKEN: ${{ github.token }} #${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token
|
|
with:
|
|
tag_name: ${{ env.BUILD_VERSION }}
|
|
release_name: ${{ env.BUILD_VERSION }}
|
|
#body_path: ./CHANGELOG.md
|
|
draft: false
|
|
prerelease: false
|
|
|
|
# TODO correct version
|
|
build_trigger:
|
|
name: Trigger successful brand build
|
|
runs-on: ubuntu-latest
|
|
needs: [github_tag]
|
|
env:
|
|
SECRET: ${{ secrets.SECRET }}
|
|
GITHUB_OCELOT_REF_JUST_BUILT: ${{ github.event.client_payload.ref }}
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v3
|
|
- name: Decrypt .env
|
|
run: gpg --quiet --batch --yes --decrypt --passphrase="${{ env.SECRET }}" --output .env .env.enc
|
|
- name: Load .env
|
|
uses: aarcangeli/load-dotenv@v1.0.0
|
|
with:
|
|
quiet: true
|
|
- name: Set GITHUB_OCELOT_REF
|
|
run: |
|
|
if [ -z ${GITHUB_OCELOT_REF} ]; then
|
|
echo "GITHUB_OCELOT_REF=${GITHUB_OCELOT_REF_JUST_BUILT}" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Checkout Ocelot code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
repository: 'Ocelot-Social-Community/Ocelot-Social'
|
|
ref: ${{ env.GITHUB_OCELOT_REF }}
|
|
path: 'ocelot/'
|
|
fetch-depth: 0
|
|
- name: Set OCELOT_GITHUB_RUN_NUMBER
|
|
run: |
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=${GITHUB_OCELOT_REF}" >> $GITHUB_ENV
|
|
fi
|
|
if [ -z ${OCELOT_GITHUB_RUN_NUMBER} ]; then
|
|
echo "OCELOT_GITHUB_RUN_NUMBER=master" >> $GITHUB_ENV
|
|
fi
|
|
shell: bash
|
|
- name: Setup env
|
|
run: |
|
|
echo "OCELOT_VERSION=$(node -p -e "require('./ocelot/package.json').version")" >> $GITHUB_ENV
|
|
echo "BRANDED_VERSION=${GITHUB_RUN_NUMBER}" >> $GITHUB_ENV
|
|
echo "BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')" >> $GITHUB_ENV
|
|
echo "BUILD_COMMIT=${GITHUB_SHA}" >> $GITHUB_ENV
|
|
- run: echo "BUILD_VERSION=${BRANDED_VERSION}-ocelot.social${OCELOT_VERSION}-${OCELOT_GITHUB_RUN_NUMBER}" >> $GITHUB_ENV
|
|
- name: Repository Dispatch
|
|
uses: peter-evans/repository-dispatch@v2
|
|
with:
|
|
token: ${{ github.token }}
|
|
event-type: trigger-ocelot-brand-build-success
|
|
repository: ${{ github.repository }}
|
|
client-payload: '{"ref": "${{ github.ref }}", "sha": "${{ github.sha }}", "ref_ocelot": "${{ github.event.client_payload.ref }}", "sha_ocelot": "${{ github.event.client_payload.sha }}", "OCELOT_VERSION": "${{ env.OCELOT_VERSION }}", "BRANDED_VERSION": "${{ env.BRANDED_VERSION }}", "BUILD_DATE": "${{ env.BUILD_DATE }}", "BUILD_COMMIT": "${{ env.BUILD_COMMIT }}", "BUILD_VERSION": "${{ env.BUILD_VERSION }}"}' |