From 5964008f241cd8eb0c06249bac92f9ee239aa3f4 Mon Sep 17 00:00:00 2001 From: Matthias Neugebauer Date: Wed, 18 Dec 2024 18:10:21 +0100 Subject: [PATCH] Add boilerplate for new functions --- .github/workflows/container-images.yml | 7 + Makefile | 7 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../function-data-buffer/Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../function-media-merge/Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + .../Dockerfile.generic.generic | 93 ++++++++++++ .../Dockerfile.linux.amd64 | 1 + .../function-script-lua/Dockerfile.linux.arm | 1 + .../Dockerfile.linux.arm64 | 1 + .../Dockerfile.linux.ppc64le | 1 + .../Dockerfile.linux.s390x | 1 + cmd/functions/main.go | 7 + ...ne.nagare.media_functions_data-buffer.yaml | 89 +++++++++++ ...e.nagare.media_functions_media-encode.yaml | 89 +++++++++++ ..._functions_media-generate-testpattern.yaml | 89 +++++++++++ ...ne.nagare.media_functions_media-merge.yaml | 89 +++++++++++ ...ia_functions_media-metadata-technical.yaml | 89 +++++++++++ ...are.media_functions_media-package-hls.yaml | 89 +++++++++++ ...ine.nagare.media_functions_script-lua.yaml | 89 +++++++++++ internal/functions/data-buffer/func.go | 61 ++++++++ internal/functions/media-encode/func.go | 61 ++++++++ .../media-generate-testpattern/func.go | 61 ++++++++ internal/functions/media-merge/func.go | 61 ++++++++ .../media-metadata-technical/func.go | 61 ++++++++ internal/functions/media-package-hls/func.go | 61 ++++++++ internal/functions/script-lua/func.go | 61 ++++++++ skaffold.yaml | 142 +++++++++++++++++- 60 files changed, 1891 insertions(+), 8 deletions(-) create mode 100644 build/package/image/function-data-buffer/Dockerfile.generic.generic create mode 120000 build/package/image/function-data-buffer/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-data-buffer/Dockerfile.linux.arm create mode 120000 build/package/image/function-data-buffer/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-data-buffer/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-data-buffer/Dockerfile.linux.s390x create mode 100644 build/package/image/function-media-encode/Dockerfile.generic.generic create mode 120000 build/package/image/function-media-encode/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-media-encode/Dockerfile.linux.arm create mode 120000 build/package/image/function-media-encode/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-media-encode/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-media-encode/Dockerfile.linux.s390x create mode 100644 build/package/image/function-media-generate-testpattern/Dockerfile.generic.generic create mode 120000 build/package/image/function-media-generate-testpattern/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-media-generate-testpattern/Dockerfile.linux.arm create mode 120000 build/package/image/function-media-generate-testpattern/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-media-generate-testpattern/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-media-generate-testpattern/Dockerfile.linux.s390x create mode 100644 build/package/image/function-media-merge/Dockerfile.generic.generic create mode 120000 build/package/image/function-media-merge/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-media-merge/Dockerfile.linux.arm create mode 120000 build/package/image/function-media-merge/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-media-merge/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-media-merge/Dockerfile.linux.s390x create mode 100644 build/package/image/function-media-metadata-technical/Dockerfile.generic.generic create mode 120000 build/package/image/function-media-metadata-technical/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-media-metadata-technical/Dockerfile.linux.arm create mode 120000 build/package/image/function-media-metadata-technical/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-media-metadata-technical/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-media-metadata-technical/Dockerfile.linux.s390x create mode 100644 build/package/image/function-media-package-hls/Dockerfile.generic.generic create mode 120000 build/package/image/function-media-package-hls/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-media-package-hls/Dockerfile.linux.arm create mode 120000 build/package/image/function-media-package-hls/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-media-package-hls/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-media-package-hls/Dockerfile.linux.s390x create mode 100644 build/package/image/function-script-lua/Dockerfile.generic.generic create mode 120000 build/package/image/function-script-lua/Dockerfile.linux.amd64 create mode 120000 build/package/image/function-script-lua/Dockerfile.linux.arm create mode 120000 build/package/image/function-script-lua/Dockerfile.linux.arm64 create mode 120000 build/package/image/function-script-lua/Dockerfile.linux.ppc64le create mode 120000 build/package/image/function-script-lua/Dockerfile.linux.s390x create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_data-buffer.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_media-encode.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_media-generate-testpattern.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_media-merge.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_media-metadata-technical.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_media-package-hls.yaml create mode 100644 config/samples/k8s/v1alpha1_engine.nagare.media_functions_script-lua.yaml create mode 100644 internal/functions/data-buffer/func.go create mode 100644 internal/functions/media-encode/func.go create mode 100644 internal/functions/media-generate-testpattern/func.go create mode 100644 internal/functions/media-merge/func.go create mode 100644 internal/functions/media-metadata-technical/func.go create mode 100644 internal/functions/media-package-hls/func.go create mode 100644 internal/functions/script-lua/func.go diff --git a/.github/workflows/container-images.yml b/.github/workflows/container-images.yml index 426b64a..269ae0c 100644 --- a/.github/workflows/container-images.yml +++ b/.github/workflows/container-images.yml @@ -21,8 +21,15 @@ jobs: strategy: matrix: image: + - function-data-buffer - function-generic-noop - function-generic-sleep + - function-media-encode + - function-media-generate-testpattern + - function-media-merge + - function-media-metadata-technical + - function-media-package-hls + - function-script-lua - gateway-nbmp - workflow-manager - workflow-manager-helper diff --git a/Makefile b/Makefile index 1d40622..8776e26 100644 --- a/Makefile +++ b/Makefile @@ -203,8 +203,15 @@ clean: ## Cleanup build output .PHONY: image image: $(addprefix image-, $(IMAGES)) ## Build all container images +## image-function-data-buffer: ## Build data-buffer function container image ## image-function-generic-noop: ## Build generic-noop function container image ## image-function-generic-sleep: ## Build generic-sleep function container image +## image-function-media-encode: ## Build media-encode function container image +## image-function-media-generate-testpattern: ## Build media-generate-testpattern function container image +## image-function-media-merge: ## Build media-merge function container image +## image-function-media-metadata-technical: ## Build media-metadata-technical function container image +## image-function-media-package-hls: ## Build media-package-hls function container image +## image-function-script-lua: ## Build script-lua function container image ## image-gateway-nbmp: ## Build NBMP gateway container image ## image-workflow-manager: ## Build workflow manager container image ## image-workflow-manager-helper: ## Build workflow manager helper container image diff --git a/build/package/image/function-data-buffer/Dockerfile.generic.generic b/build/package/image/function-data-buffer/Dockerfile.generic.generic new file mode 100644 index 0000000..bf60804 --- /dev/null +++ b/build/package/image/function-data-buffer/Dockerfile.generic.generic @@ -0,0 +1,93 @@ +# syntax=docker/dockerfile:1.4 + +ARG GOVERSION +FROM --platform=${BUILDPLATFORM} docker.io/library/golang:${GOVERSION} AS build + +ARG SKAFFOLD_GO_GCFLAGS="" + +WORKDIR /app + +COPY go.mod go.sum ./ +RUN --mount=type=cache,target=/root/.cache/go-build \ + go mod download +COPY . . + +# BUILD_DATE changes ofter so move this section down to allow for caching +ARG TARGETOS \ + TARGETARCH \ + TARGETVARIANT \ + VERSION \ + GIT_COMMIT \ + GIT_TREE_STATE \ + BUILD_DATE + +RUN --mount=type=cache,target=/root/.cache/go-build \ + --mount=type=cache,target=/go/pkg/mod \ + --mount=type=cache,target=/app/tmp,id=app-tmp-${TARGETARCH}-${TARGETVARIANT},sharing=locked \ + make build-task-shim \ + "OS=${TARGETOS}" \ + "ARCH=${TARGETARCH}" \ + "VERSION=${VERSION}" \ + "GIT_COMMIT=${GIT_COMMIT}" \ + "GIT_TREE_STATE=${GIT_TREE_STATE}" \ + "BUILD_DATE=${BUILD_DATE}" \ + && make build-functions \ + "OS=${TARGETOS}" \ + "ARCH=${TARGETARCH}" \ + "VERSION=${VERSION}" \ + "GIT_COMMIT=${GIT_COMMIT}" \ + "GIT_TREE_STATE=${GIT_TREE_STATE}" \ + "BUILD_DATE=${BUILD_DATE}" + +FROM gcr.io/distroless/static:latest +LABEL org.opencontainers.image.base.name="gcr.io/distroless/static:latest" + +ENV GOTRACEBACK=all + +ARG TARGETOS \ + TARGETARCH \ + VERSION \ + GIT_COMMIT \ + BUILD_DATE + +LABEL maintainer="Matthias Neugebauer " \ + org.opencontainers.image.created="${BUILD_DATE}" \ + org.opencontainers.image.authors="Matthias Neugebauer " \ + org.opencontainers.image.url="ghcr.io/nagare-media/engine/function-data-buffer" \ + org.opencontainers.image.documentation="https://nagare.media" \ + org.opencontainers.image.source="https://github.com/nagare-media/engine" \ + org.opencontainers.image.version="${VERSION}" \ + org.opencontainers.image.revision="${GIT_COMMIT}" \ + org.opencontainers.image.vendor="nagare media" \ + org.opencontainers.image.licenses="Apache-2.0" \ + org.opencontainers.image.title="nagare media engine" \ + org.opencontainers.image.description="nagare media engine — an open source modern cloud- and edge-native media workflow system running on Kubernetes" + +WORKDIR / +COPY --from=build "/app/bin/task-shim-${VERSION}-${TARGETOS}-${TARGETARCH}" /task-shim +COPY --from=build "/app/bin/functions-${VERSION}-${TARGETOS}-${TARGETARCH}" /data-buffer +USER 65532:65532 + +COPY <