#!/usr/bin/env bash
-container_name="centos_repo"
-# Path to folder with clonned offline-installer build directory with docker_entrypoint script
-volume_directory="."
-# Path inside container
-container_volume="/mnt/"
-# Docker image name and version
-docker_image="centos:centos7.6.1810"
+# Set distribution type
+distro_type="$(cat /etc/*-release | grep -w "ID" | awk -F'=' '{ print $2 }' | tr -d '"')"
+
+# Path to cloned offline-installer build directory with docker_entrypoint script
+volume_offline_directory="$(readlink -f $(dirname ${0}))"
+
+# Destination path for created repository
+volume_repo_directory="$(pwd)"
+
+# Path inside container with cloned offline-installer build directory
+container_offline_volume="/mnt/offline/"
+
+# Target repository path inside container
+container_repo_volume="/mnt/repo/"
+
+# Additional packages lists files path within container
+container_list_volume="/mnt/additional-lists/"
+
+# Use cache by default
+drop_cache=false
+
+# Show script usage
+help () {
+cat <<EOF
+Wrapper script running docker container for creating package repository
+
+Repository type is set with --target-platform option and the default is to use host OS platform type
+
+usage: create_repo.sh [OPTION]...
+
+
+ -d | --destination-repository target path to store downloaded packages. Current directory by default
+ -c | --cloned-directory path to directory containing this and docker-entrypoint scripts (offline-installer/build directory)
+ Set it only when you want to use different script/datalists
+ -t | --target-platform target repository platform type (ubuntu/rhel/centos)
+ -a | --additional-list additional packages list; can be used multiple times for more additional lists
+ -n | --container-name-suffix add custom suffix to docker container name
+ -r | --drop-cache remove cached packages (use package cache by default)
+ -h | --help show this help
+
+If build folder from offline repository is not specified current one will be used by default.
+EOF
+}
+
+# Get distribution type
+# Set Docker image name and version based on type of linux distribution
+# Set expected directory for RPM/DEB packages
+set_environment () {
+ case "$1" in
+ ubuntu)
+ distro_type="ubuntu"
+ docker_image="ubuntu:18.04"
+ expected_dir="resources/pkg/deb"
+ container_name="${1}_repo${container_name_suffix}"
+ ;;
+ centos|rhel)
+ distro_type="rhel"
+ docker_image="centos:centos7.9.2009"
+ expected_dir="resources/pkg/rpm"
+ container_name="${1}_repo${container_name_suffix}"
+ ;;
+ *)
+ echo "Unknown type of linux distribution."
+ exit 1
+ ;;
+ esac
+}
# Getting input parametters
-POSITIONAL=()
+if [[ $# -eq 0 ]] ; then
+ help # show help
+ exit 0
+fi
+
while [[ $# -gt 0 ]]
do
- key="$1"
- case $key in
+ case "$1" in
-h|--help)
# Help parametter
- echo -e "Script for run docker container with RPM repository\n"
- echo "-h --help: Show this help"
- echo -e "-d --directory: set root path with offline-installer directory and repository directory for RPM packages\n"
- echo "If build folder from offline repository is not specified will be used default path of current folder."
- shift # past argument
- shift # past value
- exit
+ help # show help
+ exit 0
+ ;;
+ -c|--cloned-directory)
+ # Directory parameter
+ # Set path to offline-installer build directory
+ volume_offline_directory="$2"
+ shift
+ ;;
+ -d|--destination-repository)
+ # Repository directory parameter
+ # Set destination path for created repository
+ volume_repo_directory="$2"
+ shift
;;
- -d|--directory)
- # Directory parametter
- # Sets path where is clonned offline-installer build directory
- volume_directory="$2"
- shift # past argument
- shift # past value
+ -t|--target-platform)
+ # Repository type (rpm/deb)
+ # Set target platform for repository
+ target_input="$2"
+ shift
;;
- --default)
- DEFAULT=YES
- shift # past argument
+ -a|--additional-list)
+ # Array of additional packages lists
+ additional_lists+=("$2")
+ shift
;;
- *)
+ -n|--container-name-suffix)
+ # Set custom container name suffix
+ container_name_suffix="_${2}"
+ shift
+ ;;
+ -r|--drop-cache)
+ # Set flag to clean cache
+ drop_cache=true
+ ;;
+ *)
# unknown option
- POSITIONAL+=("$1") # save it in an array for later
- shift # past argument
+ help # show help
+ exit 1
;;
esac
+ shift
done
+# Check if user specified repository type
+# This setting has higher priority than distribution type
+if ! test -z "$target_input"
+then
+ set_environment "$target_input"
+else
+ set_environment "$distro_type"
+fi
-#Check if container "centos-repo" is running
-if [ ! "$(docker ps -q -f name=$container_name)" ]; then
- if [ "$(docker ps -aq -f status=exited -f name=$container_name)" ]; then
- # cleanup
- docker rm $container_name
- fi
+# Check if path contains expected components:
+# "resources/pkg/rpm" for Rhel/CentOS or
+# "resources/pkg/deb" for Ubuntu/Debian
+if ! [[ "/$volume_repo_directory/" = *"/$expected_dir/"* ]]; then
+ # Create repo folder if it doesn't exist
+ case "$distro_type" in
+ ubuntu)
+ volume_repo_directory="$volume_repo_directory"/resources/pkg/deb
+ ;;
+ rhel)
+ volume_repo_directory="$volume_repo_directory"/resources/pkg/rpm
+ ;;
+ esac
+ [ ! -d "$volume_repo_directory" ] && mkdir -p $volume_repo_directory
+fi
+
+# Check if container is already running
+if [ ! $(docker ps -q -f name="^${container_name}$") ];
+then
# run repo container
# name of container $container_name
# docker entrypoint script from mounted volume
- #
- docker run -d \
- --name $container_name \
- -v ${volume_directory}:${container_volume} \
- --entrypoint="${container_volume}offline-installer/build/docker-entrypoint.sh" \
- -it ${docker_image} \
+ # with dynamic parameters
+ # mount additional packages lists to container
+ param_array=()
+ mounted_lists=()
+ param_array+=(--directory ${container_repo_volume})
+ param_array+=(--list ${container_offline_volume}data_lists/)
+ param_array+=(--packages-lists-path ${container_list_volume})
+ if ${drop_cache};
+ then
+ param_array+=(--drop-cache)
+ fi
+ [[ ! ${#additional_lists[@]} -eq 0 ]] && \
+ for array_list in "${additional_lists[@]}";
+ do
+ param_array+=(--additional-list "${array_list##*/}") && \
+ mounted_lists+=(-v ${array_list}:${container_list_volume}${array_list##*/})
+ done
+
+ docker run --name $container_name \
+ -v ${volume_offline_directory}:${container_offline_volume} \
+ -v ${volume_repo_directory}:${container_repo_volume} \
+ "${mounted_lists[@]}" \
--rm \
- --directory ${container_volume}resources/pkg/rhel/ \
- --list ${container_volume}offline-installer/build/data_lists/
+ --entrypoint="${container_offline_volume}docker-entrypoint.sh" \
+ ${docker_image} \
+ "${param_array[@]}"
fi