on: push: workflow_dispatch: inputs: build: description: "Build container" required: true default: false type: boolean jobs: build: runs-on: container steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Get the version from git id: version run: echo "version=$(git describe --dirty --tags)" >> $GITHUB_OUTPUT - name: Check if the container should be built id: builder env: RUN: ${{ toJSON(inputs.build || !contains(steps.version.outputs.version, '-g')) }} run: | echo "run=$RUN" >> $GITHUB_OUTPUT echo "Run build: $RUN" - name: Info - version and if the image container should be built env: VERSION: ${{ steps.version.outputs.version }} RUN: ${{ steps.builder.outputs.run }} FORCE: ${{ toJSON(inputs.build) }} run: | echo "Version $VERSION, force (manual input): $FORCE, run the build: $RUN" - uses: pnpm/action-setup@v4 name: Install pnpm with: run_install: false - name: Install Node.js uses: actions/setup-node@v4 with: node-version: 20 cache: "pnpm" - name: Install dependencies run: pnpm install - name: Update version.json from git describe run: pnpm run version - name: Set the version in package.json env: VERSION: ${{ steps.version.outputs.version }} run: sed "s/0.0.0/${VERSION}/" -i package.json - name: Build package (transpile ts => js) run: ng build - name: Set registry token for pnpm" env: LOCAL_NPM_TOKEN: ${{ secrets.LOCAL_NPM_TOKEN }} run: pnpm set "//code.philo.ydns.eu/api/packages/philorg/npm/:_authToken=${LOCAL_NPM_TOKEN}" - name: Publish if: fromJSON(steps.builder.outputs.run) run: pnpm publish --no-git-checks - name: Build container if: fromJSON(steps.builder.outputs.run) uses: actions/buildah-build@v1 with: image: gisaf-frontend oci: true labels: gisaf-frontend tags: latest ${{ steps.version.outputs.version }} containerfiles: | ./Containerfile build-args: | APP_VERSION=${{ steps.version.outputs.version }} - name: Workaround for bug of podman-login if: fromJSON(steps.builder.outputs.run) run: | mkdir -p $HOME/.docker echo "{ \"auths\": {} }" > $HOME/.docker/config.json - name: Log in to container registry (with another workaround) if: fromJSON(steps.builder.outputs.run) uses: actions/podman-login@v1 with: registry: ${{ vars.REGISTRY }} username: ${{ secrets.REGISTRY_USER }} password: ${{ secrets.REGISTRY_PASSWORD }} auth_file_path: /tmp/auth.json - name: Push the image to the registry if: fromJSON(steps.builder.outputs.run) uses: actions/push-to-registry@v2 with: registry: "docker://${{ vars.REGISTRY }}/${{ vars.ORGANISATION }}" image: gisaf-frontend tags: latest ${{ steps.version.outputs.version }}