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" 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: 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: 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 "ocelotsocialnetwork/backend-branded" > /tmp/backend-branded.tar docker save "ocelotsocialnetwork/webapp-branded" > /tmp/webapp-branded.tar docker save "ocelotsocialnetwork/maintenance-branded" > /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 }} 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: 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] steps: - name: Checkout code uses: actions/checkout@v3 - name: Decrypt .env run: gpg --quiet --batch --yes --decrypt --passphrase="${SECRET}" --output .env .env.enc - name: Load .env uses: aarcangeli/load-dotenv@v1.0.0 with: quiet: true - 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: 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}" >> $GITHUB_ENV - name: package-version-to-git-tag + build number uses: pkgdeps/git-tag-action@v2 with: 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] steps: - name: Checkout code uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch full History for changelog - 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 }}", "VERSION": "${{ github.event.client_payload.VERSION }}", "BUILD_DATE": "${{ github.event.client_payload.BUILD_DATE }}", "BUILD_COMMIT": "${{ github.event.client_payload.BUILD_COMMIT }}", "BUILD_VERSION": "${{ github.event.client_payload.BUILD_VERSION }}"}'