Skip to content

Commit

Permalink
tcp-port opt to expose Docker API to a local TCP address
Browse files Browse the repository at this point in the history
  • Loading branch information
crazy-max committed Dec 12, 2024
1 parent 2a248d8 commit 5f3653e
Show file tree
Hide file tree
Showing 6 changed files with 84 additions and 4 deletions.
28 changes: 28 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -271,3 +271,31 @@ jobs:
name: List contexts
run: |
docker context ls
tcp:
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os:
- ubuntu-latest
#- macos-14 # no virt: https://github.com/docker/actions-toolkit/issues/317
- macos-13
- windows-latest
steps:
-
name: Checkout
uses: actions/checkout@v4
-
name: Set up Docker
id: setup_docker
uses: ./
with:
version: ${{ env.DOCKER_VERSION }}
tcp-port: 2378
-
name: Check docker info through TCP
run: |
docker info
env:
DOCKER_HOST: ${{ steps.setup_docker.outputs.tcp }}
8 changes: 5 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ The following inputs can be used as `step.with` keys
| `version` | String | `latest` | Docker CE version (e.g., `v24.0.6`). |
| `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) |
| `tcp-port` | Number | | TCP port to expose the Docker API locally |
| `context` | String | `setup-docker-action` | Docker context name. |
| `set-host` | Bool | `false` | Set `DOCKER_HOST` environment variable to docker socket path. |
| `rootless` | Bool | `false` | Start daemon in rootless mode |
Expand All @@ -125,9 +126,10 @@ The following inputs can be used as `step.with` keys

The following outputs are available

| Name | Type | Description |
|--------|--------|--------------------|
| `sock` | String | Docker socket path |
| Name | Type | Description |
|--------|--------|---------------------------------------|
| `sock` | String | Docker socket path |
| `tcp` | String | Docker TCP address if tcp-port is set |

## Contributing

Expand Down
30 changes: 30 additions & 0 deletions __tests__/context.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ describe('getInputs', () => {
},
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
setHost: false
} as context.Inputs
Expand All @@ -51,6 +52,7 @@ describe('getInputs', () => {
},
context: 'foo',
daemonConfig: `{"debug":true,"features":{"containerd-snapshotter":true}}`,
tcpPort: 0,
rootless: false,
setHost: false
} as context.Inputs
Expand All @@ -69,6 +71,7 @@ describe('getInputs', () => {
},
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
setHost: true
} as context.Inputs
Expand All @@ -89,6 +92,7 @@ describe('getInputs', () => {
},
context: 'foo',
daemonConfig: `{"debug":true,"features":{"containerd-snapshotter":true}}`,
tcpPort: 0,
rootless: false,
setHost: false
} as context.Inputs
Expand All @@ -107,6 +111,7 @@ describe('getInputs', () => {
},
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
setHost: false
} as context.Inputs
Expand All @@ -127,6 +132,7 @@ describe('getInputs', () => {
setHost: false,
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
} as context.Inputs
],
Expand All @@ -146,6 +152,7 @@ describe('getInputs', () => {
setHost: false,
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
} as context.Inputs
],
Expand All @@ -164,6 +171,7 @@ describe('getInputs', () => {
setHost: false,
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: false,
} as context.Inputs
],
Expand All @@ -182,9 +190,31 @@ describe('getInputs', () => {
setHost: false,
context: '',
daemonConfig: '',
tcpPort: 0,
rootless: true,
} as context.Inputs
],
[
9,
new Map<string, string>([
['version', 'v24.0.8'],
['tcp-port', '2378'],
['set-host', 'false'],
['rootless', 'false'],
]),
{
source: {
type: 'archive',
version: 'v24.0.8',
channel: 'stable'
},
context: '',
daemonConfig: '',
tcpPort: 2378,
rootless: false,
setHost: false
} as context.Inputs
],
])(
'[%d] given %p as inputs, returns %p',
async (num: number, inputs: Map<string, string>, expected: context.Inputs) => {
Expand Down
6 changes: 6 additions & 0 deletions action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,10 @@ inputs:
daemon-config:
description: 'Docker daemon JSON configuration'
required: false
tcp-port:
description: 'TCP port to expose the Docker API locally'
default: 'false'
required: false
context:
description: 'Docker context name. (default setup-docker-action)'
required: false
Expand All @@ -32,6 +36,8 @@ inputs:
outputs:
sock:
description: "Docker socket path"
tcp:
description: "Docker TCP address if tcp-port is set"

runs:
using: 'node20'
Expand Down
2 changes: 2 additions & 0 deletions src/context.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import {parse} from 'csv-parse/sync';
export interface Inputs {
source: InstallSource;
daemonConfig?: string;
tcpPort?: number;
context: string;
setHost: boolean;
rootless: boolean;
Expand All @@ -21,6 +22,7 @@ export function getInputs(): Inputs {
return {
source: source,
daemonConfig: core.getInput('daemon-config'),
tcpPort: parseInt(core.getInput('tcp-port') || '0'),
context: core.getInput('context'),
setHost: core.getBooleanInput('set-host'),
rootless: core.getBooleanInput('rootless')
Expand Down
14 changes: 13 additions & 1 deletion src/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,20 @@ actionsToolkit.run(
throw new Error(`'default' context cannot be used.`);
}

let tcpPort: number | undefined;
let tcpAddress: string | undefined;
if (input.tcpPort > 0) {
tcpPort = input.tcpPort;
tcpAddress = `tcp://127.0.0.1:${tcpPort}`;
}

const install = new Install({
runDir: runDir,
source: input.source,
rootless: input.rootless,
contextName: input.context || 'setup-docker-action',
daemonConfig: input.daemonConfig
daemonConfig: input.daemonConfig,
localTCPPort: tcpPort
});
let toolDir;
if (!(await Docker.isAvailable()) || input.source) {
Expand All @@ -38,6 +46,10 @@ actionsToolkit.run(
await core.group(`Setting outputs`, async () => {
core.info(`sock=${sockPath}`);
core.setOutput('sock', sockPath);
if (tcpAddress) {
core.info(`tcp=${tcpAddress}`);
core.setOutput('tcp', tcpAddress);
}
});

if (input.setHost) {
Expand Down

0 comments on commit 5f3653e

Please sign in to comment.