bld_docker_debug_depot #4
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: bld_docker_debug_depot | |
| permissions: | |
| checks: write | |
| contents: read | |
| issues: read | |
| pull-requests: write | |
| on: | |
| workflow_call: | |
| inputs: | |
| docker_name: | |
| description: 'Name of the docker image to build' | |
| required: false | |
| default: "orcid/version-bumping-test" | |
| type: string | |
| context: | |
| description: 'Name of the context in the repo' | |
| required: false | |
| default: "." | |
| type: string | |
| build_args: | |
| description: 'build_args e.g wibble=blar' | |
| required: false | |
| default: "" | |
| type: string | |
| file: | |
| description: 'specify a custom dockerfile' | |
| required: false | |
| default: "" | |
| type: string | |
| version_tag: | |
| description: 'Name of the tag to build' | |
| required: false | |
| default: 'latest' | |
| type: string | |
| bump: | |
| description: 'whether to bump the version number by a major minor patch amount or none' | |
| required: false | |
| default: 'patch' | |
| type: string | |
| ref: | |
| description: 'git reference to use with the checkout use default_branch to have that calculated' | |
| required: false | |
| default: "default" | |
| type: string | |
| workflow_dispatch: | |
| inputs: | |
| docker_name: | |
| description: 'Name of the docker image to build' | |
| required: false | |
| default: "orcid/version-bumping-test" | |
| type: string | |
| context: | |
| description: 'Name of the context in the repo' | |
| required: false | |
| default: "." | |
| type: string | |
| build_args: | |
| description: 'build_args e.g wibble=blar' | |
| required: false | |
| default: "" | |
| type: string | |
| file: | |
| description: 'specify a custom dockerfile' | |
| required: false | |
| default: "" | |
| type: string | |
| version_tag: | |
| description: 'Name of the tag to build' | |
| required: false | |
| default: 'latest' | |
| type: string | |
| bump: | |
| description: 'whether to bump the version number by a major minor patch amount or none' | |
| required: false | |
| default: 'patch' | |
| type: string | |
| ref: | |
| description: 'git reference to use with the checkout use default_branch to have that calculated' | |
| required: false | |
| default: "default" | |
| type: string | |
| jobs: | |
| bld_docker: | |
| strategy: | |
| matrix: | |
| include: | |
| - artifact_name: prod | |
| docker_name: orcid/registry/orcid-web-frontend-prod | |
| build_args: "build_env=prod" | |
| file: Dockerfile.build | |
| runs-on: ubuntu-latest | |
| # Set permissions if you're using OIDC token authentication | |
| permissions: | |
| contents: read | |
| id-token: write | |
| steps: | |
| - name: git-checkout-ref-action | |
| id: ref | |
| uses: ORCID/git-checkout-ref-action@main | |
| with: | |
| default_branch: ${{ github.event.repository.default_branch }} | |
| ref: ${{ inputs.ref }} | |
| - uses: actions/checkout@v4 | |
| with: | |
| ref: ${{ steps.ref.outputs.ref }} | |
| # checkout some history so we can scan commits for bump messages | |
| # NOTE: history does not include tags! | |
| fetch-depth: 100 | |
| - name: find next version | |
| id: version | |
| uses: ORCID/version-bump-action@main | |
| with: | |
| version_tag: ${{ inputs.version_tag }} | |
| bump: ${{ inputs.bump }} | |
| - name: Set up Depot CLI | |
| uses: depot/setup-action@v1 | |
| - name: Login to private registry | |
| uses: docker/login-action@v3 | |
| with: | |
| registry: ${{ secrets.DOCKER_REG_PRIVATE }} | |
| username: ${{ secrets.DOCKER_USER }} | |
| password: ${{ secrets.DOCKER_PASSWORD }} | |
| - name: nasty hack to allow dynamic defaults | |
| id: dynamic_defaults | |
| run: | | |
| FILE="${{ matrix.file }}" | |
| echo "default_file=${FILE:-${{ inputs.context }}/Dockerfile}" >> "$GITHUB_OUTPUT" | |
| - name: show the dynamic defaults | |
| run: | | |
| echo ${{ steps.dynamic_defaults.outputs.default_file }} | |
| # - uses: docker/build-push-action@v6 | |
| # with: | |
| # push: true | |
| # tags: ${{ secrets.DOCKER_REG_PRIVATE }}/${{ matrix.docker_name}}:${{ steps.version.outputs.version_tag_numeric }} | |
| # context: ${{ inputs.context }} | |
| # cache-from: type=gha | |
| # cache-to: type=gha,mode=max | |
| # build-args: ${{ matrix.build_args }} | |
| # file: ${{ steps.dynamic_defaults.outputs.default_file }} | |
| # | |
| - name: Build and push | |
| uses: depot/build-push-action@v1 | |
| with: | |
| # if no depot.json file is at the root of your repo, you must specify the project id | |
| project: rpw5qmn3pm # default | |
| token: ${{ secrets.DEPOT_PROJECT_TOKEN }} | |
| context: ${{ inputs.context }} | |
| push: true | |
| build-args: ${{ matrix.build_args }} | |
| file: ${{ steps.dynamic_defaults.outputs.default_file }} | |
| tags: ${{ secrets.DOCKER_REG_PRIVATE }}/${{ matrix.docker_name}}:${{ steps.version.outputs.version_tag_numeric }} | |