From ae045d0bc6dc131912b12929ad8bb96f29c702f7 Mon Sep 17 00:00:00 2001 From: Brendan Weibrecht Date: Tue, 27 Apr 2021 04:07:04 +1000 Subject: [PATCH] Support saving images which are identified by SHA rather than tag --- src/ImageDetector.ts | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/ImageDetector.ts b/src/ImageDetector.ts index 905881ac..44993903 100644 --- a/src/ImageDetector.ts +++ b/src/ImageDetector.ts @@ -5,13 +5,29 @@ export class ImageDetector { async getExistingImages(): Promise { const existingSet = new Set([]) const ids = (await exec.exec(`docker image ls -q`, [], { silent: true, listeners: { stderr: console.warn }})).stdoutStr.split(`\n`).filter(id => id !== ``) - const repotags = (await exec.exec(`docker`, `image ls --format {{.Repository}}:{{.Tag}} --filter dangling=false`.split(' '), { silent: true, listeners: { stderr: console.warn }})).stdoutStr.split(`\n`).filter(id => id !== ``); + const repotags = await this.getExistingImageIdentifiers() core.debug(JSON.stringify({ log: "getExistingImages", ids, repotags })); ([...ids, ...repotags]).forEach(image => existingSet.add(image)) core.debug(JSON.stringify({ existingSet })) return Array.from(existingSet) } + async getExistingImageIdentifiers(): Promise { + return ( + await exec.exec( + `docker`, `image ls --format {{.Repository}}:{{.Tag}}:{{.ID}} --filter dangling=false`.split(' '), + { silent: true, listeners: { stderr: console.warn }} + ) + ) + .stdoutStr + .split(`\n`) + .filter(img => img !== ``) + .map(img => { + const [repository, tag, id] = img.split(':') + return (tag == '' ? id : `${repository}:${tag}`) + }) + } + async getImagesShouldSave(alreadRegisteredImages: string[]): Promise { const resultSet = new Set(await this.getExistingImages()) alreadRegisteredImages.forEach(image => resultSet.delete(image))