From 96d497f712ae9fff52022a9951dae2a20bfa3792 Mon Sep 17 00:00:00 2001 From: quebim Date: Thu, 21 Nov 2024 15:50:09 -0300 Subject: [PATCH] Add package building stages --- docker/builder/Dockerfile | 113 +++++++++++++++++++++++++++++++++----- 1 file changed, 100 insertions(+), 13 deletions(-) diff --git a/docker/builder/Dockerfile b/docker/builder/Dockerfile index 9463ecdf66eef..818d231816b30 100644 --- a/docker/builder/Dockerfile +++ b/docker/builder/Dockerfile @@ -1,3 +1,4 @@ +# Use the official Ubuntu Noble image as the base image FROM ubuntu:noble # Set environment variables for non-interactive installation @@ -7,26 +8,64 @@ ENV DEBIAN_FRONTEND=noninteractive RUN apt-get update \ && apt-get upgrade -y \ && apt-get install -y \ - wget \ - curl \ - unzip \ - gnupg2 \ - git + wget \ + curl \ + unzip \ + gnupg2 \ + git \ + build-essential \ + debmake \ + debhelper-compat \ + libxrender1 \ + libxtst6 \ + libxi6 \ + libatk1.0-0 \ + libatk-bridge2.0-0 \ + libcups2 \ + libdrm2 \ + libatspi2.0-dev \ + libxcomposite-dev \ + libxdamage1 \ + libxfixes3 \ + libxfixes-dev \ + libxrandr2 \ + libgbm-dev \ + libxkbcommon-x11-0 \ + libpangocairo-1.0-0 \ + libcairo2 \ + libcairo2-dev \ + libnss3 \ + libnspr4 \ + libnspr4-dev \ + && rm -rf /var/lib/apt/lists/* -# Define build arguments +# Define build arguments with default values ARG indexer_branch=master ARG indexer_plugins_branch=master ARG indexer_reporting_branch=master +ARG revision=0 +ARG is_stage=false +ARG distribution=tar +ARG architecture=x64 # Use build arguments as environment variables in the container -ENV INDEXER_BRANCH=${indexer_branch} -ENV INDEXER_PLUGINS_BRANCH=${indexer_plugins_branch} -ENV INDEXER_REPORTING_BRANCH=${indexer_reporting_branch} +ENV INDEXER_BRANCH=${indexer_branch} \ + INDEXER_PLUGINS_BRANCH=${indexer_plugins_branch} \ + INDEXER_REPORTING_BRANCH=${indexer_reporting_branch} \ + REVISION=${revision} \ + IS_STAGE=${is_stage} \ + DISTRIBUTION=${distribution} \ + ARCHITECTURE=${architecture} # Clone the repositories using the specified branches -RUN git clone --branch ${INDEXER_BRANCH} https://github.com/wazuh/wazuh-indexer --depth 1 && \ - git clone --branch ${INDEXER_PLUGINS_BRANCH} https://github.com/wazuh/wazuh-indexer-plugins --depth 1 && \ - git clone --branch ${INDEXER_REPORTING_BRANCH} https://github.com/wazuh/wazuh-indexer-reporting --depth 1 +RUN git clone --branch ${INDEXER_BRANCH} https://github.com/wazuh/wazuh-indexer --depth 1 /opt/wazuh-indexer && \ + git clone --branch ${INDEXER_PLUGINS_BRANCH} https://github.com/wazuh/wazuh-indexer-plugins --depth 1 /opt/wazuh-indexer-plugins && \ + git clone --branch ${INDEXER_REPORTING_BRANCH} https://github.com/wazuh/wazuh-indexer-reporting --depth 1 /opt/wazuh-indexer-reporting + +# Save repositories hashes +RUN cd /opt/wazuh-indexer && indexer_hash=$(git rev-parse --short HEAD) && \ + cd /opt/wazuh-indexer-plugins && plugins_hash=$(git rev-parse --short HEAD) && \ + cd /opt/wazuh-indexer-reporting && reporting_hash=$(git rev-parse --short HEAD) # Install OpenJDK 21 RUN wget -O- https://download.java.net/openjdk/jdk21/ri/openjdk-21+35_linux-x64_bin.tar.gz | tar xz -C /opt/ @@ -46,7 +85,55 @@ RUN wget https://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin. ENV GRADLE_HOME=/opt/gradle/gradle-${GRADLE_VERSION} ENV PATH=$GRADLE_HOME/bin:$PATH +# Copy build scripts to /opt directory +COPY ../../build-scripts/* /opt/build-scripts/ + # Clean up APT when done RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* -COPY ../../build-scripts/* . +# ---PACKAGE-BUILDING--- + +# Baptize min +RUN PACKAGE_MIN_NAME=$(bash /opt/build-scripts/baptizer.sh -m \ + -a ${ARCHITECTURE} \ + -d ${DISTRIBUTION} \ + -r ${REVISION} \ + -l ${plugins_hash} \ + -e ${reporting_hash} \ + $(if [ "${IS_STAGE}" = "true" ]; then echo "-x"; fi)) + +# Baptize package (min) +RUN PACKAGE_MIN_NAME=$(bash /opt/build-scripts/baptizer.sh \ + -a ${ARCHITECTURE} \ + -d ${DISTRIBUTION} \ + -r ${REVISION} \ + -l ${plugins_hash} \ + -e ${reporting_hash} \ + $(if [ "${IS_STAGE}" = "true" ]; then echo "-x"; fi)) + +# Baptize package +RUN PACKAGE_NAME=$(bash /opt/build-scripts/baptizer.sh \ + -a ${ARCHITECTURE} \ + -d ${DISTRIBUTION} \ + -r ${REVISION} \ + -l ${plugins_hash} \ + -e ${reporting_hash} \ + $(if [ "${IS_STAGE}" = "true" ]; then echo "-x"; fi)) + +# Build +RUN bash /opt/build-scripts/build.sh \ + -a ${ARCHITECTURE} \ + -d ${DISTRIBUTION} \ + -n ${PACKAGE_MIN_NAME} + +# Assamble +RUN bash build-scripts/assemble.sh \ + -a ${ARCHITECTURE} \ + -d ${DISTRIBUTION} \ + -r ${REVISION} + +# Create a directory to store the resulting packages \ +RUN mkdir -p /artifacts/dist/ + +# Move the resulting package to /artifacts/dist/ +RUN mv /opt/artifacts/dist/${PACKAGE_NAME} /artifacts/dist/