diff --git a/Jenkinsfile b/Jenkinsfile
index 812eee70e02ce773c8df13eb3c357cbbd91b6747..d97a3fab04b997f2292d13bddf6874bbc8842828 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -49,7 +49,15 @@ pipeline {
                 script {
                     FAILED_STAGE = env.STAGE_NAME
                     def rootVersion = getPomVersion('pom.xml')
+                    def jobVersion = getParentPomVersion('aggregation-manager-job/pom.xml')
+                    def serverVersion = getParentPomVersion('aggregation-manager-server/pom.xml')
 
+                    if(rootVersion != jobVersion) {
+                        error("Version in aggregation-manager-job stimmt nicht mit dem parent überein.")
+                    }
+                    if(rootVersion != serverVersion) {
+                        error("Version in aggregation-manager-server stimmt nicht mit dem parent überein.")
+                    }
                     if(isReleaseBranch()){
                         if ( !(rootVersion ==~ RELEASE_REGEX)) {
                             error("Keine Release Version für Branch ${env.BRANCH_NAME}.")
@@ -78,11 +86,11 @@ pipeline {
                 }
                 configFileProvider([configFile(fileId: 'maven-settings', variable: 'MAVEN_SETTINGS')]) {
                     sh "mvn -s $MAVEN_SETTINGS versions:set -DnewVersion=${JAR_TAG} -DprocessAllModules=true"
-                    
+
                 }
           }
-        } 
-        
+        }
+
         stage('Build AggregationManager') {
           steps {
                 script {
@@ -94,7 +102,7 @@ pipeline {
                 }
             }
         }
-        
+
         stage('Deploy to Nexus'){
             steps {
                 script {
@@ -106,7 +114,7 @@ pipeline {
                 }
             }
         }
-        stage('Build Docker image') {
+        stage('Build Docker images') {
           steps {
                 script {
                     FAILED_STAGE=env.STAGE_NAME
@@ -117,42 +125,62 @@ pipeline {
            }
         }
 
-        stage('Tag and Push Docker image') {
+        stage('Tag and Push Docker images') {
             steps {
                 script {
                     FAILED_STAGE=env.STAGE_NAME
                     IMAGE_TAG = buildVersionName()
 
-                    tagAndPushDockerImage(IMAGE_TAG)
+                    tagAndPushDockerImage('aggregation-manager-job', IMAGE_TAG)
+                    tagAndPushDockerImage('aggregation-manager-server', IMAGE_TAG)
 
                     if (env.BRANCH_NAME == 'main') {
-                        tagAndPushDockerImage('snapshot-latest')
-                        
+                        tagAndPushDockerImage('aggregation-manager-job', 'snapshot-latest')
+                        tagAndPushDockerImage('aggregation-manager-server', 'snapshot-latest')
+
                     }
                     else if (env.BRANCH_NAME == 'release') {
-                        tagAndPushDockerImage('latest')
+                        tagAndPushDockerImage('aggregation-manager-job', 'latest')
+                        tagAndPushDockerImage('aggregation-manager-server', 'latest')
                     }
                 }
             }
         }
 
-        stage('Test, build and deploy Helm Chart') {
+        stage('Test, build and deploy Helm Chart for Aggregation Job') {
             steps {
                 script {
                     FAILED_STAGE=env.STAGE_NAME
                     HELM_CHART_VERSION = buildVersionName()
 
-                    sh "./run_helm_test.sh"
-                   
-                    dir('src/main/helm') {
+                    sh "./run_helm_test_aggregation_job.sh"
+
+                    dir('aggregation-manager-job/src/main/helm') {
 
                         sh "helm package --version=${HELM_CHART_VERSION} ."
-                        deployHelmChart(HELM_CHART_VERSION)
+                        deployHelmChart('aggregation-manager-job', HELM_CHART_VERSION)
                     }
                 }
             }
-        }        
-    
+        }
+
+        stage('Test, build and deploy Helm Chart for Aggregation Server') {
+            steps {
+                script {
+                    FAILED_STAGE=env.STAGE_NAME
+                    HELM_CHART_VERSION = buildVersionName()
+
+                    sh "./run_helm_test_aggregation_server.sh"
+
+                    dir('aggregation-manager-server/src/main/helm') {
+
+                        sh "helm package --version=${HELM_CHART_VERSION} ."
+                        deployHelmChart('aggregation-manager-server', HELM_CHART_VERSION)
+                    }
+                }
+            }
+        }
+
 
         stage('Trigger Dev rollout') {
             when {
@@ -173,10 +201,10 @@ pipeline {
         stage('Trigger Test rollout') {
             when {
                 branch 'release'
-            }	
-            	
-            steps {	
-                script {	
+            }
+
+            steps {
+                script {
                     FAILED_STAGE = env.STAGE_NAME
 
                     cloneGitopsRepo()
@@ -185,7 +213,7 @@ pipeline {
 
                     pushTestGitopsRepo()
                 }
-            }	
+            }
         }
 
         stage ('Deploy SBOM to DependencyTrack') {
@@ -252,6 +280,10 @@ String getPomVersion(String pomFile){
     return pom.version
 }
 
+String getParentPomVersion(String filePath) {
+    def pom = readMavenPom file: filePath
+    return pom.parent.version
+}
 
 Void sendFailureMessage() {
     def room = ''
@@ -261,7 +293,7 @@ Void sendFailureMessage() {
                     "format": "org.matrix.custom.html", \
                     "formatted_body":"AggregationManager: Build Failed. Stage: ${FAILED_STAGE} Build-ID: <a
                     href='${JENKINS_URL}'>${env.BUILD_NUMBER}</a>"}"""
-       
+
     if (env.BRANCH_NAME == 'main') {
         room = "!GjqhmouBtnDbwUkAjx:matrix.ozg-sh.de"
     }
@@ -278,13 +310,13 @@ String getElementAccessToken() {
     }
 }
 
-Void deployHelmChart(String helmChartVersion) {       
+Void deployHelmChart(String helmChartName, String helmChartVersion) {
     withCredentials([usernamePassword(credentialsId: 'jenkins-nexus-login', usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]){
         if (env.BRANCH_NAME == 'release') {
-            result = sh script: '''curl -u $USERNAME:$PASSWORD https://nexus.ozg-sh.de/service/rest/v1/components?repository=ozg-base-apps -F file=@aggregation-manager-'''+helmChartVersion+'''.tgz''', returnStdout: true
+            result = sh script: '''curl -u $USERNAME:$PASSWORD https://nexus.ozg-sh.de/service/rest/v1/components?repository=ozg-base-apps -F file=@-'''+helmChartName+'''-'''+helmChartVersion+'''.tgz''', returnStdout: true
         }
         else {
-            result = sh script: '''curl -u $USERNAME:$PASSWORD https://nexus.ozg-sh.de/service/rest/v1/components?repository=ozg-base-apps-snapshot -F file=@aggregation-manager-'''+helmChartVersion+'''.tgz''', returnStdout: true
+            result = sh script: '''curl -u $USERNAME:$PASSWORD https://nexus.ozg-sh.de/service/rest/v1/components?repository=ozg-base-apps-snapshot -F file=@'''+helmChartName+'''-'''+helmChartVersion+'''.tgz''', returnStdout: true
         }
 
         if (result != '') {
@@ -308,15 +340,15 @@ String buildVersionName() {
     if (isReleaseBranch()) {
         return getPomVersion('pom.xml')
     }
-    return "${getPomVersion('pom.xml')}-${validateBranchName(env.BRANCH_NAME)}-${env.GIT_COMMIT.take(7)}".replaceAll("_", "-")
+    return "${getPomVersion('pom.xml')}-${validateBranchName(env.BRANCH_NAME)}-${env.BUILD_NUMBER}".replaceAll("_", "-")
 }
 
-Void tagAndPushDockerImage(String newTag){
+Void tagAndPushDockerImage(String imageName, String newTag){
     withCredentials([usernamePassword(credentialsId: 'jenkins-nexus-login', usernameVariable: 'USER', passwordVariable: 'PASSWORD')]) {
         sh 'docker login docker.ozg-sh.de -u ${USER} -p ${PASSWORD}'
 
-        sh "docker tag docker.ozg-sh.de/aggregation-manager:build-latest docker.ozg-sh.de/aggregation-manager:${newTag}"
-        sh "docker push docker.ozg-sh.de/aggregation-manager:${newTag}"
+        sh "docker tag docker.ozg-sh.de/${imageName}:build-latest docker.ozg-sh.de/${imageName}:${newTag}"
+        sh "docker push docker.ozg-sh.de/${imageName}:${newTag}"
     }
 }
 
@@ -339,21 +371,36 @@ Void cloneGitopsRepo() {
 }
 
 Void setNewDevAggregationManagerVersion() {
-    setNewAggregationManagerGitopsVersion("dev")
+    setNewAggregationManagerJobGitopsVersion("dev")
+    setNewAggregationManagerServerGitopsVersion("dev")
 }
 
 Void setNewTestAggregationManagerVersion() {
-    setNewAggregationManagerGitopsVersion("test")
+    setNewAggregationManagerJobGitopsVersion("test")
+    setNewAggregationManagerServerGitopsVersion("test")
+}
+
+Void setNewAggregationManagerJobGitopsVersion(String environment) {
+    dir("gitops") {
+        def envFile = "${environment}/application/values/aggregation-manager-job-values.yaml"
+
+        def envVersions = readYaml file: envFile
+
+        envVersions.aggregation_manager_job.image.tag = IMAGE_TAG
+        envVersions.aggregation_manager_job.helm.version = HELM_CHART_VERSION
+
+        writeYaml file: envFile, data: envVersions, overwrite: true
+    }
 }
 
-Void setNewAggregationManagerGitopsVersion(String environment) {
+Void setNewAggregationManagerServerGitopsVersion(String environment) {
     dir("gitops") {
-        def envFile = "${environment}/application/values/aggregation-manager-values.yaml"
+        def envFile = "${environment}/application/values/aggregation-manager-server-values.yaml"
 
         def envVersions = readYaml file: envFile
 
-        envVersions.aggregation_manager.image.tag = IMAGE_TAG
-        envVersions.aggregation_manager.helm.version = HELM_CHART_VERSION
+        envVersions.aggregation_manager_server.image.tag = IMAGE_TAG
+        envVersions.aggregation_manager_server.helm.version = HELM_CHART_VERSION
 
         writeYaml file: envFile, data: envVersions, overwrite: true
     }
diff --git a/lombok.config b/aggregation-manager-job/lombok.config
similarity index 94%
rename from lombok.config
rename to aggregation-manager-job/lombok.config
index a06fa130e8af26b659f2d3a0cb1114cd966a9b0e..650d169bcafc87be10f9129d54c24008ee7bc933 100644
--- a/lombok.config
+++ b/aggregation-manager-job/lombok.config
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2022 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/aggregation-manager-job/mvnw b/aggregation-manager-job/mvnw
new file mode 100644
index 0000000000000000000000000000000000000000..19529ddf8c6eaa08c5c75ff80652d21ce4b72f8c
--- /dev/null
+++ b/aggregation-manager-job/mvnw
@@ -0,0 +1,259 @@
+#!/bin/sh
+# ----------------------------------------------------------------------------
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#    http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+# ----------------------------------------------------------------------------
+
+# ----------------------------------------------------------------------------
+# Apache Maven Wrapper startup batch script, version 3.3.2
+#
+# Optional ENV vars
+# -----------------
+#   JAVA_HOME - location of a JDK home dir, required when download maven via java source
+#   MVNW_REPOURL - repo url base for downloading maven distribution
+#   MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven
+#   MVNW_VERBOSE - true: enable verbose log; debug: trace the mvnw script; others: silence the output
+# ----------------------------------------------------------------------------
+
+set -euf
+[ "${MVNW_VERBOSE-}" != debug ] || set -x
+
+# OS specific support.
+native_path() { printf %s\\n "$1"; }
+case "$(uname)" in
+CYGWIN* | MINGW*)
+  [ -z "${JAVA_HOME-}" ] || JAVA_HOME="$(cygpath --unix "$JAVA_HOME")"
+  native_path() { cygpath --path --windows "$1"; }
+  ;;
+esac
+
+# set JAVACMD and JAVACCMD
+set_java_home() {
+  # For Cygwin and MinGW, ensure paths are in Unix format before anything is touched
+  if [ -n "${JAVA_HOME-}" ]; then
+    if [ -x "$JAVA_HOME/jre/sh/java" ]; then
+      # IBM's JDK on AIX uses strange locations for the executables
+      JAVACMD="$JAVA_HOME/jre/sh/java"
+      JAVACCMD="$JAVA_HOME/jre/sh/javac"
+    else
+      JAVACMD="$JAVA_HOME/bin/java"
+      JAVACCMD="$JAVA_HOME/bin/javac"
+
+      if [ ! -x "$JAVACMD" ] || [ ! -x "$JAVACCMD" ]; then
+        echo "The JAVA_HOME environment variable is not defined correctly, so mvnw cannot run." >&2
+        echo "JAVA_HOME is set to \"$JAVA_HOME\", but \"\$JAVA_HOME/bin/java\" or \"\$JAVA_HOME/bin/javac\" does not exist." >&2
+        return 1
+      fi
+    fi
+  else
+    JAVACMD="$(
+      'set' +e
+      'unset' -f command 2>/dev/null
+      'command' -v java
+    )" || :
+    JAVACCMD="$(
+      'set' +e
+      'unset' -f command 2>/dev/null
+      'command' -v javac
+    )" || :
+
+    if [ ! -x "${JAVACMD-}" ] || [ ! -x "${JAVACCMD-}" ]; then
+      echo "The java/javac command does not exist in PATH nor is JAVA_HOME set, so mvnw cannot run." >&2
+      return 1
+    fi
+  fi
+}
+
+# hash string like Java String::hashCode
+hash_string() {
+  str="${1:-}" h=0
+  while [ -n "$str" ]; do
+    char="${str%"${str#?}"}"
+    h=$(((h * 31 + $(LC_CTYPE=C printf %d "'$char")) % 4294967296))
+    str="${str#?}"
+  done
+  printf %x\\n $h
+}
+
+verbose() { :; }
+[ "${MVNW_VERBOSE-}" != true ] || verbose() { printf %s\\n "${1-}"; }
+
+die() {
+  printf %s\\n "$1" >&2
+  exit 1
+}
+
+trim() {
+  # MWRAPPER-139:
+  #   Trims trailing and leading whitespace, carriage returns, tabs, and linefeeds.
+  #   Needed for removing poorly interpreted newline sequences when running in more
+  #   exotic environments such as mingw bash on Windows.
+  printf "%s" "${1}" | tr -d '[:space:]'
+}
+
+# parse distributionUrl and optional distributionSha256Sum, requires .mvn/wrapper/maven-wrapper.properties
+while IFS="=" read -r key value; do
+  case "${key-}" in
+  distributionUrl) distributionUrl=$(trim "${value-}") ;;
+  distributionSha256Sum) distributionSha256Sum=$(trim "${value-}") ;;
+  esac
+done <"${0%/*}/.mvn/wrapper/maven-wrapper.properties"
+[ -n "${distributionUrl-}" ] || die "cannot read distributionUrl property in ${0%/*}/.mvn/wrapper/maven-wrapper.properties"
+
+case "${distributionUrl##*/}" in
+maven-mvnd-*bin.*)
+  MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/
+  case "${PROCESSOR_ARCHITECTURE-}${PROCESSOR_ARCHITEW6432-}:$(uname -a)" in
+  *AMD64:CYGWIN* | *AMD64:MINGW*) distributionPlatform=windows-amd64 ;;
+  :Darwin*x86_64) distributionPlatform=darwin-amd64 ;;
+  :Darwin*arm64) distributionPlatform=darwin-aarch64 ;;
+  :Linux*x86_64*) distributionPlatform=linux-amd64 ;;
+  *)
+    echo "Cannot detect native platform for mvnd on $(uname)-$(uname -m), use pure java version" >&2
+    distributionPlatform=linux-amd64
+    ;;
+  esac
+  distributionUrl="${distributionUrl%-bin.*}-$distributionPlatform.zip"
+  ;;
+maven-mvnd-*) MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/ ;;
+*) MVN_CMD="mvn${0##*/mvnw}" _MVNW_REPO_PATTERN=/org/apache/maven/ ;;
+esac
+
+# apply MVNW_REPOURL and calculate MAVEN_HOME
+# maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash>
+[ -z "${MVNW_REPOURL-}" ] || distributionUrl="$MVNW_REPOURL$_MVNW_REPO_PATTERN${distributionUrl#*"$_MVNW_REPO_PATTERN"}"
+distributionUrlName="${distributionUrl##*/}"
+distributionUrlNameMain="${distributionUrlName%.*}"
+distributionUrlNameMain="${distributionUrlNameMain%-bin}"
+MAVEN_USER_HOME="${MAVEN_USER_HOME:-${HOME}/.m2}"
+MAVEN_HOME="${MAVEN_USER_HOME}/wrapper/dists/${distributionUrlNameMain-}/$(hash_string "$distributionUrl")"
+
+exec_maven() {
+  unset MVNW_VERBOSE MVNW_USERNAME MVNW_PASSWORD MVNW_REPOURL || :
+  exec "$MAVEN_HOME/bin/$MVN_CMD" "$@" || die "cannot exec $MAVEN_HOME/bin/$MVN_CMD"
+}
+
+if [ -d "$MAVEN_HOME" ]; then
+  verbose "found existing MAVEN_HOME at $MAVEN_HOME"
+  exec_maven "$@"
+fi
+
+case "${distributionUrl-}" in
+*?-bin.zip | *?maven-mvnd-?*-?*.zip) ;;
+*) die "distributionUrl is not valid, must match *-bin.zip or maven-mvnd-*.zip, but found '${distributionUrl-}'" ;;
+esac
+
+# prepare tmp dir
+if TMP_DOWNLOAD_DIR="$(mktemp -d)" && [ -d "$TMP_DOWNLOAD_DIR" ]; then
+  clean() { rm -rf -- "$TMP_DOWNLOAD_DIR"; }
+  trap clean HUP INT TERM EXIT
+else
+  die "cannot create temp dir"
+fi
+
+mkdir -p -- "${MAVEN_HOME%/*}"
+
+# Download and Install Apache Maven
+verbose "Couldn't find MAVEN_HOME, downloading and installing it ..."
+verbose "Downloading from: $distributionUrl"
+verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName"
+
+# select .zip or .tar.gz
+if ! command -v unzip >/dev/null; then
+  distributionUrl="${distributionUrl%.zip}.tar.gz"
+  distributionUrlName="${distributionUrl##*/}"
+fi
+
+# verbose opt
+__MVNW_QUIET_WGET=--quiet __MVNW_QUIET_CURL=--silent __MVNW_QUIET_UNZIP=-q __MVNW_QUIET_TAR=''
+[ "${MVNW_VERBOSE-}" != true ] || __MVNW_QUIET_WGET='' __MVNW_QUIET_CURL='' __MVNW_QUIET_UNZIP='' __MVNW_QUIET_TAR=v
+
+# normalize http auth
+case "${MVNW_PASSWORD:+has-password}" in
+'') MVNW_USERNAME='' MVNW_PASSWORD='' ;;
+has-password) [ -n "${MVNW_USERNAME-}" ] || MVNW_USERNAME='' MVNW_PASSWORD='' ;;
+esac
+
+if [ -z "${MVNW_USERNAME-}" ] && command -v wget >/dev/null; then
+  verbose "Found wget ... using wget"
+  wget ${__MVNW_QUIET_WGET:+"$__MVNW_QUIET_WGET"} "$distributionUrl" -O "$TMP_DOWNLOAD_DIR/$distributionUrlName" || die "wget: Failed to fetch $distributionUrl"
+elif [ -z "${MVNW_USERNAME-}" ] && command -v curl >/dev/null; then
+  verbose "Found curl ... using curl"
+  curl ${__MVNW_QUIET_CURL:+"$__MVNW_QUIET_CURL"} -f -L -o "$TMP_DOWNLOAD_DIR/$distributionUrlName" "$distributionUrl" || die "curl: Failed to fetch $distributionUrl"
+elif set_java_home; then
+  verbose "Falling back to use Java to download"
+  javaSource="$TMP_DOWNLOAD_DIR/Downloader.java"
+  targetZip="$TMP_DOWNLOAD_DIR/$distributionUrlName"
+  cat >"$javaSource" <<-END
+	public class Downloader extends java.net.Authenticator
+	{
+	  protected java.net.PasswordAuthentication getPasswordAuthentication()
+	  {
+	    return new java.net.PasswordAuthentication( System.getenv( "MVNW_USERNAME" ), System.getenv( "MVNW_PASSWORD" ).toCharArray() );
+	  }
+	  public static void main( String[] args ) throws Exception
+	  {
+	    setDefault( new Downloader() );
+	    java.nio.file.Files.copy( java.net.URI.create( args[0] ).toURL().openStream(), java.nio.file.Paths.get( args[1] ).toAbsolutePath().normalize() );
+	  }
+	}
+	END
+  # For Cygwin/MinGW, switch paths to Windows format before running javac and java
+  verbose " - Compiling Downloader.java ..."
+  "$(native_path "$JAVACCMD")" "$(native_path "$javaSource")" || die "Failed to compile Downloader.java"
+  verbose " - Running Downloader.java ..."
+  "$(native_path "$JAVACMD")" -cp "$(native_path "$TMP_DOWNLOAD_DIR")" Downloader "$distributionUrl" "$(native_path "$targetZip")"
+fi
+
+# If specified, validate the SHA-256 sum of the Maven distribution zip file
+if [ -n "${distributionSha256Sum-}" ]; then
+  distributionSha256Result=false
+  if [ "$MVN_CMD" = mvnd.sh ]; then
+    echo "Checksum validation is not supported for maven-mvnd." >&2
+    echo "Please disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2
+    exit 1
+  elif command -v sha256sum >/dev/null; then
+    if echo "$distributionSha256Sum  $TMP_DOWNLOAD_DIR/$distributionUrlName" | sha256sum -c >/dev/null 2>&1; then
+      distributionSha256Result=true
+    fi
+  elif command -v shasum >/dev/null; then
+    if echo "$distributionSha256Sum  $TMP_DOWNLOAD_DIR/$distributionUrlName" | shasum -a 256 -c >/dev/null 2>&1; then
+      distributionSha256Result=true
+    fi
+  else
+    echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available." >&2
+    echo "Please install either command, or disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2
+    exit 1
+  fi
+  if [ $distributionSha256Result = false ]; then
+    echo "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised." >&2
+    echo "If you updated your Maven version, you need to update the specified distributionSha256Sum property." >&2
+    exit 1
+  fi
+fi
+
+# unzip and move
+if command -v unzip >/dev/null; then
+  unzip ${__MVNW_QUIET_UNZIP:+"$__MVNW_QUIET_UNZIP"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -d "$TMP_DOWNLOAD_DIR" || die "failed to unzip"
+else
+  tar xzf${__MVNW_QUIET_TAR:+"$__MVNW_QUIET_TAR"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -C "$TMP_DOWNLOAD_DIR" || die "failed to untar"
+fi
+printf %s\\n "$distributionUrl" >"$TMP_DOWNLOAD_DIR/$distributionUrlNameMain/mvnw.url"
+mv -- "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" "$MAVEN_HOME" || [ -d "$MAVEN_HOME" ] || die "fail to move MAVEN_HOME"
+
+clean || :
+exec_maven "$@"
diff --git a/aggregation-manager-job/mvnw.cmd b/aggregation-manager-job/mvnw.cmd
new file mode 100644
index 0000000000000000000000000000000000000000..249bdf3822221aa612d1da2605316cabd7b07e50
--- /dev/null
+++ b/aggregation-manager-job/mvnw.cmd
@@ -0,0 +1,149 @@
+<# : batch portion
+@REM ----------------------------------------------------------------------------
+@REM Licensed to the Apache Software Foundation (ASF) under one
+@REM or more contributor license agreements.  See the NOTICE file
+@REM distributed with this work for additional information
+@REM regarding copyright ownership.  The ASF licenses this file
+@REM to you under the Apache License, Version 2.0 (the
+@REM "License"); you may not use this file except in compliance
+@REM with the License.  You may obtain a copy of the License at
+@REM
+@REM    http://www.apache.org/licenses/LICENSE-2.0
+@REM
+@REM Unless required by applicable law or agreed to in writing,
+@REM software distributed under the License is distributed on an
+@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+@REM KIND, either express or implied.  See the License for the
+@REM specific language governing permissions and limitations
+@REM under the License.
+@REM ----------------------------------------------------------------------------
+
+@REM ----------------------------------------------------------------------------
+@REM Apache Maven Wrapper startup batch script, version 3.3.2
+@REM
+@REM Optional ENV vars
+@REM   MVNW_REPOURL - repo url base for downloading maven distribution
+@REM   MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven
+@REM   MVNW_VERBOSE - true: enable verbose log; others: silence the output
+@REM ----------------------------------------------------------------------------
+
+@IF "%__MVNW_ARG0_NAME__%"=="" (SET __MVNW_ARG0_NAME__=%~nx0)
+@SET __MVNW_CMD__=
+@SET __MVNW_ERROR__=
+@SET __MVNW_PSMODULEP_SAVE=%PSModulePath%
+@SET PSModulePath=
+@FOR /F "usebackq tokens=1* delims==" %%A IN (`powershell -noprofile "& {$scriptDir='%~dp0'; $script='%__MVNW_ARG0_NAME__%'; icm -ScriptBlock ([Scriptblock]::Create((Get-Content -Raw '%~f0'))) -NoNewScope}"`) DO @(
+  IF "%%A"=="MVN_CMD" (set __MVNW_CMD__=%%B) ELSE IF "%%B"=="" (echo %%A) ELSE (echo %%A=%%B)
+)
+@SET PSModulePath=%__MVNW_PSMODULEP_SAVE%
+@SET __MVNW_PSMODULEP_SAVE=
+@SET __MVNW_ARG0_NAME__=
+@SET MVNW_USERNAME=
+@SET MVNW_PASSWORD=
+@IF NOT "%__MVNW_CMD__%"=="" (%__MVNW_CMD__% %*)
+@echo Cannot start maven from wrapper >&2 && exit /b 1
+@GOTO :EOF
+: end batch / begin powershell #>
+
+$ErrorActionPreference = "Stop"
+if ($env:MVNW_VERBOSE -eq "true") {
+  $VerbosePreference = "Continue"
+}
+
+# calculate distributionUrl, requires .mvn/wrapper/maven-wrapper.properties
+$distributionUrl = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionUrl
+if (!$distributionUrl) {
+  Write-Error "cannot read distributionUrl property in $scriptDir/.mvn/wrapper/maven-wrapper.properties"
+}
+
+switch -wildcard -casesensitive ( $($distributionUrl -replace '^.*/','') ) {
+  "maven-mvnd-*" {
+    $USE_MVND = $true
+    $distributionUrl = $distributionUrl -replace '-bin\.[^.]*$',"-windows-amd64.zip"
+    $MVN_CMD = "mvnd.cmd"
+    break
+  }
+  default {
+    $USE_MVND = $false
+    $MVN_CMD = $script -replace '^mvnw','mvn'
+    break
+  }
+}
+
+# apply MVNW_REPOURL and calculate MAVEN_HOME
+# maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash>
+if ($env:MVNW_REPOURL) {
+  $MVNW_REPO_PATTERN = if ($USE_MVND) { "/org/apache/maven/" } else { "/maven/mvnd/" }
+  $distributionUrl = "$env:MVNW_REPOURL$MVNW_REPO_PATTERN$($distributionUrl -replace '^.*'+$MVNW_REPO_PATTERN,'')"
+}
+$distributionUrlName = $distributionUrl -replace '^.*/',''
+$distributionUrlNameMain = $distributionUrlName -replace '\.[^.]*$','' -replace '-bin$',''
+$MAVEN_HOME_PARENT = "$HOME/.m2/wrapper/dists/$distributionUrlNameMain"
+if ($env:MAVEN_USER_HOME) {
+  $MAVEN_HOME_PARENT = "$env:MAVEN_USER_HOME/wrapper/dists/$distributionUrlNameMain"
+}
+$MAVEN_HOME_NAME = ([System.Security.Cryptography.MD5]::Create().ComputeHash([byte[]][char[]]$distributionUrl) | ForEach-Object {$_.ToString("x2")}) -join ''
+$MAVEN_HOME = "$MAVEN_HOME_PARENT/$MAVEN_HOME_NAME"
+
+if (Test-Path -Path "$MAVEN_HOME" -PathType Container) {
+  Write-Verbose "found existing MAVEN_HOME at $MAVEN_HOME"
+  Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD"
+  exit $?
+}
+
+if (! $distributionUrlNameMain -or ($distributionUrlName -eq $distributionUrlNameMain)) {
+  Write-Error "distributionUrl is not valid, must end with *-bin.zip, but found $distributionUrl"
+}
+
+# prepare tmp dir
+$TMP_DOWNLOAD_DIR_HOLDER = New-TemporaryFile
+$TMP_DOWNLOAD_DIR = New-Item -Itemtype Directory -Path "$TMP_DOWNLOAD_DIR_HOLDER.dir"
+$TMP_DOWNLOAD_DIR_HOLDER.Delete() | Out-Null
+trap {
+  if ($TMP_DOWNLOAD_DIR.Exists) {
+    try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null }
+    catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" }
+  }
+}
+
+New-Item -Itemtype Directory -Path "$MAVEN_HOME_PARENT" -Force | Out-Null
+
+# Download and Install Apache Maven
+Write-Verbose "Couldn't find MAVEN_HOME, downloading and installing it ..."
+Write-Verbose "Downloading from: $distributionUrl"
+Write-Verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName"
+
+$webclient = New-Object System.Net.WebClient
+if ($env:MVNW_USERNAME -and $env:MVNW_PASSWORD) {
+  $webclient.Credentials = New-Object System.Net.NetworkCredential($env:MVNW_USERNAME, $env:MVNW_PASSWORD)
+}
+[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
+$webclient.DownloadFile($distributionUrl, "$TMP_DOWNLOAD_DIR/$distributionUrlName") | Out-Null
+
+# If specified, validate the SHA-256 sum of the Maven distribution zip file
+$distributionSha256Sum = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionSha256Sum
+if ($distributionSha256Sum) {
+  if ($USE_MVND) {
+    Write-Error "Checksum validation is not supported for maven-mvnd. `nPlease disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties."
+  }
+  Import-Module $PSHOME\Modules\Microsoft.PowerShell.Utility -Function Get-FileHash
+  if ((Get-FileHash "$TMP_DOWNLOAD_DIR/$distributionUrlName" -Algorithm SHA256).Hash.ToLower() -ne $distributionSha256Sum) {
+    Write-Error "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised. If you updated your Maven version, you need to update the specified distributionSha256Sum property."
+  }
+}
+
+# unzip and move
+Expand-Archive "$TMP_DOWNLOAD_DIR/$distributionUrlName" -DestinationPath "$TMP_DOWNLOAD_DIR" | Out-Null
+Rename-Item -Path "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" -NewName $MAVEN_HOME_NAME | Out-Null
+try {
+  Move-Item -Path "$TMP_DOWNLOAD_DIR/$MAVEN_HOME_NAME" -Destination $MAVEN_HOME_PARENT | Out-Null
+} catch {
+  if (! (Test-Path -Path "$MAVEN_HOME" -PathType Container)) {
+    Write-Error "fail to move MAVEN_HOME"
+  }
+} finally {
+  try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null }
+  catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" }
+}
+
+Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD"
diff --git a/aggregation-manager-job/pom.xml b/aggregation-manager-job/pom.xml
new file mode 100644
index 0000000000000000000000000000000000000000..7546f1e416d558c42c14239e1f451f1282f3f64b
--- /dev/null
+++ b/aggregation-manager-job/pom.xml
@@ -0,0 +1,127 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+
+    Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+    Ministerpräsidenten des Landes Schleswig-Holstein
+    Staatskanzlei
+    Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+
+    Lizenziert unter der EUPL, Version 1.2 oder - sobald
+    diese von der Europäischen Kommission genehmigt wurden -
+    Folgeversionen der EUPL ("Lizenz");
+    Sie dürfen dieses Werk ausschließlich gemäß
+    dieser Lizenz nutzen.
+    Eine Kopie der Lizenz finden Sie hier:
+
+    https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+
+    Sofern nicht durch anwendbare Rechtsvorschriften
+    gefordert oder in schriftlicher Form vereinbart, wird
+    die unter der Lizenz verbreitete Software "so wie sie
+    ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+    ausdrücklich oder stillschweigend - verbreitet.
+    Die sprachspezifischen Genehmigungen und Beschränkungen
+    unter der Lizenz sind dem Lizenztext zu entnehmen.
+
+-->
+<project xmlns="https://maven.apache.org/POM/4.0.0"
+	xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance"
+	xsi:schemaLocation="https://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>de.ozgcloud.aggregation</groupId>
+		<artifactId>aggregation-manager-parent</artifactId>
+		<version>1.3.0-SNAPSHOT</version>
+		<relativePath>../</relativePath>
+	</parent>
+	<artifactId>aggregation-manager-job</artifactId>
+	<name>OZG-Cloud Aggregation Manager Job</name>
+
+	<properties>
+		<spring-boot.build-image.imageName>docker.ozg-sh.de/aggregation-manager-job:build-latest</spring-boot.build-image.imageName>
+	</properties>
+	<dependencies>
+		<dependency>
+			<artifactId>ozg-cloud-spring-boot-starter</artifactId>
+			<groupId>de.ozgcloud.api-lib</groupId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-data-mongodb</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.cloud</groupId>
+			<artifactId>spring-cloud-starter-config</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>com.fasterxml.jackson.datatype</groupId>
+			<artifactId>jackson-datatype-jsr310</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.mapstruct</groupId>
+			<artifactId>mapstruct</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>com.schibsted.spt.data</groupId>
+			<artifactId>jslt</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.hibernate</groupId>
+			<artifactId>hibernate-validator</artifactId>
+		</dependency>
+
+		<!-- Test dependencies -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-test</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<artifactId>api-lib-core</artifactId>
+			<groupId>de.ozgcloud.api-lib</groupId>
+			<type>test-jar</type>
+			<scope>test</scope>
+		</dependency>
+	</dependencies>
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-compiler-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.springframework.boot</groupId>
+				<artifactId>spring-boot-maven-plugin</artifactId>
+				<configuration>
+					<mainClass>de.ozgcloud.aggregation.AggregationManagerApplication</mainClass>
+					<image>
+						<env>
+							<BPE_DELIM_JAVA_TOOL_OPTIONS xml:space="preserve"> </BPE_DELIM_JAVA_TOOL_OPTIONS>
+							<BPE_APPEND_JAVA_TOOL_OPTIONS>-Dfile.encoding=UTF-8</BPE_APPEND_JAVA_TOOL_OPTIONS>
+						</env>
+					</image>
+				</configuration>
+			</plugin>
+			<plugin>
+				<groupId>org.jacoco</groupId>
+				<artifactId>jacoco-maven-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-failsafe-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-surefire-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>com.mycila</groupId>
+				<artifactId>license-maven-plugin</artifactId>
+			</plugin>
+		</plugins>
+	</build>
+</project>
\ No newline at end of file
diff --git a/src/main/helm/.helmignore b/aggregation-manager-job/src/main/helm/.helmignore
similarity index 100%
rename from src/main/helm/.helmignore
rename to aggregation-manager-job/src/main/helm/.helmignore
diff --git a/src/main/helm/Chart.yaml b/aggregation-manager-job/src/main/helm/Chart.yaml
similarity index 86%
rename from src/main/helm/Chart.yaml
rename to aggregation-manager-job/src/main/helm/Chart.yaml
index 83d7d422bd735e95aeb96e80df6055116bd37851..0fd6c5a925c7196f4f7c68909117b8911a450bb3 100644
--- a/src/main/helm/Chart.yaml
+++ b/aggregation-manager-job/src/main/helm/Chart.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 apiVersion: v1
 appVersion: "1.0"
-description: OZG-Cloud Helm chart for aggregation-manager
-name: aggregation-manager
+description: OZG-Cloud Helm chart for aggregation-manager-job
+name: aggregation-manager-job
 version: 0.0.0-MANAGED-BY-JENKINS
 icon: https://simpleicons.org/icons/helm.svg
diff --git a/src/main/helm/templates/_helpers.tpl b/aggregation-manager-job/src/main/helm/templates/_helpers.tpl
similarity index 97%
rename from src/main/helm/templates/_helpers.tpl
rename to aggregation-manager-job/src/main/helm/templates/_helpers.tpl
index 599e6624e87564092b83b8da4b6ce9f0ac52ce4f..8b01f744812950ccee2c4b3744329ca047b6be3e 100644
--- a/src/main/helm/templates/_helpers.tpl
+++ b/aggregation-manager-job/src/main/helm/templates/_helpers.tpl
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -22,7 +22,6 @@
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
 #
 
-
 {{/* error check 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec) */}}
 {{/* Namespace */}}
 {{- define "app.namespace" -}}
@@ -51,7 +50,7 @@
 
 {{/* Default Labels: Helm recommended best-practice labels https://helm.sh/docs/chart_best_practices/labels/ */}}
 {{- define "app.defaultLabels" }}
-app.kubernetes.io/instance: aggregation-manager
+app.kubernetes.io/instance: aggregation-manager-job
 app.kubernetes.io/managed-by: {{ include "app.managedBy" . }}
 app.kubernetes.io/name: {{ .Release.Name }}
 app.kubernetes.io/namespace: {{ include "app.namespace" . }}
diff --git a/src/main/helm/templates/configmap_bindings_type.yaml b/aggregation-manager-job/src/main/helm/templates/configmap_bindings_type.yaml
similarity index 90%
rename from src/main/helm/templates/configmap_bindings_type.yaml
rename to aggregation-manager-job/src/main/helm/templates/configmap_bindings_type.yaml
index 620446357f78f2c7648cb9de093133a50e52bacd..0656aa0e8d17ac77666e6fc9f35fdd67987f15bc 100644
--- a/src/main/helm/templates/configmap_bindings_type.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/configmap_bindings_type.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -26,7 +26,7 @@
 apiVersion: v1
 kind: ConfigMap
 metadata:
-  name: aggregation-manager-bindings-type
+  name: aggregation-manager-job-bindings-type
   namespace: {{ include "app.namespace" . }}
 data:
   type: |
diff --git a/src/main/helm/templates/cronjob.yaml b/aggregation-manager-job/src/main/helm/templates/cronjob.yaml
similarity index 97%
rename from src/main/helm/templates/cronjob.yaml
rename to aggregation-manager-job/src/main/helm/templates/cronjob.yaml
index 9dc85320384a502b02c4b26137a3839ca54996dd..f241604c10a1e8d29284042a51dad9dac8980f5f 100644
--- a/src/main/helm/templates/cronjob.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/cronjob.yaml
@@ -42,14 +42,14 @@ spec:
         metadata:
           labels:
             {{- include "app.defaultLabels" . | indent 12 }}
-            component: aggregation-manager
+            component: aggregation-manager-job
         spec:
           {{- if (.Values.serviceAccount).create }}
           serviceAccountName: {{ .Values.serviceAccount.name }}
           {{- end }}
           restartPolicy: "Never"
-          containers:   
-          - name: aggregation-manager
+          containers:
+          - name: aggregation-manager-job
             image: "{{ .Values.image.repo }}/{{ .Values.image.name }}:{{ .Values.image.tag }}"
             imagePullPolicy: Always
             env:
@@ -153,7 +153,7 @@ spec:
             {{- if ((.Values.database).tls).enabled }}
             - name: bindings
               configMap:
-                name: aggregation-manager-bindings-type
+                name: aggregation-manager-job-bindings-type
             - name: mongodb-root-ca
               secret:
                 secretName: {{ ((.Values.database).tls).secretName }}
diff --git a/src/main/helm/templates/network_policy.yaml b/aggregation-manager-job/src/main/helm/templates/network_policy.yaml
similarity index 94%
rename from src/main/helm/templates/network_policy.yaml
rename to aggregation-manager-job/src/main/helm/templates/network_policy.yaml
index 459e7e3cf3ae5825761020c609ab1851dca9acba..0a4c36b94f93b77f71247adab486983c9bc13211 100644
--- a/src/main/helm/templates/network_policy.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/network_policy.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -26,12 +26,12 @@
 apiVersion: networking.k8s.io/v1
 kind: NetworkPolicy
 metadata:
-  name: network-policy-aggregation-manager
+  name: network-policy-aggregation-manager-job
   namespace: {{ include "app.namespace" . }}
 spec:
   podSelector:
     matchLabels:
-      component: aggregation-manager
+      component: aggregation-manager-job
   policyTypes:
     - Ingress
     - Egress
diff --git a/src/main/helm/templates/service.yaml b/aggregation-manager-job/src/main/helm/templates/service.yaml
similarity index 88%
rename from src/main/helm/templates/service.yaml
rename to aggregation-manager-job/src/main/helm/templates/service.yaml
index 4e92320b65dbb25948759d97f77b61136b68d151..7021bc6081893b9d4bf0ae35f5bde9572aea7a33 100644
--- a/src/main/helm/templates/service.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/service.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -29,7 +29,7 @@ metadata:
   namespace: {{ include "app.namespace" . }}
   labels:
     {{- include "app.defaultLabels" . | indent 4 }}
-    component: aggregation-manager-service
+    component: aggregation-manager-job-service
 spec:
   type: ClusterIP
   ports:
@@ -38,4 +38,4 @@ spec:
       protocol: TCP
   selector:
     {{- include "app.matchLabels" . | indent 4 }}
-    component: aggregation-manager
+    component: aggregation-manager-job
diff --git a/src/main/helm/templates/service_account.yaml b/aggregation-manager-job/src/main/helm/templates/service_account.yaml
similarity index 94%
rename from src/main/helm/templates/service_account.yaml
rename to aggregation-manager-job/src/main/helm/templates/service_account.yaml
index 02ff46e312df7ecaba152d3626e4e3affd778f34..664e8acec9fabb26df2325ab4bc336e628151144 100644
--- a/src/main/helm/templates/service_account.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/service_account.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/main/helm/templates/service_monitor.yaml b/aggregation-manager-job/src/main/helm/templates/service_monitor.yaml
similarity index 88%
rename from src/main/helm/templates/service_monitor.yaml
rename to aggregation-manager-job/src/main/helm/templates/service_monitor.yaml
index 9911109e44cd05d27ff853a9e6901cac71c68b5b..20c0fee105500e4444f26baa4a6d1d22066c9cba 100644
--- a/src/main/helm/templates/service_monitor.yaml
+++ b/aggregation-manager-job/src/main/helm/templates/service_monitor.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -29,7 +29,7 @@ metadata:
   namespace: {{ include "app.namespace" . }}
   labels:
     {{- include "app.defaultLabels" . | indent 4 }}
-    component: aggregation-manager-service-monitor
+    component: aggregation-manager-job-service-monitor
 spec:
   endpoints:
   - port: metrics
@@ -40,4 +40,4 @@ spec:
   selector:
     matchLabels:
       {{- include "app.matchLabels" . | indent 6 }}
-      component: aggregation-manager-service
\ No newline at end of file
+      component: aggregation-manager-job-service
\ No newline at end of file
diff --git a/src/main/helm/values.yaml b/aggregation-manager-job/src/main/helm/values.yaml
similarity index 66%
rename from src/main/helm/values.yaml
rename to aggregation-manager-job/src/main/helm/values.yaml
index 1800799a5d54d14fcbab7102b5af38f0ddf798e9..e619c25c4f0b53888af78724f990ae368aa49569 100644
--- a/src/main/helm/values.yaml
+++ b/aggregation-manager-job/src/main/helm/values.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,33 +24,33 @@
 
 image:
   repo: docker.ozg-sh.de
-  name: aggregation-manager
+  name: aggregation-manager-job
   tag: latest
 
 ozgcloud:
   environment:
 
 database:
-   useExternal: false
-   databaseName: aggregation-manager-database
-   secretName: ozg-mongodb-admin-aggregation-manager-user
-   tls:
-      enabled: false
-      secretName: ozg-mongodb-tls-cert
+  useExternal: false
+  databaseName: aggregation-manager-job-database
+  secretName: ozg-mongodb-admin-aggregation-manager-job-user
+  tls:
+    enabled: false
+    secretName: ozg-mongodb-tls-cert
 
 vorgangManager:
-   grpcClientNegotiationType: PLAINTEXT
+  grpcClientNegotiationType: PLAINTEXT
 
 cronjob:
-   schedule: "0 0 * * *"
-   successfulJobsHistoryLimit: 3
-   failedJobsHistoryLimit: 3
-   concurrencyPolicy: Forbid
-   startingDeadlineSeconds: 120
+  schedule: "0 0 * * *"
+  successfulJobsHistoryLimit: 3
+  failedJobsHistoryLimit: 3
+  concurrencyPolicy: Forbid
+  startingDeadlineSeconds: 120
 
 serviceAccount:
-   create: true
-   name: aggregation-manager-service-account
+  create: true
+  name: aggregation-manager-job-service-account
 
 imagePullSecret: ""
 
diff --git a/src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java
similarity index 94%
rename from src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java
index aac2e2e6c39e8917a0544f8fb1e056a939113344..035d0f0e2bf90e5ac6c436f9c752fc15cfc9b6fd 100644
--- a/src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationCallContext.java
@@ -1,26 +1,26 @@
-/*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
 package de.ozgcloud.aggregation;
 
 import org.springframework.stereotype.Component;
diff --git a/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
similarity index 94%
rename from src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
index 2790a8f36d148eeabb25829bbd69bd5853e67a5c..22ee8742bada8d265601e0ba33d621240a065c9d 100644
--- a/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
@@ -1,49 +1,49 @@
-/*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
-package de.ozgcloud.aggregation;
-
-import org.springframework.boot.SpringApplication;
-import org.springframework.boot.autoconfigure.SpringBootApplication;
-import org.springframework.boot.context.properties.ConfigurationPropertiesScan;
-import org.springframework.context.annotation.ComponentScan;
-import org.springframework.context.annotation.EnableAspectJAutoProxy;
-import org.springframework.scheduling.annotation.EnableAsync;
-import org.springframework.scheduling.annotation.EnableScheduling;
-
-import lombok.RequiredArgsConstructor;
-
-@SpringBootApplication
-@EnableAsync
-@EnableScheduling
-@EnableAspectJAutoProxy(proxyTargetClass = true)
-@ComponentScan({ "de.ozgcloud.*" })
-@ConfigurationPropertiesScan("de.ozgcloud.*")
-@RequiredArgsConstructor
-public class AggregationManagerApplication {
-
-	public static void main(String[] args) {
-		SpringApplication.run(AggregationManagerApplication.class, args).close();
-	}
-
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
+package de.ozgcloud.aggregation;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.context.properties.ConfigurationPropertiesScan;
+import org.springframework.context.annotation.ComponentScan;
+import org.springframework.context.annotation.EnableAspectJAutoProxy;
+import org.springframework.scheduling.annotation.EnableAsync;
+import org.springframework.scheduling.annotation.EnableScheduling;
+
+import lombok.RequiredArgsConstructor;
+
+@SpringBootApplication
+@EnableAsync
+@EnableScheduling
+@EnableAspectJAutoProxy(proxyTargetClass = true)
+@ComponentScan({ "de.ozgcloud.*" })
+@ConfigurationPropertiesScan("de.ozgcloud.*")
+@RequiredArgsConstructor
+public class AggregationManagerApplication {
+
+	public static void main(String[] args) {
+		SpringApplication.run(AggregationManagerApplication.class, args).close();
+	}
+
 }
\ No newline at end of file
diff --git a/src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java
similarity index 92%
rename from src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java
index 16a2bcd3277223200e280c074decc16327349b77..00541877a3dbf271f7e375b6abf291d861e785cc 100644
--- a/src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerConfiguration.java
@@ -1,38 +1,38 @@
-/*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
-package de.ozgcloud.aggregation;
-
-import org.springframework.boot.context.properties.ConfigurationProperties;
-
-import lombok.Getter;
-import lombok.Setter;
-
-@ConfigurationProperties(prefix = "aggregation-manager")
-@Getter
-@Setter
-public class AggregationManagerConfiguration {
-
-	private int fetchingBatchSize;
-
-}
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
+package de.ozgcloud.aggregation;
+
+import org.springframework.boot.context.properties.ConfigurationProperties;
+
+import lombok.Getter;
+import lombok.Setter;
+
+@ConfigurationProperties(prefix = "aggregation-manager")
+@Getter
+@Setter
+public class AggregationManagerConfiguration {
+
+	private int fetchingBatchSize;
+
+}
diff --git a/src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java
similarity index 96%
rename from src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java
index 5a98db9ad96b7e3866d74af61b962e727e45e3d4..eec32d5d22db5bb94650f73344808f20fc3e5931 100644
--- a/src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerGrpcConfiguration.java
@@ -1,26 +1,26 @@
-/*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
 package de.ozgcloud.aggregation;
 
 import org.springframework.context.annotation.Bean;
diff --git a/src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java
similarity index 98%
rename from src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java
index 3cd83a1ba1130ed10ce21e2466db8abc71e47955..3d5596e8748fbdd4c3cf9ebcc884faa7d40fa79b 100644
--- a/src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/AggregationManagerRunner.java
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
  * Ministerpräsidenten des Landes Schleswig-Holstein
  * Staatskanzlei
  * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/main/java/de/ozgcloud/aggregation/Aggregator.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/Aggregator.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/Aggregator.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/Aggregator.java
diff --git a/src/main/java/de/ozgcloud/aggregation/ConverterConfiguration.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ConverterConfiguration.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/ConverterConfiguration.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ConverterConfiguration.java
diff --git a/src/main/java/de/ozgcloud/aggregation/TransformationProperties.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/TransformationProperties.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/TransformationProperties.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/TransformationProperties.java
diff --git a/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeReadConverter.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeReadConverter.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/ZonedDateTimeReadConverter.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeReadConverter.java
diff --git a/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeWriteConverter.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeWriteConverter.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/ZonedDateTimeWriteConverter.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/ZonedDateTimeWriteConverter.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/AggregationMapping.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/AggregationMapping.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/AggregationMapping.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/AggregationMapping.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformation.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformation.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformation.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformation.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformationService.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformationService.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformationService.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/JSLTransformationService.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/Transformation.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/Transformation.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/Transformation.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/Transformation.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/TransformationException.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/TransformationException.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/TransformationException.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/TransformationException.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/TransformationService.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/TransformationService.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/TransformationService.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/TransformationService.java
diff --git a/src/main/java/de/ozgcloud/aggregation/transformation/VorgangMapper.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/VorgangMapper.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/transformation/VorgangMapper.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/transformation/VorgangMapper.java
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepository.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepository.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepository.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepository.java
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImpl.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImpl.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImpl.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImpl.java
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java
similarity index 96%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java
index 8f368ac3845ce1d37eedfc408cf1e0b0b2ab7da3..5afa5add677eef2732f8103f6d23e4c49c8de802 100644
--- a/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentEntry.java
@@ -1,52 +1,52 @@
-/*
- * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
-package de.ozgcloud.aggregation.warehouse;
-
-import java.time.ZonedDateTime;
-
-import org.springframework.data.annotation.Id;
-import org.springframework.data.annotation.TypeAlias;
-import org.springframework.data.mongodb.core.mapping.Document;
-
-import com.fasterxml.jackson.databind.node.ObjectNode;
-
-import lombok.Builder;
-import lombok.Getter;
-
-@Document(collection = DocumentEntry.COLLECTION)
-@Getter
-@Builder
-@TypeAlias("Vorgang")
-public class DocumentEntry {
-
-	public static final String COLLECTION = "vorgang";
-
-	@Id
-	private String id;
-
-	private String status;
-	private ZonedDateTime eingangsdatum;
-	private String vorgangsname;
-	private ObjectNode payload;
-}
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
+package de.ozgcloud.aggregation.warehouse;
+
+import java.time.ZonedDateTime;
+
+import org.springframework.data.annotation.Id;
+import org.springframework.data.annotation.TypeAlias;
+import org.springframework.data.mongodb.core.mapping.Document;
+
+import com.fasterxml.jackson.databind.node.ObjectNode;
+
+import lombok.Builder;
+import lombok.Getter;
+
+@Document(collection = DocumentEntry.COLLECTION)
+@Getter
+@Builder
+@TypeAlias("Vorgang")
+public class DocumentEntry {
+
+	public static final String COLLECTION = "vorgang";
+
+	@Id
+	private String id;
+
+	private String status;
+	private ZonedDateTime eingangsdatum;
+	private String vorgangsname;
+	private ObjectNode payload;
+}
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentToJsonNodeConverter.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentToJsonNodeConverter.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/DocumentToJsonNodeConverter.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/DocumentToJsonNodeConverter.java
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/JsonNodeToDocumentConverter.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/JsonNodeToDocumentConverter.java
similarity index 100%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/JsonNodeToDocumentConverter.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/JsonNodeToDocumentConverter.java
diff --git a/src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java
similarity index 97%
rename from src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java
rename to aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java
index c31564a9a30e98564b181b174e3589510be7c12c..92632d531ca8c6e2d45cf714ed48f7072ef9ccc5 100644
--- a/src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java
+++ b/aggregation-manager-job/src/main/java/de/ozgcloud/aggregation/warehouse/WarehouseRepository.java
@@ -1,32 +1,32 @@
-/*
- * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
- * Ministerpräsidenten des Landes Schleswig-Holstein
- * Staatskanzlei
- * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
- *
- * Lizenziert unter der EUPL, Version 1.2 oder - sobald
- * diese von der Europäischen Kommission genehmigt wurden -
- * Folgeversionen der EUPL ("Lizenz");
- * Sie dürfen dieses Werk ausschließlich gemäß
- * dieser Lizenz nutzen.
- * Eine Kopie der Lizenz finden Sie hier:
- *
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
- *
- * Sofern nicht durch anwendbare Rechtsvorschriften
- * gefordert oder in schriftlicher Form vereinbart, wird
- * die unter der Lizenz verbreitete Software "so wie sie
- * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
- * ausdrücklich oder stillschweigend - verbreitet.
- * Die sprachspezifischen Genehmigungen und Beschränkungen
- * unter der Lizenz sind dem Lizenztext zu entnehmen.
- */
-package de.ozgcloud.aggregation.warehouse;
-
-import org.springframework.data.mongodb.repository.MongoRepository;
-import org.springframework.stereotype.Repository;
-
-@Repository
-public interface WarehouseRepository extends MongoRepository<DocumentEntry, String>, CustomWarehouseRepository {
-
-}
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
+package de.ozgcloud.aggregation.warehouse;
+
+import org.springframework.data.mongodb.repository.MongoRepository;
+import org.springframework.stereotype.Repository;
+
+@Repository
+public interface WarehouseRepository extends MongoRepository<DocumentEntry, String>, CustomWarehouseRepository {
+
+}
diff --git a/src/main/resources/application-local.yml b/aggregation-manager-job/src/main/resources/application-local.yml
similarity index 91%
rename from src/main/resources/application-local.yml
rename to aggregation-manager-job/src/main/resources/application-local.yml
index 5757dad77b6cf41d257b0604abf036ac0cd2db2e..f971794e9d5962d901fa845a6421360ae558671a 100644
--- a/src/main/resources/application-local.yml
+++ b/aggregation-manager-job/src/main/resources/application-local.yml
@@ -11,7 +11,7 @@ spring:
     mongodb:
       host: localhost
       port: 27017
-      database: aggregation-manager
+      database: aggregation-manager-job
 
 ozgcloud:
   vorgang-manager:
diff --git a/src/main/resources/application.yml b/aggregation-manager-job/src/main/resources/application.yml
similarity index 100%
rename from src/main/resources/application.yml
rename to aggregation-manager-job/src/main/resources/application.yml
diff --git a/src/test/helm-linter-values.yaml b/aggregation-manager-job/src/test/helm-linter-values.yaml
similarity index 93%
rename from src/test/helm-linter-values.yaml
rename to aggregation-manager-job/src/test/helm-linter-values.yaml
index 5024cc924057218b72df02830cac6d67890d6c54..ca9203d3b2911e7aa350f85a5b62f1264d4bf26e 100644
--- a/src/test/helm-linter-values.yaml
+++ b/aggregation-manager-job/src/test/helm-linter-values.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/helm/configmap_bindings_type_test.yaml b/aggregation-manager-job/src/test/helm/configmap_bindings_type_test.yaml
similarity index 72%
rename from src/test/helm/configmap_bindings_type_test.yaml
rename to aggregation-manager-job/src/test/helm/configmap_bindings_type_test.yaml
index e641ab09f0a5c15492a486ce81bbd4ed423c6af0..b02634db1d638c1c5a52370c48b638f2a51bf8bd 100644
--- a/src/test/helm/configmap_bindings_type_test.yaml
+++ b/aggregation-manager-job/src/test/helm/configmap_bindings_type_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: configmap_bindings_type
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/configmap_bindings_type.yaml
@@ -32,23 +32,23 @@ tests:
   - it: configMap should not exists
     asserts:
       - hasDocuments:
-          count: 0     
+          count: 0
   - it: should have configmap if database tls is enabled
     set:
       database:
         tls:
           enabled: true
     asserts:
-     - isKind:
-         of: ConfigMap
-     - isAPIVersion:
-         of: v1
-     - equal:
-         path: metadata.name
-         value: aggregation-manager-bindings-type
-     - equal:
-         path: metadata.namespace
-         value: sh-helm-test
-     - equal:
-        path: data.type
-        value: "ca-certificates"
\ No newline at end of file
+      - isKind:
+          of: ConfigMap
+      - isAPIVersion:
+          of: v1
+      - equal:
+          path: metadata.name
+          value: aggregation-manager-job-bindings-type
+      - equal:
+          path: metadata.namespace
+          value: sh-helm-test
+      - equal:
+          path: data.type
+          value: "ca-certificates"
diff --git a/src/test/helm/cronjob_database_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_database_test.yaml
similarity index 89%
rename from src/test/helm/cronjob_database_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_database_test.yaml
index be7ef6105fbdd24715ab8668f8b4873cff9a4378..e29aca6a4f7fe3f44eb4b75a93e96f38abe1a7ab 100644
--- a/src/test/helm/cronjob_database_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_database_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: cronjob database
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/cronjob.yaml
@@ -68,14 +68,14 @@ tests:
             name: spring_data_mongodb_uri
             valueFrom:
               secretKeyRef:
-                name: ozg-mongodb-admin-aggregation-manager-user
+                name: ozg-mongodb-admin-aggregation-manager-job-user
                 key: connectionString.standardSrv
                 optional: false
       - contains:
           path: spec.jobTemplate.spec.template.spec.containers[0].env
           content:
             name: spring_data_mongodb_database
-            value: aggregation-manager-database
+            value: aggregation-manager-job-database
   - it: should configure external mongodb if useExternal
     set:
       database.useExternal: true
@@ -84,7 +84,7 @@ tests:
           path: spec.jobTemplate.spec.template.spec.containers[0].envFrom
           content:
             secretRef:
-              name: ozg-mongodb-admin-aggregation-manager-user
+              name: ozg-mongodb-admin-aggregation-manager-job-user
   - it: should not have a volume for the mongodb certificate if tls is disabled
     set:
       database:
@@ -100,4 +100,4 @@ tests:
           enabled: false
     asserts:
       - isEmpty:
-          path: spec.jobTemplate.spec.template.spec.volumes
\ No newline at end of file
+          path: spec.jobTemplate.spec.template.spec.volumes
diff --git a/src/test/helm/cronjob_defaults_labels_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_defaults_labels_test.yaml
similarity index 73%
rename from src/test/helm/cronjob_defaults_labels_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_defaults_labels_test.yaml
index f1e13826790fb3e86a2dd5a98c5632dd97df1217..faf075d5cd2ff5765ace191962d0adc91cec7199 100644
--- a/src/test/helm/cronjob_defaults_labels_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_defaults_labels_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: test cronjob default labels
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/cronjob.yaml
@@ -36,27 +36,27 @@ tests:
     asserts:
       - equal:
           path: metadata.labels
-          value:        
-            app.kubernetes.io/instance: aggregation-manager
+          value:
+            app.kubernetes.io/instance: aggregation-manager-job
             app.kubernetes.io/managed-by: Helm
-            app.kubernetes.io/name: aggregation-manager
+            app.kubernetes.io/name: aggregation-manager-job
             app.kubernetes.io/namespace: sh-helm-test
             app.kubernetes.io/part-of: ozgcloud
             app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
-            helm.sh/chart: aggregation-manager-0.0.0-MANAGED-BY-JENKINS
+            helm.sh/chart: aggregation-manager-job-0.0.0-MANAGED-BY-JENKINS
             ozgcloud-mongodb-client: "true"
 
   - it: should have correct deyploment spec.template.metadata.labels
     asserts:
       - equal:
           path: spec.jobTemplate.spec.template.metadata.labels
-          value: 
-            app.kubernetes.io/instance: aggregation-manager
+          value:
+            app.kubernetes.io/instance: aggregation-manager-job
             app.kubernetes.io/managed-by: Helm
-            app.kubernetes.io/name: aggregation-manager
+            app.kubernetes.io/name: aggregation-manager-job
             app.kubernetes.io/namespace: sh-helm-test
             app.kubernetes.io/part-of: ozgcloud
             app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
-            component: aggregation-manager
-            helm.sh/chart: aggregation-manager-0.0.0-MANAGED-BY-JENKINS
-            ozgcloud-mongodb-client: "true"
\ No newline at end of file
+            component: aggregation-manager-job
+            helm.sh/chart: aggregation-manager-job-0.0.0-MANAGED-BY-JENKINS
+            ozgcloud-mongodb-client: "true"
diff --git a/src/test/helm/cronjob_env_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_env_test.yaml
similarity index 98%
rename from src/test/helm/cronjob_env_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_env_test.yaml
index 0964a3526aea3d15e15096043c5ee4e86a0bcc60..14aad4dd395c276f8554bbf53b2acce46e02be3f 100644
--- a/src/test/helm/cronjob_env_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_env_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/helm/cronjob_image_pull_secret_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_image_pull_secret_test.yaml
similarity index 95%
rename from src/test/helm/cronjob_image_pull_secret_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_image_pull_secret_test.yaml
index d20bffe4aae3d5fbe916855fad80f0663b279f99..c8138c28f1a946e9885c3bc2cbd4a32bbb870791 100644
--- a/src/test/helm/cronjob_image_pull_secret_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_image_pull_secret_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/helm/cronjob_resources_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_resources_test.yaml
similarity index 95%
rename from src/test/helm/cronjob_resources_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_resources_test.yaml
index 5f244b3b4a85e532c67b0d1ed0481f29ef74c730..09be4bc145d470acb07bfa37cc06288273e073c2 100644
--- a/src/test/helm/cronjob_resources_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_resources_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/helm/cronjob_service_account_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_service_account_test.yaml
similarity index 87%
rename from src/test/helm/cronjob_service_account_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_service_account_test.yaml
index a97523243694fa4f636791af27ea7c5f2b6f55c6..588230c574e77c0e8962f2b24490e0ae951a589b 100644
--- a/src/test/helm/cronjob_service_account_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_service_account_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: cronjob service account
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: by-helm-test
 templates:
   - templates/cronjob.yaml
@@ -32,11 +32,11 @@ set:
   ozgcloud:
     environment: dev
 tests:
-  - it: should use aggregation-manager service account
+  - it: should use aggregation-manager-job service account
     asserts:
       - equal:
           path: spec.jobTemplate.spec.template.spec.serviceAccountName
-          value: aggregation-manager-service-account
+          value: aggregation-manager-job-service-account
   - it: should set service account name
     set:
       serviceAccount:
@@ -51,4 +51,4 @@ tests:
         create: false
     asserts:
       - isNull:
-          path: spec.jobTemplate.spec.template.spec.serviceAccountName
\ No newline at end of file
+          path: spec.jobTemplate.spec.template.spec.serviceAccountName
diff --git a/src/test/helm/cronjob_spring_profile_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_spring_profile_test.yaml
similarity index 96%
rename from src/test/helm/cronjob_spring_profile_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_spring_profile_test.yaml
index 4a52ee5a0e5c33f80397ba62c140753e76d8ce3c..633e3513c7963674606ea6f62440aa918cfde4db 100644
--- a/src/test/helm/cronjob_spring_profile_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_spring_profile_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/helm/cronjob_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_test.yaml
similarity index 96%
rename from src/test/helm/cronjob_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_test.yaml
index 291b20282acf3b1fc3f36e78466ad2e28dae9647..119c1a1904ed7fb296c0a12791e084a21547555a 100644
--- a/src/test/helm/cronjob_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: cronjob test
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/cronjob.yaml
@@ -40,7 +40,7 @@ tests:
           of: batch/v1
       - equal:
           path: metadata.name
-          value: "aggregation-manager"
+          value: "aggregation-manager-job"
       - equal:
           path: metadata.namespace
           value: "sh-helm-test"
@@ -90,10 +90,10 @@ tests:
     asserts:
       - equal:
           path: spec.jobTemplate.spec.template.spec.containers[0].name
-          value: "aggregation-manager"
+          value: "aggregation-manager-job"
       - equal:
           path: spec.jobTemplate.spec.template.spec.containers[0].image
-          value: "docker.ozg-sh.de/aggregation-manager:latest"
+          value: "docker.ozg-sh.de/aggregation-manager-job:latest"
       - equal:
           path: spec.jobTemplate.spec.template.spec.containers[0].imagePullPolicy
           value: "Always"
diff --git a/src/test/helm/cronjob_volume_test.yaml b/aggregation-manager-job/src/test/helm/cronjob_volume_test.yaml
similarity index 95%
rename from src/test/helm/cronjob_volume_test.yaml
rename to aggregation-manager-job/src/test/helm/cronjob_volume_test.yaml
index 43f3876cdf5dc025021bc6ab17c94cde03c03a0b..ba68ac06939502e39060c8896ed71770b9ac233d 100644
--- a/src/test/helm/cronjob_volume_test.yaml
+++ b/aggregation-manager-job/src/test/helm/cronjob_volume_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: cronjob volumes tests
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
 templates:
   - templates/cronjob.yaml
 set:
@@ -80,7 +80,7 @@ tests:
           value: "bindings"
       - equal:
           path: spec.jobTemplate.spec.template.spec.volumes[0].configMap.name
-          value: "aggregation-manager-bindings-type"
+          value: "aggregation-manager-job-bindings-type"
       - equal:
           path: spec.jobTemplate.spec.template.spec.volumes[1].name
           value: "mongodb-root-ca"
diff --git a/src/test/helm/network_policy_test.yaml b/aggregation-manager-job/src/test/helm/network_policy_test.yaml
similarity index 96%
rename from src/test/helm/network_policy_test.yaml
rename to aggregation-manager-job/src/test/helm/network_policy_test.yaml
index 29891cf1d24016645c3a346991059bfac69178d5..f680b3e541d58d4a3e1db1aae30e5f821152dcc7 100644
--- a/src/test/helm/network_policy_test.yaml
+++ b/aggregation-manager-job/src/test/helm/network_policy_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -22,9 +22,9 @@
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
 #
 
-suite: network policy aggregation-manager test
+suite: network policy aggregation-manager-job test
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: by-helm-test
 templates:
   - templates/network_policy.yaml
@@ -52,7 +52,7 @@ tests:
       - equal:
           path: metadata
           value:
-            name: network-policy-aggregation-manager
+            name: network-policy-aggregation-manager-job
             namespace: by-helm-test
   - it: validate spec
     set:
@@ -107,7 +107,7 @@ tests:
                     protocol: TCP
             podSelector:
               matchLabels:
-                component: aggregation-manager
+                component: aggregation-manager-job
             policyTypes:
               - Ingress
               - Egress
diff --git a/src/test/helm/service_account_test.yaml b/aggregation-manager-job/src/test/helm/service_account_test.yaml
similarity index 91%
rename from src/test/helm/service_account_test.yaml
rename to aggregation-manager-job/src/test/helm/service_account_test.yaml
index af9a14b3680f6dde6ed29a5fa9e86030fccd527f..532d556ef4480f0ece2decd8ad3b6350bb2cd2de 100644
--- a/src/test/helm/service_account_test.yaml
+++ b/aggregation-manager-job/src/test/helm/service_account_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,7 +24,7 @@
 
 suite: test service account
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/service_account.yaml
@@ -37,7 +37,7 @@ tests:
           of: v1
       - equal:
           path: metadata.name
-          value: aggregation-manager-service-account
+          value: aggregation-manager-job-service-account
       - equal:
           path: metadata.namespace
           value: sh-helm-test
@@ -60,4 +60,4 @@ tests:
         create: false
     asserts:
       - hasDocuments:
-        count: 0
\ No newline at end of file
+        count: 0
diff --git a/src/test/helm/service_monitor_test.yaml b/aggregation-manager-job/src/test/helm/service_monitor_test.yaml
similarity index 78%
rename from src/test/helm/service_monitor_test.yaml
rename to aggregation-manager-job/src/test/helm/service_monitor_test.yaml
index ecf7e1409a9349be069138c23f8159db19bae575..de7e81b9383c35803f6677bd781b6a7cd96e0c7c 100644
--- a/src/test/helm/service_monitor_test.yaml
+++ b/aggregation-manager-job/src/test/helm/service_monitor_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -24,12 +24,12 @@
 
 suite: test service_monitor
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: sh-helm-test
 templates:
   - templates/service_monitor.yaml
 tests:
-  - it: should have basic info and the label component with value aggregation-manager-service-monitor attached
+  - it: should have basic info and the label component with value aggregation-manager-job-service-monitor attached
     asserts:
       - isKind:
           of: ServiceMonitor
@@ -37,27 +37,27 @@ tests:
           of: monitoring.coreos.com/v1
       - equal:
           path: metadata.name
-          value: aggregation-manager
+          value: aggregation-manager-job
       - equal:
           path: metadata.namespace
           value: sh-helm-test
       - equal:
           path: metadata.labels["component"]
-          value: aggregation-manager-service-monitor
-      
+          value: aggregation-manager-job-service-monitor
+
   - it: should contain default lables and component lables
     asserts:
       - equal:
           path: metadata.labels
           value:
-            app.kubernetes.io/instance: aggregation-manager
+            app.kubernetes.io/instance: aggregation-manager-job
             app.kubernetes.io/managed-by: Helm
-            app.kubernetes.io/name: aggregation-manager
+            app.kubernetes.io/name: aggregation-manager-job
             app.kubernetes.io/namespace: sh-helm-test
             app.kubernetes.io/part-of: ozgcloud
             app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
-            component: aggregation-manager-service-monitor
-            helm.sh/chart: aggregation-manager-0.0.0-MANAGED-BY-JENKINS
+            component: aggregation-manager-job-service-monitor
+            helm.sh/chart: aggregation-manager-job-0.0.0-MANAGED-BY-JENKINS
             ozgcloud-mongodb-client: "true"
 
   - it: should have the metrics endpoint configured by default
@@ -78,7 +78,7 @@ tests:
     asserts:
       - equal:
           path: spec.selector.matchLabels
-          value: 
-            app.kubernetes.io/name: aggregation-manager
+          value:
+            app.kubernetes.io/name: aggregation-manager-job
             app.kubernetes.io/namespace: sh-helm-test
-            component: aggregation-manager-service
+            component: aggregation-manager-job-service
diff --git a/src/test/helm/service_test.yaml b/aggregation-manager-job/src/test/helm/service_test.yaml
similarity index 80%
rename from src/test/helm/service_test.yaml
rename to aggregation-manager-job/src/test/helm/service_test.yaml
index 2c8b527f81f699d8e01e76bcdc64091477b702a5..99060f8e11ade7f6ffcabc7c90db318e48dd9d8a 100644
--- a/src/test/helm/service_test.yaml
+++ b/aggregation-manager-job/src/test/helm/service_test.yaml
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -27,7 +27,7 @@ suite: service
 templates:
   - templates/service.yaml
 release:
-  name: aggregation-manager
+  name: aggregation-manager-job
   namespace: helm-test
 
 tests:
@@ -36,7 +36,7 @@ tests:
       - containsDocument:
           kind: Service
           apiVersion: v1
-          name: aggregation-manager
+          name: aggregation-manager-job
           namespace: helm-test
   - it: should be of type ClusterIP
     asserts:
@@ -56,7 +56,7 @@ tests:
     asserts:
       - equal:
           path: spec.selector["app.kubernetes.io/name"]
-          value: aggregation-manager
+          value: aggregation-manager-job
       - equal:
           path: spec.selector["app.kubernetes.io/namespace"]
           value: helm-test
@@ -64,18 +64,18 @@ tests:
     asserts:
       - equal:
           path: spec.selector.component
-          value: aggregation-manager
+          value: aggregation-manager-job
   - it: should contain default lables and component lables
     asserts:
       - equal:
           path: metadata.labels
           value:
-            app.kubernetes.io/instance: aggregation-manager
+            app.kubernetes.io/instance: aggregation-manager-job
             app.kubernetes.io/managed-by: Helm
-            app.kubernetes.io/name: aggregation-manager
+            app.kubernetes.io/name: aggregation-manager-job
             app.kubernetes.io/namespace: helm-test
             app.kubernetes.io/part-of: ozgcloud
             app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
-            component: aggregation-manager-service
-            helm.sh/chart: aggregation-manager-0.0.0-MANAGED-BY-JENKINS
-            ozgcloud-mongodb-client: "true"
\ No newline at end of file
+            component: aggregation-manager-job-service
+            helm.sh/chart: aggregation-manager-job-0.0.0-MANAGED-BY-JENKINS
+            ozgcloud-mongodb-client: "true"
diff --git a/src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java
similarity index 94%
rename from src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java
index 2a71c5380dce4dcf86d7eab02d44e6fa16842cac..a4435962dfe31959a66dd33a574de6290a0a6597 100644
--- a/src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java
+++ b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerApplicationTest.java
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
  * Ministerpräsidenten des Landes Schleswig-Holstein
  * Staatskanzlei
  * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java
similarity index 99%
rename from src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java
index c7ebb19305b6318b97af1787a0acb02456d4c084..7be8d55ab3d28d778ca582d07176f4d6082fe650 100644
--- a/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java
+++ b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerITCase.java
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
  * Ministerpräsidenten des Landes Schleswig-Holstein
  * Staatskanzlei
  * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
diff --git a/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregationManagerRunnerTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/AggregatorTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregatorTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/AggregatorTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/AggregatorTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/AggregationMappingTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/AggregationMappingTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/AggregationMappingTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/AggregationMappingTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/DotExpressionTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/DotExpressionTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/DotExpressionTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/DotExpressionTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/FieldMappingTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/FieldMappingTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/FieldMappingTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/FieldMappingTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/FormIdentifierTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/FormIdentifierTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/FormIdentifierTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/FormIdentifierTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/JSLTServiceITCase.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTServiceITCase.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/JSLTServiceITCase.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTServiceITCase.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationServiceTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationServiceTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationServiceTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationServiceTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/JSLTransformationTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/transformation/VorgangMapperTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/VorgangMapperTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/transformation/VorgangMapperTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/transformation/VorgangMapperTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImplTest.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImplTest.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImplTest.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/CustomWarehouseRepositoryImplTest.java
diff --git a/src/test/java/de/ozgcloud/aggregation/warehouse/DocumentEntryTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/DocumentEntryTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/warehouse/DocumentEntryTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/DocumentEntryTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/warehouse/ObjectNodeTestFactory.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/ObjectNodeTestFactory.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/warehouse/ObjectNodeTestFactory.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/ObjectNodeTestFactory.java
diff --git a/src/test/java/de/ozgcloud/aggregation/warehouse/WarehouseRepositoryITCase.java b/aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/WarehouseRepositoryITCase.java
similarity index 100%
rename from src/test/java/de/ozgcloud/aggregation/warehouse/WarehouseRepositoryITCase.java
rename to aggregation-manager-job/src/test/java/de/ozgcloud/aggregation/warehouse/WarehouseRepositoryITCase.java
diff --git a/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension b/aggregation-manager-job/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension
similarity index 100%
rename from src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension
rename to aggregation-manager-job/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension
diff --git a/src/test/resources/application-itcase.yml b/aggregation-manager-job/src/test/resources/application-itcase.yml
similarity index 100%
rename from src/test/resources/application-itcase.yml
rename to aggregation-manager-job/src/test/resources/application-itcase.yml
diff --git a/src/test/resources/junit-platform.properties b/aggregation-manager-job/src/test/resources/junit-platform.properties
similarity index 100%
rename from src/test/resources/junit-platform.properties
rename to aggregation-manager-job/src/test/resources/junit-platform.properties
diff --git a/aggregation-manager-server/lombok.config b/aggregation-manager-server/lombok.config
new file mode 100644
index 0000000000000000000000000000000000000000..f8d3b76385742905b4dac9085c349034013f2b97
--- /dev/null
+++ b/aggregation-manager-server/lombok.config
@@ -0,0 +1,32 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+lombok.log.fieldName=LOG
+lombok.log.slf4j.flagUsage = ERROR
+lombok.log.log4j.flagUsage = ERROR
+lombok.data.flagUsage = ERROR
+lombok.nonNull.exceptionType = IllegalArgumentException
+lombok.addLombokGeneratedAnnotation = true
+lombok.copyableAnnotations += org.springframework.beans.factory.annotation.Qualifier
+lombok.copyableAnnotations += net.devh.boot.grpc.client.inject.GrpcClient
\ No newline at end of file
diff --git a/aggregation-manager-server/pom.xml b/aggregation-manager-server/pom.xml
new file mode 100644
index 0000000000000000000000000000000000000000..67fef7696f43fc4fdf238758c29be255f305d414
--- /dev/null
+++ b/aggregation-manager-server/pom.xml
@@ -0,0 +1,93 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+
+    Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+    Ministerpräsidenten des Landes Schleswig-Holstein
+    Staatskanzlei
+    Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+
+    Lizenziert unter der EUPL, Version 1.2 oder - sobald
+    diese von der Europäischen Kommission genehmigt wurden -
+    Folgeversionen der EUPL ("Lizenz");
+    Sie dürfen dieses Werk ausschließlich gemäß
+    dieser Lizenz nutzen.
+    Eine Kopie der Lizenz finden Sie hier:
+
+    https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+
+    Sofern nicht durch anwendbare Rechtsvorschriften
+    gefordert oder in schriftlicher Form vereinbart, wird
+    die unter der Lizenz verbreitete Software "so wie sie
+    ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+    ausdrücklich oder stillschweigend - verbreitet.
+    Die sprachspezifischen Genehmigungen und Beschränkungen
+    unter der Lizenz sind dem Lizenztext zu entnehmen.
+
+-->
+<project xmlns="https://maven.apache.org/POM/4.0.0"
+	xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance"
+	xsi:schemaLocation="https://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>de.ozgcloud.aggregation</groupId>
+		<artifactId>aggregation-manager-parent</artifactId>
+		<version>1.3.0-SNAPSHOT</version>
+		<relativePath>../</relativePath>
+	</parent>
+	<artifactId>aggregation-manager-server</artifactId>
+	<name>OZG-Cloud Aggregation Manager Server</name>
+
+	<properties>
+		<spring-boot.build-image.imageName>docker.ozg-sh.de/aggregation-manager-server:build-latest</spring-boot.build-image.imageName>
+	</properties>
+
+	<dependencies>
+		<!-- Spring -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-web</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+		</dependency>
+	</dependencies>
+
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-compiler-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.springframework.boot</groupId>
+				<artifactId>spring-boot-maven-plugin</artifactId>
+				<configuration>
+					<mainClass>de.ozgcloud.aggregation.AggregationManagerApplication</mainClass>
+					<image>
+						<env>
+							<BPE_DELIM_JAVA_TOOL_OPTIONS xml:space="preserve"> </BPE_DELIM_JAVA_TOOL_OPTIONS>
+							<BPE_APPEND_JAVA_TOOL_OPTIONS>-Dfile.encoding=UTF-8</BPE_APPEND_JAVA_TOOL_OPTIONS>
+						</env>
+					</image>
+				</configuration>
+			</plugin>
+			<plugin>
+				<groupId>org.jacoco</groupId>
+				<artifactId>jacoco-maven-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-failsafe-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-surefire-plugin</artifactId>
+			</plugin>
+			<plugin>
+				<groupId>com.mycila</groupId>
+				<artifactId>license-maven-plugin</artifactId>
+			</plugin>
+		</plugins>
+	</build>
+</project>
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/.helmignore b/aggregation-manager-server/src/main/helm/.helmignore
new file mode 100644
index 0000000000000000000000000000000000000000..0e8a0eb36f4ca2c939201c0d54b5d82a1ea34778
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/.helmignore
@@ -0,0 +1,23 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*.orig
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
+.vscode/
diff --git a/aggregation-manager-server/src/main/helm/Chart.yaml b/aggregation-manager-server/src/main/helm/Chart.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..4c3c0f25a70c0969fc179e41e3ca25f354ba9a8b
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/Chart.yaml
@@ -0,0 +1,30 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+apiVersion: v1
+appVersion: "1.0"
+description: OZG-Cloud Helm chart for aggregation-manager-server
+name: aggregation-manager-server
+version: 0.0.0-MANAGED-BY-JENKINS
+icon: https://simpleicons.org/icons/helm.svg
diff --git a/aggregation-manager-server/src/main/helm/templates/_helpers.tpl b/aggregation-manager-server/src/main/helm/templates/_helpers.tpl
new file mode 100644
index 0000000000000000000000000000000000000000..282313ebc33dd0695c821d2991c9001edba0f929
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/_helpers.tpl
@@ -0,0 +1,105 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+{{/* error check 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec) */}}
+{{/* Namespace */}}
+{{- define "app.namespace" -}}
+{{- if gt (len (.Release.Namespace)) 63 -}}
+{{- fail (printf ".Release.Namespace %s ist zu lang (max. 63 Zeichen)" .Release.Namespace) -}}
+{{- end -}}
+{{ printf "%s" .Release.Namespace }}
+{{- end -}}
+
+{{/* Chart: Name + Version */}}
+{{- define "app.chart" -}}
+{{- if gt (len (printf "%s-%s" .Chart.Name .Chart.Version)) 63 -}}
+{{- fail (printf ".Chart.Name-.Chart.Version %s-%s ist zu lang (max. 63 Zeichen)" .Chart.Name .Chart.Version) -}}
+{{- end -}}
+{{ printf "%s-%s" .Chart.Name .Chart.Version }}
+{{- end -}}
+
+{{/* Managed-by -> On Helm, this value is always Helm */}}
+{{- define "app.managedBy" -}}
+{{- if gt (len (.Release.Service)) 63 -}}
+{{- fail (printf ".Release.Service %s ist zu lang (max. 63 Zeichen)" .Release.Service) -}}
+{{- end -}}
+{{ printf "%s" .Release.Service }}
+{{- end -}}
+
+
+{{/* Default Labels: Helm recommended best-practice labels https://helm.sh/docs/chart_best_practices/labels/ */}}
+{{- define "app.defaultLabels" }}
+app.kubernetes.io/instance: aggregation-manager-server
+app.kubernetes.io/managed-by: {{ include "app.managedBy" . }}
+app.kubernetes.io/name: {{ .Release.Name }}
+app.kubernetes.io/namespace: {{ include "app.namespace" . }}
+app.kubernetes.io/part-of: ozgcloud
+app.kubernetes.io/version: {{ .Chart.Version }}
+helm.sh/chart: {{ include "app.chart" . }}
+ozgcloud-mongodb-client: "true"
+{{- end -}}
+
+{{- define "app.matchLabels" }}
+app.kubernetes.io/name: {{ .Release.Name }}
+app.kubernetes.io/namespace: {{ include "app.namespace" . }}
+{{- end -}}
+
+
+{{- define "app.envSpringProfiles" }}
+{{- if (.Values.env).overrideSpringProfiles -}}
+{{ printf "%s" (.Values.env).overrideSpringProfiles }}
+{{- else -}}
+{{ printf "oc, %s" (include "app.ozgcloudEnvironment" . ) }}
+{{- end -}}
+{{- end -}}
+
+{{- define "app.ozgcloudEnvironment" -}}
+{{- required "Environment muss angegeben sein" (.Values.ozgcloud).environment -}}
+{{- end -}}
+
+{{- define "app.getCustomList" -}}
+{{- with (.Values.env).customList -}}
+{{- if kindIs "map" . -}}
+{{ include "app.dictToList" . }}
+{{- else if kindIs "slice" . -}}
+{{ . | toYaml }}
+{{- end -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "app.dictToList" -}}
+{{- $customList := list -}}
+{{- range $key, $value := . -}}
+{{- $customList = append $customList (dict "name" $key "value" $value) }}
+{{- end -}}
+{{- $customList | toYaml -}}
+{{- end -}}
+
+{{- define "app.getOzgcloudAdministrationAddress" -}}
+{{- if .Values.administrationAddress -}}
+{{ printf "%s" .Values.administrationAddress }}
+{{- else -}}
+{{ printf "http://%s.%s:8080" .Values.administrationName .Release.Namespace }}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/templates/configmap_bindings_type.yaml b/aggregation-manager-server/src/main/helm/templates/configmap_bindings_type.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..63711189ff34aed1493c5506e1b5023b279becbe
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/configmap_bindings_type.yaml
@@ -0,0 +1,34 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+{{- if ((.Values.database).tls).enabled }}
+apiVersion: v1
+kind: ConfigMap
+metadata:
+  name: aggregation-manager-server-bindings-type
+  namespace: {{ include "app.namespace" . }}
+data:
+  type: |
+        ca-certificates
+{{- end }}
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/templates/deployment.yaml b/aggregation-manager-server/src/main/helm/templates/deployment.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..1fac9cbcc4c4d51d0e1ef96085c1ba91158dcc24
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/deployment.yaml
@@ -0,0 +1,138 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+apiVersion: apps/v1
+kind: Deployment
+metadata:
+  name: {{ .Release.Name }}
+  namespace: {{ include "app.namespace" . }}
+  labels:
+      {{- include "app.defaultLabels" . | indent 4 }}
+spec:
+  progressDeadlineSeconds: 600
+  replicas: {{ .Values.replicaCount }}
+  revisionHistoryLimit: 10
+  selector:
+    matchLabels:
+        {{- include "app.matchLabels" . | indent 6 }}
+  strategy:
+    rollingUpdate:
+      maxSurge: 1
+      maxUnavailable: 0
+    type: RollingUpdate
+  template:
+    metadata:
+      labels:
+        {{- include "app.defaultLabels" . | indent 8 }}
+        component: aggregation-manager-server
+    spec:
+      topologySpreadConstraints:
+        - maxSkew: 1
+          topologyKey: kubernetes.io/hostname
+          whenUnsatisfiable: ScheduleAnyway
+          labelSelector:
+            matchLabels:
+              app.kubernetes.io/name: {{ .Release.Name }}
+      {{- if (.Values.serviceAccount).create }}
+      serviceAccountName: {{ .Values.serviceAccount.name }}
+      {{- end }}
+      containers:
+      - name: aggregation-manager-server
+        image: "{{ .Values.image.repo }}/{{ .Values.image.name }}:{{ coalesce (.Values.image).tag "latest" }}"
+        imagePullPolicy: Always
+        env:
+        - name: SERVICE_BINDING_ROOT
+          value: "/bindings"
+        - name: spring_profiles_active
+          value: {{ include "app.envSpringProfiles" . }}
+        - name: ozgcloud_administration_address
+          value: {{ include "app.getOzgcloudAdministrationAddress" . }}
+        {{- with include "app.getCustomList" . }}
+{{ . | indent 8 }}
+        {{- end }}
+        ports:
+          - containerPort: 8081
+            name: metrics
+            protocol: TCP
+        readinessProbe:
+          failureThreshold: 3
+          httpGet:
+            path: /actuator/health/readiness
+            port: 8081
+            scheme: HTTP
+          periodSeconds: 10
+          successThreshold: 1
+          timeoutSeconds: 3
+        startupProbe:
+          httpGet:
+            path: /actuator/health/readiness
+            port: 8081
+            scheme: HTTP
+          failureThreshold: 10
+          initialDelaySeconds: 30
+          periodSeconds: 10
+          successThreshold: 1
+          timeoutSeconds: 5
+        resources:
+        {{- with .Values.resources }}
+{{ toYaml . | indent 10 }}
+        {{- end }}
+        securityContext:
+          allowPrivilegeEscalation: false
+          privileged: false
+          readOnlyRootFilesystem: false
+          runAsNonRoot: false
+        stdin: true
+        terminationMessagePath: /dev/termination-log
+        terminationMessagePolicy: File
+        tty: true
+        volumeMounts:
+        {{- if ((.Values.database).tls).enabled }}
+        - name: bindings
+          mountPath: "/bindings/ca-certificates/type"
+          subPath: type
+          readOnly: true
+        - name: mongodb-root-ca
+          mountPath: "/bindings/ca-certificates/mongodb-root-ca.pem"
+          subPath: ca.crt
+          readOnly: true
+        {{- end }}
+      volumes:
+        {{- if ((.Values.database).tls).enabled }}
+      - name: bindings
+        configMap:
+          name: aggregation-manager-server-bindings-type
+      - name: mongodb-root-ca
+        secret:
+          secretName: {{ ((.Values.database).tls).secretName }}
+          optional: true
+      {{- end }}
+      dnsConfig: { }
+      dnsPolicy: ClusterFirst
+      imagePullSecrets:
+      - name: {{ required "imagePullSecret must be set" .Values.imagePullSecret }}
+      restartPolicy: Always
+      schedulerName: default-scheduler
+      securityContext: { }
+      terminationGracePeriodSeconds: 30
diff --git a/aggregation-manager-server/src/main/helm/templates/network_policy.yaml b/aggregation-manager-server/src/main/helm/templates/network_policy.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..74138a34bca3f686944dd08abe10287689f7625e
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/network_policy.yaml
@@ -0,0 +1,73 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+{{- if not (.Values.networkPolicy).disabled }}
+apiVersion: networking.k8s.io/v1
+kind: NetworkPolicy
+metadata:
+  name: network-policy-aggregation-manager-server
+  namespace: {{ include "app.namespace" . }}
+spec:
+  podSelector:
+    matchLabels:
+      component: aggregation-manager-server
+  policyTypes:
+    - Ingress
+    - Egress
+  ingress:
+  - from:
+    - namespaceSelector:
+        matchLabels:
+          name: {{ (.Values.networkPolicy).monitoringNamespace | default "openshift-user-workload-monitoring" }}
+    ports:
+    - protocol: TCP
+      port: 8081
+{{- with (.Values.networkPolicy).additionalIngressConfigLocal }}
+{{ toYaml . | indent 2 }}
+{{- end }}
+{{- with (.Values.networkPolicy).additionalIngressConfigGlobal }}
+{{ toYaml . | indent 2 }}
+{{- end }}
+  egress:
+    - to:
+      - namespaceSelector:
+          matchLabels:
+            kubernetes.io/metadata.name: {{ required "networkPolicy.dnsServerNamespace must be set" (.Values.networkPolicy).dnsServerNamespace }}
+      ports:
+        - port: 53
+          protocol: UDP
+        - port: 53
+          protocol: TCP
+        - port: 5353
+          protocol: UDP
+        - port: 5353
+          protocol: TCP
+{{- with (.Values.networkPolicy).additionalEgressConfigLocal }}
+{{ toYaml . | indent 2 }}
+{{- end }}
+{{- with (.Values.networkPolicy).additionalEgressConfigGlobal }}
+{{ toYaml . | indent 2 }}
+{{- end }}
+
+{{- end }}
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/templates/service.yaml b/aggregation-manager-server/src/main/helm/templates/service.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..4af595e657094aac4bfd1b1e7d7386812f8577ae
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/service.yaml
@@ -0,0 +1,41 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+apiVersion: v1
+kind: Service
+metadata:
+  name: {{ .Release.Name }}
+  namespace: {{ include "app.namespace" . }}
+  labels:
+    {{- include "app.defaultLabels" . | indent 4 }}
+    component: aggregation-manager-server-service
+spec:
+  type: ClusterIP
+  ports:
+    - name: metrics
+      port: 8081
+      protocol: TCP
+  selector:
+    {{- include "app.matchLabels" . | indent 4 }}
+    component: aggregation-manager-server
diff --git a/aggregation-manager-server/src/main/helm/templates/service_account.yaml b/aggregation-manager-server/src/main/helm/templates/service_account.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..664e8acec9fabb26df2325ab4bc336e628151144
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/service_account.yaml
@@ -0,0 +1,31 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+{{- if (.Values.serviceAccount).create }}
+apiVersion: v1
+kind: ServiceAccount
+metadata:
+  name: {{ .Values.serviceAccount.name }}
+  namespace: {{ include "app.namespace" . }}
+{{- end }}
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/templates/service_monitor.yaml b/aggregation-manager-server/src/main/helm/templates/service_monitor.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..35f52b7999d37996d6d41d6023f1f7ca4ea68900
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/templates/service_monitor.yaml
@@ -0,0 +1,43 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+apiVersion: monitoring.coreos.com/v1
+kind: ServiceMonitor
+metadata:
+  name: {{ .Release.Name }}
+  namespace: {{ include "app.namespace" . }}
+  labels:
+    {{- include "app.defaultLabels" . | indent 4 }}
+    component: aggregation-manager-server-service-monitor
+spec:
+  endpoints:
+  - port: metrics
+    path: /actuator/prometheus
+  namespaceSelector:
+    matchNames:
+    - {{ include "app.namespace" . }}
+  selector:
+    matchLabels:
+      {{- include "app.matchLabels" . | indent 6 }}
+      component: aggregation-manager-server-service
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/helm/values.yaml b/aggregation-manager-server/src/main/helm/values.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..f00bd23b53fa51a45533aba042fcae8ed877c9be
--- /dev/null
+++ b/aggregation-manager-server/src/main/helm/values.yaml
@@ -0,0 +1,47 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+image:
+  repo: docker.ozg-sh.de
+  name: aggregation-manager-server
+  tag: latest
+
+ozgcloud:
+  environment:
+
+database:
+  useExternal: false
+  databaseName: aggregation-manager-server-database
+  secretName: ozg-mongodb-admin-aggregation-manager-server-user
+  tls:
+    enabled: false
+    secretName: ozg-mongodb-tls-cert
+
+serviceAccount:
+  create: true
+  name: aggregation-manager-server-service-account
+
+replicaCount: 1
+
+administrationName: administration
diff --git a/aggregation-manager-server/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java b/aggregation-manager-server/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
new file mode 100644
index 0000000000000000000000000000000000000000..09a4dab58b64714b9bdd109b6df084c9a4b0ab2b
--- /dev/null
+++ b/aggregation-manager-server/src/main/java/de/ozgcloud/aggregation/AggregationManagerApplication.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+ * Ministerpräsidenten des Landes Schleswig-Holstein
+ * Staatskanzlei
+ * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+ *
+ * Lizenziert unter der EUPL, Version 1.2 oder - sobald
+ * diese von der Europäischen Kommission genehmigt wurden -
+ * Folgeversionen der EUPL ("Lizenz");
+ * Sie dürfen dieses Werk ausschließlich gemäß
+ * dieser Lizenz nutzen.
+ * Eine Kopie der Lizenz finden Sie hier:
+ *
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+ *
+ * Sofern nicht durch anwendbare Rechtsvorschriften
+ * gefordert oder in schriftlicher Form vereinbart, wird
+ * die unter der Lizenz verbreitete Software "so wie sie
+ * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+ * ausdrücklich oder stillschweigend - verbreitet.
+ * Die sprachspezifischen Genehmigungen und Beschränkungen
+ * unter der Lizenz sind dem Lizenztext zu entnehmen.
+ */
+package de.ozgcloud.aggregation;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.context.properties.ConfigurationPropertiesScan;
+import org.springframework.context.annotation.ComponentScan;
+
+@SpringBootApplication
+@ComponentScan({ "de.ozgcloud.*" })
+@ConfigurationPropertiesScan("de.ozgcloud.*")
+public class AggregationManagerApplication {
+
+	public static void main(String[] args) {
+		SpringApplication.run(AggregationManagerApplication.class, args);
+	}
+
+}
\ No newline at end of file
diff --git a/aggregation-manager-server/src/main/resources/application-local.yml b/aggregation-manager-server/src/main/resources/application-local.yml
new file mode 100644
index 0000000000000000000000000000000000000000..6b1a35c08da53eb3a7f0a9d58054f1937fc6abb3
--- /dev/null
+++ b/aggregation-manager-server/src/main/resources/application-local.yml
@@ -0,0 +1,13 @@
+logging:
+  level:
+    ROOT: WARN
+    '[de.ozgcloud]': DEBUG
+  config: classpath:log4j2-local.xml
+
+spring:
+  data:
+    mongodb:
+      host: localhost
+      port: 27017
+      database: aggregation-manager-server
+
diff --git a/aggregation-manager-server/src/main/resources/application.yml b/aggregation-manager-server/src/main/resources/application.yml
new file mode 100644
index 0000000000000000000000000000000000000000..b62baf86bcf8c0273ced26d4c66e2ab65853cbdd
--- /dev/null
+++ b/aggregation-manager-server/src/main/resources/application.yml
@@ -0,0 +1,28 @@
+logging:
+  level:
+    ROOT: WARN
+    '[de.ozgcloud]': INFO,
+    '[org.springframework.security]': WARN
+
+management:
+  server:
+    port: 8081
+  health:
+    livenessState:
+      enabled: true
+    readinessState:
+      enabled: true
+  endpoint:
+    health:
+      group:
+        exploratory:
+          include: livenessState,readinessState,ping
+          show-details: always
+      probes:
+        enabled: true
+    prometheus:
+      enabled: true
+  endpoints:
+    web:
+      exposure:
+        include: health,prometheus
diff --git a/run_helm_test.sh b/aggregation-manager-server/src/test/helm-linter-values.yaml
old mode 100755
new mode 100644
similarity index 75%
rename from run_helm_test.sh
rename to aggregation-manager-server/src/test/helm-linter-values.yaml
index ac380340699509b5eea686fe129c97b4995198c4..be6b1860d5c6417dac89f2d16ba8ccd15d0a3257
--- a/run_helm_test.sh
+++ b/aggregation-manager-server/src/test/helm-linter-values.yaml
@@ -1,6 +1,5 @@
-#!/bin/sh
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
 # Ministerpräsidenten des Landes Schleswig-Holstein
 # Staatskanzlei
 # Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
@@ -23,10 +22,10 @@
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
 #
 
+ozgcloud:
+  environment: dev
 
-set -e
-
-helm template  ./src/main/helm/ -f src/test/helm-linter-values.yaml
-helm lint -f src/test/helm-linter-values.yaml ./src/main/helm/
-cd src/main/helm && helm unittest  -f '../../test/helm/**/*test.yaml' .
+networkPolicy:
+  dnsServerNamespace: dummy-dns
 
+imagePullSecret: image-pull-secret
diff --git a/aggregation-manager-server/src/test/helm/configmap_bindings_type_test.yaml b/aggregation-manager-server/src/test/helm/configmap_bindings_type_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..78c9c13265a35a814898e2d2389c5072680fc34b
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/configmap_bindings_type_test.yaml
@@ -0,0 +1,54 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: configmap_bindings_type
+release:
+  name: aggregation-manager-server
+  namespace: sh-helm-test
+templates:
+  - templates/configmap_bindings_type.yaml
+tests:
+  - it: configMap should not exists
+    asserts:
+      - hasDocuments:
+          count: 0
+  - it: should have configmap if database tls is enabled
+    set:
+      database:
+        tls:
+          enabled: true
+    asserts:
+      - isKind:
+          of: ConfigMap
+      - isAPIVersion:
+          of: v1
+      - equal:
+          path: metadata.name
+          value: aggregation-manager-server-bindings-type
+      - equal:
+          path: metadata.namespace
+          value: sh-helm-test
+      - equal:
+          path: data.type
+          value: "ca-certificates"
diff --git a/aggregation-manager-server/src/test/helm/deployment_63_char_test.yaml b/aggregation-manager-server/src/test/helm/deployment_63_char_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..f6a55a65431e0c6b6aff0fe5a20d5d508e1664c9
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_63_char_test.yaml
@@ -0,0 +1,55 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test deployment less than 63 chars
+release:
+  name: aggregation-manager-server
+  namespace: aggregation-manager-server
+
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: dev
+  imagePullSecret: image-pull-secret
+
+tests:
+  - it: should fail on .Release.Namespace length longer than 63 characters
+    release:
+      namespace: test1234567890123123456789012345678901234567890123456789012345678901234567890123456789012345678904567890
+    asserts:
+      - failedTemplate:
+          errorMessage: .Release.Namespace test1234567890123123456789012345678901234567890123456789012345678901234567890123456789012345678904567890 ist zu lang (max. 63 Zeichen)
+  - it: should not fail on .Release.Namespace length less than 63 characters
+    asserts:
+      - notFailedTemplate: {}
+  - it: should fail on .Chart.Name-.Chart.Version length longer than 63 characters
+    chart:
+      version: 1.0-test1234567890123123456789012345678901234567890123456789012345678901234567890123456789012345678904567890
+    asserts:
+      - failedTemplate:
+          errorMessage: .Chart.Name-.Chart.Version aggregation-manager-server-1.0-test1234567890123123456789012345678901234567890123456789012345678901234567890123456789012345678904567890 ist zu lang (max. 63 Zeichen)
+  - it: should not fail on .Chart.Name-.Chart.Version length less than 63 characters
+    asserts:
+      - notFailedTemplate: {}
diff --git a/aggregation-manager-server/src/test/helm/deployment_env_administration_test.yaml b/aggregation-manager-server/src/test/helm/deployment_env_administration_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..347382800f52d97ea5c10ba4833b8f717c4a2afd
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_env_administration_test.yaml
@@ -0,0 +1,60 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test deployment container environments
+templates:
+  - templates/deployment.yaml
+release:
+  namespace: sh-helm-test
+set:
+  imagePullSecret: image-pull-secret
+tests:
+  - it: should have ozgcloud_administration_address
+    set:
+      ozgcloud:
+        environment: dev
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: ozgcloud_administration_address
+            value: http://administration.sh-helm-test:8080
+
+  - it: should set ozgcloud_administration_address
+    set:
+      administrationAddress: http://test-administration:8080
+      ozgcloud:
+        environment: dev
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: ozgcloud_administration_address
+            value: http://test-administration:8080
+
+  - it: should fail template when env not set
+    set:
+    asserts:
+      - failedTemplate:
+          errormessage: Environment muss angegeben sein
diff --git a/aggregation-manager-server/src/test/helm/deployment_env_customList_test.yaml b/aggregation-manager-server/src/test/helm/deployment_env_customList_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..c12bb7be1d3e56b3f5800b9a17e46b43d13167db
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_env_customList_test.yaml
@@ -0,0 +1,72 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test environments customList
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud.environment: test
+  imagePullSecret: image-pull-secret
+tests:
+  - it: check customList as list
+    set:
+      env.customList:
+        - name: my_test_environment_name
+          value: "A test value"
+        - name: test_environment
+          value: "B test value"
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: my_test_environment_name
+            value: "A test value"
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: test_environment
+            value: "B test value"
+  - it: check customList as dict
+    set:
+      env.customList:
+        my_test_environment_name: "A test value"
+        test_environment: "B test value"
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: my_test_environment_name
+            value: "A test value"
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: test_environment
+            value: "B test value"
+  - it: check customList test value is not set by default
+    asserts:
+      - notContains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: my_test_environment_name
+            value: "A test value"
diff --git a/aggregation-manager-server/src/test/helm/deployment_image_pull_secret_test.yaml b/aggregation-manager-server/src/test/helm/deployment_image_pull_secret_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..f4e580823991d87cb8b6e3b0a0c81b2fae1c1c5a
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_image_pull_secret_test.yaml
@@ -0,0 +1,44 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test deployment imagepullsecret
+release:
+  name: eingang-adapter
+  namespace: sh-helm-test
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud.environment: test
+tests:
+  - it: should set the imagePull secret
+    set:
+      imagePullSecret: image-pull-secret
+    asserts:
+      - equal:
+          path: spec.template.spec.imagePullSecrets[0].name
+          value: image-pull-secret
+  - it: should fail tempalte when not set
+    asserts:
+      - failedTemplate:
+          errorMessage: imagePullSecret must be set
diff --git a/aggregation-manager-server/src/test/helm/deployment_resources_test.yaml b/aggregation-manager-server/src/test/helm/deployment_resources_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..4706c9929a7029e274c81f958ca4b60b2cd3d934
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_resources_test.yaml
@@ -0,0 +1,61 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: deployment_resources_test
+release:
+  name: aggregation-manager-server
+  namespace: aggregation-manager-server
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: test
+  imagePullSecret: image-pull-secret
+tests:
+  - it: validate container resources
+    set:
+      resources:
+        limits:
+          cpu: "11m"
+          memory: "22Mi"
+        requests:
+          cpu: "33m"
+          memory: "44Mi"
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].resources.limits.cpu
+          value: "11m"
+      - equal:
+          path: spec.template.spec.containers[0].resources.limits.memory
+          value: "22Mi"
+      - equal:
+          path: spec.template.spec.containers[0].resources.requests.cpu
+          value: "33m"
+      - equal:
+          path: spec.template.spec.containers[0].resources.requests.memory
+          value: "44Mi"
+  - it: test empty resources
+    asserts:
+      - isEmpty:
+          path: spec.template.spec.containers[0].resources
diff --git a/aggregation-manager-server/src/test/helm/deployment_service_account_test.yaml b/aggregation-manager-server/src/test/helm/deployment_service_account_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..eb1f736d744b9baac4940d39dee42b7427f0e8f2
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_service_account_test.yaml
@@ -0,0 +1,55 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: deployment service account
+release:
+  name: aggregation-manager-server
+  namespace: by-helm-test
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: dev
+  imagePullSecret: image-pull-secret
+tests:
+  - it: should use aggregation-manager-server service account
+    asserts:
+      - equal:
+          path: spec.template.spec.serviceAccountName
+          value: aggregation-manager-server-service-account
+  - it: should set service account name
+    set:
+      serviceAccount:
+        name: helm-service-account
+    asserts:
+      - equal:
+          path: spec.template.spec.serviceAccountName
+          value: helm-service-account
+  - it: should use default service account
+    set:
+      serviceAccount:
+        create: false
+    asserts:
+      - isNull:
+          path: spec.template.spec.serviceAccountName
diff --git a/aggregation-manager-server/src/test/helm/deployment_spring_profile_test.yaml b/aggregation-manager-server/src/test/helm/deployment_spring_profile_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..c7eea6926b708158ca05fefe3f6cb3e8c567c157
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_spring_profile_test.yaml
@@ -0,0 +1,50 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: deployment springProfile tests
+release:
+  namespace: sh-helm-test
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: dev
+  imagePullSecret: image-pull-secret
+tests:
+  - it: should override the spring profiles
+    set:
+      env.overrideSpringProfiles: oc,dev,ea
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: spring_profiles_active
+            value: oc,dev,ea
+  - it: should generate the spring profiles
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: spring_profiles_active
+            value: oc, dev
diff --git a/aggregation-manager-server/src/test/helm/deployment_test.yaml b/aggregation-manager-server/src/test/helm/deployment_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..37a00d0a32c5b8ab4620068ae0d6248b275b040a
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_test.yaml
@@ -0,0 +1,269 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: deployment_test
+release:
+  name: aggregation-manager-server
+  namespace: aggregation-manager-server
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: dev
+  imagePullSecret: image-pull-secret
+tests:
+  - it: validate deployment root configuration
+    asserts:
+      - isAPIVersion:
+          of: apps/v1
+      - isKind:
+          of: Deployment
+  - it: validate metadata
+    asserts:
+      - equal:
+          path: metadata.name
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.namespace
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.labels["app.kubernetes.io/instance"]
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.labels["app.kubernetes.io/name"]
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.labels["app.kubernetes.io/namespace"]
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.labels["app.kubernetes.io/part-of"]
+          value: ozgcloud
+      - equal:
+          path: metadata.labels["app.kubernetes.io/version"]
+          value: 0.0.0-MANAGED-BY-JENKINS
+      - equal:
+          path: metadata.labels["helm.sh/chart"]
+          value: aggregation-manager-server-0.0.0-MANAGED-BY-JENKINS
+  - it: validate spec root configuration
+    asserts:
+      - equal:
+          path: spec.progressDeadlineSeconds
+          value: 600
+      - equal:
+          path: spec.replicas
+          value: 1
+      - equal:
+          path: spec.revisionHistoryLimit
+          value: 10
+  - it: validate spec selector
+    asserts:
+      - equal:
+          path: spec.selector.matchLabels["app.kubernetes.io/name"]
+          value: aggregation-manager-server
+      - equal:
+          path: spec.selector.matchLabels["app.kubernetes.io/namespace"]
+          value: aggregation-manager-server
+  - it: validate rolling updates
+    asserts:
+      - equal:
+          path: spec.strategy.rollingUpdate.maxSurge
+          value: 1
+      - equal:
+          path: spec.strategy.rollingUpdate.maxUnavailable
+          value: 0
+      - equal:
+          path: spec.strategy.type
+          value: RollingUpdate
+  - it: validate spec template metadata
+    asserts:
+      - equal:
+          path: spec.template.metadata.labels.component
+          value: aggregation-manager-server
+      - equal:
+          path: spec.template.metadata.labels["app.kubernetes.io/instance"]
+          value: aggregation-manager-server
+      - equal:
+          path: spec.template.metadata.labels["app.kubernetes.io/name"]
+          value: aggregation-manager-server
+      - equal:
+          path: spec.template.metadata.labels["app.kubernetes.io/namespace"]
+          value: aggregation-manager-server
+      - equal:
+          path: spec.template.metadata.labels["app.kubernetes.io/part-of"]
+          value: ozgcloud
+      - equal:
+          path: spec.template.metadata.labels["app.kubernetes.io/version"]
+          value: 0.0.0-MANAGED-BY-JENKINS
+      - equal:
+          path: spec.template.metadata.labels["helm.sh/chart"]
+          value: aggregation-manager-server-0.0.0-MANAGED-BY-JENKINS
+  - it: validate spec template spec topology spread constraints
+    asserts:
+      - equal:
+          path: spec.template.spec.topologySpreadConstraints[0].maxSkew
+          value: 1
+      - equal:
+          path: spec.template.spec.topologySpreadConstraints[0].topologyKey
+          value: kubernetes.io/hostname
+      - equal:
+          path: spec.template.spec.topologySpreadConstraints[0].whenUnsatisfiable
+          value: ScheduleAnyway
+      - equal:
+          path: spec.template.spec.topologySpreadConstraints[0].labelSelector.matchLabels["app.kubernetes.io/name"]
+          value: aggregation-manager-server
+  - it: validate containers environment
+    asserts:
+      - contains:
+          path: spec.template.spec.containers[0].env
+          content:
+            name: SERVICE_BINDING_ROOT
+            value: "/bindings"
+  - it: validate image name
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].image
+          value: "docker.ozg-sh.de/aggregation-manager-server:latest"
+      - isAPIVersion:
+          of: apps/v1
+  - it: validate image pull policy
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].imagePullPolicy
+          value: Always
+  - it: validate container name
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].name
+          value: aggregation-manager-server
+  - it: validate container ports
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].ports[0].containerPort
+          value: 8081
+      - equal:
+          path: spec.template.spec.containers[0].ports[0].name
+          value: "metrics"
+      - equal:
+          path: spec.template.spec.containers[0].ports[0].protocol
+          value: "TCP"
+  - it: validate readiness probe
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.failureThreshold
+          value: 3
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.httpGet.path
+          value: /actuator/health/readiness
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.httpGet.port
+          value: 8081
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.httpGet.scheme
+          value: HTTP
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.periodSeconds
+          value: 10
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.successThreshold
+          value: 1
+      - equal:
+          path: spec.template.spec.containers[0].readinessProbe.timeoutSeconds
+          value: 3
+  - it: validate startup probe
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.failureThreshold
+          value: 10
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.httpGet.path
+          value: /actuator/health/readiness
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.httpGet.port
+          value: 8081
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.httpGet.scheme
+          value: HTTP
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.failureThreshold
+          value: 10
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.initialDelaySeconds
+          value: 30
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.periodSeconds
+          value: 10
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.successThreshold
+          value: 1
+      - equal:
+          path: spec.template.spec.containers[0].startupProbe.timeoutSeconds
+          value: 5
+  - it: validate container security context
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].securityContext.allowPrivilegeEscalation
+          value: false
+      - equal:
+          path: spec.template.spec.containers[0].securityContext.privileged
+          value: false
+      - equal:
+          path: spec.template.spec.containers[0].securityContext.readOnlyRootFilesystem
+          value: false
+      - equal:
+          path: spec.template.spec.containers[0].securityContext.runAsNonRoot
+          value: false
+  - it: validate container root config
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].stdin
+          value: true
+      - equal:
+          path: spec.template.spec.containers[0].terminationMessagePath
+          value: /dev/termination-log
+      - equal:
+          path: spec.template.spec.containers[0].terminationMessagePolicy
+          value: File
+      - equal:
+          path: spec.template.spec.containers[0].tty
+          value: true
+  - it: validate spec template spec root config
+    asserts:
+      - equal:
+          path: spec.template.spec.dnsConfig
+          value: {}
+      - equal:
+          path: spec.template.spec.dnsPolicy
+          value: ClusterFirst
+      - equal:
+          path: spec.template.spec.restartPolicy
+          value: Always
+      - equal:
+          path: spec.template.spec.schedulerName
+          value: default-scheduler
+      - equal:
+          path: spec.template.spec.securityContext
+          value: {}
+      - equal:
+          path: spec.template.spec.terminationGracePeriodSeconds
+          value: 30
diff --git a/aggregation-manager-server/src/test/helm/deployment_volume_test.yaml b/aggregation-manager-server/src/test/helm/deployment_volume_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..7f2efa110938e630db731358bf306172a4081a44
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/deployment_volume_test.yaml
@@ -0,0 +1,93 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: deployment volumes tests
+release:
+  name: aggregation-manager-server
+templates:
+  - templates/deployment.yaml
+set:
+  ozgcloud:
+    environment: "default"
+  imagePullSecret: image-pull-secret
+tests:
+  - it: should not have volumeMounts
+    asserts:
+      - isEmpty:
+          path: spec.template.spec.containers[0].volumeMounts
+  - it: should not have volumes
+    asserts:
+      - isEmpty:
+          path: spec.template.spec.volumes
+  - it: should have volumeMounts if database tls is enabled
+    set:
+      database:
+        tls:
+          enabled: true
+    asserts:
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[0].name
+          value: "bindings"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[0].mountPath
+          value: "/bindings/ca-certificates/type"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[0].subPath
+          value: "type"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[0].readOnly
+          value: true
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[1].name
+          value: "mongodb-root-ca"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[1].mountPath
+          value: "/bindings/ca-certificates/mongodb-root-ca.pem"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[1].subPath
+          value: "ca.crt"
+      - equal:
+          path: spec.template.spec.containers[0].volumeMounts[1].readOnly
+          value: true
+  - it: should have volumes on it's spec if database tls is enabled
+    set:
+      database:
+        tls:
+          enabled: true
+    asserts:
+      - equal:
+          path: spec.template.spec.volumes[0].name
+          value: "bindings"
+      - equal:
+          path: spec.template.spec.volumes[0].configMap.name
+          value: "aggregation-manager-server-bindings-type"
+      - equal:
+          path: spec.template.spec.volumes[1].name
+          value: "mongodb-root-ca"
+      - equal:
+          path: spec.template.spec.volumes[1].secret.secretName
+          value: "ozg-mongodb-tls-cert"
+      - equal:
+          path: spec.template.spec.volumes[1].secret.optional
+          value: true
diff --git a/aggregation-manager-server/src/test/helm/network_policy_test.yaml b/aggregation-manager-server/src/test/helm/network_policy_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..54308f5b7b065dc7cd9d7f2748ca2ab028d50f9a
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/network_policy_test.yaml
@@ -0,0 +1,230 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: network policy aggregation-manager-server test
+release:
+  name: aggregation-manager-server
+  namespace: by-helm-test
+templates:
+  - templates/network_policy.yaml
+
+tests:
+  - it: should match apiVersion
+    set:
+      networkPolicy:
+        dnsServerNamespace: kube-system
+    asserts:
+      - isAPIVersion:
+          of: networking.k8s.io/v1
+  - it: should match kind
+    set:
+      networkPolicy:
+        dnsServerNamespace: kube-system
+    asserts:
+      - isKind:
+          of: NetworkPolicy
+  - it: validate metadata
+    set:
+      networkPolicy:
+        dnsServerNamespace: kube-system
+    asserts:
+      - equal:
+          path: metadata
+          value:
+            name: network-policy-aggregation-manager-server
+            namespace: by-helm-test
+  - it: validate spec
+    set:
+      networkPolicy:
+        dnsServerNamespace: kube-system
+    asserts:
+      - equal:
+          path: spec
+          value:
+            egress:
+              - ports:
+                  - port: 53
+                    protocol: UDP
+                  - port: 53
+                    protocol: TCP
+                  - port: 5353
+                    protocol: UDP
+                  - port: 5353
+                    protocol: TCP
+                to:
+                  - namespaceSelector:
+                      matchLabels:
+                        kubernetes.io/metadata.name: kube-system
+            ingress:
+              - from:
+                  - namespaceSelector:
+                      matchLabels:
+                        name: openshift-user-workload-monitoring
+                ports:
+                  - port: 8081
+                    protocol: TCP
+            podSelector:
+              matchLabels:
+                component: aggregation-manager-server
+            policyTypes:
+              - Ingress
+              - Egress
+
+  - it: add ingress rule by values local
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        additionalIngressConfigLocal:
+          - from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+
+  - it: set ingress monitoring namespace rule
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        monitoringNamespace: monitoring
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            from:
+              - namespaceSelector:
+                  matchLabels:
+                    name: "monitoring"
+            ports:
+              - protocol: TCP
+                port: 8081
+  - it: add ingress rule by values global
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        additionalIngressConfigGlobal:
+          - from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+
+  - it: add ingress rule by values global
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        additionalIngressConfigGlobal:
+          - from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            from:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+
+  - it: add egress rule by values local
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        additionalIngressConfigLocal:
+          - to:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            to:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+
+  - it: add egress rule by values global
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-namespace-dns
+        additionalIngressConfigGlobal:
+          - to:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+    asserts:
+      - contains:
+          path: spec.ingress
+          content:
+            to:
+              - podSelector:
+                  matchLabels:
+                    component: client2
+
+  - it: test network policy disabled
+    set:
+      networkPolicy:
+        disabled: true
+    asserts:
+      - hasDocuments:
+          count: 0
+
+  - it: test network policy unset should be disabled
+    set:
+      networkPolicy:
+        disabled: false
+        dnsServerNamespace: test-dns-server-namespace
+    asserts:
+      - hasDocuments:
+          count: 1
+  - it: test network policy dnsServerNamespace must be set message
+    set:
+      networkPolicy:
+        disabled: false
+    asserts:
+      - failedTemplate:
+          errorMessage: networkPolicy.dnsServerNamespace must be set
+
+  - it: test network policy should be enabled by default
+    set:
+      networkPolicy:
+        dnsServerNamespace: test-dns-server-namespace
+    asserts:
+      - hasDocuments:
+          count: 1
diff --git a/aggregation-manager-server/src/test/helm/service_account_test.yaml b/aggregation-manager-server/src/test/helm/service_account_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..be94f3e7d171612a51c6ecea268180149e557543
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/service_account_test.yaml
@@ -0,0 +1,63 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test service account
+release:
+  name: aggregation-manager-server
+  namespace: sh-helm-test
+templates:
+  - templates/service_account.yaml
+tests:
+  - it: should create service account with default name
+    asserts:
+      - isKind:
+          of: ServiceAccount
+      - isAPIVersion:
+          of: v1
+      - equal:
+          path: metadata.name
+          value: aggregation-manager-server-service-account
+      - equal:
+          path: metadata.namespace
+          value: sh-helm-test
+  - it: should set service account with name
+    set:
+      serviceAccount:
+        name: helm-service-account
+    asserts:
+      - isKind:
+          of: ServiceAccount
+      - equal:
+          path: metadata.name
+          value: helm-service-account
+      - equal:
+          path: metadata.namespace
+          value: sh-helm-test
+  - it: should not create service account
+    set:
+      serviceAccount:
+        create: false
+    asserts:
+      - hasDocuments:
+        count: 0
diff --git a/aggregation-manager-server/src/test/helm/service_monitor_test.yaml b/aggregation-manager-server/src/test/helm/service_monitor_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..a65fb777ea572771b0a740b6c7dfa36160000a50
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/service_monitor_test.yaml
@@ -0,0 +1,84 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: test service_monitor
+release:
+  name: aggregation-manager-server
+  namespace: sh-helm-test
+templates:
+  - templates/service_monitor.yaml
+tests:
+  - it: should have basic info and the label component with value aggregation-manager-server-service-monitor attached
+    asserts:
+      - isKind:
+          of: ServiceMonitor
+      - isAPIVersion:
+          of: monitoring.coreos.com/v1
+      - equal:
+          path: metadata.name
+          value: aggregation-manager-server
+      - equal:
+          path: metadata.namespace
+          value: sh-helm-test
+      - equal:
+          path: metadata.labels["component"]
+          value: aggregation-manager-server-service-monitor
+
+  - it: should contain default lables and component lables
+    asserts:
+      - equal:
+          path: metadata.labels
+          value:
+            app.kubernetes.io/instance: aggregation-manager-server
+            app.kubernetes.io/managed-by: Helm
+            app.kubernetes.io/name: aggregation-manager-server
+            app.kubernetes.io/namespace: sh-helm-test
+            app.kubernetes.io/part-of: ozgcloud
+            app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
+            component: aggregation-manager-server-service-monitor
+            helm.sh/chart: aggregation-manager-server-0.0.0-MANAGED-BY-JENKINS
+            ozgcloud-mongodb-client: "true"
+
+  - it: should have the metrics endpoint configured by default
+    asserts:
+      - contains:
+          path: spec.endpoints
+          content:
+            port: metrics
+            path: /actuator/prometheus
+
+  - it: namespace selector should contain the namespace
+    asserts:
+      - contains:
+          path: spec.namespaceSelector.matchNames
+          content: sh-helm-test
+
+  - it: selector should contain helm recommended labels name and namespace
+    asserts:
+      - equal:
+          path: spec.selector.matchLabels
+          value:
+            app.kubernetes.io/name: aggregation-manager-server
+            app.kubernetes.io/namespace: sh-helm-test
+            component: aggregation-manager-server-service
diff --git a/aggregation-manager-server/src/test/helm/service_test.yaml b/aggregation-manager-server/src/test/helm/service_test.yaml
new file mode 100644
index 0000000000000000000000000000000000000000..4f4733d627851e2458863ea27e75eb91cddf4a91
--- /dev/null
+++ b/aggregation-manager-server/src/test/helm/service_test.yaml
@@ -0,0 +1,81 @@
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+suite: service
+
+templates:
+  - templates/service.yaml
+release:
+  name: aggregation-manager-server
+  namespace: helm-test
+
+tests:
+  - it: has expected document values
+    asserts:
+      - containsDocument:
+          kind: Service
+          apiVersion: v1
+          name: aggregation-manager-server
+          namespace: helm-test
+  - it: should be of type ClusterIP
+    asserts:
+      - equal:
+          path: spec.type
+          value: ClusterIP
+
+  - it: has metrics port
+    asserts:
+      - contains:
+          path: spec.ports
+          content:
+            name: metrics
+            port: 8081
+            protocol: TCP
+  - it: should contain helm recommended labels name and namespace
+    asserts:
+      - equal:
+          path: spec.selector["app.kubernetes.io/name"]
+          value: aggregation-manager-server
+      - equal:
+          path: spec.selector["app.kubernetes.io/namespace"]
+          value: helm-test
+  - it: has selector component
+    asserts:
+      - equal:
+          path: spec.selector.component
+          value: aggregation-manager-server
+  - it: should contain default lables and component lables
+    asserts:
+      - equal:
+          path: metadata.labels
+          value:
+            app.kubernetes.io/instance: aggregation-manager-server
+            app.kubernetes.io/managed-by: Helm
+            app.kubernetes.io/name: aggregation-manager-server
+            app.kubernetes.io/namespace: helm-test
+            app.kubernetes.io/part-of: ozgcloud
+            app.kubernetes.io/version: 0.0.0-MANAGED-BY-JENKINS
+            component: aggregation-manager-server-service
+            helm.sh/chart: aggregation-manager-server-0.0.0-MANAGED-BY-JENKINS
+            ozgcloud-mongodb-client: "true"
diff --git a/metabase/run_helm_test.sh b/metabase/run_helm_test.sh
index aafe0e7dd324a8e4764fad72362bc2d2039ae197..ac380340699509b5eea686fe129c97b4995198c4 100755
--- a/metabase/run_helm_test.sh
+++ b/metabase/run_helm_test.sh
@@ -1,4 +1,28 @@
 #!/bin/sh
+#
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
 
 set -e
 
diff --git a/metabase/src/main/helm/templates/_helpers.tpl b/metabase/src/main/helm/templates/_helpers.tpl
index f7ff4b68574e99a987f2551cd32dffe60b150d59..12f9deca73585fa40db31a9f2f024f6a6b8cf4ac 100644
--- a/metabase/src/main/helm/templates/_helpers.tpl
+++ b/metabase/src/main/helm/templates/_helpers.tpl
@@ -1,3 +1,27 @@
+#
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
 
 {{/* error check 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec) */}}
 {{/* Namespace */}}
diff --git a/metabase/src/main/helm/templates/metabase_pvc.yaml b/metabase/src/main/helm/templates/metabase_pvc.yaml
index db07c01c2d972a1a3ea3316f0e1f79797631cdf6..a32883623d7cce4ab81979213ceb1d40ad187864 100644
--- a/metabase/src/main/helm/templates/metabase_pvc.yaml
+++ b/metabase/src/main/helm/templates/metabase_pvc.yaml
@@ -1,3 +1,27 @@
+#
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
 apiVersion: v1
 kind: PersistentVolumeClaim
 metadata:
diff --git a/metabase/src/main/helm/templates/network_policy.yaml b/metabase/src/main/helm/templates/network_policy.yaml
index d14c0d10efcf0c709cc5d99fb66d0f09c7312b2b..87a29ecd28be88242f65ca5e2ebfe091d97c5251 100644
--- a/metabase/src/main/helm/templates/network_policy.yaml
+++ b/metabase/src/main/helm/templates/network_policy.yaml
@@ -1,3 +1,27 @@
+#
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
 {{- if not (.Values.networkPolicy).disabled }}
 apiVersion: networking.k8s.io/v1
 kind: NetworkPolicy
diff --git a/metabase/src/main/helm/templates/service.yaml b/metabase/src/main/helm/templates/service.yaml
index a3668f9d5ba070e1f79d8f767fb75fabe33b1b49..4824e596d436539c19f9be9e60d7b32c8718b732 100644
--- a/metabase/src/main/helm/templates/service.yaml
+++ b/metabase/src/main/helm/templates/service.yaml
@@ -21,6 +21,7 @@
 # Die sprachspezifischen Genehmigungen und Beschränkungen
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
 #
+
 apiVersion: v1
 kind: Service
 metadata:
diff --git a/metabase/src/test/helm-linter-values.yaml b/metabase/src/test/helm-linter-values.yaml
index 7accba8aca81ac697e89ae763523a8fc69b7b79f..2b963ba672abc992eea924d3b80c5478eee91bec 100644
--- a/metabase/src/test/helm-linter-values.yaml
+++ b/metabase/src/test/helm-linter-values.yaml
@@ -1,7 +1,8 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch das
-# Ministerium für Energiewende, Klimaschutz, Umwelt und Natur
-# Zentrales IT-Management
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
 #
 # Lizenziert unter der EUPL, Version 1.2 oder - sobald
 # diese von der Europäischen Kommission genehmigt wurden -
@@ -19,7 +20,7 @@
 # ausdrücklich oder stillschweigend - verbreitet.
 # Die sprachspezifischen Genehmigungen und Beschränkungen
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
-
+#
 
 ozgcloud:
   bezeichner: helm
diff --git a/metabase/src/test/helm/deployment_image_pull_secret_test.yaml b/metabase/src/test/helm/deployment_image_pull_secret_test.yaml
index 7db271604026bfa921751ef481f047791b624b2f..bc6140b90e93f114abe37581a2fa50b176fcb6ac 100644
--- a/metabase/src/test/helm/deployment_image_pull_secret_test.yaml
+++ b/metabase/src/test/helm/deployment_image_pull_secret_test.yaml
@@ -1,7 +1,8 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch das
-# Ministerium für Energiewende, Klimaschutz, Umwelt und Natur
-# Zentrales IT-Management
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
 #
 # Lizenziert unter der EUPL, Version 1.2 oder - sobald
 # diese von der Europäischen Kommission genehmigt wurden -
@@ -19,6 +20,7 @@
 # ausdrücklich oder stillschweigend - verbreitet.
 # Die sprachspezifischen Genehmigungen und Beschränkungen
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
 
 suite: deployment image pull secret
 
diff --git a/metabase/src/test/helm/deployment_resources_test.yaml b/metabase/src/test/helm/deployment_resources_test.yaml
index ecfc4eda7e1fa9bc9e45f5f24aeed6bb5a688f75..7c6dcc51cedec7ba35dbeef8b38dbcb3ff41657e 100644
--- a/metabase/src/test/helm/deployment_resources_test.yaml
+++ b/metabase/src/test/helm/deployment_resources_test.yaml
@@ -1,7 +1,8 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch das
-# Ministerium für Energiewende, Klimaschutz, Umwelt und Natur
-# Zentrales IT-Management
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
 #
 # Lizenziert unter der EUPL, Version 1.2 oder - sobald
 # diese von der Europäischen Kommission genehmigt wurden -
@@ -19,6 +20,7 @@
 # ausdrücklich oder stillschweigend - verbreitet.
 # Die sprachspezifischen Genehmigungen und Beschränkungen
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
 
 suite: deployment resources
 
diff --git a/metabase/src/test/helm/metabase_pvc_test.yaml b/metabase/src/test/helm/metabase_pvc_test.yaml
index 9b148478b90bda3a567c607ae44564ad05c9f07a..7017f0555660ee95af1259b100ae74e250fdbe7c 100644
--- a/metabase/src/test/helm/metabase_pvc_test.yaml
+++ b/metabase/src/test/helm/metabase_pvc_test.yaml
@@ -1,3 +1,27 @@
+#
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
 suite: test pvc
 release:
   name: metabase
diff --git a/metabase/src/test/helm/service_test.yaml b/metabase/src/test/helm/service_test.yaml
index 3cc31ee3350f0c7c205846a6b7cb5e2b4d8646d1..cf6839785d2d0f459cb73806fe46caed12fd9ff0 100644
--- a/metabase/src/test/helm/service_test.yaml
+++ b/metabase/src/test/helm/service_test.yaml
@@ -1,7 +1,8 @@
 #
-# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch das
-# Ministerium für Energiewende, Klimaschutz, Umwelt und Natur
-# Zentrales IT-Management
+# Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
 #
 # Lizenziert unter der EUPL, Version 1.2 oder - sobald
 # diese von der Europäischen Kommission genehmigt wurden -
@@ -19,6 +20,7 @@
 # ausdrücklich oder stillschweigend - verbreitet.
 # Die sprachspezifischen Genehmigungen und Beschränkungen
 # unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
 
 suite: service
 
diff --git a/pom.xml b/pom.xml
index 6e56667367ff1c879f915f17b99e18c4d826e3a9..c5a13f434ab7188c3d74d550fbe7acf360d18839 100644
--- a/pom.xml
+++ b/pom.xml
@@ -35,103 +35,47 @@
 		<relativePath />
 	</parent>
 	<groupId>de.ozgcloud.aggregation</groupId>
-	<artifactId>aggregation-manager</artifactId>
+	<artifactId>aggregation-manager-parent</artifactId>
 	<version>1.3.0-SNAPSHOT</version>
 	<name>OZG-Cloud Aggregation Manager</name>
 	<inceptionYear>2024</inceptionYear>
+	<packaging>pom</packaging>
 
+	<modules>
+		<module>aggregation-manager-job</module>
+		<module>aggregation-manager-server</module>
+	</modules>
 	<properties>
 		<ozgcloud.api-lib.version>0.19.0-SNAPSHOT</ozgcloud.api-lib.version>
 		<jslt.version>0.1.14</jslt.version>
 		<hibernate-validator.version>8.0.2.Final</hibernate-validator.version>
-		<spring-boot.build-image.imageName>docker.ozg-sh.de/aggregation-manager:build-latest</spring-boot.build-image.imageName>
 	</properties>
-	<dependencies>
-		<dependency>
-			<artifactId>ozg-cloud-spring-boot-starter</artifactId>
-			<groupId>de.ozgcloud.api-lib</groupId>
-			<version>${ozgcloud.api-lib.version}</version>
-		</dependency>
-		<dependency>
-			<groupId>org.springframework.boot</groupId>
-			<artifactId>spring-boot-starter-actuator</artifactId>
-		</dependency>
-		<dependency>
-			<groupId>org.springframework.boot</groupId>
-			<artifactId>spring-boot-starter-data-mongodb</artifactId>
-		</dependency>
-		<dependency>
-			<groupId>org.springframework.cloud</groupId>
-			<artifactId>spring-cloud-starter-config</artifactId>
-		</dependency>
-		<dependency>
-			<groupId>com.fasterxml.jackson.datatype</groupId>
-			<artifactId>jackson-datatype-jsr310</artifactId>
-		</dependency>
-		<dependency>
-			<groupId>org.mapstruct</groupId>
-			<artifactId>mapstruct</artifactId>
-		</dependency>
-		<dependency>
-			<groupId>com.schibsted.spt.data</groupId>
-			<artifactId>jslt</artifactId>
-			<version>${jslt.version}</version>
-		</dependency>
-		<dependency>
-			<groupId>org.hibernate</groupId>
-			<artifactId>hibernate-validator</artifactId>
-			<version>${hibernate-validator.version}</version>
-		</dependency>
+	<dependencyManagement>
+		<dependencies>
+			<dependency>
+				<artifactId>ozg-cloud-spring-boot-starter</artifactId>
+				<groupId>de.ozgcloud.api-lib</groupId>
+				<version>${ozgcloud.api-lib.version}</version>
+			</dependency>
+			<dependency>
+				<groupId>com.schibsted.spt.data</groupId>
+				<artifactId>jslt</artifactId>
+				<version>${jslt.version}</version>
+			</dependency>
+			<dependency>
+				<groupId>org.hibernate</groupId>
+				<artifactId>hibernate-validator</artifactId>
+				<version>${hibernate-validator.version}</version>
+			</dependency>
 
-		<!-- Test dependencies -->
-		<dependency>
-			<groupId>org.springframework.boot</groupId>
-			<artifactId>spring-boot-starter-test</artifactId>
-			<scope>test</scope>
-		</dependency>
-		<dependency>
-			<artifactId>api-lib-core</artifactId>
-			<groupId>de.ozgcloud.api-lib</groupId>
-			<version>${ozgcloud.api-lib.version}</version>
-			<type>test-jar</type>
-			<scope>test</scope>
-		</dependency>
-	</dependencies>
-	<build>
-		<plugins>
-			<plugin>
-				<groupId>org.apache.maven.plugins</groupId>
-				<artifactId>maven-compiler-plugin</artifactId>
-			</plugin>
-			<plugin>
-				<groupId>org.springframework.boot</groupId>
-				<artifactId>spring-boot-maven-plugin</artifactId>
-				<configuration>
-					<mainClass>de.ozgcloud.aggregation.AggregationManagerApplication</mainClass>
-					<image>
-						<env>
-							<BPE_DELIM_JAVA_TOOL_OPTIONS xml:space="preserve"> </BPE_DELIM_JAVA_TOOL_OPTIONS>
-							<BPE_APPEND_JAVA_TOOL_OPTIONS>-Dfile.encoding=UTF-8</BPE_APPEND_JAVA_TOOL_OPTIONS>
-						</env>
-					</image>
-				</configuration>
-			</plugin>
-			<plugin>
-				<groupId>org.jacoco</groupId>
-				<artifactId>jacoco-maven-plugin</artifactId>
-			</plugin>
-			<plugin>
-				<groupId>org.apache.maven.plugins</groupId>
-				<artifactId>maven-failsafe-plugin</artifactId>
-			</plugin>
-			<plugin>
-				<groupId>org.apache.maven.plugins</groupId>
-				<artifactId>maven-surefire-plugin</artifactId>
-			</plugin>
-			<plugin>
-				<groupId>com.mycila</groupId>
-				<artifactId>license-maven-plugin</artifactId>
-			</plugin>
-		</plugins>
-	</build>
+			<!-- Test dependencies -->
+			<dependency>
+				<artifactId>api-lib-core</artifactId>
+				<groupId>de.ozgcloud.api-lib</groupId>
+				<version>${ozgcloud.api-lib.version}</version>
+				<type>test-jar</type>
+				<scope>test</scope>
+			</dependency>
+		</dependencies>
+	</dependencyManagement>
 </project>
\ No newline at end of file
diff --git a/run_helm_test_aggregation_job.sh b/run_helm_test_aggregation_job.sh
new file mode 100755
index 0000000000000000000000000000000000000000..122f5b90875cbbdec5b4e31edc17b497cde7f132
--- /dev/null
+++ b/run_helm_test_aggregation_job.sh
@@ -0,0 +1,32 @@
+#!/bin/sh
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+
+set -e
+
+helm template  ./aggregation-manager-job/src/main/helm/ -f aggregation-manager-job/src/test/helm-linter-values.yaml
+helm lint -f aggregation-manager-job/src/test/helm-linter-values.yaml ./aggregation-manager-job/src/main/helm/
+cd aggregation-manager-job/src/main/helm && helm unittest  -f '../../test/helm/**/*test.yaml' .
+
diff --git a/run_helm_test_aggregation_server.sh b/run_helm_test_aggregation_server.sh
new file mode 100755
index 0000000000000000000000000000000000000000..b150de21ce9dd25ba55bff7441480fffdaf8ec6d
--- /dev/null
+++ b/run_helm_test_aggregation_server.sh
@@ -0,0 +1,32 @@
+#!/bin/sh
+#
+# Copyright (C) 2025 Das Land Schleswig-Holstein vertreten durch den
+# Ministerpräsidenten des Landes Schleswig-Holstein
+# Staatskanzlei
+# Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
+#
+# Lizenziert unter der EUPL, Version 1.2 oder - sobald
+# diese von der Europäischen Kommission genehmigt wurden -
+# Folgeversionen der EUPL ("Lizenz");
+# Sie dürfen dieses Werk ausschließlich gemäß
+# dieser Lizenz nutzen.
+# Eine Kopie der Lizenz finden Sie hier:
+#
+# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
+#
+# Sofern nicht durch anwendbare Rechtsvorschriften
+# gefordert oder in schriftlicher Form vereinbart, wird
+# die unter der Lizenz verbreitete Software "so wie sie
+# ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
+# ausdrücklich oder stillschweigend - verbreitet.
+# Die sprachspezifischen Genehmigungen und Beschränkungen
+# unter der Lizenz sind dem Lizenztext zu entnehmen.
+#
+
+
+set -e
+
+helm template  ./aggregation-manager-server/src/main/helm/ -f aggregation-manager-server/src/test/helm-linter-values.yaml
+helm lint -f aggregation-manager-server/src/test/helm-linter-values.yaml ./aggregation-manager-server/src/main/helm/
+cd aggregation-manager-server/src/main/helm && helm unittest  -f '../../test/helm/**/*test.yaml' .
+