mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-02-05 13:15:26 +02:00
Merge remote-tracking branch 'origin/main'
This commit is contained in:
commit
ede2ff90e4
14
.github/workflows/build.yml
vendored
14
.github/workflows/build.yml
vendored
@ -18,23 +18,18 @@ permissions:
|
||||
jobs:
|
||||
govulncheck:
|
||||
uses: caarlos0/meta/.github/workflows/govulncheck.yml@main
|
||||
with:
|
||||
cache: true
|
||||
go-version: '>=1.20.2'
|
||||
semgrep:
|
||||
uses: caarlos0/meta/.github/workflows/semgrep.yml@main
|
||||
ruleguard:
|
||||
uses: caarlos0/meta/.github/workflows/ruleguard.yml@main
|
||||
with:
|
||||
cache: true
|
||||
go-version: '>=1.20.2'
|
||||
args: '-disable largeloopcopy'
|
||||
test:
|
||||
runs-on: ubuntu-latest
|
||||
env:
|
||||
DOCKER_CLI_EXPERIMENTAL: "enabled"
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
@ -42,7 +37,7 @@ jobs:
|
||||
version: 3.x
|
||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
- uses: docker/setup-qemu-action@e81a89b1732b9c48d79cd809d8d81d79c4647a18 # v2
|
||||
- uses: docker/setup-buildx-action@f03ac48505955848960e80bbb68046aa35c7b9e7 # v2
|
||||
- uses: docker/setup-buildx-action@4b4e9c3e2d4531116a6f8ba8e71fc6e2cb6e6c8c # v2
|
||||
- name: setup-snapcraft
|
||||
# FIXME: the mkdirs are a hack for https://github.com/goreleaser/goreleaser/issues/1715
|
||||
run: |
|
||||
@ -50,10 +45,9 @@ jobs:
|
||||
sudo apt-get -yq --no-install-suggests --no-install-recommends install snapcraft
|
||||
mkdir -p $HOME/.cache/snapcraft/download
|
||||
mkdir -p $HOME/.cache/snapcraft/stage-packages
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
cache: true
|
||||
go-version: stable
|
||||
- uses: sigstore/cosign-installer@v3.0.1
|
||||
- uses: anchore/sbom-action/download-syft@v0.13.3
|
||||
- name: setup-validate-krew-manifest
|
||||
|
13
.github/workflows/codeql.yml
vendored
13
.github/workflows/codeql.yml
vendored
@ -15,11 +15,10 @@ jobs:
|
||||
contents: read
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
cache: true
|
||||
- uses: github/codeql-action/init@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
|
||||
- uses: github/codeql-action/autobuild@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
|
||||
- uses: github/codeql-action/analyze@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
|
||||
go-version: stable
|
||||
- uses: github/codeql-action/init@168b99b3c22180941ae7dbdd5f5c9678ede476ba # v2
|
||||
- uses: github/codeql-action/autobuild@168b99b3c22180941ae7dbdd5f5c9678ede476ba # v2
|
||||
- uses: github/codeql-action/analyze@168b99b3c22180941ae7dbdd5f5c9678ede476ba # v2
|
||||
|
2
.github/workflows/depsreview.yaml
vendored
2
.github/workflows/depsreview.yaml
vendored
@ -8,7 +8,7 @@ jobs:
|
||||
dependency-review:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: actions/dependency-review-action@v3
|
||||
with:
|
||||
allow-licenses: BSD-2-Clause, BSD-3-Clause, MIT, Apache-2.0, MPL-2.0
|
||||
|
6
.github/workflows/docs.yml
vendored
6
.github/workflows/docs.yml
vendored
@ -17,13 +17,13 @@ jobs:
|
||||
htmltest:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
with:
|
||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
go-version: stable
|
||||
- run: task docs:build
|
||||
- uses: wjdp/htmltest-action@09118714cd26bef56bd3d0819e4f9b1dce6f60a9 # master
|
||||
with:
|
||||
|
6
.github/workflows/fig.yml
vendored
6
.github/workflows/fig.yml
vendored
@ -13,10 +13,10 @@ jobs:
|
||||
fig:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
go-version: stable
|
||||
cache: true
|
||||
- run: go run . generate-fig-spec >goreleaser.ts
|
||||
- uses: withfig/push-to-fig-autocomplete-action@v1
|
||||
|
2
.github/workflows/generate-releases.yml
vendored
2
.github/workflows/generate-releases.yml
vendored
@ -12,7 +12,7 @@ jobs:
|
||||
contents: write # for stefanzweifel/git-auto-commit-action to push code in repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
token: ${{ secrets.GH_PAT }}
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
|
6
.github/workflows/generate.yml
vendored
6
.github/workflows/generate.yml
vendored
@ -19,12 +19,12 @@ jobs:
|
||||
contents: write # for stefanzweifel/git-auto-commit-action to push code in repo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
token: ${{ secrets.GH_PAT }}
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
go-version: stable
|
||||
cache: true
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
- run: task docs:generate
|
||||
|
2
.github/workflows/gitleaks.yml
vendored
2
.github/workflows/gitleaks.yml
vendored
@ -14,7 +14,7 @@ jobs:
|
||||
gitleaks:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- uses: gitleaks/gitleaks-action@v2
|
||||
|
2
.github/workflows/grype.yml
vendored
2
.github/workflows/grype.yml
vendored
@ -17,7 +17,7 @@ jobs:
|
||||
contents: read
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: anchore/scan-action@v3
|
||||
with:
|
||||
path: "."
|
||||
|
8
.github/workflows/lint.yml
vendored
8
.github/workflows/lint.yml
vendored
@ -17,12 +17,12 @@ jobs:
|
||||
name: lint
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
go-version: stable
|
||||
cache: false
|
||||
- name: golangci-lint
|
||||
uses: golangci/golangci-lint-action@08e2f20817b15149a52b5b3ebe7de50aff2ba8c5 # v3
|
||||
with:
|
||||
skip-go-installation: true
|
||||
args: --timeout=5m
|
||||
|
15
.github/workflows/release.yml
vendored
15
.github/workflows/release.yml
vendored
@ -49,7 +49,7 @@ jobs:
|
||||
matrix:
|
||||
format: [ deb, rpm, apk ]
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
@ -57,7 +57,7 @@ jobs:
|
||||
version: 3.x
|
||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
- uses: docker/setup-qemu-action@e81a89b1732b9c48d79cd809d8d81d79c4647a18 # v2
|
||||
- uses: actions/cache@940f3d7cf195ba83374c77632d1e2cbb2f24ae68 # v3
|
||||
- uses: actions/cache@88522ab9f39a2ea568f7027eddc7d8d8bc9d59c8 # v3
|
||||
with:
|
||||
path: |
|
||||
./dist/*.deb
|
||||
@ -70,7 +70,7 @@ jobs:
|
||||
env:
|
||||
DOCKER_CLI_EXPERIMENTAL: "enabled"
|
||||
steps:
|
||||
- uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3
|
||||
- uses: actions/checkout@24cb9080177205b6e8c946b17badbe402adc938f # v3
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1
|
||||
@ -78,7 +78,7 @@ jobs:
|
||||
version: 3.x
|
||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
- uses: docker/setup-qemu-action@e81a89b1732b9c48d79cd809d8d81d79c4647a18 # v2
|
||||
- uses: docker/setup-buildx-action@f03ac48505955848960e80bbb68046aa35c7b9e7 # v2
|
||||
- uses: docker/setup-buildx-action@4b4e9c3e2d4531116a6f8ba8e71fc6e2cb6e6c8c # v2
|
||||
- name: setup-snapcraft
|
||||
# FIXME: the mkdirs are a hack for https://github.com/goreleaser/goreleaser/issues/1715
|
||||
run: |
|
||||
@ -86,11 +86,10 @@ jobs:
|
||||
sudo apt-get -yq --no-install-suggests --no-install-recommends install snapcraft
|
||||
mkdir -p $HOME/.cache/snapcraft/download
|
||||
mkdir -p $HOME/.cache/snapcraft/stage-packages
|
||||
- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3
|
||||
- uses: actions/setup-go@4d34df0c2316fe8122ab82dc22947d607c0c91f9 # v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
cache: true
|
||||
- uses: actions/cache@940f3d7cf195ba83374c77632d1e2cbb2f24ae68 # v3
|
||||
go-version: stable
|
||||
- uses: actions/cache@88522ab9f39a2ea568f7027eddc7d8d8bc9d59c8 # v3
|
||||
with:
|
||||
path: |
|
||||
./dist/*.deb
|
||||
|
42
go.mod
42
go.mod
@ -8,27 +8,27 @@ require (
|
||||
github.com/atc0005/go-teams-notify/v2 v2.7.0
|
||||
github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220517224237-e6f29200ae04
|
||||
github.com/caarlos0/ctrlc v1.2.0
|
||||
github.com/caarlos0/env/v7 v7.0.0
|
||||
github.com/caarlos0/env/v7 v7.1.0
|
||||
github.com/caarlos0/go-reddit/v3 v3.0.1
|
||||
github.com/caarlos0/go-shellwords v1.0.12
|
||||
github.com/caarlos0/log v0.2.1
|
||||
github.com/caarlos0/log v0.2.2
|
||||
github.com/charmbracelet/keygen v0.3.0
|
||||
github.com/charmbracelet/lipgloss v0.6.0
|
||||
github.com/charmbracelet/lipgloss v0.7.1
|
||||
github.com/chrismellard/docker-credential-acr-env v0.0.0-20220327082430-c57b701bfc08
|
||||
github.com/dghubble/go-twitter v0.0.0-20211115160449-93a8679adecb
|
||||
github.com/dghubble/oauth1 v0.7.2
|
||||
github.com/disgoorg/disgo v0.15.2
|
||||
github.com/disgoorg/disgo v0.15.3
|
||||
github.com/disgoorg/snowflake/v2 v2.0.1
|
||||
github.com/distribution/distribution/v3 v3.0.0-20221021092657-c47a966fded8
|
||||
github.com/go-telegram-bot-api/telegram-bot-api v4.6.4+incompatible
|
||||
github.com/google/go-containerregistry v0.13.0
|
||||
github.com/google/go-containerregistry v0.14.0
|
||||
github.com/google/go-github/v50 v50.1.0
|
||||
github.com/google/ko v0.12.0
|
||||
github.com/google/uuid v1.3.0
|
||||
github.com/goreleaser/fileglob v1.3.0
|
||||
github.com/goreleaser/nfpm/v2 v2.26.0
|
||||
github.com/goreleaser/nfpm/v2 v2.27.1
|
||||
github.com/hashicorp/go-multierror v1.1.1
|
||||
github.com/imdario/mergo v0.3.13
|
||||
github.com/imdario/mergo v0.3.14
|
||||
github.com/invopop/jsonschema v0.7.0
|
||||
github.com/jarcoal/httpmock v1.3.0
|
||||
github.com/klauspost/pgzip v1.2.5
|
||||
@ -36,20 +36,20 @@ require (
|
||||
github.com/mitchellh/go-homedir v1.1.0
|
||||
github.com/muesli/mango-cobra v1.2.0
|
||||
github.com/muesli/roff v0.1.0
|
||||
github.com/muesli/termenv v0.14.0
|
||||
github.com/muesli/termenv v0.15.1
|
||||
github.com/ory/dockertest/v3 v3.9.1
|
||||
github.com/slack-go/slack v0.12.1
|
||||
github.com/spf13/cobra v1.6.1
|
||||
github.com/stretchr/testify v1.8.2
|
||||
github.com/ulikunitz/xz v0.5.11
|
||||
github.com/withfig/autocomplete-tools/integrations/cobra v1.2.1
|
||||
github.com/xanzy/go-gitlab v0.80.2
|
||||
github.com/xanzy/go-gitlab v0.81.0
|
||||
gocloud.dev v0.29.0
|
||||
golang.org/x/crypto v0.7.0
|
||||
golang.org/x/oauth2 v0.6.0
|
||||
golang.org/x/sync v0.1.0
|
||||
golang.org/x/text v0.8.0
|
||||
golang.org/x/tools v0.6.0
|
||||
golang.org/x/tools v0.7.0
|
||||
gopkg.in/mail.v2 v2.3.1
|
||||
gopkg.in/yaml.v3 v3.0.1
|
||||
)
|
||||
@ -115,7 +115,7 @@ require (
|
||||
github.com/aws/aws-sdk-go-v2/service/ssooidc v1.14.1 // indirect
|
||||
github.com/aws/aws-sdk-go-v2/service/sts v1.18.3 // indirect
|
||||
github.com/aws/smithy-go v1.13.5 // indirect
|
||||
github.com/aymanbagabas/go-osc52 v1.2.1 // indirect
|
||||
github.com/aymanbagabas/go-osc52/v2 v2.0.1 // indirect
|
||||
github.com/beorn7/perks v1.0.1 // indirect
|
||||
github.com/blakesmith/ar v0.0.0-20190502131153-809d4375e1fb // indirect
|
||||
github.com/caarlos0/sshmarshal v0.0.0-20220308164159-9ddb9f83c6b3 // indirect
|
||||
@ -123,16 +123,16 @@ require (
|
||||
github.com/cenkalti/backoff/v4 v4.2.0 // indirect
|
||||
github.com/cespare/xxhash/v2 v2.2.0 // indirect
|
||||
github.com/containerd/continuity v0.3.0 // indirect
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.12.1 // indirect
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.14.3 // indirect
|
||||
github.com/cpuguy83/go-md2man/v2 v2.0.2 // indirect
|
||||
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||
github.com/dghubble/sling v1.4.0 // indirect
|
||||
github.com/dimchansky/utfbom v1.1.1 // indirect
|
||||
github.com/disgoorg/json v1.0.0 // indirect
|
||||
github.com/disgoorg/log v1.2.0 // indirect
|
||||
github.com/docker/cli v20.10.20+incompatible // indirect
|
||||
github.com/docker/cli v23.0.1+incompatible // indirect
|
||||
github.com/docker/distribution v2.8.1+incompatible // indirect
|
||||
github.com/docker/docker v20.10.23+incompatible // indirect
|
||||
github.com/docker/docker v23.0.1+incompatible // indirect
|
||||
github.com/docker/docker-credential-helpers v0.7.0 // indirect
|
||||
github.com/docker/go-connections v0.4.0 // indirect
|
||||
github.com/docker/go-metrics v0.0.1 // indirect
|
||||
@ -157,29 +157,29 @@ require (
|
||||
github.com/gogo/protobuf v1.3.2 // indirect
|
||||
github.com/golang-jwt/jwt/v4 v4.4.3 // indirect
|
||||
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
|
||||
github.com/golang/protobuf v1.5.2 // indirect
|
||||
github.com/golang/protobuf v1.5.3 // indirect
|
||||
github.com/google/go-cmp v0.5.9 // indirect
|
||||
github.com/google/go-querystring v1.1.0 // indirect
|
||||
github.com/google/shlex v0.0.0-20191202100458-e7afc7fbc510 // indirect
|
||||
github.com/google/wire v0.5.0 // indirect
|
||||
github.com/googleapis/enterprise-certificate-proxy v0.2.3 // indirect
|
||||
github.com/googleapis/gax-go/v2 v2.7.0 // indirect
|
||||
github.com/goreleaser/chglog v0.4.1 // indirect
|
||||
github.com/goreleaser/chglog v0.4.2 // indirect
|
||||
github.com/gorilla/mux v1.8.0 // indirect
|
||||
github.com/gorilla/websocket v1.5.0 // indirect
|
||||
github.com/hashicorp/errwrap v1.1.0 // indirect
|
||||
github.com/hashicorp/go-cleanhttp v0.5.2 // indirect
|
||||
github.com/hashicorp/go-retryablehttp v0.7.1 // indirect
|
||||
github.com/hashicorp/go-retryablehttp v0.7.2 // indirect
|
||||
github.com/hashicorp/go-version v1.6.0 // indirect
|
||||
github.com/hashicorp/hcl v1.0.0 // indirect
|
||||
github.com/huandu/xstrings v1.3.2 // indirect
|
||||
github.com/iancoleman/orderedmap v0.2.0 // indirect
|
||||
github.com/inconshreveable/mousetrap v1.0.1 // indirect
|
||||
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
||||
github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99 // indirect
|
||||
github.com/jmespath/go-jmespath v0.4.0 // indirect
|
||||
github.com/josharian/intern v1.0.0 // indirect
|
||||
github.com/kevinburke/ssh_config v1.1.0 // indirect
|
||||
github.com/klauspost/compress v1.15.15 // indirect
|
||||
github.com/klauspost/compress v1.16.3 // indirect
|
||||
github.com/kylelemons/godebug v1.1.0 // indirect
|
||||
github.com/letsencrypt/boulder v0.0.0-20220929215747-76583552c2be // indirect
|
||||
github.com/lucasb-eyer/go-colorful v1.2.0 // indirect
|
||||
@ -235,7 +235,7 @@ require (
|
||||
go.mongodb.org/mongo-driver v1.11.0 // indirect
|
||||
go.opencensus.io v0.24.0 // indirect
|
||||
golang.org/x/exp v0.0.0-20230124195608-d38c7dcee874 // indirect
|
||||
golang.org/x/mod v0.8.0 // indirect
|
||||
golang.org/x/mod v0.9.0 // indirect
|
||||
golang.org/x/net v0.8.0 // indirect
|
||||
golang.org/x/sys v0.6.0 // indirect
|
||||
golang.org/x/term v0.6.0 // indirect
|
||||
@ -245,7 +245,7 @@ require (
|
||||
google.golang.org/appengine v1.6.7 // indirect
|
||||
google.golang.org/genproto v0.0.0-20230209215440-0dfe4f8abfcc // indirect
|
||||
google.golang.org/grpc v1.53.0 // indirect
|
||||
google.golang.org/protobuf v1.28.1 // indirect
|
||||
google.golang.org/protobuf v1.29.1 // indirect
|
||||
gopkg.in/alexcesaro/quotedprintable.v3 v3.0.0-20150716171945-2caba252f4dc // indirect
|
||||
gopkg.in/ini.v1 v1.67.0 // indirect
|
||||
gopkg.in/square/go-jose.v2 v2.6.0 // indirect
|
||||
|
85
go.sum
85
go.sum
@ -842,8 +842,8 @@ github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220228164355-
|
||||
github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220517224237-e6f29200ae04 h1:p2I85zYI9z5/c/3Q0LiO3RtNXcmXHTtJfml/hV16zNg=
|
||||
github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220517224237-e6f29200ae04/go.mod h1:Z+bXnIbhKJYSvxNwsNnwde7pDKxuqlEZCbUBoTwAqf0=
|
||||
github.com/aybabtme/rgbterm v0.0.0-20170906152045-cc83f3b3ce59/go.mod h1:q/89r3U2H7sSsE2t6Kca0lfwTK8JdoNGS/yzM/4iH5I=
|
||||
github.com/aymanbagabas/go-osc52 v1.2.1 h1:q2sWUyDcozPLcLabEMd+a+7Ea2DitxZVN9hTxab9L4E=
|
||||
github.com/aymanbagabas/go-osc52 v1.2.1/go.mod h1:zT8H+Rk4VSabYN90pWyugflM3ZhpTZNC7cASDfUCdT4=
|
||||
github.com/aymanbagabas/go-osc52/v2 v2.0.1 h1:HwpRHbFMcZLEVr42D4p7XBqjyuxQH5SMiErDT4WkJ2k=
|
||||
github.com/aymanbagabas/go-osc52/v2 v2.0.1/go.mod h1:uYgXzlJ7ZpABp8OJ+exZzJJhRNQ2ASbcXHWsFqH8hp8=
|
||||
github.com/beeker1121/goque v1.0.3-0.20191103205551-d618510128af/go.mod h1:84CWnaDz4g1tEVnFLnuBigmGK15oPohy0RfvSN8d4eg=
|
||||
github.com/beevik/etree v1.1.0/go.mod h1:r8Aw8JqVegEf0w2fDnATrX9VpkMcyFeM0FhwO62wh+A=
|
||||
github.com/benbjohnson/clock v1.0.3/go.mod h1:bGMdMPoPVvcYyt1gHDf4J2KE153Yf9BuiUKYMaxlTDM=
|
||||
@ -882,15 +882,15 @@ github.com/bytecodealliance/wasmtime-go v0.36.0/go.mod h1:q320gUxqyI8yB+ZqRuaJOE
|
||||
github.com/caarlos0/ctrlc v1.0.0/go.mod h1:CdXpj4rmq0q/1Eb44M9zi2nKB0QraNKuRGYGrrHhcQw=
|
||||
github.com/caarlos0/ctrlc v1.2.0 h1:AtbThhmbeYx1WW3WXdWrd94EHKi+0NPRGS4/4pzrjwk=
|
||||
github.com/caarlos0/ctrlc v1.2.0/go.mod h1:n3gDlSjsXZ7rbD9/RprIR040b7oaLfNStikPd4gFago=
|
||||
github.com/caarlos0/env/v7 v7.0.0 h1:cyczlTd/zREwSr9ch/mwaDl7Hse7kJuUY8hvHfXu5WI=
|
||||
github.com/caarlos0/env/v7 v7.0.0/go.mod h1:LPPWniDUq4JaO6Q41vtlyikhMknqymCLBw0eX4dcH1E=
|
||||
github.com/caarlos0/env/v7 v7.1.0 h1:9lzTF5amyQeWHZzuZeKlCb5FWSUxpG1js43mhbY8ozg=
|
||||
github.com/caarlos0/env/v7 v7.1.0/go.mod h1:LPPWniDUq4JaO6Q41vtlyikhMknqymCLBw0eX4dcH1E=
|
||||
github.com/caarlos0/go-reddit/v3 v3.0.1 h1:w8ugvsrHhaE/m4ez0BO/sTBOBWI9WZTjG7VTecHnql4=
|
||||
github.com/caarlos0/go-reddit/v3 v3.0.1/go.mod h1:QlwgmG5SAqxMeQvg/A2dD1x9cIZCO56BMnMdjXLoisI=
|
||||
github.com/caarlos0/go-rpmutils v0.2.1-0.20211112020245-2cd62ff89b11 h1:IRrDwVlWQr6kS1U8/EtyA1+EHcc4yl8pndcqXWrEamg=
|
||||
github.com/caarlos0/go-shellwords v1.0.12 h1:HWrUnu6lGbWfrDcFiHcZiwOLzHWjjrPVehULaTFgPp8=
|
||||
github.com/caarlos0/go-shellwords v1.0.12/go.mod h1:bYeeX1GrTLPl5cAMYEzdm272qdsQAZiaHgeF0KTk1Gw=
|
||||
github.com/caarlos0/log v0.2.1 h1:E5vf0Sg24tUbrGanknDu2UH0CZq6cCColThb8gTQnHQ=
|
||||
github.com/caarlos0/log v0.2.1/go.mod h1:BLxpdZKXvWBjB6fshua4c8d7ApdYjypEDok6ibt+pXk=
|
||||
github.com/caarlos0/log v0.2.2 h1:Rier7889+dTKHjvwf0cMNu8DjMF+/wCYC7wrPj9fXFk=
|
||||
github.com/caarlos0/log v0.2.2/go.mod h1:IbSeDN+hKHdOwE6t2z9i2rcraz+r6N1XZkRHE4BAKm0=
|
||||
github.com/caarlos0/sshmarshal v0.0.0-20220308164159-9ddb9f83c6b3 h1:w2ANoiT4ubmh4Nssa3/QW1M7lj3FZkma8f8V5aBDxXM=
|
||||
github.com/caarlos0/sshmarshal v0.0.0-20220308164159-9ddb9f83c6b3/go.mod h1:7Pd/0mmq9x/JCzKauogNjSQEhivBclCQHfr9dlpDIyA=
|
||||
github.com/caarlos0/testfs v0.4.4 h1:3PHvzHi5Lt+g332CiShwS8ogTgS3HjrmzZxCm6JCDr8=
|
||||
@ -926,8 +926,8 @@ github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XL
|
||||
github.com/charithe/durationcheck v0.0.9/go.mod h1:SSbRIBVfMjCi/kEB6K65XEA83D6prSM8ap1UCpNKtgg=
|
||||
github.com/charmbracelet/keygen v0.3.0 h1:mXpsQcH7DDlST5TddmXNXjS0L7ECk4/kLQYyBcsan2Y=
|
||||
github.com/charmbracelet/keygen v0.3.0/go.mod h1:1ukgO8806O25lUZ5s0IrNur+RlwTBERlezdgW71F5rM=
|
||||
github.com/charmbracelet/lipgloss v0.6.0 h1:1StyZB9vBSOyuZxQUcUwGr17JmojPNm87inij9N3wJY=
|
||||
github.com/charmbracelet/lipgloss v0.6.0/go.mod h1:tHh2wr34xcHjC2HCXIlGSG1jaDF0S0atAUvBMP6Ppuk=
|
||||
github.com/charmbracelet/lipgloss v0.7.1 h1:17WMwi7N1b1rVWOjMT+rCh7sQkvDU75B2hbZpc5Kc1E=
|
||||
github.com/charmbracelet/lipgloss v0.7.1/go.mod h1:yG0k3giv8Qj8edTCbbg6AlQ5e8KNWpFujkNawKNhE2c=
|
||||
github.com/chavacava/garif v0.0.0-20210405164556-e8a0a408d6af/go.mod h1:Qjyv4H3//PWVzTeCezG2b9IRn6myJxJSr4TD/xo6ojU=
|
||||
github.com/checkpoint-restore/go-criu/v4 v4.1.0/go.mod h1:xUQBLp4RLc5zJtWY++yjOoMoB5lihDt7fai+75m+rGw=
|
||||
github.com/checkpoint-restore/go-criu/v5 v5.0.0/go.mod h1:cfwC0EG7HMUenopBsUf9d89JlCLQIfgVcNsNN0t6T2M=
|
||||
@ -1052,8 +1052,8 @@ github.com/containerd/stargz-snapshotter/estargz v0.4.1/go.mod h1:x7Q9dg9QYb4+EL
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.10.1/go.mod h1:aE5PCyhFMwR8sbrErO5eM2GcvkyXTTJremG883D4qF0=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.11.4/go.mod h1:7vRJIcImfY8bpifnMjt+HTJoQxASq7T28MYbP15/Nf0=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.12.0/go.mod h1:AIQ59TewBFJ4GOPEQXujcrJ/EKxh5xXZegW1rkR1P/M=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.12.1 h1:+7nYmHJb0tEkcRaAW+MHqoKaJYZmkikupxCqVtmPuY0=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.12.1/go.mod h1:12VUuCq3qPq4y8yUW+l5w3+oXV3cx2Po3KSe/SmPGqw=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.14.3 h1:OqlDCK3ZVUO6C3B/5FSkDwbkEETK84kQgEeFwDC+62k=
|
||||
github.com/containerd/stargz-snapshotter/estargz v0.14.3/go.mod h1:KY//uOCIkSuNAHhJogcZtrNHdKrA99/FCCRjE3HD36o=
|
||||
github.com/containerd/ttrpc v0.0.0-20190828154514-0e0f228740de/go.mod h1:PvCDdDGpgqzQIzDW1TphrGLssLDZp2GuS+X5DkEJB8o=
|
||||
github.com/containerd/ttrpc v0.0.0-20190828172938-92c8520ef9f8/go.mod h1:PvCDdDGpgqzQIzDW1TphrGLssLDZp2GuS+X5DkEJB8o=
|
||||
github.com/containerd/ttrpc v0.0.0-20191028202541-4f1b8fe65a5c/go.mod h1:LPm1u0xBw8r8NOKoOdNMeVHSawSsltak+Ihv+etqsE8=
|
||||
@ -1159,8 +1159,8 @@ github.com/digitalocean/godo v1.95.0/go.mod h1:NRpFznZFvhHjBoqZAaOD3khVzsJ3EibzK
|
||||
github.com/dimchansky/utfbom v1.1.0/go.mod h1:rO41eb7gLfo8SF1jd9F8HplJm1Fewwi4mQvIirEdv+8=
|
||||
github.com/dimchansky/utfbom v1.1.1 h1:vV6w1AhK4VMnhBno/TPVCoK9U/LP0PkLCS9tbxHdi/U=
|
||||
github.com/dimchansky/utfbom v1.1.1/go.mod h1:SxdoEBH5qIqFocHMyGOXVAybYJdr71b1Q/j0mACtrfE=
|
||||
github.com/disgoorg/disgo v0.15.2 h1:cmdMCHBL17GgkYOJl6d2Btc3MbQiIdzwF6D8lwdJ7L8=
|
||||
github.com/disgoorg/disgo v0.15.2/go.mod h1:hUkznOmm+f+owh/MuOBX0sDviQV5cL0FqcWbpIyV1Y0=
|
||||
github.com/disgoorg/disgo v0.15.3 h1:BLPn38jdvn1DigBsiQZIkWdLwSzCax4rUQkufOWzQ6w=
|
||||
github.com/disgoorg/disgo v0.15.3/go.mod h1:hUkznOmm+f+owh/MuOBX0sDviQV5cL0FqcWbpIyV1Y0=
|
||||
github.com/disgoorg/json v1.0.0 h1:kDhSM661fgIuNoZF3BO5/odaR5NSq80AWb937DH+Pdo=
|
||||
github.com/disgoorg/json v1.0.0/go.mod h1:BHDwdde0rpQFDVsRLKhma6Y7fTbQKub/zdGO5O9NqqA=
|
||||
github.com/disgoorg/log v1.2.0 h1:sqlXnu/ZKAlIlHV9IO+dbMto7/hCQ474vlIdMWk8QKo=
|
||||
@ -1178,8 +1178,8 @@ github.com/docker/cli v0.0.0-20191017083524-a8ff7f821017/go.mod h1:JLrzqnKDaYBop
|
||||
github.com/docker/cli v20.10.11+incompatible/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
|
||||
github.com/docker/cli v20.10.16+incompatible/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
|
||||
github.com/docker/cli v20.10.17+incompatible/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
|
||||
github.com/docker/cli v20.10.20+incompatible h1:lWQbHSHUFs7KraSN2jOJK7zbMS2jNCHI4mt4xUFUVQ4=
|
||||
github.com/docker/cli v20.10.20+incompatible/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
|
||||
github.com/docker/cli v23.0.1+incompatible h1:LRyWITpGzl2C9e9uGxzisptnxAn1zfZKXy13Ul2Q5oM=
|
||||
github.com/docker/cli v23.0.1+incompatible/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
|
||||
github.com/docker/distribution v0.0.0-20190905152932-14b96e55d84c/go.mod h1:0+TTO4EOBfRPhZXAeF1Vu+W3hHZ8eLp8PgKVZlcvtFY=
|
||||
github.com/docker/distribution v2.7.1-0.20190205005809-0d3efadf0154+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
|
||||
github.com/docker/distribution v2.7.1+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
|
||||
@ -1190,8 +1190,9 @@ github.com/docker/docker v20.10.11+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05
|
||||
github.com/docker/docker v20.10.14+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||
github.com/docker/docker v20.10.16+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||
github.com/docker/docker v20.10.17+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||
github.com/docker/docker v20.10.23+incompatible h1:1ZQUUYAdh+oylOT85aA2ZcfRp22jmLhoaEcVEfK8dyA=
|
||||
github.com/docker/docker v20.10.23+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||
github.com/docker/docker v23.0.1+incompatible h1:vjgvJZxprTTE1A37nm+CLNAdwu6xZekyoiVlUZEINcY=
|
||||
github.com/docker/docker v23.0.1+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||
github.com/docker/docker-credential-helpers v0.6.3/go.mod h1:WRaJzqw3CTB9bk10avuGsjVBZsD05qeibJ1/TYlvc0Y=
|
||||
github.com/docker/docker-credential-helpers v0.6.4/go.mod h1:ofX3UI0Gz1TteYBjtgs07O36Pyasyp66D2uKT7H8W1c=
|
||||
github.com/docker/docker-credential-helpers v0.7.0 h1:xtCHsjxogADNZcdv1pKUHXryefjlVRqWqIhk/uXJp0A=
|
||||
@ -1580,8 +1581,9 @@ github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw
|
||||
github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
|
||||
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
|
||||
github.com/golang/protobuf v1.5.1/go.mod h1:DopwsBzvsk0Fs44TXzsVbJyPhcCPeIwnvohx4u74HPM=
|
||||
github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
|
||||
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
|
||||
github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg=
|
||||
github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
|
||||
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||
github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||
github.com/golang/snappy v0.0.2/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||
@ -1629,8 +1631,8 @@ github.com/google/go-containerregistry v0.5.1/go.mod h1:Ct15B4yir3PLOP5jsy0GNeYV
|
||||
github.com/google/go-containerregistry v0.7.1-0.20211118220127-abdc633f8305/go.mod h1:6cMIl1RfryEiPzBE67OgtZdEiLWz4myqCQIiBMy3CsM=
|
||||
github.com/google/go-containerregistry v0.9.0/go.mod h1:9eq4BnSufyT1kHNffX+vSXVonaJ7yaIOulrKZejMxnQ=
|
||||
github.com/google/go-containerregistry v0.11.0/go.mod h1:BBaYtsHPHA42uEgAvd/NejvAfPSlz281sJWqupjSxfk=
|
||||
github.com/google/go-containerregistry v0.13.0 h1:y1C7Z3e149OJbOPDBxLYR8ITPz8dTKqQwjErKVHJC8k=
|
||||
github.com/google/go-containerregistry v0.13.0/go.mod h1:J9FQ+eSS4a1aC2GNZxvNpbWhgp0487v+cgiilB4FqDo=
|
||||
github.com/google/go-containerregistry v0.14.0 h1:z58vMqHxuwvAsVwvKEkmVBz2TlgBgH5k6koEXBtlYkw=
|
||||
github.com/google/go-containerregistry v0.14.0/go.mod h1:aiJ2fp/SXvkWgmYHioXnbMdlgB8eXiiYOY55gfN91Wk=
|
||||
github.com/google/go-github/v28 v28.1.1/go.mod h1:bsqJWQX05omyWVmc00nEUql9mhQyv38lDZ8kPZcQVoM=
|
||||
github.com/google/go-github/v45 v45.2.0/go.mod h1:FObaZJEDSTa/WGCzZ2Z3eoCDXWJKMenWWTrd8jrta28=
|
||||
github.com/google/go-github/v50 v50.1.0 h1:hMUpkZjklC5GJ+c3GquSqOP/T4BNsB7XohaPhtMOzRk=
|
||||
@ -1730,14 +1732,14 @@ github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1 h1:EGx4pi6eqNxGa
|
||||
github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY=
|
||||
github.com/gordonklaus/ineffassign v0.0.0-20200309095847-7953dde2c7bf/go.mod h1:cuNKsD1zp2v6XfE/orVX2QE1LC+i254ceGcVeDT3pTU=
|
||||
github.com/gordonklaus/ineffassign v0.0.0-20210225214923-2e10b2664254/go.mod h1:M9mZEtGIsR1oDaZagNPNG9iq9n2HrhZ17dsXk73V3Lw=
|
||||
github.com/goreleaser/chglog v0.4.1 h1:6IAduyHpR58u3OFBdTrg8I/qAaBAmYYZ4Wq1Fz30QUY=
|
||||
github.com/goreleaser/chglog v0.4.1/go.mod h1:85xT/GTwDCzLdjysP9aj+x6hQ+IxAv8SXx9MTrgcY2Y=
|
||||
github.com/goreleaser/chglog v0.4.2 h1:afmbT1d7lX/q+GF8wv3a1Dofs2j/Y9YkiCpGemWR6mI=
|
||||
github.com/goreleaser/chglog v0.4.2/go.mod h1:u/F03un4hMCQrp65qSWCkkC6T+G7YLKZ+AM2mITE47s=
|
||||
github.com/goreleaser/fileglob v1.3.0 h1:/X6J7U8lbDpQtBvGcwwPS6OpzkNVlVEsFUVRx9+k+7I=
|
||||
github.com/goreleaser/fileglob v1.3.0/go.mod h1:Jx6BoXv3mbYkEzwm9THo7xbr5egkAraxkGorbJb4RxU=
|
||||
github.com/goreleaser/goreleaser v0.134.0/go.mod h1:ZT6Y2rSYa6NxQzIsdfWWNWAlYGXGbreo66NmE+3X3WQ=
|
||||
github.com/goreleaser/nfpm v1.2.1/go.mod h1:TtWrABZozuLOttX2uDlYyECfQX7x5XYkVxhjYcR6G9w=
|
||||
github.com/goreleaser/nfpm/v2 v2.26.0 h1:nL7sXwsMLsc+NWE4Eddev+ZZomRaucT0WSnWkLwuxBM=
|
||||
github.com/goreleaser/nfpm/v2 v2.26.0/go.mod h1:AQAOZ89rL4rHbv6ZdwyCWkjMam3LrHi9QIq56TnjUQk=
|
||||
github.com/goreleaser/nfpm/v2 v2.27.1 h1:+q7/aY+SCQjB5OKiqzdBVoFIhG1XnxRBU2Pxqt8qm3U=
|
||||
github.com/goreleaser/nfpm/v2 v2.27.1/go.mod h1:o5coBBYYdw+tifbB6DJLL/rR42bUmI5mWCKGumJmEt8=
|
||||
github.com/gorhill/cronexpr v0.0.0-20180427100037-88b0669f7d75/go.mod h1:g2644b03hfBX9Ov0ZBDgXXens4rxSxmqFBbhvKv2yVA=
|
||||
github.com/gorilla/context v1.1.1/go.mod h1:kBGZzfjB9CEq2AlWe17Uuf7NDRt0dE0s8S51q0aT7Yg=
|
||||
github.com/gorilla/handlers v0.0.0-20150720190736-60c7bfde3e33/go.mod h1:Qkdc/uu4tH4g6mTK6auzZ766c4CA0Ng8+o/OAirnOIQ=
|
||||
@ -1835,8 +1837,9 @@ github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es
|
||||
github.com/hashicorp/go-retryablehttp v0.6.4/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||
github.com/hashicorp/go-retryablehttp v0.6.6/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||
github.com/hashicorp/go-retryablehttp v0.7.0/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||
github.com/hashicorp/go-retryablehttp v0.7.1 h1:sUiuQAnLlbvmExtFQs72iFW/HXeUn8Z1aJLQ4LJJbTQ=
|
||||
github.com/hashicorp/go-retryablehttp v0.7.1/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||
github.com/hashicorp/go-retryablehttp v0.7.2 h1:AcYqCvkpalPnPF2pn0KamgwamS42TqUDDYFRKq/RAd0=
|
||||
github.com/hashicorp/go-retryablehttp v0.7.2/go.mod h1:Jy/gPYAdjqffZ/yFGCFV2doI5wjtH1ewM9u8iYVjtX8=
|
||||
github.com/hashicorp/go-rootcerts v1.0.0/go.mod h1:K6zTfqpRlCUIjkwsN4Z+hiSfzSTQa6eBIzfwKfwNnHU=
|
||||
github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
|
||||
github.com/hashicorp/go-secure-stdlib/base62 v0.1.1/go.mod h1:EdWO6czbmthiwZ3/PUsDV+UD1D5IRU4ActiaWGwt0Yw=
|
||||
@ -1927,13 +1930,14 @@ github.com/imdario/mergo v0.3.9/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJ
|
||||
github.com/imdario/mergo v0.3.10/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
|
||||
github.com/imdario/mergo v0.3.11/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
|
||||
github.com/imdario/mergo v0.3.12/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
|
||||
github.com/imdario/mergo v0.3.13 h1:lFzP57bqS/wsqKssCGmtLAb8A0wKjLGrve2q3PPVcBk=
|
||||
github.com/imdario/mergo v0.3.13/go.mod h1:4lJ1jqUDcsbIECGy0RUJAXNIhg+6ocWgb1ALK2O4oXg=
|
||||
github.com/imdario/mergo v0.3.14 h1:fOqeC1+nCuuk6PKQdg9YmosXX7Y7mHX6R/0ZldI9iHo=
|
||||
github.com/imdario/mergo v0.3.14/go.mod h1:WBLT9ZmE3lPoWsEzCh9LPo3TiwVN+ZKEjmz+hD27ysY=
|
||||
github.com/in-toto/in-toto-golang v0.3.4-0.20211211042327-af1f9fb822bf/go.mod h1:twl9XmClqj6/h/HANQQYaJZVKPPW/Mz53bd2t6UXGQA=
|
||||
github.com/in-toto/in-toto-golang v0.3.4-0.20220709202702-fa494aaa0add/go.mod h1:DQI8vlV6h6qSY/tCOoYKtxjWrkyiNpJ3WTV/WoBllmQ=
|
||||
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
||||
github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc=
|
||||
github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
||||
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
|
||||
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
||||
github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
|
||||
github.com/influxdata/influxdb1-client v0.0.0-20200827194710-b269163b24ab/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
|
||||
github.com/intel/goresctrl v0.2.0/go.mod h1:+CZdzouYFn5EsxgqAQTEzMfwKwuc0fVdMrT9FCCAVRQ=
|
||||
@ -2083,9 +2087,8 @@ github.com/klauspost/compress v1.15.1/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47e
|
||||
github.com/klauspost/compress v1.15.4/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
||||
github.com/klauspost/compress v1.15.7/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
||||
github.com/klauspost/compress v1.15.8/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
||||
github.com/klauspost/compress v1.15.11/go.mod h1:QPwzmACJjUTFsnSHH934V6woptycfrDDJnH7hvFVbGM=
|
||||
github.com/klauspost/compress v1.15.15 h1:EF27CXIuDsYJ6mmvtBRlEuB2UVOqHG1tAXgZ7yIO+lw=
|
||||
github.com/klauspost/compress v1.15.15/go.mod h1:ZcK2JAFqKOpnBlxcLsJzYfrS9X1akm9fHZNnD9+Vo/4=
|
||||
github.com/klauspost/compress v1.16.3 h1:XuJt9zzcnaz6a16/OU53ZjWp/v7/42WcR5t2a0PcNQY=
|
||||
github.com/klauspost/compress v1.16.3/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE=
|
||||
github.com/klauspost/cpuid v1.2.0/go.mod h1:Pj4uuM528wm8OyEC2QMXAi2YiTZ96dNQPGgoMS4s3ek=
|
||||
github.com/klauspost/pgzip v1.2.5 h1:qnWYvvKqedOF2ulHpMG72XQol4ILEJ8k2wwRl/Km8oE=
|
||||
github.com/klauspost/pgzip v1.2.5/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs=
|
||||
@ -2177,8 +2180,8 @@ github.com/markbates/safe v1.0.1/go.mod h1:nAqgmRi7cY2nqMc92/bSEeQA+R4OheNU2T1kN
|
||||
github.com/marstr/guid v1.1.0/go.mod h1:74gB1z2wpxxInTG6yaqA7KrtM0NZ+RbrcqDvYHefzho=
|
||||
github.com/matoous/godox v0.0.0-20210227103229-6504466cf951/go.mod h1:1BELzlh859Sh1c6+90blK8lbYy0kwQf1bYlBhBysy1s=
|
||||
github.com/matryer/is v1.2.0/go.mod h1:2fLPjFQM9rhQ15aVEtbuwhJinnOqrmgXPNdZsdwlWXA=
|
||||
github.com/matryer/is v1.4.0 h1:sosSmIWwkYITGrxZ25ULNDeKiMNzFSr4V/eqBQP0PeE=
|
||||
github.com/matryer/is v1.4.0/go.mod h1:8I/i5uYgLzgsgEloJE1U6xx5HkBQpAZvepWuujKwMRU=
|
||||
github.com/matryer/is v1.4.1 h1:55ehd8zaGABKLXQUe2awZ99BD/PTc2ls+KV/dXphgEQ=
|
||||
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
||||
github.com/mattn/go-colorable v0.1.1/go.mod h1:FuOcm+DKB9mbwrcAfNl7/TZVBZ6rcnceauSikq3lYCQ=
|
||||
github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE=
|
||||
@ -2210,7 +2213,6 @@ github.com/mattn/go-runewidth v0.0.4/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzp
|
||||
github.com/mattn/go-runewidth v0.0.6/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI=
|
||||
github.com/mattn/go-runewidth v0.0.7/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI=
|
||||
github.com/mattn/go-runewidth v0.0.9/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI=
|
||||
github.com/mattn/go-runewidth v0.0.10/go.mod h1:RAqKPSqVFrSLVXbA8x7dzmKdmGzieGRCM46jaSJTDAk=
|
||||
github.com/mattn/go-runewidth v0.0.12/go.mod h1:RAqKPSqVFrSLVXbA8x7dzmKdmGzieGRCM46jaSJTDAk=
|
||||
github.com/mattn/go-runewidth v0.0.13/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w=
|
||||
github.com/mattn/go-runewidth v0.0.14 h1:+xnbZSEeDbOIg5/mE6JF0w6n9duR1l3/WmbinWVwUuU=
|
||||
@ -2322,14 +2324,12 @@ github.com/muesli/mango-cobra v1.2.0 h1:DQvjzAM0PMZr85Iv9LIMaYISpTOliMEg+uMFtNbY
|
||||
github.com/muesli/mango-cobra v1.2.0/go.mod h1:vMJL54QytZAJhCT13LPVDfkvCUJ5/4jNUKF/8NC2UjA=
|
||||
github.com/muesli/mango-pflag v0.1.0 h1:UADqbYgpUyRoBja3g6LUL+3LErjpsOwaC9ywvBWe7Sg=
|
||||
github.com/muesli/mango-pflag v0.1.0/go.mod h1:YEQomTxaCUp8PrbhFh10UfbhbQrM/xJ4i2PB8VTLLW0=
|
||||
github.com/muesli/reflow v0.2.1-0.20210115123740-9e1d0d53df68/go.mod h1:Xk+z4oIWdQqJzsxyjgl3P22oYZnHdZ8FFTHAQQt5BMQ=
|
||||
github.com/muesli/reflow v0.3.0 h1:IFsN6K9NfGtjeggFP+68I4chLZV2yIKsXJFNZ+eWh6s=
|
||||
github.com/muesli/reflow v0.3.0/go.mod h1:pbwTDkVPibjO2kyvBQRBxTWEEGDGq0FlB1BIKtnHY/8=
|
||||
github.com/muesli/roff v0.1.0 h1:YD0lalCotmYuF5HhZliKWlIx7IEhiXeSfq7hNjFqGF8=
|
||||
github.com/muesli/roff v0.1.0/go.mod h1:pjAHQM9hdUUwm/krAfrLGgJkXJ+YuhtsfZ42kieB2Ig=
|
||||
github.com/muesli/termenv v0.11.1-0.20220204035834-5ac8409525e0/go.mod h1:Bd5NYQ7pd+SrtBSrSNoBBmXlcY8+Xj4BMJgh8qcZrvs=
|
||||
github.com/muesli/termenv v0.14.0 h1:8x9NFfOe8lmIWK4pgy3IfVEy47f+ppe3tUqdPZG2Uy0=
|
||||
github.com/muesli/termenv v0.14.0/go.mod h1:kG/pF1E7fh949Xhe156crRUrHNyK221IuGO7Ez60Uc8=
|
||||
github.com/muesli/termenv v0.15.1 h1:UzuTb/+hhlBugQz28rpzey4ZuKcZ03MeKsoG7IJZIxs=
|
||||
github.com/muesli/termenv v0.15.1/go.mod h1:HeAQPTzpfs016yGtA4g00CsdYnVLJvxsS4ANqrZs2sQ=
|
||||
github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ=
|
||||
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ=
|
||||
github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
|
||||
@ -2921,8 +2921,8 @@ github.com/withfig/autocomplete-tools/packages/cobra v0.0.0-20220122124547-31d38
|
||||
github.com/x448/float16 v0.8.4/go.mod h1:14CWIYCyZA/cWjXOioeEpHeN/83MdbZDRQHoFcYsOfg=
|
||||
github.com/xanzy/go-gitlab v0.31.0/go.mod h1:sPLojNBn68fMUWSxIJtdVVIP8uSBYqesTfDUseX11Ug=
|
||||
github.com/xanzy/go-gitlab v0.72.0/go.mod h1:d/a0vswScO7Agg1CZNz15Ic6SSvBG9vfw8egL99t4kA=
|
||||
github.com/xanzy/go-gitlab v0.80.2 h1:CH1Q7NDklqZllox4ICVF4PwlhQGfPtE+w08Jsb74ZX0=
|
||||
github.com/xanzy/go-gitlab v0.80.2/go.mod h1:DlByVTSXhPsJMYL6+cm8e8fTJjeBmhrXdC/yvkKKt6M=
|
||||
github.com/xanzy/go-gitlab v0.81.0 h1:ofbhZ5ZY9AjHATWQie4qd2JfncdUmvcSA/zfQB767Dk=
|
||||
github.com/xanzy/go-gitlab v0.81.0/go.mod h1:VMbY3JIWdZ/ckvHbQqkyd3iYk2aViKrNIQ23IbFMQDo=
|
||||
github.com/xanzy/ssh-agent v0.2.1/go.mod h1:mLlQY/MoOhWBj+gOGMQkOeiEvkx+8pJSI+0Bx9h2kr4=
|
||||
github.com/xanzy/ssh-agent v0.3.0/go.mod h1:3s9xbODqPuuhK9JV1R321M/FlMZSBvE5aY6eAcqrDh0=
|
||||
github.com/xanzy/ssh-agent v0.3.1 h1:AmzO1SSWxw73zxFZPRwaMN1MohDw8UyHnmuxyceTEGo=
|
||||
@ -3282,8 +3282,8 @@ golang.org/x/mod v0.6.0-dev.0.20220106191415-9b9b3d81d5e3/go.mod h1:3p9vT2HGsQu2
|
||||
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4=
|
||||
golang.org/x/mod v0.6.0/go.mod h1:4mET923SAdbXp2ki8ey+zGs1SLqsuM2Y0uvdZR/fUNI=
|
||||
golang.org/x/mod v0.7.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
|
||||
golang.org/x/mod v0.8.0 h1:LUYupSeNrTNCGzR/hVBk2NHZO4hXcVaW1k4Qx7rjPx8=
|
||||
golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
|
||||
golang.org/x/mod v0.9.0 h1:KENHtAZL2y3NLMYZeHY9DW8HW8V+kQyJsY/V9JlKvCs=
|
||||
golang.org/x/mod v0.9.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
|
||||
golang.org/x/net v0.0.0-20180530234432-1e491301e022/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||
golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||
golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||
@ -3818,8 +3818,8 @@ golang.org/x/tools v0.2.0/go.mod h1:y4OqIKeOV/fWJetJ8bXPU1sEVniLMIyDAZWeHdV+NTA=
|
||||
golang.org/x/tools v0.3.0/go.mod h1:/rWhSS2+zyEVwoJf8YAX6L2f0ntZ7Kn/mGgAWcipA5k=
|
||||
golang.org/x/tools v0.4.0/go.mod h1:UE5sM2OK9E/d67R0ANs2xJizIymRP5gJU295PvKXxjQ=
|
||||
golang.org/x/tools v0.5.0/go.mod h1:N+Kgy78s5I24c24dU8OfWNEotWjutIs8SnJvn5IDq+k=
|
||||
golang.org/x/tools v0.6.0 h1:BOw41kyTf3PuCW1pVQf8+Cyg8pMlkYB1oo9iJ6D/lKM=
|
||||
golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU=
|
||||
golang.org/x/tools v0.7.0 h1:W4OVu8VVOaIO0yzWMNdepAulS7YfoS3Zabrm8DOXXU4=
|
||||
golang.org/x/tools v0.7.0/go.mod h1:4pg6aUX35JBAogB10C9AtvVL+qowtN4pT3CGSQex14s=
|
||||
golang.org/x/xerrors v0.0.0-20190410155217-1f06c39b4373/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
golang.org/x/xerrors v0.0.0-20190513163551-3ee3066db522/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||
@ -4154,8 +4154,9 @@ google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp0
|
||||
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||
google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||
google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||
google.golang.org/protobuf v1.28.1 h1:d0NfwRgPtno5B1Wa6L2DAG+KivqkdutMf1UhdNx175w=
|
||||
google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||
google.golang.org/protobuf v1.29.1 h1:7QBf+IK2gx70Ap/hDsOmam3GE0v9HicjfEdAxE62UoM=
|
||||
google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||
gopkg.in/airbrake/gobrake.v2 v2.0.9/go.mod h1:/h5ZAUhDkGaJfjzjKLSjv6zCL6O0LLBxU4K+aSYdM/U=
|
||||
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
|
||||
gopkg.in/alexcesaro/quotedprintable.v3 v3.0.0-20150716171945-2caba252f4dc h1:2gGKlE2+asNV9m7xrywl36YYNnBG5ZQ0r/BOOxqPpmk=
|
||||
|
@ -68,12 +68,12 @@ func NewGitea(ctx *context.Context, token string) (Client, error) {
|
||||
return &giteaClient{client: client}, nil
|
||||
}
|
||||
|
||||
func (c *giteaClient) Changelog(ctx *context.Context, repo Repo, prev, current string) (string, error) {
|
||||
func (c *giteaClient) Changelog(_ *context.Context, _ Repo, _, _ string) (string, error) {
|
||||
return "", ErrNotImplemented
|
||||
}
|
||||
|
||||
// CloseMilestone closes a given milestone.
|
||||
func (c *giteaClient) CloseMilestone(ctx *context.Context, repo Repo, title string) error {
|
||||
func (c *giteaClient) CloseMilestone(_ *context.Context, repo Repo, title string) error {
|
||||
closedState := gitea.StateClosed
|
||||
opts := gitea.EditMilestoneOption{
|
||||
State: &closedState,
|
||||
@ -87,7 +87,7 @@ func (c *giteaClient) CloseMilestone(ctx *context.Context, repo Repo, title stri
|
||||
return err
|
||||
}
|
||||
|
||||
func (c *giteaClient) GetDefaultBranch(ctx *context.Context, repo Repo) (string, error) {
|
||||
func (c *giteaClient) GetDefaultBranch(_ *context.Context, repo Repo) (string, error) {
|
||||
projectID := repo.String()
|
||||
p, res, err := c.client.GetRepo(repo.Owner, repo.Name)
|
||||
if err != nil {
|
||||
|
@ -58,7 +58,7 @@ func NewGitLab(ctx *context.Context, token string) (Client, error) {
|
||||
return &gitlabClient{client: client}, nil
|
||||
}
|
||||
|
||||
func (c *gitlabClient) Changelog(ctx *context.Context, repo Repo, prev, current string) (string, error) {
|
||||
func (c *gitlabClient) Changelog(_ *context.Context, repo Repo, prev, current string) (string, error) {
|
||||
cmpOpts := &gitlab.CompareOptions{
|
||||
From: &prev,
|
||||
To: ¤t,
|
||||
@ -82,7 +82,7 @@ func (c *gitlabClient) Changelog(ctx *context.Context, repo Repo, prev, current
|
||||
}
|
||||
|
||||
// GetDefaultBranch get the default branch
|
||||
func (c *gitlabClient) GetDefaultBranch(ctx *context.Context, repo Repo) (string, error) {
|
||||
func (c *gitlabClient) GetDefaultBranch(_ *context.Context, repo Repo) (string, error) {
|
||||
projectID := repo.String()
|
||||
p, res, err := c.client.Projects.GetProject(projectID, nil)
|
||||
if err != nil {
|
||||
@ -97,7 +97,7 @@ func (c *gitlabClient) GetDefaultBranch(ctx *context.Context, repo Repo) (string
|
||||
}
|
||||
|
||||
// CloseMilestone closes a given milestone.
|
||||
func (c *gitlabClient) CloseMilestone(ctx *context.Context, repo Repo, title string) error {
|
||||
func (c *gitlabClient) CloseMilestone(_ *context.Context, repo Repo, title string) error {
|
||||
milestone, err := c.getMilestoneByTitle(repo, title)
|
||||
if err != nil {
|
||||
return err
|
||||
|
@ -319,7 +319,7 @@ func TestGitLabCreateReleaseReleaseNotExists(t *testing.T) {
|
||||
_, err = client.CreateRelease(ctx, "body")
|
||||
require.NoError(t, err)
|
||||
require.True(t, createdRelease)
|
||||
require.Equal(t, 3, totalRequests)
|
||||
require.Equal(t, 2, totalRequests)
|
||||
})
|
||||
}
|
||||
}
|
||||
@ -375,7 +375,7 @@ func TestGitLabCreateReleaseReleaseExists(t *testing.T) {
|
||||
_, err = client.CreateRelease(ctx, "body")
|
||||
require.NoError(t, err)
|
||||
require.True(t, createdRelease)
|
||||
require.Equal(t, 3, totalRequests)
|
||||
require.Equal(t, 2, totalRequests)
|
||||
}
|
||||
|
||||
func TestGitLabCreateReleaseUnkownHTTPError(t *testing.T) {
|
||||
@ -399,7 +399,7 @@ func TestGitLabCreateReleaseUnkownHTTPError(t *testing.T) {
|
||||
|
||||
_, err = client.CreateRelease(ctx, "body")
|
||||
require.Error(t, err)
|
||||
require.Equal(t, 2, totalRequests)
|
||||
require.Equal(t, 1, totalRequests)
|
||||
}
|
||||
|
||||
func TestGitlabGetDefaultBranch(t *testing.T) {
|
||||
@ -429,7 +429,7 @@ func TestGitlabGetDefaultBranch(t *testing.T) {
|
||||
|
||||
_, err = client.GetDefaultBranch(ctx, repo)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, 2, totalRequests)
|
||||
require.Equal(t, 1, totalRequests)
|
||||
}
|
||||
|
||||
func TestGitlabGetDefaultBranchErr(t *testing.T) {
|
||||
|
@ -40,14 +40,14 @@ type Mock struct {
|
||||
ReleaseNotesParams []string
|
||||
}
|
||||
|
||||
func (c *Mock) Changelog(ctx *context.Context, repo Repo, prev, current string) (string, error) {
|
||||
func (c *Mock) Changelog(_ *context.Context, _ Repo, _, _ string) (string, error) {
|
||||
if c.Changes != "" {
|
||||
return c.Changes, nil
|
||||
}
|
||||
return "", ErrNotImplemented
|
||||
}
|
||||
|
||||
func (c *Mock) GenerateReleaseNotes(ctx *context.Context, repo Repo, prev, current string) (string, error) {
|
||||
func (c *Mock) GenerateReleaseNotes(_ *context.Context, _ Repo, prev, current string) (string, error) {
|
||||
if c.ReleaseNotes != "" {
|
||||
c.ReleaseNotesParams = []string{prev, current}
|
||||
return c.ReleaseNotes, nil
|
||||
@ -55,7 +55,7 @@ func (c *Mock) GenerateReleaseNotes(ctx *context.Context, repo Repo, prev, curre
|
||||
return "", ErrNotImplemented
|
||||
}
|
||||
|
||||
func (c *Mock) CloseMilestone(ctx *context.Context, repo Repo, title string) error {
|
||||
func (c *Mock) CloseMilestone(_ *context.Context, _ Repo, title string) error {
|
||||
if c.FailToCloseMilestone {
|
||||
return errors.New("milestone failed")
|
||||
}
|
||||
@ -65,11 +65,11 @@ func (c *Mock) CloseMilestone(ctx *context.Context, repo Repo, title string) err
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *Mock) GetDefaultBranch(ctx *context.Context, repo Repo) (string, error) {
|
||||
func (c *Mock) GetDefaultBranch(_ *context.Context, _ Repo) (string, error) {
|
||||
return "", ErrNotImplemented
|
||||
}
|
||||
|
||||
func (c *Mock) CreateRelease(ctx *context.Context, body string) (string, error) {
|
||||
func (c *Mock) CreateRelease(_ *context.Context, _ string) (string, error) {
|
||||
if c.FailToCreateRelease {
|
||||
return "", errors.New("release failed")
|
||||
}
|
||||
@ -77,18 +77,18 @@ func (c *Mock) CreateRelease(ctx *context.Context, body string) (string, error)
|
||||
return "", nil
|
||||
}
|
||||
|
||||
func (c *Mock) ReleaseURLTemplate(ctx *context.Context) (string, error) {
|
||||
func (c *Mock) ReleaseURLTemplate(_ *context.Context) (string, error) {
|
||||
return "https://dummyhost/download/{{ .Tag }}/{{ .ArtifactName }}", nil
|
||||
}
|
||||
|
||||
func (c *Mock) CreateFile(ctx *context.Context, commitAuthor config.CommitAuthor, repo Repo, content []byte, path, msg string) error {
|
||||
func (c *Mock) CreateFile(_ *context.Context, _ config.CommitAuthor, _ Repo, content []byte, path, _ string) error {
|
||||
c.CreatedFile = true
|
||||
c.Content = string(content)
|
||||
c.Path = path
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *Mock) Upload(ctx *context.Context, releaseID string, artifact *artifact.Artifact, file *os.File) error {
|
||||
func (c *Mock) Upload(_ *context.Context, _ string, artifact *artifact.Artifact, file *os.File) error {
|
||||
c.Lock.Lock()
|
||||
defer c.Lock.Unlock()
|
||||
if c.UploadedFilePaths == nil {
|
||||
|
@ -1,3 +1,3 @@
|
||||
[1;m •[0m first
|
||||
[1;m •[0m [1;mDEPRECATED: `foo.bar.whatever: foobar` should not be used anymore, check https://goreleaser.com/deprecations#foobarwhatever-foobar for more info[0m
|
||||
[1;m •[0m last
|
||||
• first
|
||||
• DEPRECATED: `foo.bar.whatever: foobar` should not be used anymore, check https://goreleaser.com/deprecations#foobarwhatever-foobar for more info
|
||||
• last
|
||||
|
@ -1,3 +1,3 @@
|
||||
[1;m •[0m first
|
||||
[1;m •[0m [1;mDEPRECATED: some custom template with a url https://goreleaser.com/deprecations#something-else[0m
|
||||
[1;m •[0m last
|
||||
• first
|
||||
• DEPRECATED: some custom template with a url https://goreleaser.com/deprecations#something-else
|
||||
• last
|
||||
|
@ -63,13 +63,13 @@ func copyFile(src, dst string, mode os.FileMode) error {
|
||||
}
|
||||
defer original.Close()
|
||||
|
||||
new, err := os.OpenFile(dst, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, mode)
|
||||
f, err := os.OpenFile(dst, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, mode)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to open '%s': %w", dst, err)
|
||||
}
|
||||
defer new.Close()
|
||||
defer f.Close()
|
||||
|
||||
if _, err := io.Copy(new, original); err != nil {
|
||||
if _, err := io.Copy(f, original); err != nil {
|
||||
return fmt.Errorf("failed to copy: %w", err)
|
||||
}
|
||||
return nil
|
||||
|
@ -122,10 +122,7 @@ func (Pipe) Run(ctx *context.Context) error {
|
||||
continue
|
||||
}
|
||||
g.Go(func() error {
|
||||
if err := create(ctx, archive, artifacts); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
return create(ctx, archive, artifacts)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -34,7 +34,7 @@ func (f *fakeBuilder) WithDefaults(build config.Build) (config.Build, error) {
|
||||
return build, nil
|
||||
}
|
||||
|
||||
func (f *fakeBuilder) Build(ctx *context.Context, build config.Build, options api.Options) error {
|
||||
func (f *fakeBuilder) Build(ctx *context.Context, _ config.Build, options api.Options) error {
|
||||
if f.fail {
|
||||
return errFailedBuild
|
||||
}
|
||||
@ -90,8 +90,7 @@ func TestBuild(t *testing.T) {
|
||||
)
|
||||
opts, err := buildOptionsForTarget(ctx, ctx.Config.Builds[0], "darwin_amd64")
|
||||
require.NoError(t, err)
|
||||
error := doBuild(ctx, ctx.Config.Builds[0], *opts)
|
||||
require.NoError(t, error)
|
||||
require.NoError(t, doBuild(ctx, ctx.Config.Builds[0], *opts))
|
||||
}
|
||||
|
||||
func TestRunPipe(t *testing.T) {
|
||||
|
@ -30,9 +30,9 @@ var cmd cmder = stdCmd{}
|
||||
// Pipe for chocolatey packaging.
|
||||
type Pipe struct{}
|
||||
|
||||
func (Pipe) String() string { return "chocolatey packages" }
|
||||
func (Pipe) Skip(ctx *context.Context) bool { return len(ctx.Config.Chocolateys) == 0 }
|
||||
func (Pipe) Dependencies(ctx *context.Context) []string { return []string{"choco"} }
|
||||
func (Pipe) String() string { return "chocolatey packages" }
|
||||
func (Pipe) Skip(ctx *context.Context) bool { return len(ctx.Config.Chocolateys) == 0 }
|
||||
func (Pipe) Dependencies(_ *context.Context) []string { return []string{"choco"} }
|
||||
|
||||
// Default sets the pipe defaults.
|
||||
func (Pipe) Default(ctx *context.Context) error {
|
||||
|
@ -311,6 +311,6 @@ type fakeCmd struct {
|
||||
|
||||
var _ cmder = fakeCmd{}
|
||||
|
||||
func (f fakeCmd) Exec(ctx *context.Context, name string, args ...string) ([]byte, error) {
|
||||
func (f fakeCmd) Exec(_ *context.Context, _ string, _ ...string) ([]byte, error) {
|
||||
return f.execFn()
|
||||
}
|
||||
|
@ -51,7 +51,7 @@ type dockerImager struct {
|
||||
|
||||
var dockerDigestPattern = regexp.MustCompile("sha256:[a-z0-9]{64}")
|
||||
|
||||
func (i dockerImager) Push(ctx *context.Context, image string, flags []string) (string, error) {
|
||||
func (i dockerImager) Push(ctx *context.Context, image string, _ []string) (string, error) {
|
||||
bts, err := runCommandWithOutput(ctx, ".", "docker", "push", image)
|
||||
if err != nil {
|
||||
return "", fmt.Errorf("failed to push %s: %w", image, err)
|
||||
|
@ -288,14 +288,23 @@ func getPreviousTag(ctx *context.Context, current string) (string, error) {
|
||||
}
|
||||
|
||||
func gitTagsPointingAt(ctx *context.Context, ref string) ([]string, error) {
|
||||
return git.CleanAllLines(git.Run(
|
||||
ctx,
|
||||
args := []string{}
|
||||
if ctx.Config.Git.PrereleaseSuffix != "" {
|
||||
args = append(
|
||||
args,
|
||||
"-c",
|
||||
"versionsort.suffix="+ctx.Config.Git.PrereleaseSuffix,
|
||||
)
|
||||
}
|
||||
args = append(
|
||||
args,
|
||||
"tag",
|
||||
"--points-at",
|
||||
ref,
|
||||
"--sort",
|
||||
ctx.Config.Git.TagSort,
|
||||
))
|
||||
)
|
||||
return git.CleanAllLines(git.Run(ctx, args...))
|
||||
}
|
||||
|
||||
func gitDescribe(ctx *context.Context, ref string) (string, error) {
|
||||
|
@ -170,6 +170,24 @@ func TestShallowClone(t *testing.T) {
|
||||
}
|
||||
|
||||
func TestTagSortOrder(t *testing.T) {
|
||||
testlib.Mktmp(t)
|
||||
testlib.GitInit(t)
|
||||
testlib.GitRemoteAdd(t, "git@github.com:foo/bar.git")
|
||||
testlib.GitCommit(t, "commit1")
|
||||
testlib.GitCommit(t, "commit2")
|
||||
testlib.GitCommit(t, "commit3")
|
||||
testlib.GitTag(t, "v0.0.2")
|
||||
testlib.GitTag(t, "v0.0.1")
|
||||
ctx := testctx.NewWithCfg(config.Project{
|
||||
Git: config.Git{
|
||||
TagSort: "-version:refname",
|
||||
},
|
||||
})
|
||||
require.NoError(t, Pipe{}.Run(ctx))
|
||||
require.Equal(t, "v0.0.2", ctx.Git.CurrentTag)
|
||||
}
|
||||
|
||||
func TestTagSortOrderPrerelease(t *testing.T) {
|
||||
testlib.Mktmp(t)
|
||||
testlib.GitInit(t)
|
||||
testlib.GitRemoteAdd(t, "git@github.com:foo/bar.git")
|
||||
@ -180,7 +198,8 @@ func TestTagSortOrder(t *testing.T) {
|
||||
testlib.GitTag(t, "v0.0.1")
|
||||
ctx := testctx.NewWithCfg(config.Project{
|
||||
Git: config.Git{
|
||||
TagSort: "-version:creatordate",
|
||||
TagSort: "-version:refname",
|
||||
PrereleaseSuffix: "-",
|
||||
},
|
||||
})
|
||||
require.NoError(t, Pipe{}.Run(ctx))
|
||||
|
@ -8,13 +8,16 @@ import (
|
||||
"fmt"
|
||||
"io"
|
||||
"path/filepath"
|
||||
"strconv"
|
||||
"sync"
|
||||
"time"
|
||||
|
||||
"github.com/awslabs/amazon-ecr-credential-helper/ecr-login"
|
||||
"github.com/chrismellard/docker-credential-acr-env/pkg/credhelper"
|
||||
"github.com/google/go-containerregistry/pkg/authn"
|
||||
"github.com/google/go-containerregistry/pkg/authn/github"
|
||||
"github.com/google/go-containerregistry/pkg/name"
|
||||
v1 "github.com/google/go-containerregistry/pkg/v1"
|
||||
"github.com/google/go-containerregistry/pkg/v1/google"
|
||||
"github.com/google/go-containerregistry/pkg/v1/remote"
|
||||
"github.com/google/ko/pkg/build"
|
||||
@ -138,7 +141,10 @@ type buildOptions struct {
|
||||
workingDir string
|
||||
platforms []string
|
||||
baseImage string
|
||||
labels map[string]string
|
||||
tags []string
|
||||
creationTime *v1.Time
|
||||
koDataCreationTime *v1.Time
|
||||
sbom string
|
||||
ldflags []string
|
||||
bare bool
|
||||
@ -187,6 +193,15 @@ func (o *buildOptions) makeBuilder(ctx *context.Context) (*build.Caching, error)
|
||||
return nil, nil, fmt.Errorf("unexpected base image media type: %s", desc.MediaType)
|
||||
}),
|
||||
}
|
||||
if o.creationTime != nil {
|
||||
buildOptions = append(buildOptions, build.WithCreationTime(*o.creationTime))
|
||||
}
|
||||
if o.koDataCreationTime != nil {
|
||||
buildOptions = append(buildOptions, build.WithKoDataCreationTime(*o.koDataCreationTime))
|
||||
}
|
||||
for k, v := range o.labels {
|
||||
buildOptions = append(buildOptions, build.WithLabel(k, v))
|
||||
}
|
||||
switch o.sbom {
|
||||
case "spdx":
|
||||
buildOptions = append(buildOptions, build.WithSPDX("devel"))
|
||||
@ -195,7 +210,7 @@ func (o *buildOptions) makeBuilder(ctx *context.Context) (*build.Caching, error)
|
||||
case "go.version-m":
|
||||
buildOptions = append(buildOptions, build.WithGoVersionSBOM())
|
||||
case "none":
|
||||
// don't do anything.
|
||||
buildOptions = append(buildOptions, build.WithDisabledSBOM())
|
||||
default:
|
||||
return nil, fmt.Errorf("unknown sbom type: %q", o.sbom)
|
||||
}
|
||||
@ -299,6 +314,33 @@ func buildBuildOptions(ctx *context.Context, cfg config.Ko) (*buildOptions, erro
|
||||
}
|
||||
opts.tags = tags
|
||||
|
||||
if cfg.CreationTime != "" {
|
||||
creationTime, err := getTimeFromTemplate(ctx, cfg.CreationTime)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
opts.creationTime = creationTime
|
||||
}
|
||||
|
||||
if cfg.KoDataCreationTime != "" {
|
||||
koDataCreationTime, err := getTimeFromTemplate(ctx, cfg.KoDataCreationTime)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
opts.koDataCreationTime = koDataCreationTime
|
||||
}
|
||||
|
||||
if len(cfg.Labels) > 0 {
|
||||
opts.labels = make(map[string]string, len(cfg.Labels))
|
||||
for k, v := range cfg.Labels {
|
||||
tv, err := tmpl.New(ctx).Apply(v)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
opts.labels[k] = tv
|
||||
}
|
||||
}
|
||||
|
||||
if len(cfg.Env) > 0 {
|
||||
env, err := applyTemplate(ctx, cfg.Env)
|
||||
if err != nil {
|
||||
@ -336,3 +378,16 @@ func applyTemplate(ctx *context.Context, templateable []string) ([]string, error
|
||||
}
|
||||
return templated, nil
|
||||
}
|
||||
|
||||
func getTimeFromTemplate(ctx *context.Context, t string) (*v1.Time, error) {
|
||||
epoch, err := tmpl.New(ctx).Apply(t)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
seconds, err := strconv.ParseInt(epoch, 10, 64)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &v1.Time{Time: time.Unix(seconds, 0)}, nil
|
||||
}
|
||||
|
@ -2,10 +2,15 @@ package ko
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"strconv"
|
||||
"strings"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
_ "github.com/distribution/distribution/v3/registry/auth/htpasswd"
|
||||
_ "github.com/distribution/distribution/v3/registry/storage/driver/inmemory"
|
||||
"github.com/google/go-containerregistry/pkg/name"
|
||||
"github.com/google/go-containerregistry/pkg/v1/remote"
|
||||
"github.com/goreleaser/goreleaser/internal/testctx"
|
||||
"github.com/goreleaser/goreleaser/internal/testlib"
|
||||
"github.com/goreleaser/goreleaser/pkg/config"
|
||||
@ -120,19 +125,24 @@ func TestPublishPipeSuccess(t *testing.T) {
|
||||
testlib.StartRegistry(t, "ko_registry", registryPort)
|
||||
|
||||
table := []struct {
|
||||
Name string
|
||||
SBOM string
|
||||
BaseImage string
|
||||
Platforms []string
|
||||
Name string
|
||||
SBOM string
|
||||
BaseImage string
|
||||
Labels map[string]string
|
||||
ExpectedLabels map[string]string
|
||||
Platforms []string
|
||||
CreationTime string
|
||||
KoDataCreationTime string
|
||||
}{
|
||||
{
|
||||
// Must be first as others add an SBOM for the same image
|
||||
Name: "sbom-none",
|
||||
SBOM: "none",
|
||||
},
|
||||
{
|
||||
Name: "sbom-spdx",
|
||||
SBOM: "spdx",
|
||||
},
|
||||
{
|
||||
Name: "sbom-none",
|
||||
SBOM: "none",
|
||||
},
|
||||
{
|
||||
Name: "sbom-cyclonedx",
|
||||
SBOM: "cyclonedx",
|
||||
@ -149,11 +159,27 @@ func TestPublishPipeSuccess(t *testing.T) {
|
||||
Name: "multiple-platforms",
|
||||
Platforms: []string{"linux/amd64", "linux/arm64"},
|
||||
},
|
||||
{
|
||||
Name: "labels",
|
||||
Labels: map[string]string{"foo": "bar", "project": "{{.ProjectName}}"},
|
||||
ExpectedLabels: map[string]string{"foo": "bar", "project": "test"},
|
||||
},
|
||||
{
|
||||
Name: "creation-time",
|
||||
CreationTime: "1672531200",
|
||||
},
|
||||
{
|
||||
Name: "kodata-creation-time",
|
||||
KoDataCreationTime: "1672531200",
|
||||
},
|
||||
}
|
||||
|
||||
repository := fmt.Sprintf("%sgoreleasertest/testapp", registry)
|
||||
|
||||
for _, table := range table {
|
||||
t.Run(table.Name, func(t *testing.T) {
|
||||
ctx := testctx.NewWithCfg(config.Project{
|
||||
ProjectName: "test",
|
||||
Builds: []config.Build{
|
||||
{
|
||||
ID: "foo",
|
||||
@ -166,20 +192,110 @@ func TestPublishPipeSuccess(t *testing.T) {
|
||||
},
|
||||
Kos: []config.Ko{
|
||||
{
|
||||
ID: "default",
|
||||
Build: "foo",
|
||||
WorkingDir: "./testdata/app/",
|
||||
BaseImage: table.BaseImage,
|
||||
Repository: fmt.Sprintf("%s/goreleasertest", registry),
|
||||
Platforms: table.Platforms,
|
||||
Tags: []string{table.Name},
|
||||
SBOM: table.SBOM,
|
||||
ID: "default",
|
||||
Build: "foo",
|
||||
WorkingDir: "./testdata/app/",
|
||||
BaseImage: table.BaseImage,
|
||||
Repository: repository,
|
||||
Labels: table.Labels,
|
||||
Platforms: table.Platforms,
|
||||
Tags: []string{table.Name},
|
||||
CreationTime: table.CreationTime,
|
||||
KoDataCreationTime: table.KoDataCreationTime,
|
||||
SBOM: table.SBOM,
|
||||
Bare: true,
|
||||
},
|
||||
},
|
||||
})
|
||||
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
require.NoError(t, Pipe{}.Publish(ctx))
|
||||
|
||||
ref, err := name.ParseReference(
|
||||
fmt.Sprintf("%s:%s", repository, table.Name),
|
||||
name.Insecure,
|
||||
)
|
||||
require.NoError(t, err)
|
||||
|
||||
index, err := remote.Index(ref)
|
||||
if len(table.Platforms) > 1 {
|
||||
require.NoError(t, err)
|
||||
imf, err := index.IndexManifest()
|
||||
require.NoError(t, err)
|
||||
|
||||
platforms := make([]string, 0, len(imf.Manifests))
|
||||
for _, mf := range imf.Manifests {
|
||||
platforms = append(platforms, mf.Platform.String())
|
||||
}
|
||||
require.ElementsMatch(t, table.Platforms, platforms)
|
||||
} else {
|
||||
require.Error(t, err)
|
||||
}
|
||||
|
||||
image, err := remote.Image(ref)
|
||||
require.NoError(t, err)
|
||||
|
||||
digest, err := image.Digest()
|
||||
require.NoError(t, err)
|
||||
|
||||
sbomRef, err := name.ParseReference(
|
||||
fmt.Sprintf(
|
||||
"%s:%s.sbom",
|
||||
repository,
|
||||
strings.Replace(digest.String(), ":", "-", 1),
|
||||
),
|
||||
name.Insecure,
|
||||
)
|
||||
require.NoError(t, err)
|
||||
|
||||
sbom, err := remote.Image(sbomRef)
|
||||
if table.SBOM == "none" {
|
||||
require.Error(t, err)
|
||||
} else {
|
||||
require.NoError(t, err)
|
||||
|
||||
layers, err := sbom.Layers()
|
||||
require.NoError(t, err)
|
||||
require.NotEmpty(t, layers)
|
||||
|
||||
mediaType, err := layers[0].MediaType()
|
||||
require.NoError(t, err)
|
||||
|
||||
switch table.SBOM {
|
||||
case "spdx", "":
|
||||
require.Equal(t, "spdx+json", string(mediaType))
|
||||
case "cyclonedx":
|
||||
require.Equal(t, "application/vnd.cyclonedx+json", string(mediaType))
|
||||
case "go.version-m":
|
||||
require.Equal(t, "application/vnd.go.version-m", string(mediaType))
|
||||
default:
|
||||
require.Fail(t, "unknown SBOM type", table.SBOM)
|
||||
}
|
||||
}
|
||||
|
||||
configFile, err := image.ConfigFile()
|
||||
require.NoError(t, err)
|
||||
require.GreaterOrEqual(t, len(configFile.History), 3)
|
||||
|
||||
require.Equal(t, table.ExpectedLabels, configFile.Config.Labels)
|
||||
|
||||
var creationTime time.Time
|
||||
if table.CreationTime != "" {
|
||||
ct, err := strconv.ParseInt(table.CreationTime, 10, 64)
|
||||
require.NoError(t, err)
|
||||
creationTime = time.Unix(ct, 0).UTC()
|
||||
|
||||
require.Equal(t, creationTime, configFile.Created.Time)
|
||||
}
|
||||
require.Equal(t, creationTime, configFile.History[len(configFile.History)-1].Created.Time)
|
||||
|
||||
var koDataCreationTime time.Time
|
||||
if table.KoDataCreationTime != "" {
|
||||
kdct, err := strconv.ParseInt(table.KoDataCreationTime, 10, 64)
|
||||
require.NoError(t, err)
|
||||
koDataCreationTime = time.Unix(kdct, 0).UTC()
|
||||
}
|
||||
require.Equal(t, koDataCreationTime, configFile.History[len(configFile.History)-2].Created.Time)
|
||||
})
|
||||
}
|
||||
}
|
||||
@ -212,6 +328,13 @@ func TestPublishPipeError(t *testing.T) {
|
||||
require.EqualError(t, Pipe{}.Publish(ctx), `build: could not parse reference: not a valid image hopefully`)
|
||||
})
|
||||
|
||||
t.Run("invalid label tmpl", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].Labels = map[string]string{"nope": "{{.Nope}}"}
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
testlib.RequireTemplateError(t, Pipe{}.Publish(ctx))
|
||||
})
|
||||
|
||||
t.Run("invalid sbom", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].SBOM = "nope"
|
||||
@ -233,6 +356,38 @@ func TestPublishPipeError(t *testing.T) {
|
||||
testlib.RequireTemplateError(t, Pipe{}.Publish(ctx))
|
||||
})
|
||||
|
||||
t.Run("invalid creation time", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].CreationTime = "nope"
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
err := Pipe{}.Publish(ctx)
|
||||
require.Error(t, err)
|
||||
require.Contains(t, err.Error(), `strconv.ParseInt: parsing "nope": invalid syntax`)
|
||||
})
|
||||
|
||||
t.Run("invalid creation time tmpl", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].CreationTime = "{{.Nope}}"
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
testlib.RequireTemplateError(t, Pipe{}.Publish(ctx))
|
||||
})
|
||||
|
||||
t.Run("invalid kodata creation time", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].KoDataCreationTime = "nope"
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
err := Pipe{}.Publish(ctx)
|
||||
require.Error(t, err)
|
||||
require.Contains(t, err.Error(), `strconv.ParseInt: parsing "nope": invalid syntax`)
|
||||
})
|
||||
|
||||
t.Run("invalid kodata creation time tmpl", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Kos[0].KoDataCreationTime = "{{.Nope}}"
|
||||
require.NoError(t, Pipe{}.Default(ctx))
|
||||
testlib.RequireTemplateError(t, Pipe{}.Publish(ctx))
|
||||
})
|
||||
|
||||
t.Run("invalid env tmpl", func(t *testing.T) {
|
||||
ctx := makeCtx()
|
||||
ctx.Config.Builds[0].Env = []string{"{{.Nope}}"}
|
||||
|
@ -15,8 +15,8 @@ import (
|
||||
// Pipe implementation.
|
||||
type Pipe struct{}
|
||||
|
||||
func (Pipe) String() string { return "storing release metadata" }
|
||||
func (Pipe) Skip(ctx *context.Context) bool { return false }
|
||||
func (Pipe) String() string { return "storing release metadata" }
|
||||
func (Pipe) Skip(_ *context.Context) bool { return false }
|
||||
|
||||
// Run the pipe.
|
||||
func (Pipe) Run(ctx *context.Context) error {
|
||||
|
@ -195,6 +195,7 @@ type Manifest struct {
|
||||
PreInstall []string `json:"pre_install,omitempty"` // An array of strings, of the commands to be executed before an application is installed.
|
||||
PostInstall []string `json:"post_install,omitempty"` // An array of strings, of the commands to be executed after an application is installed.
|
||||
Depends []string `json:"depends,omitempty"` // A string or an array of strings.
|
||||
Shortcuts [][]string `json:"shortcuts,omitempty"` // A two-dimensional array of string, specifies the shortcut values to make available in the startmenu.
|
||||
}
|
||||
|
||||
// Resource represents a combination of a url and a binary name for an architecture.
|
||||
@ -225,6 +226,7 @@ func dataFor(ctx *context.Context, cl client.Client, artifacts []*artifact.Artif
|
||||
PreInstall: ctx.Config.Scoop.PreInstall,
|
||||
PostInstall: ctx.Config.Scoop.PostInstall,
|
||||
Depends: ctx.Config.Scoop.Depends,
|
||||
Shortcuts: ctx.Config.Scoop.Shortcuts,
|
||||
}
|
||||
|
||||
if ctx.Config.Scoop.URLTemplate == "" {
|
||||
|
@ -99,9 +99,9 @@ const defaultNameTemplate = `{{ .ProjectName }}_{{ .Version }}_{{ .Os }}_{{ .Arc
|
||||
// Pipe for snapcraft packaging.
|
||||
type Pipe struct{}
|
||||
|
||||
func (Pipe) String() string { return "snapcraft packages" }
|
||||
func (Pipe) Skip(ctx *context.Context) bool { return len(ctx.Config.Snapcrafts) == 0 }
|
||||
func (Pipe) Dependencies(ctx *context.Context) []string { return []string{"snapcraft"} }
|
||||
func (Pipe) String() string { return "snapcraft packages" }
|
||||
func (Pipe) Skip(ctx *context.Context) bool { return len(ctx.Config.Snapcrafts) == 0 }
|
||||
func (Pipe) Dependencies(_ *context.Context) []string { return []string{"snapcraft"} }
|
||||
|
||||
// Default sets the pipe defaults.
|
||||
func (Pipe) Default(ctx *context.Context) error {
|
||||
|
@ -52,6 +52,7 @@ const (
|
||||
isSnapshot = "IsSnapshot"
|
||||
env = "Env"
|
||||
date = "Date"
|
||||
now = "Now"
|
||||
timestamp = "Timestamp"
|
||||
modulePath = "ModulePath"
|
||||
releaseNotes = "ReleaseNotes"
|
||||
@ -80,37 +81,43 @@ func New(ctx *context.Context) *Template {
|
||||
sv := ctx.Semver
|
||||
rawVersionV := fmt.Sprintf("%d.%d.%d", sv.Major, sv.Minor, sv.Patch)
|
||||
|
||||
fields := map[string]interface{}{}
|
||||
for k, v := range map[string]interface{}{
|
||||
projectName: ctx.Config.ProjectName,
|
||||
modulePath: ctx.ModulePath,
|
||||
version: ctx.Version,
|
||||
rawVersion: rawVersionV,
|
||||
summary: ctx.Git.Summary,
|
||||
tag: ctx.Git.CurrentTag,
|
||||
previousTag: ctx.Git.PreviousTag,
|
||||
branch: ctx.Git.Branch,
|
||||
commit: ctx.Git.Commit,
|
||||
shortCommit: ctx.Git.ShortCommit,
|
||||
fullCommit: ctx.Git.FullCommit,
|
||||
commitDate: ctx.Git.CommitDate.UTC().Format(time.RFC3339),
|
||||
commitTimestamp: ctx.Git.CommitDate.UTC().Unix(),
|
||||
gitURL: ctx.Git.URL,
|
||||
env: ctx.Env,
|
||||
date: ctx.Date.UTC().Format(time.RFC3339),
|
||||
timestamp: ctx.Date.UTC().Unix(),
|
||||
now: ctx.Date.UTC(),
|
||||
major: ctx.Semver.Major,
|
||||
minor: ctx.Semver.Minor,
|
||||
patch: ctx.Semver.Patch,
|
||||
prerelease: ctx.Semver.Prerelease,
|
||||
isSnapshot: ctx.Snapshot,
|
||||
releaseNotes: ctx.ReleaseNotes,
|
||||
releaseURL: ctx.ReleaseURL,
|
||||
tagSubject: ctx.Git.TagSubject,
|
||||
tagContents: ctx.Git.TagContents,
|
||||
tagBody: ctx.Git.TagBody,
|
||||
runtimeK: ctx.Runtime,
|
||||
} {
|
||||
fields[k] = v
|
||||
}
|
||||
|
||||
return &Template{
|
||||
fields: Fields{
|
||||
projectName: ctx.Config.ProjectName,
|
||||
modulePath: ctx.ModulePath,
|
||||
version: ctx.Version,
|
||||
rawVersion: rawVersionV,
|
||||
tag: ctx.Git.CurrentTag,
|
||||
previousTag: ctx.Git.PreviousTag,
|
||||
branch: ctx.Git.Branch,
|
||||
commit: ctx.Git.Commit,
|
||||
shortCommit: ctx.Git.ShortCommit,
|
||||
fullCommit: ctx.Git.FullCommit,
|
||||
commitDate: ctx.Git.CommitDate.UTC().Format(time.RFC3339),
|
||||
commitTimestamp: ctx.Git.CommitDate.UTC().Unix(),
|
||||
gitURL: ctx.Git.URL,
|
||||
summary: ctx.Git.Summary,
|
||||
tagSubject: ctx.Git.TagSubject,
|
||||
tagContents: ctx.Git.TagContents,
|
||||
tagBody: ctx.Git.TagBody,
|
||||
releaseURL: ctx.ReleaseURL,
|
||||
env: ctx.Env,
|
||||
date: ctx.Date.UTC().Format(time.RFC3339),
|
||||
timestamp: ctx.Date.UTC().Unix(),
|
||||
major: ctx.Semver.Major,
|
||||
minor: ctx.Semver.Minor,
|
||||
patch: ctx.Semver.Patch,
|
||||
prerelease: ctx.Semver.Prerelease,
|
||||
isSnapshot: ctx.Snapshot,
|
||||
releaseNotes: ctx.ReleaseNotes,
|
||||
runtimeK: ctx.Runtime,
|
||||
},
|
||||
fields: fields,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -6,6 +6,7 @@ import (
|
||||
"runtime"
|
||||
"testing"
|
||||
"text/template"
|
||||
"time"
|
||||
|
||||
"github.com/goreleaser/goreleaser/internal/artifact"
|
||||
"github.com/goreleaser/goreleaser/internal/testctx"
|
||||
@ -38,6 +39,7 @@ func TestWithArtifact(t *testing.T) {
|
||||
func(ctx *context.Context) {
|
||||
ctx.ModulePath = "github.com/goreleaser/goreleaser"
|
||||
ctx.ReleaseNotes = "test release notes"
|
||||
ctx.Date = time.Unix(1678327562, 0)
|
||||
},
|
||||
)
|
||||
for expect, tmpl := range map[string]string{
|
||||
@ -75,6 +77,9 @@ func TestWithArtifact(t *testing.T) {
|
||||
"artifact path: /tmp/foo.exe": "artifact path: {{ .ArtifactPath }}",
|
||||
"artifact basename: foo.exe": "artifact basename: {{ base .ArtifactPath }}",
|
||||
"artifact dir: /tmp": "artifact dir: {{ dir .ArtifactPath }}",
|
||||
"2023": `{{ .Now.Format "2006" }}`,
|
||||
"2023-03-09T02:06:02Z": `{{ .Date }}`,
|
||||
"1678327562": `{{ .Timestamp }}`,
|
||||
|
||||
"remove this": "{{ filter .Env.MULTILINE \".*remove.*\" }}",
|
||||
"something with\nmultiple lines\nto test things": "{{ reverseFilter .Env.MULTILINE \".*remove.*\" }}",
|
||||
|
@ -14,7 +14,7 @@ func (*dummy) WithDefaults(build config.Build) (config.Build, error) {
|
||||
return build, nil
|
||||
}
|
||||
|
||||
func (*dummy) Build(ctx *context.Context, build config.Build, options Options) error {
|
||||
func (*dummy) Build(_ *context.Context, _ config.Build, _ Options) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
|
@ -18,7 +18,8 @@ import (
|
||||
|
||||
// Git configs.
|
||||
type Git struct {
|
||||
TagSort string `yaml:"tag_sort,omitempty" json:"tag_sort,omitempty"`
|
||||
TagSort string `yaml:"tag_sort,omitempty" json:"tag_sort,omitempty"`
|
||||
PrereleaseSuffix string `yaml:"prerelease_suffix,omitempty" json:"prerelease_suffix,omitempty"`
|
||||
}
|
||||
|
||||
// GitHubURLs holds the URLs to be used when using github enterprise.
|
||||
@ -201,21 +202,24 @@ type Krew struct {
|
||||
|
||||
// Ko contains the ko section
|
||||
type Ko struct {
|
||||
ID string `yaml:"id,omitempty" json:"id,omitempty"`
|
||||
Build string `yaml:"build,omitempty" json:"build,omitempty"`
|
||||
Main string `yaml:"main,omitempty" json:"main,omitempty"`
|
||||
WorkingDir string `yaml:"working_dir,omitempty" json:"working_dir,omitempty"`
|
||||
BaseImage string `yaml:"base_image,omitempty" json:"base_image,omitempty"`
|
||||
Repository string `yaml:"repository,omitempty" json:"repository,omitempty"`
|
||||
Platforms []string `yaml:"platforms,omitempty" json:"platforms,omitempty"`
|
||||
Tags []string `yaml:"tags,omitempty" json:"tags,omitempty"`
|
||||
SBOM string `yaml:"sbom,omitempty" json:"sbom,omitempty"`
|
||||
Ldflags []string `yaml:"ldflags,omitempty" json:"ldflags,omitempty"`
|
||||
Flags []string `yaml:"flags,omitempty" json:"flags,omitempty"`
|
||||
Env []string `yaml:"env,omitempty" json:"env,omitempty"`
|
||||
Bare bool `yaml:"bare,omitempty" json:"bare,omitempty"`
|
||||
PreserveImportPaths bool `yaml:"preserve_import_paths,omitempty" json:"preserve_import_paths,omitempty"`
|
||||
BaseImportPaths bool `yaml:"base_import_paths,omitempty" json:"base_import_paths,omitempty"`
|
||||
ID string `yaml:"id,omitempty" json:"id,omitempty"`
|
||||
Build string `yaml:"build,omitempty" json:"build,omitempty"`
|
||||
Main string `yaml:"main,omitempty" json:"main,omitempty"`
|
||||
WorkingDir string `yaml:"working_dir,omitempty" json:"working_dir,omitempty"`
|
||||
BaseImage string `yaml:"base_image,omitempty" json:"base_image,omitempty"`
|
||||
Labels map[string]string `yaml:"labels,omitempty" json:"labels,omitempty"`
|
||||
Repository string `yaml:"repository,omitempty" json:"repository,omitempty"`
|
||||
Platforms []string `yaml:"platforms,omitempty" json:"platforms,omitempty"`
|
||||
Tags []string `yaml:"tags,omitempty" json:"tags,omitempty"`
|
||||
CreationTime string `yaml:"creation_time,omitempty" json:"creation_time,omitempty"`
|
||||
KoDataCreationTime string `yaml:"ko_data_creation_time,omitempty" json:"ko_data_creation_time,omitempty"`
|
||||
SBOM string `yaml:"sbom,omitempty" json:"sbom,omitempty"`
|
||||
Ldflags []string `yaml:"ldflags,omitempty" json:"ldflags,omitempty"`
|
||||
Flags []string `yaml:"flags,omitempty" json:"flags,omitempty"`
|
||||
Env []string `yaml:"env,omitempty" json:"env,omitempty"`
|
||||
Bare bool `yaml:"bare,omitempty" json:"bare,omitempty"`
|
||||
PreserveImportPaths bool `yaml:"preserve_import_paths,omitempty" json:"preserve_import_paths,omitempty"`
|
||||
BaseImportPaths bool `yaml:"base_import_paths,omitempty" json:"base_import_paths,omitempty"`
|
||||
}
|
||||
|
||||
// Scoop contains the scoop.sh section.
|
||||
@ -234,6 +238,7 @@ type Scoop struct {
|
||||
PreInstall []string `yaml:"pre_install,omitempty" json:"pre_install,omitempty"`
|
||||
PostInstall []string `yaml:"post_install,omitempty" json:"post_install,omitempty"`
|
||||
Depends []string `yaml:"depends,omitempty" json:"depends,omitempty"`
|
||||
Shortcuts [][]string `yaml:"shortcuts,omitempty" json:"shortcuts,omitempty"`
|
||||
Goamd64 string `yaml:"goamd64,omitempty" json:"goamd64,omitempty"`
|
||||
}
|
||||
|
||||
|
@ -36,7 +36,7 @@ nfpms:
|
||||
|
||||
type errorReader struct{}
|
||||
|
||||
func (errorReader) Read(p []byte) (n int, err error) {
|
||||
func (errorReader) Read(_ []byte) (n int, err error) {
|
||||
return 1, fmt.Errorf("error")
|
||||
}
|
||||
|
||||
|
@ -36,5 +36,5 @@ var Healthcheckers = []Healthchecker{
|
||||
|
||||
type system struct{}
|
||||
|
||||
func (system) String() string { return "system" }
|
||||
func (system) Dependencies(ctx *context.Context) []string { return []string{"git", "go"} }
|
||||
func (system) String() string { return "system" }
|
||||
func (system) Dependencies(_ *context.Context) []string { return []string{"git", "go"} }
|
||||
|
@ -34,10 +34,9 @@ jobs:
|
||||
with:
|
||||
fetch-depth: 0
|
||||
- run: git fetch --force --tags
|
||||
- uses: actions/setup-go@v3
|
||||
- uses: actions/setup-go@v4
|
||||
with:
|
||||
go-version: '>=1.20.2'
|
||||
cache: true
|
||||
go-version: stable
|
||||
# More assembly might be required: Docker logins, GPG, etc. It all depends
|
||||
# on your needs.
|
||||
- uses: goreleaser/goreleaser-action@v4
|
||||
@ -71,11 +70,6 @@ jobs:
|
||||
For more information, take a look at
|
||||
[actions/checkout#290](https://github.com/actions/checkout/issues/290).
|
||||
|
||||
#### Caching go dependencies
|
||||
When using the `setup-go` action, you can optionally set `cache: true` for
|
||||
it to aumatically cache and restore your go dependencies, which usually
|
||||
helps speed up build times.
|
||||
|
||||
!!! tip
|
||||
For detailed instructions please follow GitHub Actions [workflow syntax][syntax].
|
||||
|
||||
|
@ -255,3 +255,6 @@ archives:
|
||||
|
||||
Make sure to check the rest of the documentation above, as doing this has some
|
||||
implications.
|
||||
|
||||
If you have customization that might rely on archives, for instance,
|
||||
`brews.install`, make sure to fix them too.
|
||||
|
@ -12,4 +12,11 @@ git:
|
||||
#
|
||||
# Default: `-version:refname`
|
||||
tag_sort: -version:creatordate
|
||||
|
||||
# What should be used to specify prerelease suffix while sorting tags when gathering
|
||||
# the current and previous tags if there are more than one tag in the same commit.
|
||||
#
|
||||
# Since: v1.17.0.
|
||||
# Default: empty, uses what's defined in the git configuration.
|
||||
prerelease_suffix: "-"
|
||||
```
|
||||
|
@ -39,6 +39,13 @@ kos:
|
||||
# Defaults to cgr.dev/chainguard/static.
|
||||
base_image: alpine
|
||||
|
||||
# Labels for the image.
|
||||
#
|
||||
# Defaults to null.
|
||||
# Since v1.17.
|
||||
labels:
|
||||
foo: bar
|
||||
|
||||
# Repository to push to.
|
||||
#
|
||||
# Defaults to the value of $KO_DOCKER_REPO.
|
||||
@ -58,6 +65,20 @@ kos:
|
||||
- latest
|
||||
- '{{.Tag}}'
|
||||
|
||||
# Creation time given to the image
|
||||
# in seconds since the Unix epoch as a string.
|
||||
#
|
||||
# Defaults to empty string.
|
||||
# Since v1.17.
|
||||
creation_time: '{{.CommitTimestamp}}'
|
||||
|
||||
# Creation time given to the files in the kodata directory
|
||||
# in seconds since the Unix epoch as a string.
|
||||
#
|
||||
# Defaults to empty string.
|
||||
# Since v1.17.
|
||||
ko_data_creation_time: '{{.CommitTimestamp}}'
|
||||
|
||||
# SBOM format to use.
|
||||
#
|
||||
# Defaults to spdx.
|
||||
|
@ -140,6 +140,20 @@ nfpms:
|
||||
- src: path/to/foo
|
||||
dst: /usr/bin/foo
|
||||
|
||||
# This will add all files in some/directory or in subdirectories at the
|
||||
# same level under the directory /etc. This means the tree structure in
|
||||
# some/directory will not be replicated.
|
||||
- src: some/directory/
|
||||
dst: /etc
|
||||
|
||||
# This will replicate the directory structure under some/directory at
|
||||
# /etc, using the "tree" type.
|
||||
#
|
||||
# Since v1.17.0.
|
||||
- src: some/directory/
|
||||
dst: /etc
|
||||
type: tree
|
||||
|
||||
# Simple config file
|
||||
- src: path/to/foo.conf
|
||||
dst: /etc/foo.conf
|
||||
|
@ -82,6 +82,13 @@ scoop:
|
||||
# Since GoReleaser v1.16.0.
|
||||
depends: ["git", "foo"]
|
||||
|
||||
|
||||
# A two-dimensional array of string, specifies the shortcut values to make available in the startmenu.
|
||||
# The array has to contain a executable/label pair. The third and fourth element are optional.
|
||||
# Defaults to empty.
|
||||
# Since GoReleaser v1.17.0.
|
||||
shortcuts: [["drumroll.exe", "drumroll"]]
|
||||
|
||||
# GOAMD64 to specify which amd64 version to use if there are multiple versions
|
||||
# from the build section.
|
||||
# Default is v1.
|
||||
|
@ -37,6 +37,7 @@ Key |Description
|
||||
`.IsNightly` |`true` if `--nightly` is set, `false` otherwise
|
||||
`.Env` |a map with system's environment variables
|
||||
`.Date` |current UTC date in RFC 3339 format
|
||||
`.Now` |current UTC date as `time.Time` struct, allows all `time.Time` functions (e.g. `{{ .Now.Format "2006" }}`) . Since v1.17.
|
||||
`.Timestamp` |current UTC time in Unix format
|
||||
`.ModulePath` |the go module path, as reported by `go list -m`
|
||||
`incpatch "v1.2.4"` |increments the patch of the given version[^panic-if-not-semver]
|
||||
|
2
www/docs/static/latest
vendored
2
www/docs/static/latest
vendored
@ -1 +1 @@
|
||||
v1.16.0
|
||||
v1.16.2
|
||||
|
2
www/docs/static/latest-pro
vendored
2
www/docs/static/latest-pro
vendored
@ -1 +1 @@
|
||||
v1.16.1-pro
|
||||
v1.16.2-pro
|
||||
|
3
www/docs/static/releases-pro.json
generated
vendored
3
www/docs/static/releases-pro.json
generated
vendored
@ -1,4 +1,7 @@
|
||||
[
|
||||
{
|
||||
"tag_name": "v1.16.2-pro"
|
||||
},
|
||||
{
|
||||
"tag_name": "v1.16.1-pro"
|
||||
},
|
||||
|
6
www/docs/static/releases.json
generated
vendored
6
www/docs/static/releases.json
generated
vendored
@ -1,4 +1,10 @@
|
||||
[
|
||||
{
|
||||
"tag_name": "v1.16.2"
|
||||
},
|
||||
{
|
||||
"tag_name": "v1.16.1"
|
||||
},
|
||||
{
|
||||
"tag_name": "v1.16.0"
|
||||
},
|
||||
|
4
www/docs/static/schema-pro.json
generated
vendored
4
www/docs/static/schema-pro.json
generated
vendored
@ -720,6 +720,7 @@
|
||||
"config",
|
||||
"config|noreplace",
|
||||
"dir",
|
||||
"tree",
|
||||
""
|
||||
],
|
||||
"default": ""
|
||||
@ -1077,6 +1078,9 @@
|
||||
"properties": {
|
||||
"tag_sort": {
|
||||
"type": "string"
|
||||
},
|
||||
"prerelease_suffix": {
|
||||
"type": "string"
|
||||
}
|
||||
},
|
||||
"additionalProperties": false,
|
||||
|
27
www/docs/static/schema.json
generated
vendored
27
www/docs/static/schema.json
generated
vendored
@ -666,6 +666,7 @@
|
||||
"config",
|
||||
"config|noreplace",
|
||||
"dir",
|
||||
"tree",
|
||||
""
|
||||
],
|
||||
"default": ""
|
||||
@ -986,6 +987,9 @@
|
||||
"properties": {
|
||||
"tag_sort": {
|
||||
"type": "string"
|
||||
},
|
||||
"prerelease_suffix": {
|
||||
"type": "string"
|
||||
}
|
||||
},
|
||||
"additionalProperties": false,
|
||||
@ -1272,6 +1276,14 @@
|
||||
"base_image": {
|
||||
"type": "string"
|
||||
},
|
||||
"labels": {
|
||||
"patternProperties": {
|
||||
".*": {
|
||||
"type": "string"
|
||||
}
|
||||
},
|
||||
"type": "object"
|
||||
},
|
||||
"repository": {
|
||||
"type": "string"
|
||||
},
|
||||
@ -1287,6 +1299,12 @@
|
||||
},
|
||||
"type": "array"
|
||||
},
|
||||
"creation_time": {
|
||||
"type": "string"
|
||||
},
|
||||
"ko_data_creation_time": {
|
||||
"type": "string"
|
||||
},
|
||||
"sbom": {
|
||||
"type": "string"
|
||||
},
|
||||
@ -2416,6 +2434,15 @@
|
||||
},
|
||||
"type": "array"
|
||||
},
|
||||
"shortcuts": {
|
||||
"items": {
|
||||
"items": {
|
||||
"type": "string"
|
||||
},
|
||||
"type": "array"
|
||||
},
|
||||
"type": "array"
|
||||
},
|
||||
"goamd64": {
|
||||
"type": "string"
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user