Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/keilerkonzept/dockerfile-json

🐳 parse & print a Dockerfile as JSON, query (e.g. extract base images) using JSONPath.
https://github.com/keilerkonzept/dockerfile-json

base-images build-args cli docker dockerfile extract golang jq json jsonpath

Last synced: about 2 months ago
JSON representation

🐳 parse & print a Dockerfile as JSON, query (e.g. extract base images) using JSONPath.

Awesome Lists containing this project

README

        

# dockerfile-json

Prints Dockerfiles as JSON to stdout, optionally evaluates build args. Uses the [official Dockerfile parser](https://github.com/moby/buildkit/blob/master/frontend/dockerfile/) from buildkit. Plays well with `jq`.

## Contents

- [Contents](#contents)
- [Get it](#get-it)
- [Usage](#usage)
- [Examples](#examples)
- [JSON output](#json-output)
- [Extract build stage names](#extract-build-stage-names)
- [Extract base images](#extract-base-images)
- [Expand build args, omit stage aliases and `scratch`](#expand-build-args-omit-stage-aliases-and-scratch)
- [Set build args, omit stage aliases and `scratch`](#set-build-args-omit-stage-aliases-and-scratch)
- [Expand build args, include all base names](#expand-build-args-include-all-base-names)
- [Ignore build args, include all base names](#ignore-build-args-include-all-base-names)

## Get it

Using go get:

```bash
go get -u github.com/keilerkonzept/dockerfile-json
```

Or [download the binary for your platform](https://github.com/keilerkonzept/dockerfile-json/releases/latest) from the releases page.

## Usage

### CLI

```text
dockerfile-json [PATHS...]

Usage of dockerfile-json:
-build-arg value
a key/value pair KEY[=VALUE]
-expand-build-args
expand build args (default true)
-jsonpath string
select parts of the output using JSONPath (https://goessner.net/articles/JsonPath)
-jsonpath-raw
when using JSONPath, output raw strings, not JSON values
-quiet
suppress log output (stderr)
```

## Examples

### JSON output

`Dockerfile`
```Dockerfile
ARG ALPINE_TAG=3.10

FROM alpine:${ALPINE_TAG} AS build
RUN --network=host echo "Hello world" > abc

FROM build AS test
RUN --security=insecure echo "foo" > bar

FROM scratch
COPY --from=build --chown=nobody:nobody abc .
RUN --mount=type=bind,source=./abc,target=/def
CMD ["echo"]
```

```sh
$ dockerfile-json Dockerfile | jq .
```
```json
{
"MetaArgs": [
{
"Key": "ALPINE_TAG",
"DefaultValue": "3.10",
"ProvidedValue": null,
"Value": "3.10"
}
],
"Stages": [
{
"Name": "build",
"OrigCmd": "FROM",
"BaseName": "alpine:3.10",
"Platform": "",
"Comment": "",
"SourceCode": "FROM alpine:${ALPINE_TAG} AS build",
"Location": [
{
"Start": {
"Line": 3,
"Character": 0
},
"End": {
"Line": 3,
"Character": 0
}
}
],
"As": "build",
"From": {
"Image": "alpine:3.10"
},
"Commands": [
{
"CmdLine": [
"echo \"Hello world\" > abc"
],
"Files": null,
"FlagsUsed": [
"network"
],
"Mounts": [],
"Name": "RUN",
"NetworkMode": "host",
"PrependShell": true,
"Security": "sandbox"
}
]
},
{
"Name": "test",
"OrigCmd": "FROM",
"BaseName": "build",
"Platform": "",
"Comment": "",
"SourceCode": "FROM build AS test",
"Location": [
{
"Start": {
"Line": 6,
"Character": 0
},
"End": {
"Line": 6,
"Character": 0
}
}
],
"As": "test",
"From": {
"Stage": {
"Named": "build",
"Index": 0
}
},
"Commands": [
{
"CmdLine": [
"echo \"foo\" > bar"
],
"Files": null,
"FlagsUsed": [
"security"
],
"Mounts": [],
"Name": "RUN",
"NetworkMode": "default",
"PrependShell": true,
"Security": "insecure"
}
]
},
{
"Name": "",
"OrigCmd": "FROM",
"BaseName": "scratch",
"Platform": "",
"Comment": "",
"SourceCode": "FROM scratch",
"Location": [
{
"Start": {
"Line": 9,
"Character": 0
},
"End": {
"Line": 9,
"Character": 0
}
}
],
"From": {
"Scratch": true
},
"Commands": [
{
"Chmod": "",
"Chown": "nobody:nobody",
"DestPath": ".",
"ExcludePatterns": null,
"From": "build",
"Link": false,
"Mounts": null,
"Name": "COPY",
"NetworkMode": "",
"Parents": false,
"Security": "",
"SourceContents": null,
"SourcePaths": [
"abc"
]
},
{
"CmdLine": [],
"Files": null,
"FlagsUsed": [
"mount"
],
"Mounts": [
{
"Type": "bind",
"From": "",
"Source": "",
"Target": "",
"ReadOnly": true,
"SizeLimit": 0,
"CacheID": "",
"CacheSharing": "",
"Required": false,
"Env": null,
"Mode": null,
"UID": null,
"GID": null
}
],
"Name": "RUN",
"NetworkMode": "default",
"PrependShell": true,
"Security": "sandbox"
},
{
"CmdLine": [
"echo"
],
"Files": null,
"Mounts": null,
"Name": "CMD",
"NetworkMode": "",
"PrependShell": false,
"Security": ""
}
]
}
]
}
```

### Extract build stage names

`Dockerfile`
```Dockerfile
FROM maven:alpine AS build
# ...

FROM build AS test
# ...

FROM openjdk:jre-alpine
# ...
```

```sh
$ dockerfile-json --jsonpath=..As Dockerfile
```
```json
"build"
"test"
```

### Extract base images

`Dockerfile`
```Dockerfile
ARG ALPINE_TAG=3.10
ARG APP_BASE=scratch

FROM alpine:$ALPINE_TAG AS build
# ...

FROM build
# ...

FROM $APP_BASE
# ...
```

#### Expand build args, omit stage aliases and `scratch`

Using `jq`:
```sh
$ dockerfile-json Dockerfile |
jq '.Stages[] | select(.From | .Stage or .Scratch | not) | .BaseName'
```
```json
"alpine:3.10"
```

Using `--jsonpath`:
```sh

$ dockerfile-json --jsonpath=..Image Dockerfile
```
```json
"alpine:3.10"
```

Using `--jsonpath`, `--jsonpath-raw` output:
```sh
$ dockerfile-json --jsonpath=..Image --jsonpath-raw Dockerfile
```
```json
alpine:3.10
```

#### Set build args, omit stage aliases and `scratch`

```sh
$ dockerfile-json --build-arg ALPINE_TAG=hello-world --jsonpath=..Image Dockerfile
```
```json
"alpine:hello-world"
```

#### Expand build args, include all base names

```sh
$ dockerfile-json --jsonpath=..BaseName Dockerfile
```
```json
"alpine:3.10"
"build"
"scratch"
```

#### Ignore build args, include all base names

```sh
$ dockerfile-json --expand-build-args=false --jsonpath=..BaseName Dockerfile
```
```json
"alpine:${ALPINE_TAG}"
"build"
"${APP_BASE}"
```