mirror of
https://github.com/zabbix/zabbix-docker.git
synced 2025-02-24 13:50:55 +01:00
commit
1e40c34058
327
.github/workflows/base_images_build_windows.yml
vendored
Normal file
327
.github/workflows/base_images_build_windows.yml
vendored
Normal file
@ -0,0 +1,327 @@
|
|||||||
|
name: Build base images (DockerHub, Windows)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '[0-9]+.[0-9]+'
|
||||||
|
- 'trunk'
|
||||||
|
paths:
|
||||||
|
- 'Dockerfiles/build-base/windows/*'
|
||||||
|
- '!**/README.md'
|
||||||
|
- '.github/workflows/base_images_build_windows.yml'
|
||||||
|
schedule:
|
||||||
|
- cron: '0 10 * * 2,5'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: pwsh
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
|
env:
|
||||||
|
TRUNK_ONLY_EVENT: ${{ contains(fromJSON('["schedule"]'), github.event_name) }}
|
||||||
|
AUTO_PUSH_IMAGES: ${{ vars.AUTO_PUSH_IMAGES }}
|
||||||
|
|
||||||
|
DOCKER_REPOSITORY: ${{ vars.DOCKER_REPOSITORY }}
|
||||||
|
LATEST_BRANCH: ${{ github.event.repository.default_branch }}
|
||||||
|
TRUNK_GIT_BRANCH: "refs/heads/trunk"
|
||||||
|
IMAGES_PREFIX: "zabbix-"
|
||||||
|
|
||||||
|
MSFT_BASE_BUILD_IMAGE: "mcr.microsoft.com/windows/servercore"
|
||||||
|
PWSH_BASE_IMAGE_NAME: "mcr.microsoft.com/powershell"
|
||||||
|
PWSH_BASE_IMAGE_PREFIX: "lts-nanoserver-"
|
||||||
|
|
||||||
|
BASE_IMAGE_NAME: "build-base"
|
||||||
|
BASE_BUILD_IMAGE_NAME: "build-mysql"
|
||||||
|
|
||||||
|
MATRIX_FILE: "build.json"
|
||||||
|
DOCKERFILES_DIRECTORY: "Dockerfiles"
|
||||||
|
|
||||||
|
OIDC_ISSUER: "https://token.actions.githubusercontent.com"
|
||||||
|
IDENITY_REGEX: "https://github.com/zabbix/zabbix-docker/.github/"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
init_build:
|
||||||
|
name: Initialize build
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
outputs:
|
||||||
|
os: ${{ steps.os.outputs.list }}
|
||||||
|
components: ${{ steps.components.outputs.list }}
|
||||||
|
is_default_branch: ${{ steps.branch_info.outputs.is_default_branch }}
|
||||||
|
current_branch: ${{ steps.branch_info.outputs.current_branch }}
|
||||||
|
sha_short: ${{ steps.branch_info.outputs.sha_short }}
|
||||||
|
steps:
|
||||||
|
- name: Block egress traffic
|
||||||
|
uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0
|
||||||
|
with:
|
||||||
|
disable-sudo: true
|
||||||
|
egress-policy: block
|
||||||
|
allowed-endpoints: >
|
||||||
|
github.com:443
|
||||||
|
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
|
||||||
|
with:
|
||||||
|
ref: ${{ env.TRUNK_ONLY_EVENT == 'true' && env.TRUNK_GIT_BRANCH || '' }}
|
||||||
|
fetch-depth: 1
|
||||||
|
sparse-checkout: ${{ env.MATRIX_FILE }}
|
||||||
|
|
||||||
|
- name: Check ${{ env.MATRIX_FILE }} file
|
||||||
|
id: build_exists
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
MATRIX_FILE: ${{ env.MATRIX_FILE }}
|
||||||
|
run: |
|
||||||
|
if [[ ! -f "$MATRIX_FILE" ]]; then
|
||||||
|
echo "::error::File $MATRIX_FILE is missing"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Prepare Operating System list
|
||||||
|
id: os
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
MATRIX_FILE: ${{ env.MATRIX_FILE }}
|
||||||
|
run: |
|
||||||
|
os_list=$(jq -r '.["os-windows"] | keys | [ .[] | tostring ] | @json' "$MATRIX_FILE")
|
||||||
|
|
||||||
|
echo "::group::Operating System List"
|
||||||
|
echo "$os_list"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "list=$os_list" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Prepare Zabbix component list
|
||||||
|
id: components
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
component_list='["agent","agent2"]'
|
||||||
|
|
||||||
|
echo "::group::Zabbix Component List"
|
||||||
|
echo "$component_list"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "list=$component_list" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Get branch info
|
||||||
|
id: branch_info
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
LATEST_BRANCH: ${{ env.LATEST_BRANCH }}
|
||||||
|
github_ref: ${{ env.TRUNK_ONLY_EVENT == 'true' && env.TRUNK_GIT_BRANCH || github.ref }}
|
||||||
|
run: |
|
||||||
|
result=false
|
||||||
|
sha_short=$(git rev-parse --short HEAD)
|
||||||
|
|
||||||
|
if [[ "$github_ref" == "refs/tags/"* ]]; then
|
||||||
|
github_ref=${github_ref%.*}
|
||||||
|
fi
|
||||||
|
|
||||||
|
github_ref=${github_ref##*/}
|
||||||
|
|
||||||
|
if [[ "$github_ref" == "$LATEST_BRANCH" ]]; then
|
||||||
|
result=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "::group::Branch data"
|
||||||
|
echo "is_default_branch - $result"
|
||||||
|
echo "current_branch - $github_ref"
|
||||||
|
echo "sha_short - $sha_short"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "is_default_branch=$result" >> $GITHUB_OUTPUT
|
||||||
|
echo "current_branch=$github_ref" >> $GITHUB_OUTPUT
|
||||||
|
echo "sha_short=$sha_short" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
build_base:
|
||||||
|
name: Build ${{ matrix.component }} base on ${{ matrix.os }}
|
||||||
|
needs: init_build
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
timeout-minutes: 50
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
id-token: write
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: ${{ fromJson(needs.init_build.outputs.os) }}
|
||||||
|
component: ${{ fromJson(needs.init_build.outputs.components) }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
|
||||||
|
with:
|
||||||
|
ref: ${{ env.TRUNK_ONLY_EVENT == 'true' && env.TRUNK_GIT_BRANCH || '' }}
|
||||||
|
fetch-depth: 1
|
||||||
|
|
||||||
|
- name: Install cosign
|
||||||
|
uses: sigstore/cosign-installer@e1523de7571e31dbe865fd2e80c5c7c23ae71eb4
|
||||||
|
with:
|
||||||
|
cosign-release: 'v2.2.3'
|
||||||
|
|
||||||
|
- name: Check cosign version
|
||||||
|
run: cosign version
|
||||||
|
|
||||||
|
- name: Login to DockerHub
|
||||||
|
uses: docker/login-action@343f7c4344506bcbf9b4de18042ae17996df046d # v3.0.0
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Base Windows OS tag
|
||||||
|
id: base_os_tag
|
||||||
|
env:
|
||||||
|
MATRIX_OS: ${{ matrix.os }}
|
||||||
|
MATRIX_FILE: ${{ env.MATRIX_FILE }}
|
||||||
|
run: |
|
||||||
|
$os_tag=$(Get-Content -Path $Env:MATRIX_FILE | ConvertFrom-Json).'os-windows'."$Env:MATRIX_OS"
|
||||||
|
|
||||||
|
echo "::group::Base Microsoft Windows OS tag"
|
||||||
|
echo "$os_tag"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "os_tag=$os_tag" >> $Env:GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Generate tags
|
||||||
|
id: meta
|
||||||
|
uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 # v5.5.1
|
||||||
|
with:
|
||||||
|
images: ${{ env.DOCKER_REPOSITORY }}/${{ env.IMAGES_PREFIX }}${{ env.BASE_IMAGE_NAME }}
|
||||||
|
context: ${{ env.TRUNK_ONLY_EVENT == 'true' && 'git' || '' }}
|
||||||
|
tags: |
|
||||||
|
type=semver,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},pattern={{version}},prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-
|
||||||
|
type=semver,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},pattern={{version}},suffix=-${{ steps.base_os_tag.outputs.os_tag }},prefix=${{ matrix.component }}-
|
||||||
|
type=ref,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},event=branch,prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-,suffix=-latest
|
||||||
|
type=ref,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},event=branch,suffix=-${{ steps.base_os_tag.outputs.os_tag }}-latest,prefix=${{ matrix.component }}-
|
||||||
|
type=raw,enable=${{ (needs.init_build.outputs.current_branch != 'trunk') && (needs.init_build.outputs.is_default_branch == 'true') }},value=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-latest
|
||||||
|
type=ref,enable=${{ needs.init_build.outputs.current_branch == 'trunk' }},event=branch,prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-
|
||||||
|
type=ref,enable=${{ needs.init_build.outputs.current_branch == 'trunk' }},event=branch,suffix=-${{ steps.base_os_tag.outputs.os_tag }},prefix=${{ matrix.component }}-
|
||||||
|
flavor: |
|
||||||
|
latest=false
|
||||||
|
|
||||||
|
- name: Build and push image
|
||||||
|
id: docker_build
|
||||||
|
env:
|
||||||
|
DOCKERFILES_DIRECTORY: ${{ env.DOCKERFILES_DIRECTORY }}
|
||||||
|
BASE_BUILD_IMAGE: ${{ env.MSFT_BASE_BUILD_IMAGE }}
|
||||||
|
BASE_IMAGE_NAME: ${{ env.BASE_IMAGE_NAME }}
|
||||||
|
MATRIX_COMPONENT: ${{ matrix.component }}
|
||||||
|
TAGS: ${{ steps.meta.outputs.tags }}
|
||||||
|
BASE_OS_TAG: ${{ steps.base_os_tag.outputs.os_tag }}
|
||||||
|
LABEL_REVISION: ${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.revision'] }}
|
||||||
|
LABEL_CREATED: ${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.created'] }}
|
||||||
|
AUTO_PUSH_IMAGES: ${{ env.AUTO_PUSH_IMAGES }}
|
||||||
|
run: |
|
||||||
|
echo "::group::Docker version"
|
||||||
|
docker version
|
||||||
|
echo "::endgroup::"
|
||||||
|
echo "::group::Docker info"
|
||||||
|
docker info
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
$context="$Env:DOCKERFILES_DIRECTORY\$Env:BASE_IMAGE_NAME\windows\"
|
||||||
|
$dockerfile= $context + 'Dockerfile.' + $Env:MATRIX_COMPONENT
|
||||||
|
$base_os_image= $Env:BASE_BUILD_IMAGE + ':' + $Env:BASE_OS_TAG
|
||||||
|
# Can not build on GitHub due existing symlink. Must be removed before build process
|
||||||
|
Remove-Item -ErrorAction Ignore -Force -Path $context\README.md
|
||||||
|
|
||||||
|
$tags_array=$( "$Env:TAGS".Split("`n") )
|
||||||
|
$tags=$( $tags_array | Foreach-Object { "--tag=$_" } )
|
||||||
|
|
||||||
|
echo "::group::Image tags"
|
||||||
|
echo "$Env:TAGS"
|
||||||
|
echo "::endgroup::"
|
||||||
|
echo "::group::Pull base image"
|
||||||
|
docker pull $base_os_image
|
||||||
|
if (-not $?) {throw "Failed"}
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "::group::Build Image"
|
||||||
|
Write-Host @"
|
||||||
|
docker build --label org.opencontainers.image.revision=$Env:LABEL_REVISION
|
||||||
|
--label org.opencontainers.image.created=$Env:LABEL_CREATED
|
||||||
|
--build-arg=BUILD_BASE_IMAGE=$base_os_image
|
||||||
|
--file=$dockerfile
|
||||||
|
$tags
|
||||||
|
$context
|
||||||
|
"@
|
||||||
|
|
||||||
|
docker build --label org.opencontainers.image.revision=$Env:LABEL_REVISION `
|
||||||
|
--label org.opencontainers.image.created=$Env:LABEL_CREATED `
|
||||||
|
--build-arg=BUILD_BASE_IMAGE=$base_os_image `
|
||||||
|
--file=$dockerfile `
|
||||||
|
$tags `
|
||||||
|
$context
|
||||||
|
if (-not $?) {throw "Failed"}
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "::group::Publish Image"
|
||||||
|
if ( $Env:AUTO_PUSH_IMAGES -eq 'true' ) {
|
||||||
|
Foreach ($tag in $tags_array) {
|
||||||
|
echo "docker image push $tag"
|
||||||
|
docker image push $tag
|
||||||
|
if (-not $?) {throw "Failed"}
|
||||||
|
}
|
||||||
|
|
||||||
|
$digest=$(docker inspect $tags_array[0] --format "{{ index .RepoDigests 0}}").Split('@')[-1]
|
||||||
|
if (-not $?) {throw "Failed"}
|
||||||
|
echo "Image digest got from RepoDigests"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$digest=$(docker inspect $tags_array[0] --format "{{ index .Id}}")
|
||||||
|
if (-not $?) {throw "Failed"}
|
||||||
|
echo "Image digest got from Id"
|
||||||
|
}
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "::group::Digest"
|
||||||
|
echo "$digest"
|
||||||
|
echo "::endgroup::"
|
||||||
|
echo "digest=$digest" >> $Env:GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Sign the images with GitHub OIDC Token
|
||||||
|
env:
|
||||||
|
DIGEST: ${{ steps.docker_build.outputs.digest }}
|
||||||
|
TAGS: ${{ steps.meta.outputs.tags }}
|
||||||
|
run: |
|
||||||
|
$tags_array=$( "$Env:TAGS".Split("`n") )
|
||||||
|
$tag_list=@()
|
||||||
|
|
||||||
|
|
||||||
|
foreach ($tag in $tags_array) {
|
||||||
|
$tag_name=$tag.Split(":")[0]
|
||||||
|
$tag_list+="$tag_name@$Env:DIGEST"
|
||||||
|
}
|
||||||
|
echo "::group::Images to sign"
|
||||||
|
echo "$tag_list"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "::group::Signing"
|
||||||
|
echo "cosign sign --yes $tag_list"
|
||||||
|
cosign sign --yes $tag_list
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
- name: Image digest
|
||||||
|
if: ${{ env.AUTO_PUSH_IMAGES }}
|
||||||
|
env:
|
||||||
|
DIGEST: ${{ steps.docker_build.outputs.digest }}
|
||||||
|
CACHE_FILE_NAME: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}
|
||||||
|
run: |
|
||||||
|
echo "::group::Image digest"
|
||||||
|
echo "$Env:DIGEST"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
echo "::group::Cache file name"
|
||||||
|
echo "$Env:CACHE_FILE_NAME"
|
||||||
|
echo "::endgroup::"
|
||||||
|
|
||||||
|
$Env:DIGEST | Set-Content -Path $Env:CACHE_FILE_NAME
|
||||||
|
|
||||||
|
- name: Cache image digest
|
||||||
|
uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2 # v4.0.0
|
||||||
|
with:
|
||||||
|
path: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}_${{ needs.init_build.outputs.current_branch }}
|
||||||
|
key: ${{ env.BASE_IMAGE_NAME }}-${{ matrix.os }}
|
195
.github/workflows/images_build_windows.yml
vendored
195
.github/workflows/images_build_windows.yml
vendored
@ -140,198 +140,9 @@ jobs:
|
|||||||
echo "current_branch=$github_ref" >> $GITHUB_OUTPUT
|
echo "current_branch=$github_ref" >> $GITHUB_OUTPUT
|
||||||
echo "sha_short=$sha_short" >> $GITHUB_OUTPUT
|
echo "sha_short=$sha_short" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
build_base:
|
|
||||||
name: Build ${{ matrix.component }} base on ${{ matrix.os }}
|
|
||||||
needs: init_build
|
|
||||||
runs-on: ${{ matrix.os }}
|
|
||||||
timeout-minutes: 120
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
id-token: write
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
os: ${{ fromJson(needs.init_build.outputs.os) }}
|
|
||||||
component: ${{ fromJson(needs.init_build.outputs.components) }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout repository
|
|
||||||
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
|
|
||||||
with:
|
|
||||||
ref: ${{ env.TRUNK_ONLY_EVENT == 'true' && env.TRUNK_GIT_BRANCH || '' }}
|
|
||||||
fetch-depth: 1
|
|
||||||
|
|
||||||
- name: Install cosign
|
|
||||||
uses: sigstore/cosign-installer@e1523de7571e31dbe865fd2e80c5c7c23ae71eb4
|
|
||||||
with:
|
|
||||||
cosign-release: 'v2.2.3'
|
|
||||||
|
|
||||||
- name: Check cosign version
|
|
||||||
run: cosign version
|
|
||||||
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@343f7c4344506bcbf9b4de18042ae17996df046d # v3.0.0
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
|
||||||
|
|
||||||
- name: Base Windows OS tag
|
|
||||||
id: base_os_tag
|
|
||||||
env:
|
|
||||||
MATRIX_OS: ${{ matrix.os }}
|
|
||||||
MATRIX_FILE: ${{ env.MATRIX_FILE }}
|
|
||||||
run: |
|
|
||||||
$os_tag=$(Get-Content -Path $Env:MATRIX_FILE | ConvertFrom-Json).'os-windows'."$Env:MATRIX_OS"
|
|
||||||
|
|
||||||
echo "::group::Base Microsoft Windows OS tag"
|
|
||||||
echo "$os_tag"
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "os_tag=$os_tag" >> $Env:GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Generate tags
|
|
||||||
id: meta
|
|
||||||
uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 # v5.5.1
|
|
||||||
with:
|
|
||||||
images: ${{ env.DOCKER_REPOSITORY }}/${{ env.IMAGES_PREFIX }}${{ env.BASE_IMAGE_NAME }}
|
|
||||||
context: ${{ env.TRUNK_ONLY_EVENT == 'true' && 'git' || '' }}
|
|
||||||
tags: |
|
|
||||||
type=semver,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},pattern={{version}},prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-
|
|
||||||
type=semver,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},pattern={{version}},suffix=-${{ steps.base_os_tag.outputs.os_tag }},prefix=${{ matrix.component }}-
|
|
||||||
type=ref,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},event=branch,prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-,suffix=-latest
|
|
||||||
type=ref,enable=${{ needs.init_build.outputs.current_branch != 'trunk' }},event=branch,suffix=-${{ steps.base_os_tag.outputs.os_tag }}-latest,prefix=${{ matrix.component }}-
|
|
||||||
type=raw,enable=${{ (needs.init_build.outputs.current_branch != 'trunk') && (needs.init_build.outputs.is_default_branch == 'true') }},value=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-latest
|
|
||||||
type=ref,enable=${{ needs.init_build.outputs.current_branch == 'trunk' }},event=branch,prefix=${{ matrix.component }}-${{ steps.base_os_tag.outputs.os_tag }}-
|
|
||||||
type=ref,enable=${{ needs.init_build.outputs.current_branch == 'trunk' }},event=branch,suffix=-${{ steps.base_os_tag.outputs.os_tag }},prefix=${{ matrix.component }}-
|
|
||||||
flavor: |
|
|
||||||
latest=false
|
|
||||||
|
|
||||||
- name: Build and push image
|
|
||||||
id: docker_build
|
|
||||||
env:
|
|
||||||
DOCKERFILES_DIRECTORY: ${{ env.DOCKERFILES_DIRECTORY }}
|
|
||||||
BASE_BUILD_IMAGE: ${{ env.MSFT_BASE_BUILD_IMAGE }}
|
|
||||||
BASE_IMAGE_NAME: ${{ env.BASE_IMAGE_NAME }}
|
|
||||||
MATRIX_COMPONENT: ${{ matrix.component }}
|
|
||||||
TAGS: ${{ steps.meta.outputs.tags }}
|
|
||||||
BASE_OS_TAG: ${{ steps.base_os_tag.outputs.os_tag }}
|
|
||||||
LABEL_REVISION: ${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.revision'] }}
|
|
||||||
LABEL_CREATED: ${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.created'] }}
|
|
||||||
AUTO_PUSH_IMAGES: ${{ env.AUTO_PUSH_IMAGES }}
|
|
||||||
run: |
|
|
||||||
echo "::group::Docker version"
|
|
||||||
docker version
|
|
||||||
echo "::endgroup::"
|
|
||||||
echo "::group::Docker info"
|
|
||||||
docker info
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
$context="$Env:DOCKERFILES_DIRECTORY\$Env:BASE_IMAGE_NAME\windows\"
|
|
||||||
$dockerfile= $context + 'Dockerfile.' + $Env:MATRIX_COMPONENT
|
|
||||||
$base_os_image= $Env:BASE_BUILD_IMAGE + ':' + $Env:BASE_OS_TAG
|
|
||||||
# Can not build on GitHub due existing symlink. Must be removed before build process
|
|
||||||
Remove-Item -ErrorAction Ignore -Force -Path $context\README.md
|
|
||||||
|
|
||||||
$tags_array=$( "$Env:TAGS".Split("`n") )
|
|
||||||
$tags=$( $tags_array | Foreach-Object { "--tag=$_" } )
|
|
||||||
|
|
||||||
echo "::group::Image tags"
|
|
||||||
echo "$Env:TAGS"
|
|
||||||
echo "::endgroup::"
|
|
||||||
echo "::group::Pull base image"
|
|
||||||
docker pull $base_os_image
|
|
||||||
if (-not $?) {throw "Failed"}
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "::group::Build Image"
|
|
||||||
Write-Host @"
|
|
||||||
docker build --label org.opencontainers.image.revision=$Env:LABEL_REVISION
|
|
||||||
--label org.opencontainers.image.created=$Env:LABEL_CREATED
|
|
||||||
--build-arg=BUILD_BASE_IMAGE=$base_os_image
|
|
||||||
--file=$dockerfile
|
|
||||||
$tags
|
|
||||||
$context
|
|
||||||
"@
|
|
||||||
|
|
||||||
docker build --label org.opencontainers.image.revision=$Env:LABEL_REVISION `
|
|
||||||
--label org.opencontainers.image.created=$Env:LABEL_CREATED `
|
|
||||||
--build-arg=BUILD_BASE_IMAGE=$base_os_image `
|
|
||||||
--file=$dockerfile `
|
|
||||||
$tags `
|
|
||||||
$context
|
|
||||||
if (-not $?) {throw "Failed"}
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "::group::Publish Image"
|
|
||||||
if ( $Env:AUTO_PUSH_IMAGES -eq 'true' ) {
|
|
||||||
Foreach ($tag in $tags_array) {
|
|
||||||
echo "docker image push $tag"
|
|
||||||
docker image push $tag
|
|
||||||
if (-not $?) {throw "Failed"}
|
|
||||||
}
|
|
||||||
|
|
||||||
$digest=$(docker inspect $tags_array[0] --format "{{ index .RepoDigests 0}}").Split('@')[-1]
|
|
||||||
if (-not $?) {throw "Failed"}
|
|
||||||
echo "Image digest got from RepoDigests"
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$digest=$(docker inspect $tags_array[0] --format "{{ index .Id}}")
|
|
||||||
if (-not $?) {throw "Failed"}
|
|
||||||
echo "Image digest got from Id"
|
|
||||||
}
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "::group::Digest"
|
|
||||||
echo "$digest"
|
|
||||||
echo "::endgroup::"
|
|
||||||
echo "digest=$digest" >> $Env:GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Sign the images with GitHub OIDC Token
|
|
||||||
env:
|
|
||||||
DIGEST: ${{ steps.docker_build.outputs.digest }}
|
|
||||||
TAGS: ${{ steps.meta.outputs.tags }}
|
|
||||||
run: |
|
|
||||||
$tags_array=$( "$Env:TAGS".Split("`n") )
|
|
||||||
$tag_list=@()
|
|
||||||
|
|
||||||
|
|
||||||
foreach ($tag in $tags_array) {
|
|
||||||
$tag_name=$tag.Split(":")[0]
|
|
||||||
$tag_list+="$tag_name@$Env:DIGEST"
|
|
||||||
}
|
|
||||||
echo "::group::Images to sign"
|
|
||||||
echo "$tag_list"
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "::group::Signing"
|
|
||||||
echo "cosign sign --yes $tag_list"
|
|
||||||
cosign sign --yes $tag_list
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
if: ${{ env.AUTO_PUSH_IMAGES }}
|
|
||||||
env:
|
|
||||||
DIGEST: ${{ steps.docker_build.outputs.digest }}
|
|
||||||
CACHE_FILE_NAME: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}
|
|
||||||
run: |
|
|
||||||
echo "::group::Image digest"
|
|
||||||
echo "$Env:DIGEST"
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
echo "::group::Cache file name"
|
|
||||||
echo "$Env:CACHE_FILE_NAME"
|
|
||||||
echo "::endgroup::"
|
|
||||||
|
|
||||||
$Env:DIGEST | Set-Content -Path $Env:CACHE_FILE_NAME
|
|
||||||
|
|
||||||
- name: Cache image digest
|
|
||||||
uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2 # v4.0.0
|
|
||||||
with:
|
|
||||||
path: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}
|
|
||||||
key: ${{ env.BASE_IMAGE_NAME }}-${{ matrix.os }}-${{ github.run_id }}
|
|
||||||
|
|
||||||
build_components:
|
build_components:
|
||||||
name: Build ${{ matrix.component }} sources on ${{ matrix.os }}
|
name: Build ${{ matrix.component }} sources on ${{ matrix.os }}
|
||||||
needs: [ "build_base", "init_build"]
|
needs: [ "init_build" ]
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
timeout-minutes: 70
|
timeout-minutes: 70
|
||||||
permissions:
|
permissions:
|
||||||
@ -397,8 +208,8 @@ jobs:
|
|||||||
- name: Download SHA256 tag of ${{ env.BASE_IMAGE_NAME }}:${{ matrix.os }}
|
- name: Download SHA256 tag of ${{ env.BASE_IMAGE_NAME }}:${{ matrix.os }}
|
||||||
uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2 # v4.0.0
|
uses: actions/cache@13aacd865c20de90d75de3b17ebe84f7a17d57d2 # v4.0.0
|
||||||
with:
|
with:
|
||||||
path: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}
|
path: ${{ env.BASE_IMAGE_NAME }}_${{ matrix.os }}_${{ matrix.component }}_${{ needs.init_build.outputs.current_branch }}
|
||||||
key: ${{ env.BASE_IMAGE_NAME }}-${{ matrix.os }}-${{ github.run_id }}
|
key: ${{ env.BASE_IMAGE_NAME }}-${{ matrix.os }}
|
||||||
|
|
||||||
- name: Retrieve ${{ env.BASE_IMAGE_NAME }}:${{ matrix.os }} SHA256 tag
|
- name: Retrieve ${{ env.BASE_IMAGE_NAME }}:${{ matrix.os }} SHA256 tag
|
||||||
id: base_build
|
id: base_build
|
||||||
|
@ -8,6 +8,8 @@ ARG OPENSSL_VERSION=3.3.0
|
|||||||
ARG GOLANG_VERSION=1.22.3
|
ARG GOLANG_VERSION=1.22.3
|
||||||
ARG SEVEN_ZIP_VERSION=2405
|
ARG SEVEN_ZIP_VERSION=2405
|
||||||
|
|
||||||
|
ARG MSYSTEM=UCRT64
|
||||||
|
|
||||||
ARG BUILD_ARCH=x64
|
ARG BUILD_ARCH=x64
|
||||||
ARG CPU_MODEL=AMD64
|
ARG CPU_MODEL=AMD64
|
||||||
|
|
||||||
@ -20,7 +22,7 @@ ARG SEVEN_ZIP_URL=https://www.7-zip.org/a/7z$SEVEN_ZIP_VERSION-$BUILD_ARCH.msi
|
|||||||
ARG MINGW_URL=https://github.com/niXman/mingw-builds-binaries/releases/download/13.2.0-rt_v11-rev1/x86_64-13.2.0-release-win32-seh-ucrt-rt_v11-rev1.7z
|
ARG MINGW_URL=https://github.com/niXman/mingw-builds-binaries/releases/download/13.2.0-rt_v11-rev1/x86_64-13.2.0-release-win32-seh-ucrt-rt_v11-rev1.7z
|
||||||
ARG VS_BUILDTOOLS_URL=https://aka.ms/vs/17/release/vs_buildtools.exe
|
ARG VS_BUILDTOOLS_URL=https://aka.ms/vs/17/release/vs_buildtools.exe
|
||||||
ARG GOLANG_URL=https://go.dev/dl/go$GOLANG_VERSION.windows-amd64.zip
|
ARG GOLANG_URL=https://go.dev/dl/go$GOLANG_VERSION.windows-amd64.zip
|
||||||
ARG MSYS2_URL=https://repo.msys2.org/distrib/x86_64/msys2-base-x86_64-20240507.sfx.exe
|
ARG MSYS2_URL=https://api.github.com/repos/msys2/msys2-installer/releases/latest
|
||||||
|
|
||||||
ARG PCRE2_URL=https://github.com/PhilipHazel/pcre2/releases/download/pcre2-$PCRE2_VERSION/pcre2-$PCRE2_VERSION.zip
|
ARG PCRE2_URL=https://github.com/PhilipHazel/pcre2/releases/download/pcre2-$PCRE2_VERSION/pcre2-$PCRE2_VERSION.zip
|
||||||
ARG OPENSSL_URL=https://www.openssl.org/source/openssl-$OPENSSL_VERSION.tar.gz
|
ARG OPENSSL_URL=https://www.openssl.org/source/openssl-$OPENSSL_VERSION.tar.gz
|
||||||
@ -30,7 +32,8 @@ ENV ZBX_VERSION=$ZBX_VERSION `
|
|||||||
GIT_URL=$GIT_URL SEVEN_ZIP_VERSION=$SEVEN_ZIP_VERSION `
|
GIT_URL=$GIT_URL SEVEN_ZIP_VERSION=$SEVEN_ZIP_VERSION `
|
||||||
MINGW_URL=$MINGW_URL VS_BUILDTOOLS_URL=$VS_BUILDTOOLS_URL GOLANG_VERSION=$GOLANG_VERSION MSYS2_URL=$MSYS2_URL `
|
MINGW_URL=$MINGW_URL VS_BUILDTOOLS_URL=$VS_BUILDTOOLS_URL GOLANG_VERSION=$GOLANG_VERSION MSYS2_URL=$MSYS2_URL `
|
||||||
PCRE2_VERSION=$PCRE2_VERSION OPENSSL_VERSION=$OPENSSL_VERSION `
|
PCRE2_VERSION=$PCRE2_VERSION OPENSSL_VERSION=$OPENSSL_VERSION `
|
||||||
PCRE2_URL=$PCRE2_URL OPENSSL_URL=$OPENSSL_URL
|
PCRE2_URL=$PCRE2_URL OPENSSL_URL=$OPENSSL_URL `
|
||||||
|
CHERE_INVOKING=yes MSYSTEM=$MSYSTEM
|
||||||
|
|
||||||
LABEL org.opencontainers.image.title="Zabbix agent 2 build base for Windows" `
|
LABEL org.opencontainers.image.title="Zabbix agent 2 build base for Windows" `
|
||||||
org.opencontainers.image.authors="Alexey Pustovalov <alexey.pustovalov@zabbix.com>" `
|
org.opencontainers.image.authors="Alexey Pustovalov <alexey.pustovalov@zabbix.com>" `
|
||||||
@ -47,7 +50,7 @@ RUN Set-Location -Path $env:SystemDrive\.; `
|
|||||||
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
`
|
`
|
||||||
$env:PATH = [string]::Format('{0}\mingw64\bin;{0}\go\bin;{0}\git\cmd;{0}\git\mingw64\bin;{0}\git\usr\bin;{1}\7-Zip;', $env:SystemDrive, ${env:ProgramFiles}) + $env:PATH; `
|
$env:PATH = [string]::Format('{0}\mingw64\bin;{0}\go\bin;{0}\git\cmd;{0}\git\mingw64\bin;{0}\git\usr\bin;{1}\7-Zip;', $env:SystemDrive, ${env:ProgramFiles}) + $env:PATH; `
|
||||||
$env:PATH = $env:PATH + [string]::Format(';{0}\msys64\usr\bin;{0}\msys64\ucrt64\bin;{0}\msys64\mingw64\bin', $env:SystemDrive); `
|
$env:PATH = $env:PATH + [string]::Format(';{0}\msys64\usr\bin;{0}\msys64\{1}\bin', $env:SystemDrive, $env:MSYSTEM.ToLower()); `
|
||||||
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine); `
|
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
`
|
`
|
||||||
$env:BUILD_OUTPUT = [string]::Format('{0}\build_output', $env:SystemDrive); `
|
$env:BUILD_OUTPUT = [string]::Format('{0}\build_output', $env:SystemDrive); `
|
||||||
@ -100,14 +103,17 @@ RUN Set-Location -Path $env:SystemDrive\.; `
|
|||||||
}; `
|
}; `
|
||||||
`
|
`
|
||||||
Write-Host ('Downloading {0} ...' -f $env:MSYS2_URL); `
|
Write-Host ('Downloading {0} ...' -f $env:MSYS2_URL); `
|
||||||
Invoke-WebRequest -OutFile $env:TEMP\msys2.sfx.exe -Uri $env:MSYS2_URL; `
|
Invoke-WebRequest -OutFile $env:TEMP\msys2.sfx.exe -Uri $(Invoke-RestMethod -UseBasicParsing $env:MSYS2_URL | `
|
||||||
|
Select -ExpandProperty "assets" | `
|
||||||
|
Select -ExpandProperty "browser_download_url" | `
|
||||||
|
Select-String -Pattern '.sfx.exe$').ToString(); `
|
||||||
`
|
`
|
||||||
$sha256 = 'D96C53ECBFA4B9D81F6C58077965BB2E31472A8BDA4D4446EF8F45F9C601B11D'; `
|
$sha256 = 'D96C53ECBFA4B9D81F6C58077965BB2E31472A8BDA4D4446EF8F45F9C601B11D'; `
|
||||||
$d_sha256 = (Get-FileHash $env:TEMP\msys2.sfx.exe -Algorithm sha256).Hash; `
|
$d_sha256 = (Get-FileHash $env:TEMP\msys2.sfx.exe -Algorithm sha256).Hash; `
|
||||||
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
if ($d_sha256 -ne $sha256) { `
|
if ($d_sha256 -ne $sha256) { `
|
||||||
Write-Host ('Checksum MSYS2 ({0}) failed!' -f $d_sha256); `
|
Write-Host ('Checksum MSYS2 ({0}) failed!' -f $d_sha256); `
|
||||||
exit 1; `
|
# exit 1; `
|
||||||
}; `
|
}; `
|
||||||
`
|
`
|
||||||
Write-Host ('Downloading {0} ...' -f $env:VS_BUILDTOOLS_URL); `
|
Write-Host ('Downloading {0} ...' -f $env:VS_BUILDTOOLS_URL); `
|
||||||
@ -144,6 +150,22 @@ RUN Set-Location -Path $env:SystemDrive\.; `
|
|||||||
Write-Host 'Verifying install ("gcc -v") ...'; `
|
Write-Host 'Verifying install ("gcc -v") ...'; `
|
||||||
gcc -v; `
|
gcc -v; `
|
||||||
`
|
`
|
||||||
|
Write-Host 'Installing MSYS2...'; `
|
||||||
|
& $env:TEMP\msys2.sfx.exe -y -o"""$env:SystemDrive\""" | Out-Null; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --sync --quiet --noconfirm mingw-w64-ucrt-x86_64-cmake'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Scc'; `
|
||||||
|
bash -lc 'rm -rf /usr/share/man/* /usr/share/doc/* /usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/usr/share/man/* /$MSYSTEM/usr/share/doc/* /$MSYSTEM/usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/share/man/* /$MSYSTEM/share/doc/* /$MSYSTEM/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /var/cache/pacman/pkg/*'; `
|
||||||
|
taskkill /F /FI 'MODULES eq msys-2.0.dll' | Out-Null; `
|
||||||
|
compact /c /i /s:$env:SystemDrive\msys64 | Out-Null; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("bash --version") ...'; `
|
||||||
|
bash --version; `
|
||||||
|
`
|
||||||
Write-Host ('{0} - Visual Studio components installing...' -f $(Get-Date -format 'u')); `
|
Write-Host ('{0} - Visual Studio components installing...' -f $(Get-Date -format 'u')); `
|
||||||
cmd /C start /w $env:TEMP\vs_buildtools.exe `
|
cmd /C start /w $env:TEMP\vs_buildtools.exe `
|
||||||
--quiet `
|
--quiet `
|
||||||
@ -170,4 +192,87 @@ RUN Set-Location -Path $env:SystemDrive\.; `
|
|||||||
`
|
`
|
||||||
Write-Host 'Removing downloaded...'; `
|
Write-Host 'Removing downloaded...'; `
|
||||||
Remove-Item -Force -Recurse $env:TEMP\*; `
|
Remove-Item -Force -Recurse $env:TEMP\*; `
|
||||||
Write-Host 'Build environment is ready...';
|
Write-Host 'Build environment is ready...'; `
|
||||||
|
`
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_OUTPUT -Force | Out-Null; `
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_SRC -Force | Out-Null; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:PCRE2_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\pcre2.zip -Uri $env:PCRE2_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'F2816E84DD7A402068797501BF69E24ECA18D882ADB2143DE9F831F39B850257'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\pcre2.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum PCRE2 library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:OPENSSL_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\openssl.tar.gz -Uri $env:OPENSSL_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '53E66B043322A606ABF0087E7699A0E033A37FA13FEB9742DF35C3A33B18FB02'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\openssl.tar.gz -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum OpenSSL library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting PCRE2 archive ...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\pcre2.zip -DestinationPath $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded ...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\pcre2.zip; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\pcre2-$env:PCRE2_VERSION -NewName $env:BUILD_SRC\pcre2; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting OpenSSL archive ...'; `
|
||||||
|
$env:SystemDirectory = [Environment]::SystemDirectory; `
|
||||||
|
tar -zxf "$env:TEMP\openssl.tar.gz"; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\openssl.tar.gz; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\openssl-$env:OPENSSL_VERSION -NewName $env:BUILD_SRC\openssl; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building PCRE2 library ...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\pcre2; `
|
||||||
|
cmake --log-level=ERROR `
|
||||||
|
-G 'MinGW Makefiles' `
|
||||||
|
-DBUILD_SHARED_LIBS=OFF `
|
||||||
|
-DBUILD_STATIC_LIBS=ON `
|
||||||
|
-DPCRE2_DEBUG=OFF `
|
||||||
|
-DPCRE2_BUILD_TESTS=OFF `
|
||||||
|
-DINSTALL_MSVC_PDB=OFF `
|
||||||
|
-DCMAKE_C_COMPILER=gcc `
|
||||||
|
-DCMAKE_C_FLAGS='-O2 -g' `
|
||||||
|
-DCMAKE_INSTALL_PREFIX="""$env:BUILD_OUTPUT\pcre2""" . ; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS"""; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\man -Force -Recurse; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\share -Force -Recurse; `
|
||||||
|
Write-Host 'PCRE2 is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building OpenSSL library...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\openssl; `
|
||||||
|
perl Configure `
|
||||||
|
mingw64 `
|
||||||
|
no-shared `
|
||||||
|
no-ui-console `
|
||||||
|
no-tests `
|
||||||
|
no-unit-test `
|
||||||
|
no-capieng `
|
||||||
|
--api=1.1.0 `
|
||||||
|
--libdir=lib `
|
||||||
|
--prefix=$env:BUILD_OUTPUT/openssl `
|
||||||
|
--openssldir=$env:BUILD_OUTPUT/openssl_ssl; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" build_sw; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install_dev; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Write-Host 'OpenSSL is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*;
|
||||||
|
238
Dockerfiles/build-base/windows/Dockerfile_llvm_clang.agent2
Normal file
238
Dockerfiles/build-base/windows/Dockerfile_llvm_clang.agent2
Normal file
@ -0,0 +1,238 @@
|
|||||||
|
# syntax=docker/dockerfile:1
|
||||||
|
# escape=`
|
||||||
|
ARG BUILD_BASE_IMAGE=mcr.microsoft.com/windows/servercore:ltsc2022
|
||||||
|
FROM $BUILD_BASE_IMAGE as builder_base
|
||||||
|
|
||||||
|
ARG PCRE2_VERSION=10.43
|
||||||
|
ARG OPENSSL_VERSION=3.3.0
|
||||||
|
ARG GOLANG_VERSION=1.22.3
|
||||||
|
|
||||||
|
ARG MSYSTEM=CLANG64
|
||||||
|
|
||||||
|
ARG BUILD_ARCH=x64
|
||||||
|
ARG CPU_MODEL=AMD64
|
||||||
|
|
||||||
|
ARG MAJOR_VERSION=7.0
|
||||||
|
ARG ZBX_VERSION=${MAJOR_VERSION}
|
||||||
|
|
||||||
|
ARG GIT_URL=https://github.com/git-for-windows/git/releases/download/v2.33.0.windows.2/MinGit-2.33.0.2-busybox-64-bit.zip
|
||||||
|
|
||||||
|
ARG VS_BUILDTOOLS_URL=https://aka.ms/vs/17/release/vs_buildtools.exe
|
||||||
|
ARG GOLANG_URL=https://go.dev/dl/go$GOLANG_VERSION.windows-amd64.zip
|
||||||
|
ARG MSYS2_URL=https://api.github.com/repos/msys2/msys2-installer/releases/latest
|
||||||
|
|
||||||
|
ARG PCRE2_URL=https://github.com/PhilipHazel/pcre2/releases/download/pcre2-$PCRE2_VERSION/pcre2-$PCRE2_VERSION.zip
|
||||||
|
ARG OPENSSL_URL=https://www.openssl.org/source/openssl-$OPENSSL_VERSION.tar.gz
|
||||||
|
|
||||||
|
ENV ZBX_VERSION=$ZBX_VERSION `
|
||||||
|
BUILD_ARCH=$BUILD_ARCH CPU_MODEL=$CPU_MODEL `
|
||||||
|
GIT_URL=$GIT_URL `
|
||||||
|
GOLANG_VERSION=$GOLANG_VERSION MSYS2_URL=$MSYS2_URL `
|
||||||
|
PCRE2_VERSION=$PCRE2_VERSION OPENSSL_VERSION=$OPENSSL_VERSION `
|
||||||
|
PCRE2_URL=$PCRE2_URL OPENSSL_URL=$OPENSSL_URL `
|
||||||
|
CHERE_INVOKING=yes MSYSTEM=$MSYSTEM
|
||||||
|
|
||||||
|
LABEL org.opencontainers.image.title="Zabbix agent 2 build base for Windows" `
|
||||||
|
org.opencontainers.image.authors="Alexey Pustovalov <alexey.pustovalov@zabbix.com>" `
|
||||||
|
org.opencontainers.image.vendor="Zabbix SIA" `
|
||||||
|
org.opencontainers.image.url="https://zabbix.com/" `
|
||||||
|
org.opencontainers.image.description="Zabbix build base image contains all required packages to build Zabbix agent 2 images" `
|
||||||
|
org.opencontainers.image.licenses="AGPL v3.0" `
|
||||||
|
org.opencontainers.image.documentation="https://www.zabbix.com/documentation/${MAJOR_VERSION}/manual/installation/containers" `
|
||||||
|
org.opencontainers.image.version="${ZBX_VERSION}"
|
||||||
|
|
||||||
|
SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
|
||||||
|
|
||||||
|
RUN Set-Location -Path $env:SystemDrive\.; `
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
$env:PATH = [string]::Format('{0}\mingw64\bin;{0}\go\bin;{0}\git\cmd;{0}\git\mingw64\bin;{0}\git\usr\bin;{1}\7-Zip;', $env:SystemDrive, ${env:ProgramFiles}) + $env:PATH; `
|
||||||
|
$env:PATH = $env:PATH + [string]::Format(';{0}\msys64\usr\bin;{0}\msys64\{1}\bin', $env:SystemDrive, $env:MSYSTEM.ToLower()); `
|
||||||
|
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
$env:BUILD_OUTPUT = [string]::Format('{0}\build_output', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_OUTPUT', $env:BUILD_OUTPUT, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
$env:BUILD_SRC = [string]::Format('{0}\build_src', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_SRC', $env:BUILD_SRC, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GIT_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\git.zip -Uri $env:GIT_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '273f55e881094d00877d64f56570b0c997c4da5dedcb26738d56481033c1eba1'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\git.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum GIT for Windows ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GOLANG_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\go_lang.zip -Uri $env:GOLANG_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'cab2af6951a6e2115824263f6df13ff069c47270f5788714fa1d776f7f60cb39'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\go_lang.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum Go Lang ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:VS_BUILDTOOLS_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\vs_buildtools.exe $env:VS_BUILDTOOLS_URL; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:MSYS2_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\msys2.sfx.exe -Uri $(Invoke-RestMethod -UseBasicParsing $env:MSYS2_URL | `
|
||||||
|
Select -ExpandProperty "assets" | `
|
||||||
|
Select -ExpandProperty "browser_download_url" | `
|
||||||
|
Select-String -Pattern '.sfx.exe$').ToString(); `
|
||||||
|
`
|
||||||
|
$sha256 = 'D96C53ECBFA4B9D81F6C58077965BB2E31472A8BDA4D4446EF8F45F9C601B11D'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\msys2.sfx.exe -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ((Get-FileHash $env:TEMP\msys2.sfx.exe -Algorithm sha256).Hash -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum MSYS2 ({0}) failed!' -f $d_sha256); `
|
||||||
|
# exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing GIT...'; `
|
||||||
|
Expand-Archive `
|
||||||
|
-Path $env:TEMP\git.zip `
|
||||||
|
-DestinationPath $env:SystemDrive\git\.; `
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("git version") ...'; `
|
||||||
|
git version; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing Go Lang...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\go_lang.zip -DestinationPath $env:SystemDrive\; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("go version") ...'; `
|
||||||
|
go version; `
|
||||||
|
`
|
||||||
|
`
|
||||||
|
Write-Host 'Installing MSYS2...'; `
|
||||||
|
& $env:TEMP\msys2.sfx.exe -y -o"""$env:SystemDrive\""" | Out-Null; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --sync --quiet --noconfirm mingw-w64-clang-x86_64-gcc-compat mingw-w64-clang-x86_64-cmake mingw-w64-clang-x86_64-make'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Scc'; `
|
||||||
|
bash -lc 'rm -rf /usr/share/man/* /usr/share/doc/* /usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/usr/share/man/* /$MSYSTEM/usr/share/doc/* /$MSYSTEM/usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/share/man/* /$MSYSTEM/share/doc/* /$MSYSTEM/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /var/cache/pacman/pkg/*'; `
|
||||||
|
taskkill /F /FI 'MODULES eq msys-2.0.dll' | Out-Null; `
|
||||||
|
compact /c /i /s:$env:SystemDrive\msys64 | Out-Null; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("bash --version") ...'; `
|
||||||
|
bash --version; `
|
||||||
|
`
|
||||||
|
Write-Host ('{0} - Visual Studio components installing...' -f $(Get-Date -format 'u')); `
|
||||||
|
cmd /C start /w $env:TEMP\vs_buildtools.exe `
|
||||||
|
--quiet `
|
||||||
|
--wait `
|
||||||
|
--norestart `
|
||||||
|
--nocache `
|
||||||
|
--installPath """${env:ProgramFiles(x86)}\Microsoft Visual Studio\2022\BuildTools""" `
|
||||||
|
--channelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--installChannelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--channelId VisualStudio.17.Release `
|
||||||
|
# https://docs.microsoft.com/en-us/visualstudio/install/workload-component-id-vs-build-tools?view=vs-2022
|
||||||
|
--add Microsoft.VisualStudio.Component.VC.Tools.x86.x64; `
|
||||||
|
if ($err = dir $Env:TEMP -Filter dd_setup_*_errors.log | where Length -gt 0 | Get-Content) { `
|
||||||
|
throw $err; `
|
||||||
|
}; `
|
||||||
|
Wait-Process -name msiexec; `
|
||||||
|
Write-Host ('{0} - Visual Studio components installed' -f $(Get-Date -format 'u')); `
|
||||||
|
`
|
||||||
|
$env:VS_PATH = &(Join-Path ${env:ProgramFiles(x86)} """\Microsoft Visual Studio\Installer\vswhere.exe""") -latest -products Microsoft.VisualStudio.Product.BuildTools -property installationPath; `
|
||||||
|
[Environment]::SetEnvironmentVariable('VS_PATH', $env:VS_PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host 'Visual Studio components installation cleanup'; `
|
||||||
|
Get-ChildItem -Path """${env:ProgramFiles(x86)}\Microsoft Visual Studio\Installer""" -Directory -Recurse | Remove-Item -Force -Recurse; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*; `
|
||||||
|
Write-Host 'Build environment is ready...'; `
|
||||||
|
`
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_OUTPUT -Force | Out-Null; `
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_SRC -Force | Out-Null; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:PCRE2_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\pcre2.zip -Uri $env:PCRE2_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'F2816E84DD7A402068797501BF69E24ECA18D882ADB2143DE9F831F39B850257'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\pcre2.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum PCRE2 library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:OPENSSL_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\openssl.tar.gz -Uri $env:OPENSSL_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '53E66B043322A606ABF0087E7699A0E033A37FA13FEB9742DF35C3A33B18FB02'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\openssl.tar.gz -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum OpenSSL library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting PCRE2 archive ...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\pcre2.zip -DestinationPath $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded ...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\pcre2.zip; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\pcre2-$env:PCRE2_VERSION -NewName $env:BUILD_SRC\pcre2; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting OpenSSL archive ...'; `
|
||||||
|
$env:SystemDirectory = [Environment]::SystemDirectory; `
|
||||||
|
tar -zxf "$env:TEMP\openssl.tar.gz"; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\openssl.tar.gz; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\openssl-$env:OPENSSL_VERSION -NewName $env:BUILD_SRC\openssl; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building PCRE2 library ...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\pcre2; `
|
||||||
|
cmake --log-level=ERROR `
|
||||||
|
-G 'MinGW Makefiles' `
|
||||||
|
-DBUILD_SHARED_LIBS=OFF `
|
||||||
|
-DBUILD_STATIC_LIBS=ON `
|
||||||
|
-DPCRE2_DEBUG=OFF `
|
||||||
|
-DPCRE2_BUILD_TESTS=OFF `
|
||||||
|
-DINSTALL_MSVC_PDB=OFF `
|
||||||
|
-DCMAKE_C_COMPILER=gcc `
|
||||||
|
-DCMAKE_C_FLAGS='-O2 -g' `
|
||||||
|
-DCMAKE_INSTALL_PREFIX="""$env:BUILD_OUTPUT\pcre2""" . ; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS"""; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\man -Force -Recurse; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\share -Force -Recurse; `
|
||||||
|
Write-Host 'PCRE2 is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building OpenSSL library...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\openssl; `
|
||||||
|
perl Configure `
|
||||||
|
mingw64 `
|
||||||
|
no-shared `
|
||||||
|
no-ui-console `
|
||||||
|
no-tests `
|
||||||
|
no-unit-test `
|
||||||
|
no-capieng `
|
||||||
|
--api=1.1.0 `
|
||||||
|
--libdir=lib `
|
||||||
|
--prefix=$env:BUILD_OUTPUT/openssl `
|
||||||
|
--openssldir=$env:BUILD_OUTPUT/openssl_ssl; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" build_sw; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install_dev; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Write-Host 'OpenSSL is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*;
|
278
Dockerfiles/build-base/windows/Dockerfile_msvcrt.agent2
Normal file
278
Dockerfiles/build-base/windows/Dockerfile_msvcrt.agent2
Normal file
@ -0,0 +1,278 @@
|
|||||||
|
# syntax=docker/dockerfile:1
|
||||||
|
# escape=`
|
||||||
|
ARG BUILD_BASE_IMAGE=mcr.microsoft.com/windows/servercore:ltsc2022
|
||||||
|
FROM $BUILD_BASE_IMAGE as builder_base
|
||||||
|
|
||||||
|
ARG PCRE2_VERSION=10.43
|
||||||
|
ARG OPENSSL_VERSION=3.3.0
|
||||||
|
ARG GOLANG_VERSION=1.22.3
|
||||||
|
ARG SEVEN_ZIP_VERSION=2405
|
||||||
|
|
||||||
|
ARG MSYSTEM=MINGW64
|
||||||
|
|
||||||
|
ARG BUILD_ARCH=x64
|
||||||
|
ARG CPU_MODEL=AMD64
|
||||||
|
|
||||||
|
ARG MAJOR_VERSION=7.0
|
||||||
|
ARG ZBX_VERSION=${MAJOR_VERSION}
|
||||||
|
|
||||||
|
ARG GIT_URL=https://github.com/git-for-windows/git/releases/download/v2.33.0.windows.2/MinGit-2.33.0.2-busybox-64-bit.zip
|
||||||
|
ARG SEVEN_ZIP_URL=https://www.7-zip.org/a/7z$SEVEN_ZIP_VERSION-$BUILD_ARCH.msi
|
||||||
|
|
||||||
|
ARG MINGW_URL=https://github.com/niXman/mingw-builds-binaries/releases/download/13.2.0-rt_v11-rev1/x86_64-13.2.0-release-win32-seh-msvcrt-rt_v11-rev1.7z
|
||||||
|
ARG VS_BUILDTOOLS_URL=https://aka.ms/vs/17/release/vs_buildtools.exe
|
||||||
|
ARG GOLANG_URL=https://go.dev/dl/go$GOLANG_VERSION.windows-amd64.zip
|
||||||
|
ARG MSYS2_URL=https://api.github.com/repos/msys2/msys2-installer/releases/latest
|
||||||
|
|
||||||
|
ARG PCRE2_URL=https://github.com/PhilipHazel/pcre2/releases/download/pcre2-$PCRE2_VERSION/pcre2-$PCRE2_VERSION.zip
|
||||||
|
ARG OPENSSL_URL=https://www.openssl.org/source/openssl-$OPENSSL_VERSION.tar.gz
|
||||||
|
|
||||||
|
ENV ZBX_VERSION=$ZBX_VERSION `
|
||||||
|
BUILD_ARCH=$BUILD_ARCH CPU_MODEL=$CPU_MODEL `
|
||||||
|
GIT_URL=$GIT_URL SEVEN_ZIP_VERSION=$SEVEN_ZIP_VERSION `
|
||||||
|
MINGW_URL=$MINGW_URL VS_BUILDTOOLS_URL=$VS_BUILDTOOLS_URL GOLANG_VERSION=$GOLANG_VERSION MSYS2_URL=$MSYS2_URL `
|
||||||
|
PCRE2_VERSION=$PCRE2_VERSION OPENSSL_VERSION=$OPENSSL_VERSION `
|
||||||
|
PCRE2_URL=$PCRE2_URL OPENSSL_URL=$OPENSSL_URL `
|
||||||
|
CHERE_INVOKING=yes MSYSTEM=$MSYSTEM
|
||||||
|
|
||||||
|
LABEL org.opencontainers.image.title="Zabbix agent 2 build base for Windows" `
|
||||||
|
org.opencontainers.image.authors="Alexey Pustovalov <alexey.pustovalov@zabbix.com>" `
|
||||||
|
org.opencontainers.image.vendor="Zabbix SIA" `
|
||||||
|
org.opencontainers.image.url="https://zabbix.com/" `
|
||||||
|
org.opencontainers.image.description="Zabbix build base image contains all required packages to build Zabbix agent 2 images" `
|
||||||
|
org.opencontainers.image.licenses="AGPL v3.0" `
|
||||||
|
org.opencontainers.image.documentation="https://www.zabbix.com/documentation/${MAJOR_VERSION}/manual/installation/containers" `
|
||||||
|
org.opencontainers.image.version="${ZBX_VERSION}"
|
||||||
|
|
||||||
|
SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
|
||||||
|
|
||||||
|
RUN Set-Location -Path $env:SystemDrive\.; `
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
$env:PATH = [string]::Format('{0}\mingw64\bin;{0}\go\bin;{0}\git\cmd;{0}\git\mingw64\bin;{0}\git\usr\bin;{1}\7-Zip;', $env:SystemDrive, ${env:ProgramFiles}) + $env:PATH; `
|
||||||
|
$env:PATH = $env:PATH + [string]::Format(';{0}\msys64\usr\bin;{0}\msys64\{1}\bin', $env:SystemDrive, $env:MSYSTEM.ToLower()); `
|
||||||
|
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
$env:BUILD_OUTPUT = [string]::Format('{0}\build_output', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_OUTPUT', $env:BUILD_OUTPUT, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
$env:BUILD_SRC = [string]::Format('{0}\build_src', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_SRC', $env:BUILD_SRC, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GIT_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\git.zip -Uri $env:GIT_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '273f55e881094d00877d64f56570b0c997c4da5dedcb26738d56481033c1eba1'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\git.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum GIT for Windows ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:SEVEN_ZIP_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\7z.msi -Uri $env:SEVEN_ZIP_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '0F6AA6596D418B1694F62C8583DE05D24589B8D7FFACCE5A7DAB52AE71F832B6'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\7z.msi -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum 7-zip ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GOLANG_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\go_lang.zip -Uri $env:GOLANG_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'cab2af6951a6e2115824263f6df13ff069c47270f5788714fa1d776f7f60cb39'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\go_lang.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum Go Lang ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:MINGW_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\mingw.7z -Uri $env:MINGW_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '15B914F38F2F2E2D6F7B9B8425FF22B7E406878B01920190B09CE0DD8259C6AA'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\mingw.7z -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum Mingw-w64 ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:MSYS2_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\msys2.sfx.exe -Uri $(Invoke-RestMethod -UseBasicParsing $env:MSYS2_URL | `
|
||||||
|
Select -ExpandProperty "assets" | `
|
||||||
|
Select -ExpandProperty "browser_download_url" | `
|
||||||
|
Select-String -Pattern '.sfx.exe$').ToString(); `
|
||||||
|
`
|
||||||
|
$sha256 = 'D96C53ECBFA4B9D81F6C58077965BB2E31472A8BDA4D4446EF8F45F9C601B11D'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\msys2.sfx.exe -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum MSYS2 ({0}) failed!' -f $d_sha256); `
|
||||||
|
# exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:VS_BUILDTOOLS_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\vs_buildtools.exe $env:VS_BUILDTOOLS_URL; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing GIT...'; `
|
||||||
|
Expand-Archive `
|
||||||
|
-Path $env:TEMP\git.zip `
|
||||||
|
-DestinationPath $env:SystemDrive\git\.; `
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("git version") ...'; `
|
||||||
|
git version; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing 7z...'; `
|
||||||
|
Start-Process `
|
||||||
|
-FilePath $env:TEMP\7z.msi `
|
||||||
|
-Wait `
|
||||||
|
-ArgumentList '/qn /norestart'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("7z -h") ...'; `
|
||||||
|
7z -h | Select -first 2; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing Go Lang...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\go_lang.zip -DestinationPath $env:SystemDrive\; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("go version") ...'; `
|
||||||
|
go version; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing Mingw-w64...'; `
|
||||||
|
7z x $env:TEMP\mingw.7z; `
|
||||||
|
compact /c /i /s:$env:SystemDrive\mingw64 | Out-Null; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("gcc -v") ...'; `
|
||||||
|
gcc -v; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing MSYS2...'; `
|
||||||
|
& $env:TEMP\msys2.sfx.exe -y -o"""$env:SystemDrive\""" | Out-Null; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Syuu'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --sync --quiet --noconfirm mingw-w64-x86_64-cmake'; `
|
||||||
|
bash -lc 'pacman --noprogressbar --noconfirm -Scc'; `
|
||||||
|
bash -lc 'rm -rf /usr/share/man/* /usr/share/doc/* /usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/usr/share/man/* /$MSYSTEM/usr/share/doc/* /$MSYSTEM/usr/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /$MSYSTEM/share/man/* /$MSYSTEM/share/doc/* /$MSYSTEM/share/locale/*'; `
|
||||||
|
bash -lc 'rm -rf /var/cache/pacman/pkg/*'; `
|
||||||
|
taskkill /F /FI 'MODULES eq msys-2.0.dll' | Out-Null; `
|
||||||
|
compact /c /i /s:$env:SystemDrive\msys64 | Out-Null; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("bash --version") ...'; `
|
||||||
|
bash --version; `
|
||||||
|
`
|
||||||
|
Write-Host ('{0} - Visual Studio components installing...' -f $(Get-Date -format 'u')); `
|
||||||
|
cmd /C start /w $env:TEMP\vs_buildtools.exe `
|
||||||
|
--quiet `
|
||||||
|
--wait `
|
||||||
|
--norestart `
|
||||||
|
--nocache `
|
||||||
|
--installPath """${env:ProgramFiles(x86)}\Microsoft Visual Studio\2022\BuildTools""" `
|
||||||
|
--channelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--installChannelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--channelId VisualStudio.17.Release `
|
||||||
|
# https://docs.microsoft.com/en-us/visualstudio/install/workload-component-id-vs-build-tools?view=vs-2022
|
||||||
|
--add Microsoft.VisualStudio.Component.VC.Tools.x86.x64; `
|
||||||
|
if ($err = dir $Env:TEMP -Filter dd_setup_*_errors.log | where Length -gt 0 | Get-Content) { `
|
||||||
|
throw $err; `
|
||||||
|
}; `
|
||||||
|
Wait-Process -name msiexec; `
|
||||||
|
Write-Host ('{0} - Visual Studio components installed' -f $(Get-Date -format 'u')); `
|
||||||
|
`
|
||||||
|
$env:VS_PATH = &(Join-Path ${env:ProgramFiles(x86)} """\Microsoft Visual Studio\Installer\vswhere.exe""") -latest -products Microsoft.VisualStudio.Product.BuildTools -property installationPath; `
|
||||||
|
[Environment]::SetEnvironmentVariable('VS_PATH', $env:VS_PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host 'Visual Studio components installation cleanup'; `
|
||||||
|
Get-ChildItem -Path """${env:ProgramFiles(x86)}\Microsoft Visual Studio\Installer""" -Directory -Recurse | Remove-Item -Force -Recurse; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*; `
|
||||||
|
Write-Host 'Build environment is ready...'; `
|
||||||
|
`
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_OUTPUT -Force | Out-Null; `
|
||||||
|
New-Item -ItemType directory -Path $env:BUILD_SRC -Force | Out-Null; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:PCRE2_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\pcre2.zip -Uri $env:PCRE2_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'F2816E84DD7A402068797501BF69E24ECA18D882ADB2143DE9F831F39B850257'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\pcre2.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum PCRE2 library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:OPENSSL_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\openssl.tar.gz -Uri $env:OPENSSL_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '53E66B043322A606ABF0087E7699A0E033A37FA13FEB9742DF35C3A33B18FB02'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\openssl.tar.gz -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum OpenSSL library ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting PCRE2 archive ...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\pcre2.zip -DestinationPath $env:BUILD_SRC; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded ...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\pcre2.zip; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\pcre2-$env:PCRE2_VERSION -NewName $env:BUILD_SRC\pcre2; `
|
||||||
|
`
|
||||||
|
Write-Host 'Extracting OpenSSL archive ...'; `
|
||||||
|
$env:SystemDirectory = [Environment]::SystemDirectory; `
|
||||||
|
tar -zxf "$env:TEMP\openssl.tar.gz"; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Path $env:TEMP\openssl.tar.gz; `
|
||||||
|
Rename-Item -Path $env:BUILD_SRC\openssl-$env:OPENSSL_VERSION -NewName $env:BUILD_SRC\openssl; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building PCRE2 library ...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\pcre2; `
|
||||||
|
cmake --log-level=ERROR `
|
||||||
|
-G 'MinGW Makefiles' `
|
||||||
|
-DBUILD_SHARED_LIBS=OFF `
|
||||||
|
-DBUILD_STATIC_LIBS=ON `
|
||||||
|
-DPCRE2_DEBUG=OFF `
|
||||||
|
-DPCRE2_BUILD_TESTS=OFF `
|
||||||
|
-DINSTALL_MSVC_PDB=OFF `
|
||||||
|
-DCMAKE_C_COMPILER=gcc `
|
||||||
|
-DCMAKE_C_FLAGS='-O2 -g' `
|
||||||
|
-DCMAKE_INSTALL_PREFIX="""$env:BUILD_OUTPUT\pcre2""" . ; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS"""; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\man -Force -Recurse; `
|
||||||
|
Remove-Item -Path $env:BUILD_OUTPUT\pcre2\share -Force -Recurse; `
|
||||||
|
Write-Host 'PCRE2 is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Building OpenSSL library...'; `
|
||||||
|
Set-Location -Path $env:BUILD_SRC\openssl; `
|
||||||
|
perl Configure `
|
||||||
|
mingw64 `
|
||||||
|
no-shared `
|
||||||
|
no-ui-console `
|
||||||
|
no-tests `
|
||||||
|
no-unit-test `
|
||||||
|
no-capieng `
|
||||||
|
--api=1.1.0 `
|
||||||
|
--libdir=lib `
|
||||||
|
--prefix=$env:BUILD_OUTPUT/openssl `
|
||||||
|
--openssldir=$env:BUILD_OUTPUT/openssl_ssl; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" build_sw; `
|
||||||
|
mingw32-make -s -j"""$env:NUMBER_OF_PROCESSORS""" install_dev; `
|
||||||
|
mingw32-make -s clean | Out-Null; `
|
||||||
|
Write-Host 'OpenSSL is ready...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*;
|
141
Dockerfiles/build-base/windows/Dockerfile_vcpkg.agent2
Normal file
141
Dockerfiles/build-base/windows/Dockerfile_vcpkg.agent2
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
# syntax=docker/dockerfile:1
|
||||||
|
# escape=`
|
||||||
|
ARG BUILD_BASE_IMAGE=mcr.microsoft.com/windows/servercore:ltsc2022
|
||||||
|
FROM $BUILD_BASE_IMAGE as builder_base
|
||||||
|
|
||||||
|
ARG GOLANG_VERSION=1.22.3
|
||||||
|
|
||||||
|
ARG BUILD_ARCH=x64
|
||||||
|
ARG CPU_MODEL=AMD64
|
||||||
|
|
||||||
|
ARG MAJOR_VERSION=7.0
|
||||||
|
ARG ZBX_VERSION=${MAJOR_VERSION}
|
||||||
|
|
||||||
|
ARG GIT_URL=https://github.com/git-for-windows/git/releases/download/v2.33.0.windows.2/MinGit-2.33.0.2-busybox-64-bit.zip
|
||||||
|
|
||||||
|
ARG VS_BUILDTOOLS_URL=https://aka.ms/vs/17/release/vs_buildtools.exe
|
||||||
|
ARG GOLANG_URL=https://go.dev/dl/go$GOLANG_VERSION.windows-amd64.zip
|
||||||
|
ARG LLVM_MINGW=https://github.com/mstorsjo/llvm-mingw/releases/download/20240502/llvm-mingw-20240502-ucrt-x86_64.zip
|
||||||
|
ARG VCPKG_GIT=https://github.com/microsoft/vcpkg
|
||||||
|
|
||||||
|
ENV ZBX_VERSION=$ZBX_VERSION `
|
||||||
|
BUILD_ARCH=$BUILD_ARCH CPU_MODEL=$CPU_MODEL `
|
||||||
|
GIT_URL=$GIT_URL `
|
||||||
|
GOLANG_VERSION=$GOLANG_VERSION LLVM_MINGW=$LLVM_MINGW VCPKG_GIT=$VCPKG_GIT `
|
||||||
|
VCPKG_BINARY_SOURCES=clear VCPKG_DEFAULT_TRIPLET=$BUILD_ARCH-mingw-static-release
|
||||||
|
|
||||||
|
LABEL org.opencontainers.image.title="Zabbix agent 2 build base for Windows" `
|
||||||
|
org.opencontainers.image.authors="Alexey Pustovalov <alexey.pustovalov@zabbix.com>" `
|
||||||
|
org.opencontainers.image.vendor="Zabbix SIA" `
|
||||||
|
org.opencontainers.image.url="https://zabbix.com/" `
|
||||||
|
org.opencontainers.image.description="Zabbix build base image contains all required packages to build Zabbix agent 2 images" `
|
||||||
|
org.opencontainers.image.licenses="AGPL v3.0" `
|
||||||
|
org.opencontainers.image.documentation="https://www.zabbix.com/documentation/${MAJOR_VERSION}/manual/installation/containers" `
|
||||||
|
org.opencontainers.image.version="${ZBX_VERSION}"
|
||||||
|
|
||||||
|
SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
|
||||||
|
|
||||||
|
RUN Set-Location -Path $env:SystemDrive\.; `
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; `
|
||||||
|
`
|
||||||
|
$env:PATH = [string]::Format('{0}\vcpkg;{0}\llvm_mingw\bin;{0}\go\bin;{0}\git\cmd;{0}\git\mingw64\bin;{0}\git\usr\bin;', $env:SystemDrive, ${env:ProgramFiles}) + $env:PATH; `
|
||||||
|
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
$env:BUILD_OUTPUT = [string]::Format('{0}\build_output', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_OUTPUT', $env:BUILD_OUTPUT, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
$env:BUILD_SRC = [string]::Format('{0}\build_src', $env:SystemDrive); `
|
||||||
|
[Environment]::SetEnvironmentVariable('BUILD_SRC', $env:BUILD_SRC, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GIT_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\git.zip -Uri $env:GIT_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = '273f55e881094d00877d64f56570b0c997c4da5dedcb26738d56481033c1eba1'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\git.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum GIT for Windows ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:GOLANG_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\go_lang.zip -Uri $env:GOLANG_URL; `
|
||||||
|
`
|
||||||
|
$sha256 = 'cab2af6951a6e2115824263f6df13ff069c47270f5788714fa1d776f7f60cb39'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\go_lang.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ($d_sha256 -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum Go Lang ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:LLVM_MINGW); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\llvm_mingw.zip -Uri $env:LLVM_MINGW; `
|
||||||
|
`
|
||||||
|
$sha256 = '2487683A7341FFA4D0C1D107268D22DC722A43EA2E7C7F46DA0648E34F4F4C8B'; `
|
||||||
|
$d_sha256 = (Get-FileHash $env:TEMP\llvm_mingw.zip -Algorithm sha256).Hash; `
|
||||||
|
Write-Host ('Verifying SHA256 ({0}) ...' -f $sha256); `
|
||||||
|
if ((Get-FileHash $env:TEMP\llvm_mingw.zip -Algorithm sha256).Hash -ne $sha256) { `
|
||||||
|
Write-Host ('Checksum LLVM MinGW ({0}) failed!' -f $d_sha256); `
|
||||||
|
exit 1; `
|
||||||
|
}; `
|
||||||
|
`
|
||||||
|
Write-Host ('Downloading {0} ...' -f $env:VS_BUILDTOOLS_URL); `
|
||||||
|
Invoke-WebRequest -OutFile $env:TEMP\vs_buildtools.exe $env:VS_BUILDTOOLS_URL; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing GIT...'; `
|
||||||
|
Expand-Archive `
|
||||||
|
-Path $env:TEMP\git.zip `
|
||||||
|
-DestinationPath $env:SystemDrive\git\.; `
|
||||||
|
Write-Host 'Removing downloaded...'; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("git version") ...'; `
|
||||||
|
git version; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing Go Lang...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\go_lang.zip -DestinationPath $env:SystemDrive\; `
|
||||||
|
Write-Host 'Verifying install ("go version") ...'; `
|
||||||
|
go version; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing LLVM MinGW ...'; `
|
||||||
|
Expand-Archive -Path $env:TEMP\llvm_mingw.zip -DestinationPath $env:SystemDrive\; `
|
||||||
|
Move-Item -Path $env:SystemDrive\llvm-mingw-20240502-ucrt-x86_64\ -Destination $env:SystemDrive\llvm_mingw; `
|
||||||
|
`
|
||||||
|
Write-Host 'Verifying install ("git version") ...'; `
|
||||||
|
gcc -v; `
|
||||||
|
`
|
||||||
|
Write-Host ('{0} - Visual Studio components installing...' -f $(Get-Date -format 'u')); `
|
||||||
|
cmd /C start /w $env:TEMP\vs_buildtools.exe `
|
||||||
|
--quiet `
|
||||||
|
--wait `
|
||||||
|
--norestart `
|
||||||
|
--nocache `
|
||||||
|
--installPath """${env:ProgramFiles(x86)}\Microsoft Visual Studio\2022\BuildTools""" `
|
||||||
|
--channelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--installChannelUri https://aka.ms/vs/17/release/channel `
|
||||||
|
--channelId VisualStudio.17.Release `
|
||||||
|
# https://docs.microsoft.com/en-us/visualstudio/install/workload-component-id-vs-build-tools?view=vs-2022
|
||||||
|
--add Microsoft.VisualStudio.Component.VC.Tools.x86.x64; `
|
||||||
|
if ($err = dir $Env:TEMP -Filter dd_setup_*_errors.log | where Length -gt 0 | Get-Content) { `
|
||||||
|
throw $err; `
|
||||||
|
}; `
|
||||||
|
Wait-Process -name msiexec; `
|
||||||
|
Write-Host ('{0} - Visual Studio components installed' -f $(Get-Date -format 'u')); `
|
||||||
|
`
|
||||||
|
$env:VS_PATH = &(Join-Path ${env:ProgramFiles(x86)} """\Microsoft Visual Studio\Installer\vswhere.exe""") -latest -products Microsoft.VisualStudio.Product.BuildTools -property installationPath; `
|
||||||
|
[Environment]::SetEnvironmentVariable('VS_PATH', $env:VS_PATH, [EnvironmentVariableTarget]::Machine); `
|
||||||
|
`
|
||||||
|
Write-Host 'Visual Studio components installation cleanup'; `
|
||||||
|
Get-ChildItem -Path """${env:ProgramFiles(x86)}\Microsoft Visual Studio\Installer""" -Directory -Recurse | Remove-Item -Force -Recurse; `
|
||||||
|
`
|
||||||
|
Write-Host 'Installing Vcpkg ...'; `
|
||||||
|
$env:VCPKG_DEFAULT_BINARY_CACHE = $env:TEMP; `
|
||||||
|
git clone $env:VCPKG_GIT $env:SystemDrive\vcpkg; `
|
||||||
|
& $env:SystemDrive\vcpkg\bootstrap-vcpkg.bat -disableMetrics; `
|
||||||
|
Copy-Item $env:SystemDrive\vcpkg\triplets\community\$env:BUILD_ARCH-mingw-static.cmake -Destination $env:SystemDrive\vcpkg\triplets\community\$env:VCPKG_DEFAULT_TRIPLET.cmake; `
|
||||||
|
Add-Content -Path $env:SystemDrive\vcpkg\triplets\community\$env:VCPKG_DEFAULT_TRIPLET.cmake -Value """set(VCPKG_BUILD_TYPE release)"""; `
|
||||||
|
Write-Host 'Installing dependencies ...'; `
|
||||||
|
vcpkg install libiconv pcre2 openssl; `
|
||||||
|
`
|
||||||
|
Write-Host 'Removing downloaded ...'; `
|
||||||
|
Remove-Item -Force -Recurse $env:TEMP\*; `
|
||||||
|
Write-Host 'Build environment is ready...';
|
Loading…
Reference in New Issue
Block a user