Skip to content

Commit

Permalink
build/push manifest
Browse files Browse the repository at this point in the history
  • Loading branch information
arturcic committed Jan 20, 2025
1 parent 6229b93 commit 8890a6d
Show file tree
Hide file tree
Showing 6 changed files with 161 additions and 26 deletions.
63 changes: 59 additions & 4 deletions .github/workflows/build-deps.yml
Original file line number Diff line number Diff line change
Expand Up @@ -85,26 +85,81 @@ jobs:
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: '[Build Docker images]'
- name: '[Build Docker images] DockerHub'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildDeps --arch=${{ matrix.arch }} `
--dotnet_distro=${{ matrix.distro }} --docker_registry=dockerhub `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
- name: Login to GitHub Container Registry
if: success() && env.PUSH_IMAGES == 'true'
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.DOCKER_GITHUB_TOKEN }}
- name: '[Build Docker images]'
- name: '[Build Docker images] GitHub'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildDeps --arch=${{ matrix.arch }} `
--dotnet_distro=${{ matrix.distro }} --docker_registry=github `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
build_deps_manifests:
name: Build Deps Manifests
needs: [ build_deps ]
env:
PUSH_IMAGES: ${{github.event_name != 'pull_request' && github.repository_owner == 'GitTools'}}
runs-on: ubuntu-24.04
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use cached cake frosting
id: cache-cake
uses: actions/cache@v4
with:
path: run
key: run-${{ runner.os }}-${{ hashFiles('./build/**') }}
- name: Setup .NET SDK
uses: actions/setup-dotnet@v4
with:
global-json-file: build/global.json
- name: Set up Docker
uses: docker/setup-docker-action@v4
with:
daemon-config: '{ "features": { "containerd-snapshotter": true } }'
- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v3
with:
version: 'latest'
driver-opts: 'image=moby/buildkit:buildx-stable-1'
install: true
- name: Login to DockerHub
if: success() && env.PUSH_IMAGES == 'true'
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: '[Build Docker manifests] DockerHub'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildDepsManifests `
--dotnet_distro=${{ matrix.distro }} --docker_registry=dockerhub `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
- name: Login to GitHub Container Registry
if: success() && env.PUSH_IMAGES == 'true'
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.DOCKER_GITHUB_TOKEN }}
- name: '[Build Docker manifests] GitHub'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildDepsManifests `
--dotnet_distro=${{ matrix.distro }} --docker_registry=github `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
42 changes: 42 additions & 0 deletions build/build/Tasks/BaseDockerBuildManifest.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
namespace Build;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

public abstract class BaseDockerBuildManifest : FrostingTask<BuildContext>
{
protected const string Prefix = "org.opencontainers.image";

private static readonly string[] Annotations =
[
$"{Prefix}.authors=GitTools Maintainers",
$"{Prefix}.vendor=GitTools",
$"{Prefix}.licenses=MIT",
$"{Prefix}.source=https://github.com/GitTools/build-images.git",
$"{Prefix}.created={DateTime.UtcNow:O}",
];

protected void DockerManifest(BuildContext context, DockerDepsImage dockerImage)
{
var manifestTags = dockerImage.GetDockerTags(context.DockerRegistry);
foreach (var tag in manifestTags)
{
var amd64Tag = $"{tag}-{Architecture.Amd64.ToSuffix()}";
var arm64Tag = $"{tag}-{Architecture.Arm64.ToSuffix()}";

var settings = GetManifestSettings(dockerImage, tag);
context.DockerBuildXImageToolsCreate(settings, [amd64Tag, arm64Tag]);
}
}

protected virtual DockerBuildXImageToolsCreateSettings GetManifestSettings(DockerDepsImage dockerImage, string tag)
{
var settings = new DockerBuildXImageToolsCreateSettings
{
Tag = [tag],
Annotation =
[
.. Annotations.Select(a => "index:" + a).ToArray(),
]
};
return settings;
}
}
11 changes: 0 additions & 11 deletions build/build/Tasks/DockerBuildDeps.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
using DockerBuildXBuildSettings = Build.Cake.Docker.DockerBuildXBuildSettings;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

namespace Build;

Expand All @@ -14,16 +13,6 @@ public override void Run(BuildContext context)
{
DockerImage(context, dockerImage);
}

if (!context.PushImages)
return;

// build/push manifests
// foreach (var group in context.DepsImages.GroupBy(x => new { x.Distro }))
// {
// var dockerImage = group.First();
// DockerManifest(context, dockerImage);
// }
}

protected override DirectoryPath GetWorkingDir(DockerDepsImage dockerImage) =>
Expand Down
29 changes: 29 additions & 0 deletions build/build/Tasks/DockerBuildDepsManifest.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
namespace Build;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

public class DockerBuildDepsManifest : BaseDockerBuildManifest
{
public override void Run(BuildContext context)
{
if (!context.PushImages)
return;

// build/push manifests
foreach (var group in context.DepsImages.GroupBy(x => new { x.Distro }))
{
var dockerImage = group.First();
DockerManifest(context, dockerImage);
}
}

protected override DockerBuildXImageToolsCreateSettings GetManifestSettings(DockerDepsImage dockerImage, string tag)
{
var settings = base.GetManifestSettings(dockerImage, tag);
settings.Annotation =
[
.. settings.Annotation,
$"index:{Prefix}.description=GitTools deps images ({dockerImage.Distro})"
];
return settings;
}
}
11 changes: 0 additions & 11 deletions build/build/Tasks/DockerBuildImages.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
using DockerBuildXBuildSettings = Build.Cake.Docker.DockerBuildXBuildSettings;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

namespace Build;

Expand All @@ -14,16 +13,6 @@ public override void Run(BuildContext context)
{
DockerImage(context, dockerImage);
}

if (!context.PushImages)
return;

// build/push manifests
// foreach (var group in context.Images.GroupBy(x => new { x.Distro, x.Variant, x.Version }))
// {
// var dockerImage = group.First();
// DockerManifest(context, dockerImage);
// }
}

protected override void DockerImage(BuildContext context, DockerDepsImage dockerImage)
Expand Down
31 changes: 31 additions & 0 deletions build/build/Tasks/DockerBuildImagesManifest.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
namespace Build;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

public class DockerBuildImagesManifest : BaseDockerBuildManifest
{
public override void Run(BuildContext context)
{
if (!context.PushImages)
return;

// build/push manifests
foreach (var group in context.Images.GroupBy(x => new { x.Distro, x.Variant, x.Version }))
{
var dockerImage = group.First();
DockerManifest(context, dockerImage);
}
}

protected override DockerBuildXImageToolsCreateSettings GetManifestSettings(DockerDepsImage dockerImage, string tag)
{
var (distro, version, variant, _) = (DockerImage)dockerImage;
var suffix = $"({distro}-{variant}-{version})";
var settings = base.GetManifestSettings(dockerImage, tag);
settings.Annotation =
[
.. settings.Annotation,
$"index:{Prefix}.description=GitTools build images {suffix}",
];
return settings;
}
}

0 comments on commit 8890a6d

Please sign in to comment.