diff --git a/.github/workflows/base-ci-goreleaser.yaml b/.github/workflows/base-ci-goreleaser.yaml
index 97cefb5d..515def50 100644
--- a/.github/workflows/base-ci-goreleaser.yaml
+++ b/.github/workflows/base-ci-goreleaser.yaml
@@ -32,7 +32,7 @@ jobs:
GOARCH: arm
- GOOS: windows
GOARCH: s390x
- runs-on: ubuntu-20.04
+ runs-on: ubuntu-22.04
steps:
- name: Checkout
@@ -45,6 +45,12 @@ jobs:
with:
platforms: arm64,ppc64le,linux/arm/v7,s390x
+ - name: Setup wixl # Required to build MSI packages for Windows
+ if: ${{ matrix.GOOS }} == 'windows' && (${{ matrix.GOARCH }} == '386' || ${{ matrix.GOARCH }} == 'amd64')
+ run: |
+ sudo apt-get update
+ sudo apt-get install -y wixl
+
- name: Setup Docker Buildx
uses: docker/setup-buildx-action@d70bba72b1f3fd22344832f00baa16ece964efeb # v3.3.0
diff --git a/.github/workflows/base-release.yaml b/.github/workflows/base-release.yaml
index 5139cd6c..0f5ed37b 100644
--- a/.github/workflows/base-release.yaml
+++ b/.github/workflows/base-release.yaml
@@ -32,7 +32,7 @@ jobs:
GOARCH: arm
- GOOS: windows
GOARCH: s390x
- runs-on: ubuntu-20.04
+ runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
@@ -54,6 +54,12 @@ jobs:
go-version: '1.22'
check-latest: true
+ - name: Setup wixl # Required to build MSI packages for Windows
+ if: ${{ matrix.GOOS }} == 'windows' && (${{ matrix.GOARCH }} == '386' || ${{ matrix.GOARCH }} == 'amd64')
+ run: |
+ sudo apt-get update
+ sudo apt-get install -y wixl
+
- name: Generate distribution sources
run: make generate-sources
@@ -95,7 +101,7 @@ jobs:
release:
name: ${{ inputs.distribution }} Release
- runs-on: ubuntu-20.04
+ runs-on: ubuntu-22.04
needs: prepare
permissions:
diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml
index 708fc3d5..03b940fc 100644
--- a/.github/workflows/ci.yaml
+++ b/.github/workflows/ci.yaml
@@ -9,7 +9,7 @@ on:
jobs:
build:
name: Build
- runs-on: ubuntu-20.04
+ runs-on: ubuntu-22.04
steps:
- name: Checkout
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index c3d85310..e40a1a21 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -6,7 +6,8 @@ This repository contains a set of resources that ultimately results in OpenTelem
### Distribution directory
-Each distribution has its own directory at the root of this repository, such as `opentelemetry-collector`. Within each one of those, you'll find at least two files:
+Each distribution has its own directory under the [`distributions`](./distributions/) folder, such as [`otelcol`](./distributions/otelcol/).
+Within each one of those, you'll find at least two files:
- `Dockerfile`, determining how to build the container image for this distribution
- `manifest.yaml`, which is used with [ocb](https://github.com/open-telemetry/opentelemetry-collector/tree/main/cmd/builder) to generate the sources for the distribution.
diff --git a/cmd/goreleaser/internal/configure.go b/cmd/goreleaser/internal/configure.go
index 00cd2980..21cc2e46 100644
--- a/cmd/goreleaser/internal/configure.go
+++ b/cmd/goreleaser/internal/configure.go
@@ -24,8 +24,7 @@ import (
"path"
"strings"
- "github.com/goreleaser/goreleaser/pkg/config"
- "github.com/goreleaser/nfpm/v2/files"
+ "github.com/goreleaser/goreleaser-pro/pkg/config"
)
const ArmArch = "arm"
@@ -45,6 +44,7 @@ func Generate(dist string) config.Project {
Env: []string{"COSIGN_YES=true"},
Builds: Builds(dist),
Archives: Archives(dist),
+ MSI: WinPackages(dist),
NFPMs: Packages(dist),
Dockers: DockerImages(dist),
DockerManifests: DockerManifests(dist),
@@ -102,6 +102,26 @@ func Archive(dist string) config.Archive {
}
}
+func WinPackages(dist string) []config.MSI {
+ return []config.MSI{
+ WinPackage(dist),
+ }
+}
+
+// Package configures goreleaser to build a Windows MSI package.
+// https://goreleaser.com/customization/msi/
+func WinPackage(dist string) config.MSI {
+ return config.MSI{
+ ID: dist,
+ Name: fmt.Sprintf("%s_{{ .Version }}_{{ .Os }}_{{ .MsiArch }}", dist),
+ WXS: "windows-installer.wxs",
+ Files: []string{
+ "config.yaml",
+ "opentelemetry.ico",
+ },
+ }
+}
+
func Packages(dist string) (r []config.NFPM) {
return []config.NFPM{
Package(dist),
@@ -127,7 +147,7 @@ func Package(dist string) config.NFPM {
PostInstall: "postinstall.sh",
PreRemove: "preremove.sh",
},
- Contents: files.Contents{
+ Contents: config.NFPMContents{
{
Source: fmt.Sprintf("%s.service", dist),
Destination: path.Join("/lib", "systemd", "system", fmt.Sprintf("%s.service", dist)),
diff --git a/distributions/otelcol-contrib/.goreleaser.yaml b/distributions/otelcol-contrib/.goreleaser.yaml
index 515d8ba6..477c2e64 100644
--- a/distributions/otelcol-contrib/.goreleaser.yaml
+++ b/distributions/otelcol-contrib/.goreleaser.yaml
@@ -3,6 +3,13 @@ partial:
project_name: opentelemetry-collector-releases
env:
- COSIGN_YES=true
+msi:
+ - id: otelcol-contrib
+ name: otelcol-contrib_{{ .Version }}_{{ .Os }}_{{ .MsiArch }}
+ wxs: windows-installer.wxs
+ extra_files:
+ - config.yaml
+ - opentelemetry.ico
builds:
- id: otelcol-contrib
goos:
diff --git a/distributions/otelcol-contrib/opentelemetry.ico b/distributions/otelcol-contrib/opentelemetry.ico
new file mode 100644
index 00000000..9bdd4cf5
Binary files /dev/null and b/distributions/otelcol-contrib/opentelemetry.ico differ
diff --git a/distributions/otelcol-contrib/windows-installer.wxs b/distributions/otelcol-contrib/windows-installer.wxs
new file mode 100644
index 00000000..0c7d7135
--- /dev/null
+++ b/distributions/otelcol-contrib/windows-installer.wxs
@@ -0,0 +1,88 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ NOT COLLECTOR_SVC_ARGS
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/distributions/otelcol/.goreleaser.yaml b/distributions/otelcol/.goreleaser.yaml
index d1e19e3e..fb7ff6fc 100644
--- a/distributions/otelcol/.goreleaser.yaml
+++ b/distributions/otelcol/.goreleaser.yaml
@@ -3,6 +3,13 @@ partial:
project_name: opentelemetry-collector-releases
env:
- COSIGN_YES=true
+msi:
+ - id: otelcol
+ name: otelcol_{{ .Version }}_{{ .Os }}_{{ .MsiArch }}
+ wxs: windows-installer.wxs
+ extra_files:
+ - config.yaml
+ - opentelemetry.ico
builds:
- id: otelcol
goos:
diff --git a/distributions/otelcol/opentelemetry.ico b/distributions/otelcol/opentelemetry.ico
new file mode 100644
index 00000000..9bdd4cf5
Binary files /dev/null and b/distributions/otelcol/opentelemetry.ico differ
diff --git a/distributions/otelcol/windows-installer.wxs b/distributions/otelcol/windows-installer.wxs
new file mode 100644
index 00000000..0c7d7135
--- /dev/null
+++ b/distributions/otelcol/windows-installer.wxs
@@ -0,0 +1,88 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ NOT COLLECTOR_SVC_ARGS
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/go.mod b/go.mod
index a60b7b0a..7d24d12d 100644
--- a/go.mod
+++ b/go.mod
@@ -5,7 +5,7 @@ go 1.21
toolchain go1.21.7
require (
- github.com/goreleaser/goreleaser v1.25.1
+ github.com/goreleaser/goreleaser-pro v1.25.1-pro
github.com/goreleaser/nfpm/v2 v2.37.1
gopkg.in/yaml.v3 v3.0.1
)
diff --git a/go.sum b/go.sum
index 3c7cfcbc..80fb0232 100644
--- a/go.sum
+++ b/go.sum
@@ -21,6 +21,8 @@ github.com/goreleaser/fileglob v1.3.0 h1:/X6J7U8lbDpQtBvGcwwPS6OpzkNVlVEsFUVRx9+
github.com/goreleaser/fileglob v1.3.0/go.mod h1:Jx6BoXv3mbYkEzwm9THo7xbr5egkAraxkGorbJb4RxU=
github.com/goreleaser/goreleaser v1.25.1 h1:a9skjeROotTN5GPPJDHDfhmOK4n13cBgJ34sTdXRDN0=
github.com/goreleaser/goreleaser v1.25.1/go.mod h1:nsbhCYp9eImbE2fyd9/3Tgv5hjuGuDIQRoBozEUEYbc=
+github.com/goreleaser/goreleaser-pro v1.25.1-pro h1:NOoSx96oAK0zNA1+hiL0p6pY1DWL101kwPmpmkiExXk=
+github.com/goreleaser/goreleaser-pro v1.25.1-pro/go.mod h1:7q9HURJC4ZYBT9VyX3XlqjK0kwe5QbG/VIUAJSP3CKc=
github.com/goreleaser/nfpm/v2 v2.37.1 h1:RUmeEt8OlEVeSzKRrO5Vl5qVWCtUwx4j9uivGuRo5fw=
github.com/goreleaser/nfpm/v2 v2.37.1/go.mod h1:q8+sZXFqn106/eGw+9V+I8+izFxZ/sJjrhwmEUxXhUg=
github.com/invopop/jsonschema v0.12.0 h1:6ovsNSuvn9wEQVOyc72aycBMVQFKz7cPdMJn10CvzRI=