mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-23 05:41:19 -05:00
Build GCP guest agent from github actions in constellation repo
This commit is contained in:
parent
23dfc5549b
commit
abb4fb4f0f
67
.github/workflows/build-gcp-guest-agent.yml
vendored
Normal file
67
.github/workflows/build-gcp-guest-agent.yml
vendored
Normal file
@ -0,0 +1,67 @@
|
||||
name: Build and Upload GCP guest-agent container
|
||||
env:
|
||||
REGISTRY: ghcr.io
|
||||
on: [workflow_dispatch]
|
||||
|
||||
# Abort runs of *this* workflow, if a new commit with the same ref is pushed.
|
||||
concurrency:
|
||||
group: ${{ github.workflow }}-${{ github.ref }}
|
||||
cancel-in-progress: true
|
||||
|
||||
jobs:
|
||||
build-gcp-guest-agent:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
strategy:
|
||||
matrix:
|
||||
version: ["20220713.00"]
|
||||
include:
|
||||
- version: "20220713.00"
|
||||
latest: true
|
||||
steps:
|
||||
- uses: actions/checkout@2541b1294d2704b0964813337f33b291d3f8596b
|
||||
with:
|
||||
repository: "GoogleCloudPlatform/guest-agent"
|
||||
ref: refs/tags/${{ matrix.version }}
|
||||
path: "guest-agent"
|
||||
|
||||
- uses: actions/checkout@2541b1294d2704b0964813337f33b291d3f8596b
|
||||
with:
|
||||
path: "constellation"
|
||||
|
||||
- name: Docker meta
|
||||
id: meta
|
||||
uses: docker/metadata-action@69f6fc9d46f2f8bf0d5491e4aabe0bb8c6a4678a
|
||||
with:
|
||||
images: |
|
||||
${{ env.REGISTRY }}/edgelesssys/gcp-guest-agent
|
||||
flavor: |
|
||||
latest=${{ matrix.latest || false }}
|
||||
tags: |
|
||||
type=raw,value=${{ matrix.version }}
|
||||
- name: Set up Docker Buildx
|
||||
id: docker-setup
|
||||
uses: docker/setup-buildx-action@dc7b9719a96d48369863986a06765841d7ea23f6
|
||||
- name: Log in to the Container registry
|
||||
id: docker-login
|
||||
uses: docker/login-action@49ed152c8eca782a232dede0303416e8f356c37b
|
||||
with:
|
||||
registry: ${{ env.REGISTRY }}
|
||||
username: ${{ github.actor }}
|
||||
password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
- name: Prepare hardcoded configuration file
|
||||
run: |
|
||||
cp "${GITHUB_WORKSPACE}/constellation/3rdparty/gcp-guest-agent/instance_configs.cfg" "${GITHUB_WORKSPACE}/guest-agent/"
|
||||
|
||||
- name: Build and push container image
|
||||
id: build
|
||||
uses: docker/build-push-action@c84f38281176d4c9cdb1626ffafcd6b3911b5d94
|
||||
with:
|
||||
context: ./guest-agent
|
||||
file: ./constellation/3rdparty/gcp-guest-agent/Dockerfile
|
||||
push: true
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
31
3rdparty/gcp-guest-agent/Dockerfile
vendored
Normal file
31
3rdparty/gcp-guest-agent/Dockerfile
vendored
Normal file
@ -0,0 +1,31 @@
|
||||
FROM ubuntu:22.04 as build
|
||||
|
||||
# Install packages
|
||||
RUN apt-get update && apt-get install -y \
|
||||
wget \
|
||||
git
|
||||
|
||||
# Install Go
|
||||
ARG GO_VER=1.18
|
||||
RUN wget https://go.dev/dl/go${GO_VER}.linux-amd64.tar.gz && \
|
||||
tar -C /usr/local -xzf go${GO_VER}.linux-amd64.tar.gz && \
|
||||
rm go${GO_VER}.linux-amd64.tar.gz
|
||||
ENV PATH ${PATH}:/usr/local/go/bin
|
||||
|
||||
# Download go dependencies
|
||||
WORKDIR /src/
|
||||
COPY go.mod ./
|
||||
COPY go.sum ./
|
||||
RUN go mod download all
|
||||
|
||||
# Build
|
||||
ARG VERSION=latest
|
||||
COPY . /src
|
||||
WORKDIR /src/google_guest_agent
|
||||
RUN CGO_ENABLED=0 go build -ldflags="-s -w -X main.version=${VERSION}" -mod=readonly
|
||||
WORKDIR /
|
||||
|
||||
FROM scratch as run
|
||||
COPY --from=build /src/google_guest_agent/google_guest_agent /
|
||||
COPY instance_configs.cfg /etc/default/
|
||||
ENTRYPOINT [ "/google_guest_agent" ]
|
41
3rdparty/gcp-guest-agent/instance_configs.cfg
vendored
Normal file
41
3rdparty/gcp-guest-agent/instance_configs.cfg
vendored
Normal file
@ -0,0 +1,41 @@
|
||||
[Accounts]
|
||||
deprovision_remove = /bin/false
|
||||
gpasswd_add_cmd = /bin/false
|
||||
gpasswd_remove_cmd = /bin/false
|
||||
groupadd_cmd = /bin/false
|
||||
groups = nobody
|
||||
useradd_cmd = /bin/false
|
||||
userdel_cmd = /bin/false
|
||||
|
||||
[Daemons]
|
||||
accounts_daemon = false
|
||||
clock_skew_daemon = false
|
||||
network_daemon = true
|
||||
|
||||
[InstanceSetup]
|
||||
host_key_types = ecdsa,ed25519,rsa
|
||||
network_enabled = true
|
||||
optimize_local_ssd = false
|
||||
set_boto_config = false
|
||||
set_host_keys = false
|
||||
set_multiqueue = false
|
||||
|
||||
[IpForwarding]
|
||||
ethernet_proto_id = 66
|
||||
ip_aliases = false
|
||||
target_instance_ips = true
|
||||
|
||||
[MetadataScripts]
|
||||
default_shell = /bin/false
|
||||
run_dir =
|
||||
shutdown = false
|
||||
startup = false
|
||||
|
||||
[NetworkInterfaces]
|
||||
dhclient_script = /bin/false
|
||||
dhcp_command = /bin/false
|
||||
ip_forwarding = true
|
||||
setup = false
|
||||
|
||||
[diagnostics]
|
||||
enable = false
|
@ -13,7 +13,6 @@ type gcpGuestAgentDaemonset struct {
|
||||
}
|
||||
|
||||
// NewGCPGuestAgentDaemonset creates a new GCP Guest Agent Daemonset.
|
||||
// The GCP guest agent is built in a separate repository: https://github.com/edgelesssys/gcp-guest-agent
|
||||
// It is used automatically to add loadbalancer IPs to the local routing table of GCP instances.
|
||||
func NewGCPGuestAgentDaemonset() *gcpGuestAgentDaemonset {
|
||||
return &gcpGuestAgentDaemonset{
|
||||
@ -65,7 +64,7 @@ func NewGCPGuestAgentDaemonset() *gcpGuestAgentDaemonset {
|
||||
Containers: []k8s.Container{
|
||||
{
|
||||
Name: "gcp-guest-agent",
|
||||
Image: versions.GcpGuestImage, // built from https://github.com/edgelesssys/gcp-guest-agent
|
||||
Image: versions.GcpGuestImage,
|
||||
SecurityContext: &k8s.SecurityContext{
|
||||
Privileged: func(b bool) *bool { return &b }(true),
|
||||
Capabilities: &k8s.Capabilities{
|
||||
|
@ -34,7 +34,7 @@ const (
|
||||
AccessManagerImage = "ghcr.io/edgelesssys/constellation/access-manager:v1.4.0"
|
||||
KmsImage = "ghcr.io/edgelesssys/constellation/kmsserver:v1.4.0"
|
||||
VerificationImage = "ghcr.io/edgelesssys/constellation/verification-service:v1.4.0"
|
||||
GcpGuestImage = "ghcr.io/edgelesssys/gcp-guest-agent:latest"
|
||||
GcpGuestImage = "ghcr.io/edgelesssys/gcp-guest-agent:20220713.00"
|
||||
NodeOperatorCatalogImage = "ghcr.io/edgelesssys/constellation/node-operator-catalog"
|
||||
NodeOperatorVersion = "v1.4.1-0.20220809082533-41bdd362a18a"
|
||||
NodeMaintenanceOperatorCatalogImage = "quay.io/medik8s/node-maintenance-operator-catalog"
|
||||
|
Loading…
Reference in New Issue
Block a user