From 5790fc7d66e0174ed50bf25cd2a1755427c967da Mon Sep 17 00:00:00 2001 From: CrazyMax <1951866+crazy-max@users.noreply.github.com> Date: Thu, 29 Feb 2024 16:32:34 +0100 Subject: [PATCH] set-host input to set DOCKER_HOST env var --- .github/workflows/ci.yml | 20 ++++++++++++++++++++ README.md | 1 + action.yml | 4 ++++ src/context.ts | 4 +++- src/main.ts | 7 +++++++ 5 files changed, 35 insertions(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 498b171..11c5676 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -249,3 +249,23 @@ jobs: name: Dump context if: always() uses: crazy-max/ghaction-dump-context@v2 + + set-host: + runs-on: ubuntu-latest + steps: + - + name: Checkout + uses: actions/checkout@v4 + - + name: Set up Docker + uses: ./ + with: + set-host: true + - + name: List contexts + run: | + docker context ls + - + name: Dump context + if: always() + uses: crazy-max/ghaction-dump-context@v2 diff --git a/README.md b/README.md index 5a494e0..84a3a5f 100644 --- a/README.md +++ b/README.md @@ -106,6 +106,7 @@ The following inputs can be used as `step.with` keys | `channel` | String | `stable` | Docker CE [channel](https://download.docker.com/linux/static/) (e.g, `stable`, `edge` or `test`). | | `daemon-config` | String | | [Docker daemon JSON configuration](https://docs.docker.com/engine/reference/commandline/dockerd/#daemon-configuration-file) | | `context` | String | `setup-docker-action` | Docker context name. | +| `set-host` | Bool | `false` | Set `DOCKER_HOST` environment variable to docker socket path. | ### outputs diff --git a/action.yml b/action.yml index 5282f26..5a347a4 100644 --- a/action.yml +++ b/action.yml @@ -20,6 +20,10 @@ inputs: context: description: 'Docker context name. (default setup-docker-action)' required: false + set-host: + description: 'Set DOCKER_HOST environment variable to docker socket path' + default: 'false' + required: false outputs: sock: diff --git a/src/context.ts b/src/context.ts index 40ee91b..34ba9a7 100644 --- a/src/context.ts +++ b/src/context.ts @@ -5,6 +5,7 @@ export interface Inputs { channel: string; daemonConfig?: string; context: string; + setHost: boolean; } export function getInputs(): Inputs { @@ -12,6 +13,7 @@ export function getInputs(): Inputs { version: core.getInput('version') || 'latest', channel: core.getInput('channel'), daemonConfig: core.getInput('daemon-config'), - context: core.getInput('context') + context: core.getInput('context'), + setHost: core.getBooleanInput('set-host') }; } diff --git a/src/main.ts b/src/main.ts index f1c2b76..d9cf10e 100644 --- a/src/main.ts +++ b/src/main.ts @@ -39,6 +39,13 @@ actionsToolkit.run( core.info(`sock=${sockPath}`); core.setOutput('sock', sockPath); }); + + if (input.setHost) { + await core.group(`Setting Docker host`, async () => { + core.exportVariable('DOCKER_HOST', sockPath); + core.info(`DOCKER_HOST=${sockPath}`); + }); + } } await core.group(`Docker info`, async () => {