Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/iarekylew00t/regctl-installer
📦 GitHub Action for installing the regctl CLI tool
https://github.com/iarekylew00t/regctl-installer
docker docker-registry github-actions regclient regctl setup-action typescript-action
Last synced: 2 months ago
JSON representation
📦 GitHub Action for installing the regctl CLI tool
- Host: GitHub
- URL: https://github.com/iarekylew00t/regctl-installer
- Owner: IAreKyleW00t
- License: apache-2.0
- Created: 2023-03-16T03:47:31.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-21T02:13:43.000Z (3 months ago)
- Last Synced: 2024-10-21T05:32:18.514Z (3 months ago)
- Topics: docker, docker-registry, github-actions, regclient, regctl, setup-action, typescript-action
- Language: TypeScript
- Homepage: https://github.com/marketplace/actions/regctl-installer
- Size: 1.24 MB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# 📦 regctl-installer
[![CI](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/ci.yml/badge.svg)](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/ci.yml)
[![Tests](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/test.yml/badge.svg)](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/test.yml)
[![Check dist/](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/check-dist.yml/badge.svg)](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/check-dist.yml)
[![CodeQL](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/codeql.yml/badge.svg)](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/codeql.yml)
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-regctl--installer-blue?style=flat&logo=github)](https://github.com/marketplace/actions/regctl-installer)
[![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/IAreKyleW00t/regctl-installer?style=flat&label=Latest%20Version&color=blue)](https://github.com/IAreKyleW00t/regctl-installer/tags)
[![License](https://img.shields.io/github/license/IAreKyleW00t/regctl-installer?label=License)](https://github.com/IAreKyleW00t/regctl-installer/blob/main/LICENSE)
[![Dependabot](https://img.shields.io/badge/Dependabot-0366d6?style=flat&logo=dependabot&logoColor=white)](.github/dependabot.yml)This Action downloads [`regctl`](https://github.com/regclient/regclient) and
adds it to your `PATH`, with optional signature verification if you use
[Cosign](https://github.com/sigstore/cosign).For a quick start guide on the usage of `regctl`, refer to
[its documentation](https://github.com/regclient/regclient/blob/main/docs/regctl.md).For available `regctl` releases, refer to
[its releases](https://github.com/regclient/regclient/releases).> This action supports Linux, macOS and Windows runners (results may vary with
> self-hosted runners).## Quick Start
```yaml
- name: Install regctl
uses: iarekylew00t/regctl-installer@v3
```## Usage
> [!NOTE]
>
> `cosign` must be in your `PATH` for signature verification or it will be
> skipped - See
> [Automatic verification with Cosign](#automatic-verification-with-cosign).### Inputs
| Name | Type | Description | Default |
| ---------------- | ------- | ------------------------------------------ | --------------------- |
| `regctl-release` | String | `regctl` release version to be installed | `latest` |
| `verify` | Boolean | Perform signature verification on `regctl` | `true` |
| `cache` | Boolean | Whether to utilize cache with `regctl` | `true` |
| `token` | String | GitHub token for REST API access | `${{ github.token }}` |### Outputs
| Name | Type | Description |
| ----------- | ------- | ----------------------------------------- |
| `version` | String | The version of `regctl` the was installed |
| `cache-hit` | Boolean | If `regctl` was installed via cache |## Examples
### Pinned version
```yaml
- name: Install regctl
uses: iarekylew00t/regctl-installer@v3
with:
regctl-release: v0.7.1
```### Authenticate using Action
```yaml
- name: Install regctl
uses: iarekylew00t/regctl-installer@v3- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}- name: Login to GHCR
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ github.token }}
```### Authenticate using `regctl`
```yaml
- name: Install regctl
uses: iarekylew00t/regctl-installer@v3- name: Login to DockerHub
run: |
echo "${{ secrets.DOCKERHUB_TOKEN }}" | \
regctl registry login docker.io \
--user "${{ vars.DOCKERHUB_USERNAME }}" \
--pass-stdin- name: Login to GHCR
run: |
echo "${{ github.token }}" | \
regctl registry login ghcr.io \
--user "${{ github.actor }}" \
--pass-stdin
```### Automatic verification with Cosign
```yaml
- name: Install Cosign
uses: sigstore/[email protected]- name: Install regctl
uses: iarekylew00t/regctl-installer@v3
```## Development
> [!CAUTION]
>
> Since this is a TypeScript action you **must** transpile it into native
> JavaScript. This is done for you automatically as part of the `npm run all`
> command and will be validated via the
> [`check-dist.yml`](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/check-dist.yml)
> Workflow in any PR.1. ⚙️ Install the version of [Node.js](https://nodejs.org/en) as defined in the
[`.node-version`](.node-version).
You can use [asdf](https://github.com/asdf-vm/asdf) to help manage your
project runtimes.```sh
asdf plugin add nodejs https://github.com/asdf-vm/asdf-nodejs.git
asdf install
```2. 🛠️ Install dependencies
```sh
npm install
```3. 🏗️ Format, lint, test, and package your code changes.
```sh
npm run all
```## Releases
For maintainers, the following release process should be used when cutting new
versions.1. ⏬ Ensure all changes are in the `main` branch and all necessary
[Workflows](https://github.com/IAreKyleW00t/regctl-installer/actions) are
passing.```sh
git checkout main
git pull
```2. ✅ Ensure the [`package.json`](package.json#L4) and
[`package-lock.json`](package-lock.json#L3) files are updated to with the new
version being cut.```sh
npm update
```3. 🔖 Create a new Tag, push it up, then create a
[new Release](https://github.com/IAreKyleW00t/regctl-installer/releases/new)
for the version.```sh
git tag v1.2.3
git push -u origin v1.2.3
```Alternatively you can create the Tag on the GitHub Release page itself.
When the tag is pushed it will kick off the
[Shared Tags](https://github.com/IAreKyleW00t/regctl-installer/actions/workflows/shared-tags.yml)
Workflows to update the `v$MAJOR` and `v$MAJOR.MINOR` tags.## Contributing
Feel free to contribute and make things better by opening an
[Issue](https://github.com/IAreKyleW00t/regctl-installer/issues) or
[Pull Request](https://github.com/IAreKyleW00t/regctl-installer/pulls).
Thank you for your contribution! ❤️## License
See
[LICENSE](https://github.com/IAreKyleW00t/regctl-installer/blob/main/LICENSE).