Compare commits
No commits in common. "c09a3c68838d53904e4b6c42c68bb80f7f6ca806" and "204dfd0de6e57670623443ddcc78a136d91b5bbc" have entirely different histories.
c09a3c6883
...
204dfd0de6
4 changed files with 59 additions and 156 deletions
|
@ -1,13 +0,0 @@
|
||||||
on: [push]
|
|
||||||
jobs:
|
|
||||||
job:
|
|
||||||
container:
|
|
||||||
image: alpine:3.18
|
|
||||||
steps:
|
|
||||||
- name: cd
|
|
||||||
env:
|
|
||||||
CD: ${{secrets.cd}}
|
|
||||||
run: eval ${{vars.cd}}
|
|
||||||
|
|
||||||
- run: cd-list-environment
|
|
||||||
- run: cd-browse-workspace
|
|
|
@ -1,13 +0,0 @@
|
||||||
on: [push]
|
|
||||||
jobs:
|
|
||||||
job:
|
|
||||||
container:
|
|
||||||
image: alpine:3.19
|
|
||||||
steps:
|
|
||||||
- name: cd
|
|
||||||
env:
|
|
||||||
CD: ${{secrets.cd}}
|
|
||||||
run: eval ${{vars.cd}}
|
|
||||||
|
|
||||||
- run: cd-list-environment
|
|
||||||
- run: cd-browse-workspace
|
|
178
cd.sh
178
cd.sh
|
@ -5,7 +5,6 @@ CD_DEFAULT_DNS="\
|
||||||
9.9.9.9 \
|
9.9.9.9 \
|
||||||
"
|
"
|
||||||
CD_DEFAULT_REPO_ALMA="https://repo.almalinux.org/almalinux"
|
CD_DEFAULT_REPO_ALMA="https://repo.almalinux.org/almalinux"
|
||||||
CD_DEFAULT_REPO_ALPINE="https://dl-cdn.alpinelinux.org/alpine"
|
|
||||||
CD_DEFAULT_REPO_DEBIAN="https://deb.debian.org/debian"
|
CD_DEFAULT_REPO_DEBIAN="https://deb.debian.org/debian"
|
||||||
|
|
||||||
CD_PYTHON_MODULES="\
|
CD_PYTHON_MODULES="\
|
||||||
|
@ -16,12 +15,10 @@ rwx \
|
||||||
# main
|
# main
|
||||||
cd_main () {
|
cd_main () {
|
||||||
cd_set_environment_variables
|
cd_set_environment_variables
|
||||||
|
cd_set_dns_resolving
|
||||||
cd_set_packages_repositories
|
cd_set_packages_repositories
|
||||||
#
|
|
||||||
cd_list_working_directory
|
|
||||||
cd_set_packages_configuration
|
cd_set_packages_configuration
|
||||||
cd_set_https_verification_off
|
cd_set_https_verification_off
|
||||||
cd_set_dns_resolving
|
|
||||||
cd_update_packages_catalog
|
cd_update_packages_catalog
|
||||||
cd_install_packages_tools
|
cd_install_packages_tools
|
||||||
cd_install_ca_certificates
|
cd_install_ca_certificates
|
||||||
|
@ -47,13 +44,7 @@ cd_set_environment_variables () {
|
||||||
case "$(cd_grep_os ID)" in
|
case "$(cd_grep_os ID)" in
|
||||||
"almalinux")
|
"almalinux")
|
||||||
CD_OS_ID="${CD_OS_ALMA}"
|
CD_OS_ID="${CD_OS_ALMA}"
|
||||||
CD_OS_VERSION=$(cd_grep_os VERSION_ID \
|
CD_OS_VERSION="$(cd_grep_os VERSION_ID)"
|
||||||
| sed "s|^\([0-9]\+\)\..*|\1|")
|
|
||||||
;;
|
|
||||||
"alpine")
|
|
||||||
CD_OS_ID="${CD_OS_ALPINE}"
|
|
||||||
CD_OS_VERSION=$(cd_grep_os VERSION_ID \
|
|
||||||
| sed "s|^\([0-9]\+\.[0-9]\+\)\..*|\1|")
|
|
||||||
;;
|
;;
|
||||||
"debian")
|
"debian")
|
||||||
CD_OS_ID="${CD_OS_DEBIAN}"
|
CD_OS_ID="${CD_OS_DEBIAN}"
|
||||||
|
@ -61,16 +52,16 @@ cd_set_environment_variables () {
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
#
|
#
|
||||||
|
CD_CA_PACKAGE="ca-certificates"
|
||||||
CD_DNS_FILE="/etc/resolv.conf"
|
CD_DNS_FILE="/etc/resolv.conf"
|
||||||
CD_PKG_CA="ca-certificates"
|
CD_GIT_PACKAGE="git"
|
||||||
CD_PKG_GIT="git"
|
|
||||||
#
|
#
|
||||||
case "${CD_OS_ID}" in
|
case "${CD_OS_ID}" in
|
||||||
"${CD_OS_ALMA}")
|
"${CD_OS_ALMA}")
|
||||||
CD_OS_REPO="${CD_DEFAULT_REPO_ALMA}"
|
CD_OS_REPO="${CD_DEFAULT_REPO_ALMA}"
|
||||||
[ "${CD_REPO_ALMA}" ] && CD_OS_REPO="${CD_REPO_ALMA}"
|
[ "${CD_REPO_ALMA}" ] && CD_OS_REPO="${CD_REPO_ALMA}"
|
||||||
case "${CD_OS_VERSION}" in
|
case "${CD_OS_VERSION}" in
|
||||||
"8"|"9") ;;
|
"8."*|"9."*) cd_nop ;;
|
||||||
*) cd_error_os "CD_OS_VERSION" ;;
|
*) cd_error_os "CD_OS_VERSION" ;;
|
||||||
esac
|
esac
|
||||||
CD_CA_ROOT="/etc/pki/ca-trust/source/anchors"
|
CD_CA_ROOT="/etc/pki/ca-trust/source/anchors"
|
||||||
|
@ -95,29 +86,6 @@ skip_if_unavailable=False
|
||||||
CD_PYTHON_PACKAGE="python3.11"
|
CD_PYTHON_PACKAGE="python3.11"
|
||||||
CD_PYTHON_PACKAGES="/usr/lib64/python3.11/site-packages"
|
CD_PYTHON_PACKAGES="/usr/lib64/python3.11/site-packages"
|
||||||
;;
|
;;
|
||||||
"${CD_OS_ALPINE}")
|
|
||||||
CD_OS_REPO="${CD_DEFAULT_REPO_ALPINE}"
|
|
||||||
[ "${CD_REPO_ALPINE}" ] && CD_OS_REPO="${CD_REPO_ALPINE}"
|
|
||||||
case "${CD_OS_VERSION}" in
|
|
||||||
"3.18"|"3.19") ;;
|
|
||||||
*) cd_error_os "CD_OS_VERSION" ;;
|
|
||||||
esac
|
|
||||||
CD_CA_ROOT="/usr/local/share/ca-certificates"
|
|
||||||
CD_CMD_CA="update-ca-certificates"
|
|
||||||
CD_CMD_CLEAN="apk cache purge"
|
|
||||||
CD_CMD_INSTALL="apk add"
|
|
||||||
CD_CMD_UPDATE="apk update"
|
|
||||||
CD_CMD_UPGRADE="apk upgrade"
|
|
||||||
CD_PKG_PKG=""
|
|
||||||
# TODO
|
|
||||||
CD_PM_CONF_PATH=""
|
|
||||||
CD_PM_CONF_TEXT=""
|
|
||||||
CD_PM_HTTPS_PATH="/etc/apk/repositories.d/https"
|
|
||||||
CD_PM_HTTPS_TEXT="--no-verify"
|
|
||||||
CD_PYTHON_COMMAND="python3.11"
|
|
||||||
CD_PYTHON_PACKAGE="python3"
|
|
||||||
CD_PYTHON_PACKAGES="/usr/lib/python3.11/site-packages"
|
|
||||||
;;
|
|
||||||
"${CD_OS_DEBIAN}")
|
"${CD_OS_DEBIAN}")
|
||||||
export DEBIAN_FRONTEND="noninteractive"
|
export DEBIAN_FRONTEND="noninteractive"
|
||||||
#
|
#
|
||||||
|
@ -176,20 +144,13 @@ Dir::Etc::SourceParts \"\";
|
||||||
CD_PROJECTS_URL="${CD_SERVER_URL}/${CD_PROJECTS_GROUP}"
|
CD_PROJECTS_URL="${CD_SERVER_URL}/${CD_PROJECTS_GROUP}"
|
||||||
CD_PROJECT_URL="${CD_PROJECTS_URL}/${CD_PROJECT_NAME}"
|
CD_PROJECT_URL="${CD_PROJECTS_URL}/${CD_PROJECT_NAME}"
|
||||||
#
|
#
|
||||||
cd_echo "CD_CA" "CD_CA_ROOT"
|
cd_echo "CD_CA"
|
||||||
cd_split
|
cd_split
|
||||||
cd_echo "CD_OS_ID" "CD_OS_VERSION"
|
cd_echo "CD_OS_ID" "CD_OS_VERSION"
|
||||||
cd_split
|
cd_split
|
||||||
cd_echo "CD_CMD_CA" \
|
|
||||||
"CD_CMD_CLEAN" "CD_CMD_INSTALL" "CD_CMD_UPDATE" "CD_CMD_UPGRADE"
|
|
||||||
cd_split
|
|
||||||
cd_echo "CD_DNS_FILE"
|
cd_echo "CD_DNS_FILE"
|
||||||
cd_split
|
cd_split
|
||||||
cd_echo "CD_PKG_CA" "CD_PKG_GIT" "CD_PKG_PKG"
|
cd_echo "CD_PYTHON_PACKAGE" "CD_PYTHON_PACKAGES" "CD_CA_ROOT"
|
||||||
cd_split
|
|
||||||
cd_echo "CD_PM_CONF_PATH" "CD_PM_HTTPS_PATH"
|
|
||||||
cd_split
|
|
||||||
cd_echo "CD_PYTHON_COMMAND" "CD_PYTHON_PACKAGE" "CD_PYTHON_PACKAGES"
|
|
||||||
cd_split
|
cd_split
|
||||||
cd_echo "CD_SERVER_URL" \
|
cd_echo "CD_SERVER_URL" \
|
||||||
"CD_PROJECTS_GROUP" "CD_PROJECT_NAME" "CD_PROJECT_BRANCH"
|
"CD_PROJECTS_GROUP" "CD_PROJECT_NAME" "CD_PROJECT_BRANCH"
|
||||||
|
@ -197,58 +158,6 @@ Dir::Etc::SourceParts \"\";
|
||||||
cd_echo "CD_PROJECTS_URL" "CD_PROJECT_URL"
|
cd_echo "CD_PROJECTS_URL" "CD_PROJECT_URL"
|
||||||
}
|
}
|
||||||
|
|
||||||
cd_set_packages_repositories () {
|
|
||||||
local expression
|
|
||||||
local file
|
|
||||||
cd_step "Set packages repositories"
|
|
||||||
case "${CD_OS_ID}" in
|
|
||||||
"${CD_OS_ALMA}")
|
|
||||||
file="/etc/yum.repos.d/almalinux.repo"
|
|
||||||
cd_sed "${file}" \
|
|
||||||
"|^mirrorlist|# mirrorlist|" \
|
|
||||||
"|${CD_DEFAULT_REPO_ALMA}|${CD_OS_REPO}|" \
|
|
||||||
"|^# baseurl|baseurl|"
|
|
||||||
cd_cat "${file}"
|
|
||||||
;;
|
|
||||||
"${CD_OS_ALPINE}")
|
|
||||||
file="/etc/apk/repositories"
|
|
||||||
cd_write "${file}" "\
|
|
||||||
${CD_OS_REPO}/v${CD_OS_VERSION}/main
|
|
||||||
${CD_OS_REPO}/v${CD_OS_VERSION}/community
|
|
||||||
"
|
|
||||||
;;
|
|
||||||
"${CD_OS_DEBIAN}")
|
|
||||||
file="/etc/apt/sources.list"
|
|
||||||
cd_write "${file}" "\
|
|
||||||
deb ${CD_OS_REPO} ${CD_OS_VERSION} main
|
|
||||||
deb ${CD_OS_REPO} ${CD_OS_VERSION}-backports main
|
|
||||||
deb ${CD_OS_REPO} ${CD_OS_VERSION}-updates main
|
|
||||||
deb ${CD_OS_REPO}-security ${CD_OS_VERSION}-security main
|
|
||||||
"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# agnostic steps
|
|
||||||
|
|
||||||
cd_list_working_directory () {
|
|
||||||
cd_step "List working directory"
|
|
||||||
cd_ls "."
|
|
||||||
}
|
|
||||||
|
|
||||||
cd_set_packages_configuration () {
|
|
||||||
cd_step "Set packages configuration"
|
|
||||||
cd_write "${CD_PM_CONF_PATH}" "${CD_PM_CONF_TEXT}"
|
|
||||||
}
|
|
||||||
|
|
||||||
cd_set_https_verification_off () {
|
|
||||||
if [ "${CD_CA}" -o "${CD_OS_ID}" = "${CD_OS_DEBIAN}" ] ; then
|
|
||||||
cd_step "Set HTTPS verification off"
|
|
||||||
cd_mkdir "$(dirname "${CD_PM_HTTPS_PATH}")"
|
|
||||||
cd_write "${CD_PM_HTTPS_PATH}" "${CD_PM_HTTPS_TEXT}"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
cd_set_dns_resolving () {
|
cd_set_dns_resolving () {
|
||||||
local server
|
local server
|
||||||
local servers
|
local servers
|
||||||
|
@ -262,6 +171,45 @@ local text=""
|
||||||
cd_write "${CD_DNS_FILE}" "${text}"
|
cd_write "${CD_DNS_FILE}" "${text}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cd_set_packages_repositories () {
|
||||||
|
local expression
|
||||||
|
local file
|
||||||
|
cd_step "Set packages repositories"
|
||||||
|
case "${CD_OS_ID}" in
|
||||||
|
"${CD_OS_ALMA}")
|
||||||
|
file="/etc/yum.repos.d/almalinux.repo"
|
||||||
|
cd_sed "${file}" \
|
||||||
|
"|^mirrorlist|# mirrorlist|" \
|
||||||
|
"|${CD_DEFAULT_REPO_ALMA}|${CD_OS_REPO}|" \
|
||||||
|
"|^# baseurl|baseurl|"
|
||||||
|
cd_cat "${file}"
|
||||||
|
;;
|
||||||
|
"${CD_OS_DEBIAN}")
|
||||||
|
cd_write "/etc/apt/sources.list" "\
|
||||||
|
deb ${CD_OS_REPO} ${CD_OS_VERSION} main
|
||||||
|
deb ${CD_OS_REPO} ${CD_OS_VERSION}-backports main
|
||||||
|
deb ${CD_OS_REPO} ${CD_OS_VERSION}-updates main
|
||||||
|
deb ${CD_OS_REPO}-security ${CD_OS_VERSION}-security main
|
||||||
|
"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# agnostic steps
|
||||||
|
|
||||||
|
cd_set_packages_configuration () {
|
||||||
|
cd_step "Set packages configuration"
|
||||||
|
cd_write "${CD_PM_CONF_PATH}" "${CD_PM_CONF_TEXT}"
|
||||||
|
}
|
||||||
|
|
||||||
|
cd_set_https_verification_off () {
|
||||||
|
if [ "${CD_CA}" -o "${CD_OS_ID}" = "${CD_OS_DEBIAN}" ] ; then
|
||||||
|
cd_step "Set HTTPS verification off"
|
||||||
|
cd_mkdir "$(dirname "${CD_PM_HTTPS_PATH}")"
|
||||||
|
cd_write "${CD_PM_HTTPS_PATH}" "${CD_PM_HTTPS_TEXT}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
cd_update_packages_catalog () {
|
cd_update_packages_catalog () {
|
||||||
cd_step "Update packages catalog"
|
cd_step "Update packages catalog"
|
||||||
${CD_CMD_UPDATE} || exit
|
${CD_CMD_UPDATE} || exit
|
||||||
|
@ -274,22 +222,18 @@ cd_install_packages_tools () {
|
||||||
|
|
||||||
cd_install_ca_certificates () {
|
cd_install_ca_certificates () {
|
||||||
cd_step "Install CA"
|
cd_step "Install CA"
|
||||||
cd_install_package "${CD_PKG_CA}"
|
cd_install_package "${CD_CA_PACKAGE}"
|
||||||
}
|
}
|
||||||
|
|
||||||
cd_write_ca_certificates () {
|
cd_write_ca_certificates () {
|
||||||
local index
|
local index
|
||||||
local path
|
|
||||||
local text
|
local text
|
||||||
cd_step "Write CA certificates"
|
cd_step "Write CA certificates"
|
||||||
cd_mkdir "${CD_CA_ROOT}"
|
cd_mkdir "${CD_CA_ROOT}"
|
||||||
index=1
|
index=1
|
||||||
eval "text=\"\${CD_CA_${index}}\""
|
eval "text=\"\${CD_CA_${index}}\""
|
||||||
while [ "${text}" ] ; do
|
while [ "${text}" ] ; do
|
||||||
path="${CD_CA_ROOT}/${index}.crt"
|
cd_write "${CD_CA_ROOT}/${index}.crt" "${text}"
|
||||||
cd_split
|
|
||||||
cd_write "${path}" "${text}"
|
|
||||||
cd_openssl "${path}"
|
|
||||||
index=$((index+1))
|
index=$((index+1))
|
||||||
eval "text=\"\${CD_CA_${index}}\""
|
eval "text=\"\${CD_CA_${index}}\""
|
||||||
done
|
done
|
||||||
|
@ -314,7 +258,7 @@ cd_upgrade_packages () {
|
||||||
|
|
||||||
cd_install_git () {
|
cd_install_git () {
|
||||||
cd_step "Install Git"
|
cd_step "Install Git"
|
||||||
cd_install_package "${CD_PKG_GIT}"
|
cd_install_package "${CD_GIT_PACKAGE}"
|
||||||
}
|
}
|
||||||
|
|
||||||
cd_install_python () {
|
cd_install_python () {
|
||||||
|
@ -376,7 +320,7 @@ ${1}
|
||||||
# functions
|
# functions
|
||||||
|
|
||||||
cd_cat () {
|
cd_cat () {
|
||||||
if [ "${1}" ] ; then
|
if [ -f "${1}" ] ; then
|
||||||
echo "╭╴$(realpath "${1}")"
|
echo "╭╴$(realpath "${1}")"
|
||||||
cat "${1}" || exit
|
cat "${1}" || exit
|
||||||
fi
|
fi
|
||||||
|
@ -408,7 +352,8 @@ local variable="${1}"
|
||||||
if [ "${variable}" ] ; then
|
if [ "${variable}" ] ; then
|
||||||
grep "^${variable}=" "/etc/os-release" \
|
grep "^${variable}=" "/etc/os-release" \
|
||||||
| sed "s|^${variable}=||" \
|
| sed "s|^${variable}=||" \
|
||||||
| sed "s|^\"\(.*\)\"$|\1|"
|
| sed "s|^\"\(.*\)\"$|\1|" \
|
||||||
|
| sed "s|^\([0-9]\+\)\..*|\1|"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -425,13 +370,6 @@ cd_ln_python () {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
cd_ls () {
|
|
||||||
if [ "${1}" ] ; then
|
|
||||||
echo "╭╴$(realpath "${1}")"
|
|
||||||
ls --all -l "${1}" || exit
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
cd_mkdir () {
|
cd_mkdir () {
|
||||||
if [ "${1}" ] ; then
|
if [ "${1}" ] ; then
|
||||||
echo "→ ${1}"
|
echo "→ ${1}"
|
||||||
|
@ -439,16 +377,11 @@ cd_mkdir () {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
cd_openssl () {
|
cd_nop () { true ; }
|
||||||
local file="${1}"
|
|
||||||
if [ "${file}" ] ; then
|
|
||||||
openssl x509 -noout -text -in "${file}" || exit
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
cd_rm () {
|
cd_rm () {
|
||||||
if [ -e "${1}" ] ; then
|
if [ -e "${1}" ] ; then
|
||||||
echo "← ${1}"
|
echo "← $(realpath "${1}")"
|
||||||
rm --recursive "${1}" || exit
|
rm --recursive "${1}" || exit
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -486,8 +419,6 @@ cd_write () {
|
||||||
local file="${1}"
|
local file="${1}"
|
||||||
local text="${2}"
|
local text="${2}"
|
||||||
if [ "${file}" ] ; then
|
if [ "${file}" ] ; then
|
||||||
[ -f "${file}" ] && cd_cat "${file}"
|
|
||||||
echo "→ ${1}"
|
|
||||||
echo -n "${text}" > "${file}" || exit
|
echo -n "${text}" > "${file}" || exit
|
||||||
cd_cat "${file}"
|
cd_cat "${file}"
|
||||||
fi
|
fi
|
||||||
|
@ -499,7 +430,6 @@ CD_ERROR_CI=2
|
||||||
CD_ERROR_OS=1
|
CD_ERROR_OS=1
|
||||||
|
|
||||||
CD_OS_ALMA="alma"
|
CD_OS_ALMA="alma"
|
||||||
CD_OS_ALPINE="alpine"
|
|
||||||
CD_OS_DEBIAN="debian"
|
CD_OS_DEBIAN="debian"
|
||||||
|
|
||||||
# run
|
# run
|
||||||
|
|
11
readme.md
11
readme.md
|
@ -6,18 +6,17 @@ from various CA, CI, OCI / OS.
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
* [ ] support
|
* [ ] support
|
||||||
* [X] package repositories mirror
|
* [ ] package repositories mirror
|
||||||
* [X] custom CA certificates
|
* [ ] custom CA certificates
|
||||||
* [X] known CA certificates
|
* [X] known CA certificates
|
||||||
* [ ] Operating Systems
|
* [ ] Operating Systems
|
||||||
* [X] Alma
|
* [X] Alma
|
||||||
* [ ] Alpine
|
* [ ] Alpine
|
||||||
* [X] Debian
|
* [X] Debian
|
||||||
* [ ] Rocky
|
* [ ] Rocky
|
||||||
* [ ] Continuous Integration platforms
|
* [X] Continuous Integration platforms
|
||||||
* [X] GitHub → Gitea → ForgeJo
|
* [X] GitHub → Gitea → ForgeJo
|
||||||
* [X] GitLab
|
* [X] GitLab
|
||||||
* [ ] SourceHut
|
|
||||||
|
|
||||||
## How
|
## How
|
||||||
|
|
||||||
|
@ -34,9 +33,9 @@ from various CA, CI, OCI / OS.
|
||||||
|
|
||||||
* handle cloning credentials
|
* handle cloning credentials
|
||||||
* make steps more agnostic
|
* make steps more agnostic
|
||||||
* reduce single conditions with &&
|
* show CA certificates as text
|
||||||
* write Python bootstrap
|
* write Python bootstrap
|
||||||
|
|
||||||
|
* first list working directory
|
||||||
* integrate project repository cloning
|
* integrate project repository cloning
|
||||||
* override repository and framework locations
|
* override repository and framework locations
|
||||||
* show previous states of directories & files
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue