mirror of
https://github.com/11notes/docker-kms-gui.git
synced 2025-10-23 04:52:15 +00:00
[upgrade] docker.yml workflow to new javascript version
This commit is contained in:
259
.github/workflows/docker.yml
vendored
259
.github/workflows/docker.yml
vendored
@@ -43,6 +43,13 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
docker:
|
docker:
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-22.04
|
||||||
|
|
||||||
|
services:
|
||||||
|
registry:
|
||||||
|
image: registry:2
|
||||||
|
ports:
|
||||||
|
- 5000:5000
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
actions: read
|
actions: read
|
||||||
contents: write
|
contents: write
|
||||||
@@ -56,63 +63,103 @@ jobs:
|
|||||||
ref: ${{ github.ref_name }}
|
ref: ${{ github.ref_name }}
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: init / inputs to env
|
|
||||||
if: github.event_name == 'workflow_dispatch'
|
|
||||||
run: |
|
|
||||||
cat << 'EOF' > .inputs
|
|
||||||
${{ toJSON(github.event.inputs) }}
|
|
||||||
EOF
|
|
||||||
for KEY in $(cat .inputs | jq --raw-output 'keys[]' | tr '\n' ' '); do echo "input_$(echo ${KEY} | tr '[:upper:]' '[:lower:]')=$(cat .inputs | jq --raw-output '.'${KEY}'')" >> $GITHUB_ENV; done
|
|
||||||
rm -rf .inputs
|
|
||||||
|
|
||||||
- name: init / .json to env
|
|
||||||
uses: rgarcia-phi/json-to-variables@9835d537368468c4e4de5254dc3efeadda183793
|
|
||||||
with:
|
|
||||||
filename: '.json'
|
|
||||||
|
|
||||||
- name: init / setup environment
|
- name: init / setup environment
|
||||||
run: |
|
uses: actions/github-script@62c3794a3eb6788d9a2a72b219504732c0c9a298
|
||||||
: # set image
|
with:
|
||||||
LOCAL_IMAGE=${json_image}
|
script: |
|
||||||
if [ ! -z ${input_image} ]; then LOCAL_IMAGE=${input_image}; fi
|
const { existsSync, readFileSync } = require('node:fs');
|
||||||
echo "IMAGE=${LOCAL_IMAGE}" >> $GITHUB_ENV
|
const { resolve } = require('node:path');
|
||||||
|
const inputs = `${{ toJSON(github.event.inputs) }}`;
|
||||||
|
const opt = {input:{}, dot:{}};
|
||||||
|
|
||||||
: # set defaults
|
try{
|
||||||
echo "IMAGE_ARCH=${json_arch:-linux/amd64,linux/arm64}" >> $GITHUB_ENV
|
if(inputs.length > 0){
|
||||||
echo "WORKFLOW_GITHUB_RELEASE=${input_release:-true}" >> $GITHUB_ENV;
|
opt.input = JSON.parse(inputs);
|
||||||
echo "WORKFLOW_GITHUB_README=${input_readme:-true}" >> $GITHUB_ENV;
|
}
|
||||||
echo "WORKFLOW_GRYPE_SCAN=${json_grype_scan:-true}" >> $GITHUB_ENV;
|
}catch(e){
|
||||||
echo "WORKFLOW_GRYPE_SEVERITY_CUTOFF=${json_grype_severity:-high}" >> $GITHUB_ENV;
|
core.warning('could not parse github.event.inputs');
|
||||||
|
}
|
||||||
|
|
||||||
: # create tags for semver, stable and other shenanigans
|
try{
|
||||||
LOCAL_SHA=$(git rev-parse --short HEAD)
|
const path = resolve('.json');
|
||||||
LOCAL_SEMVER_MAJOR=$(awk -F. '{ print $1 }' <<< ${json_semver_version})
|
if(existsSync(path)){
|
||||||
LOCAL_SEMVER_MINOR=$(awk -F. '{ print $2 }' <<< ${json_semver_version})
|
try{
|
||||||
LOCAL_SEMVER_PATCH=$(awk -F. '{ print $3 }' <<< ${json_semver_version})
|
opt.dot = JSON.parse(readFileSync(path).toString());
|
||||||
LOCAL_SEMVER_PREFIX=""
|
}catch(e){
|
||||||
LOCAL_SEMVER_SUFFIX=""
|
throw new Error('could not parse .json');
|
||||||
LOCAL_SEMVER_RC=""
|
}
|
||||||
LOCAL_TAGS="${LOCAL_IMAGE}:${LOCAL_SHA}"
|
}else{
|
||||||
if [ ! -z ${input_semverprefix} ]; then LOCAL_SEMVER_PREFIX="${input_semverprefix}-"; fi
|
throw new Error('.json does not exist');
|
||||||
if [ ! -z ${input_semversuffix} ]; then LOCAL_SEMVER_SUFFIX="-${input_semversuffix}"; fi
|
}
|
||||||
if [ ! -z ${json_semver_rc} ]; then LOCAL_SEMVER_RC="${json_semver_rc}"; fi
|
}catch(e){
|
||||||
if [ ! -z ${LOCAL_SEMVER_MAJOR} ]; then LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}${LOCAL_SEMVER_MAJOR}${LOCAL_SEMVER_SUFFIX}"; fi
|
core.setFailed(e);
|
||||||
if [ ! -z ${LOCAL_SEMVER_MINOR} ]; then LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}${LOCAL_SEMVER_MAJOR}.${LOCAL_SEMVER_MINOR}${LOCAL_SEMVER_SUFFIX}"; fi
|
}
|
||||||
if [ ! -z ${LOCAL_SEMVER_PATCH} ]; then LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}${LOCAL_SEMVER_MAJOR}.${LOCAL_SEMVER_MINOR}.${LOCAL_SEMVER_PATCH}${LOCAL_SEMVER_SUFFIX}"; fi
|
|
||||||
if echo "${LOCAL_TAGS}" | grep -q "${json_semver_stable}" ; then LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}stable${LOCAL_SEMVER_SUFFIX}"; fi
|
|
||||||
if echo "${LOCAL_TAGS}" | grep -q "${json_semver_latest}" ; then LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}latest${LOCAL_SEMVER_SUFFIX}"; fi
|
|
||||||
if [ ! -z ${json_semver_tags} ]; then SPECIAL_LOCAL_TAGS=$(echo ${json_semver_tags} | sed 's/,/ /g'); for LOCAL_TAG in ${json_semver_tags}; do LOCAL_TAGS="${LOCAL_TAGS},${LOCAL_IMAGE}:${LOCAL_SEMVER_PREFIX}${LOCAL_TAG}${LOCAL_SEMVER_SUFFIX}"; done; fi
|
|
||||||
echo "IMAGE_TAGS=${LOCAL_TAGS}" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
: # if for whatever reason UID/GID must be changed at build time
|
const docker = {
|
||||||
if [ ! -z ${input_uid} ]; then echo "IMAGE_UID=${input_uid}" >> $GITHUB_ENV; else echo "IMAGE_UID=${json_uid:-1000}" >> $GITHUB_ENV; fi
|
image:{
|
||||||
if [ ! -z ${input_gid} ]; then echo "IMAGE_GID=${input_gid}" >> $GITHUB_ENV; else echo "IMAGE_GID=${json_gid:-1000}" >> $GITHUB_ENV; fi
|
name:(opt.input?.image || opt.dot.image),
|
||||||
|
arch:(opt.dot.arch || 'linux/amd64,linux/arm64'),
|
||||||
|
prefix:((opt.input?.semverprefix) ? `${opt.input?.semverprefix}-` : ''),
|
||||||
|
suffix:((opt.input?.semversuffix) ? `-${opt.input?.semversuffix}` : ''),
|
||||||
|
description:(opt.dot?.readme?.description || ''),
|
||||||
|
tags:[],
|
||||||
|
},
|
||||||
|
app:{
|
||||||
|
name:opt.dot.name,
|
||||||
|
version:opt.dot.semver.version,
|
||||||
|
root:opt.dot.root,
|
||||||
|
UID:(opt.input?.uid || 1000),
|
||||||
|
GID:(opt.input?.gid || 1000),
|
||||||
|
no_cache:new Date().getTime(),
|
||||||
|
},
|
||||||
|
cache:{
|
||||||
|
registry:'localhost:5000/',
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
: # set rc, prefix or suffix globally for semver and version
|
docker.cache.name = `${docker.image.name}:${docker.image.prefix}buildcache${docker.image.suffix}`;
|
||||||
echo "IMAGE_SEMVER_PREFIX=${LOCAL_SEMVER_PREFIX}" >> $GITHUB_ENV
|
docker.cache.grype = `${docker.cache.registry}${docker.image.name}:${docker.image.prefix}grype${docker.image.suffix}`;
|
||||||
echo "IMAGE_SEMVER_SUFFIX=${LOCAL_SEMVER_SUFFIX}" >> $GITHUB_ENV
|
|
||||||
echo "IMAGE_VERSION_RC=${LOCAL_SEMVER_RC}" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
|
// setup tags
|
||||||
|
const semver = opt.dot.semver.version.split('.');
|
||||||
|
docker.image.tags.push(`${context.sha.substring(0,7)}`);
|
||||||
|
if(Array.isArray(semver)){
|
||||||
|
if(semver.length >= 0) docker.image.tags.push(`${semver[0]}`);
|
||||||
|
if(semver.length >= 1) docker.image.tags.push(`${semver[0]}.${semver[1]}`);
|
||||||
|
if(semver.length >= 2) docker.image.tags.push(`${semver[0]}.${semver[1]}.${semver[2]}`);
|
||||||
|
}
|
||||||
|
if(opt.dot.semver?.stable && new RegExp(opt.dot.semver.stable, 'ig').test(docker.image.tags.join(','))) docker.image.tags.push('stable');
|
||||||
|
if(opt.dot.semver?.latest && new RegExp(opt.dot.semver.latest, 'ig').test(docker.image.tags.join(','))) docker.image.tags.push('latest');
|
||||||
|
|
||||||
|
for(let i=0; i<docker.image.tags.length; i++){
|
||||||
|
docker.image.tags[i] = `${docker.image.name}:${docker.image.prefix}${docker.image.tags[i]}${docker.image.suffix}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
// setup build arguments
|
||||||
|
const arguments = [];
|
||||||
|
for(const argument in docker.app){
|
||||||
|
arguments.push(`APP_${argument.toUpperCase()}=${docker.app[argument]}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// export to environment
|
||||||
|
core.exportVariable('DOCKER_CACHE_REGISTRY', docker.cache.registry);
|
||||||
|
core.exportVariable('DOCKER_CACHE_NAME', docker.cache.name);
|
||||||
|
core.exportVariable('DOCKER_CACHE_GRYPE', docker.cache.grype);
|
||||||
|
|
||||||
|
core.exportVariable('DOCKER_IMAGE_NAME', docker.image.name);
|
||||||
|
core.exportVariable('DOCKER_IMAGE_ARCH', docker.image.arch);
|
||||||
|
core.exportVariable('DOCKER_IMAGE_TAGS', docker.image.tags.join(','));
|
||||||
|
core.exportVariable('DOCKER_IMAGE_DESCRIPTION', docker.image.description);
|
||||||
|
core.exportVariable('DOCKER_IMAGE_ARGUMENTS', arguments.join("\r\n"));
|
||||||
|
|
||||||
|
core.exportVariable('WORKFLOW_CREATE_RELEASE', (opt.input?.release || true));
|
||||||
|
core.exportVariable('WORKFLOW_CREATE_README', (opt.input?.readme || true));
|
||||||
|
core.exportVariable('WORKFLOW_GRYPE_FAIL_ON_SEVERITY', (opt.json?.grpye?.fail || true));
|
||||||
|
core.exportVariable('WORKFLOW_GRYPE_SEVERITY_CUTOFF', (opt.json?.grpye?.severity || 'high'));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# DOCKER
|
||||||
- name: docker / login to hub
|
- name: docker / login to hub
|
||||||
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567
|
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567
|
||||||
with:
|
with:
|
||||||
@@ -124,58 +171,45 @@ jobs:
|
|||||||
|
|
||||||
- name: docker / setup buildx
|
- name: docker / setup buildx
|
||||||
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5
|
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5
|
||||||
|
with:
|
||||||
|
driver-opts: network=host
|
||||||
|
|
||||||
- name: grype / build & push & tag
|
- name: docker / build & push & tag grype
|
||||||
id: grype-tag
|
id: docker-build
|
||||||
uses: docker/build-push-action@67a2d409c0a876cbe6b11854e3e25193efe4e62d
|
uses: docker/build-push-action@67a2d409c0a876cbe6b11854e3e25193efe4e62d
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
file: arch.dockerfile
|
file: arch.dockerfile
|
||||||
push: true
|
push: true
|
||||||
platforms: ${{ env.IMAGE_ARCH }}
|
platforms: ${{ env.DOCKER_IMAGE_ARCH }}
|
||||||
cache-from: type=registry,ref=${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}buildcache${{ env.IMAGE_SEMVER_SUFFIX }}
|
cache-from: type=registry,ref=${{ env.DOCKER_CACHE_NAME }}
|
||||||
cache-to: type=registry,ref=${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}buildcache${{ env.IMAGE_SEMVER_SUFFIX }},mode=max,compression=zstd,force-compression=true
|
cache-to: type=registry,ref=${{ env.DOCKER_CACHE_REGISTRY }}${{ env.DOCKER_CACHE_NAME }},mode=max,compression=zstd,force-compression=true
|
||||||
build-args: |
|
build-args: |
|
||||||
APP_IMAGE=${{ env.IMAGE }}
|
${{ env.DOCKER_IMAGE_ARGUMENTS }}
|
||||||
APP_NAME=${{ env.json_name }}
|
|
||||||
APP_VERSION=${{ env.json_semver_version }}
|
|
||||||
APP_ROOT=${{ env.json_root }}
|
|
||||||
APP_UID=${{ env.IMAGE_UID }}
|
|
||||||
APP_GID=${{ env.IMAGE_GID }}
|
|
||||||
APP_VERSION_PREFIX=${{ env.IMAGE_SEMVER_PREFIX }}
|
|
||||||
APP_VERSION_SUFFIX=${{ env.IMAGE_SEMVER_SUFFIX }}
|
|
||||||
APP_VERSION_RC=${{ env.IMAGE_VERSION_RC }}
|
|
||||||
APP_NO_CACHE=$(date +%s)
|
|
||||||
tags: |
|
tags: |
|
||||||
${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}grype${{ env.IMAGE_SEMVER_SUFFIX }}
|
${{ env.DOCKER_CACHE_GRYPE }}
|
||||||
|
|
||||||
- name: grype / scan
|
- name: grype / scan
|
||||||
if: env.WORKFLOW_GRYPE_SCAN == 'true'
|
id: grype
|
||||||
id: grype-scan
|
|
||||||
uses: anchore/scan-action@abae793926ec39a78ab18002bc7fc45bbbd94342
|
uses: anchore/scan-action@abae793926ec39a78ab18002bc7fc45bbbd94342
|
||||||
with:
|
with:
|
||||||
image: ${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}grype${{ env.IMAGE_SEMVER_SUFFIX }}
|
image: ${{ env.DOCKER_CACHE_GRYPE }}
|
||||||
|
fail-build: ${{ env.WORKFLOW_GRYPE_FAIL_ON_SEVERITY }}
|
||||||
severity-cutoff: ${{ env.WORKFLOW_GRYPE_SEVERITY_CUTOFF }}
|
severity-cutoff: ${{ env.WORKFLOW_GRYPE_SEVERITY_CUTOFF }}
|
||||||
by-cve: true
|
|
||||||
output-format: 'sarif'
|
output-format: 'sarif'
|
||||||
|
by-cve: true
|
||||||
|
cache-db: true
|
||||||
|
|
||||||
- name: grype / delete tag
|
- name: grype / fail
|
||||||
if: steps.grype-tag.outcome == 'success'
|
if: failure() || steps.grype.outcome == 'failure'
|
||||||
run: |
|
uses: anchore/scan-action@abae793926ec39a78ab18002bc7fc45bbbd94342
|
||||||
curl --request DELETE \
|
|
||||||
--url https://hub.docker.com/v2/repositories/${{ env.IMAGE }}/tags/${{ env.IMAGE_SEMVER_PREFIX }}grype${{ env.IMAGE_SEMVER_SUFFIX }}/ \
|
|
||||||
--header 'authorization: jwt ${{ secrets.DOCKER_TOKEN }}' \
|
|
||||||
--header 'content-type: application/json' \
|
|
||||||
--fail
|
|
||||||
|
|
||||||
- name: codeql / upload
|
|
||||||
id: codeql-upload
|
|
||||||
if: steps.grype-scan.outcome == 'success'
|
|
||||||
uses: github/codeql-action/upload-sarif@48ab28a6f5dbc2a99bf1e0131198dd8f1df78169
|
|
||||||
with:
|
with:
|
||||||
sarif_file: ${{ steps.grype-scan.outputs.sarif }}
|
image: ${{ env.DOCKER_CACHE_GRYPE }}
|
||||||
wait-for-processing: false
|
fail-build: false
|
||||||
category: grype
|
severity-cutoff: ${{ env.WORKFLOW_GRYPE_SEVERITY_CUTOFF }}
|
||||||
|
output-format: 'table'
|
||||||
|
by-cve: true
|
||||||
|
cache-db: true
|
||||||
|
|
||||||
- name: docker / build & push
|
- name: docker / build & push
|
||||||
uses: docker/build-push-action@67a2d409c0a876cbe6b11854e3e25193efe4e62d
|
uses: docker/build-push-action@67a2d409c0a876cbe6b11854e3e25193efe4e62d
|
||||||
@@ -185,24 +219,19 @@ jobs:
|
|||||||
push: true
|
push: true
|
||||||
sbom: true
|
sbom: true
|
||||||
provenance: mode=max
|
provenance: mode=max
|
||||||
platforms: ${{ env.IMAGE_ARCH }}
|
platforms: ${{ env.DOCKER_IMAGE_ARCH }}
|
||||||
cache-from: type=registry,ref=${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}buildcache${{ env.IMAGE_SEMVER_SUFFIX }}
|
cache-from: type=registry,ref=${{ env.DOCKER_CACHE_REGISTRY }}${{ env.DOCKER_CACHE_NAME }}
|
||||||
cache-to: type=registry,ref=${{ env.IMAGE }}:${{ env.IMAGE_SEMVER_PREFIX }}buildcache${{ env.IMAGE_SEMVER_SUFFIX }},mode=max,compression=zstd,force-compression=true
|
cache-to: type=registry,ref=${{ env.DOCKER_CACHE_NAME }},mode=max,compression=zstd,force-compression=true
|
||||||
build-args: |
|
build-args: |
|
||||||
APP_IMAGE=${{ env.IMAGE }}
|
${{ env.DOCKER_IMAGE_ARGUMENTS }}
|
||||||
APP_NAME=${{ env.json_name }}
|
|
||||||
APP_VERSION=${{ env.json_semver_version }}
|
|
||||||
APP_ROOT=${{ env.json_root }}
|
|
||||||
APP_UID=${{ env.IMAGE_UID }}
|
|
||||||
APP_GID=${{ env.IMAGE_GID }}
|
|
||||||
APP_VERSION_PREFIX=${{ env.IMAGE_SEMVER_PREFIX }}
|
|
||||||
APP_VERSION_SUFFIX=${{ env.IMAGE_SEMVER_SUFFIX }}
|
|
||||||
APP_VERSION_RC=${{ env.IMAGE_VERSION_RC }}
|
|
||||||
APP_NO_CACHE=$(date +%s)
|
|
||||||
tags: |
|
tags: |
|
||||||
${{ env.IMAGE_TAGS }}
|
${{ env.DOCKER_IMAGE_TAGS }}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# RELEASE
|
||||||
- name: github / release / log
|
- name: github / release / log
|
||||||
|
continue-on-error: true
|
||||||
id: git-log
|
id: git-log
|
||||||
run: |
|
run: |
|
||||||
LOCAL_LAST_TAG=$(git describe --abbrev=0 --tags `git rev-list --tags --skip=1 --max-count=1`)
|
LOCAL_LAST_TAG=$(git describe --abbrev=0 --tags `git rev-list --tags --skip=1 --max-count=1`)
|
||||||
@@ -215,14 +244,14 @@ jobs:
|
|||||||
echo "${EOF}" >> ${GITHUB_OUTPUT}
|
echo "${EOF}" >> ${GITHUB_OUTPUT}
|
||||||
|
|
||||||
- name: github / release / markdown
|
- name: github / release / markdown
|
||||||
if: env.WORKFLOW_GITHUB_RELEASE == 'true'
|
if: env.WORKFLOW_CREATE_RELEASE == 'true' && steps.git-log.outcome == 'success'
|
||||||
id: git-release
|
id: git-release
|
||||||
uses: 11notes/action-docker-release@v1
|
uses: 11notes/action-docker-release@v1
|
||||||
with:
|
with:
|
||||||
git_log: ${{ steps.git-log.outputs.commits }}
|
git_log: ${{ steps.git-log.outputs.commits }}
|
||||||
|
|
||||||
- name: github / release / create
|
- name: github / release / create
|
||||||
if: env.WORKFLOW_GITHUB_RELEASE == 'true' && steps.git-release.outcome == 'success'
|
if: env.WORKFLOW_CREATE_RELEASE == 'true' && steps.git-release.outcome == 'success'
|
||||||
uses: actions/create-release@4c11c9fe1dcd9636620a16455165783b20fc7ea0
|
uses: actions/create-release@4c11c9fe1dcd9636620a16455165783b20fc7ea0
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
@@ -233,22 +262,26 @@ jobs:
|
|||||||
draft: false
|
draft: false
|
||||||
prerelease: false
|
prerelease: false
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# README
|
||||||
- name: github / checkout master
|
- name: github / checkout master
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
run: |
|
run: |
|
||||||
git checkout master
|
git checkout master
|
||||||
|
|
||||||
- name: github / create README.md
|
- name: github / create README.md
|
||||||
continue-on-error: true
|
|
||||||
if: env.WORKFLOW_GITHUB_README == 'true'
|
|
||||||
id: github-readme
|
id: github-readme
|
||||||
|
continue-on-error: true
|
||||||
|
if: env.WORKFLOW_CREATE_README == 'true' && steps.docker-build.outcome == 'success'
|
||||||
uses: 11notes/action-docker-readme@v1
|
uses: 11notes/action-docker-readme@v1
|
||||||
with:
|
with:
|
||||||
sarif_file: ${{ steps.grype-scan.outputs.sarif }}
|
sarif_file: ${{ steps.grype.outputs.sarif }}
|
||||||
|
build_output_metadata: ${{ steps.docker-build.outputs.metadata }}
|
||||||
|
|
||||||
- name: github / commit & push
|
- name: github / commit & push
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
if: steps.github-readme.outcome == 'success'
|
if: steps.github-readme.outcome == 'success' && hashFiles('README.md') != ''
|
||||||
run: |
|
run: |
|
||||||
git config user.name "github-actions[bot]"
|
git config user.name "github-actions[bot]"
|
||||||
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
|
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
|
||||||
@@ -257,17 +290,21 @@ jobs:
|
|||||||
git push
|
git push
|
||||||
|
|
||||||
- name: docker / push README.md to docker hub
|
- name: docker / push README.md to docker hub
|
||||||
if: hashFiles('README.md') != ''
|
continue-on-error: true
|
||||||
|
if: steps.github-readme.outcome == 'success' && hashFiles('README.md') != ''
|
||||||
uses: christian-korneck/update-container-description-action@d36005551adeaba9698d8d67a296bd16fa91f8e8
|
uses: christian-korneck/update-container-description-action@d36005551adeaba9698d8d67a296bd16fa91f8e8
|
||||||
env:
|
env:
|
||||||
DOCKER_USER: 11notes
|
DOCKER_USER: 11notes
|
||||||
DOCKER_PASS: ${{ secrets.DOCKER_TOKEN }}
|
DOCKER_PASS: ${{ secrets.DOCKER_TOKEN }}
|
||||||
with:
|
with:
|
||||||
destination_container_repo: ${{ env.IMAGE }}
|
destination_container_repo: ${{ env.DOCKER_IMAGE_NAME }}
|
||||||
provider: dockerhub
|
provider: dockerhub
|
||||||
short_description: ${{ env.json_readme_description }}
|
short_description: ${{ env.DOCKER_IMAGE_DESCRIPTION }}
|
||||||
readme_file: 'README.md'
|
readme_file: 'README.md'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# REPOSITORY SETTINGS
|
||||||
- name: github / update description and set repo defaults
|
- name: github / update description and set repo defaults
|
||||||
run: |
|
run: |
|
||||||
curl --request PATCH \
|
curl --request PATCH \
|
||||||
@@ -275,7 +312,7 @@ jobs:
|
|||||||
--header 'authorization: Bearer ${{ secrets.REPOSITORY_TOKEN }}' \
|
--header 'authorization: Bearer ${{ secrets.REPOSITORY_TOKEN }}' \
|
||||||
--header 'content-type: application/json' \
|
--header 'content-type: application/json' \
|
||||||
--data '{
|
--data '{
|
||||||
"description":"${{ env.json_readme_description }}",
|
"description":"${{ env.DOCKER_IMAGE_DESCRIPTION }}",
|
||||||
"homepage":"",
|
"homepage":"",
|
||||||
"has_issues":true,
|
"has_issues":true,
|
||||||
"has_discussions":true,
|
"has_discussions":true,
|
||||||
|
Reference in New Issue
Block a user