Browse Source

Merge pull request #482 from snusifer/fix-ignore-mender-conf2

fix: user defined overlay not to be ignored with demo config enabled
4.0.x
mikaelthd 2 years ago
committed by GitHub
parent
commit
586a9b8478
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 4
      configs/mender_convert_demo_config
  2. 9
      mender-convert-modify
  3. 11
      scripts/bootstrap-rootfs-overlay-demo-server.sh
  4. 12
      scripts/bootstrap-rootfs-overlay-hosted-server.sh
  5. 16
      scripts/bootstrap-rootfs-overlay-production-server.sh

4
configs/mender_convert_demo_config

@ -9,7 +9,7 @@ enable_demo_configuration_in_file() {
run_and_log_cmd "mkdir -p work/rootfs/etc/mender" run_and_log_cmd "mkdir -p work/rootfs/etc/mender"
if [ ! -f work/rootfs/etc/mender/mender.conf ]; then if [ ! -f work/rootfs/etc/mender/mender.conf ]; then
log_error "No Mender configuration file found in the work folder." log_error 'No Mender configuration file found in the work folder. Either run a bootstrap script and pass the output directory as an overlay to mender-convert, or pass your own overlay with an $OVERLAY/etc/mender/mender.conf file.'
exit 1 exit 1
fi fi
@ -32,4 +32,4 @@ EOF
log_warn "New mender.conf contents: $(cat work/rootfs/etc/mender/mender.conf)" log_warn "New mender.conf contents: $(cat work/rootfs/etc/mender/mender.conf)"
} }
PLATFORM_MODIFY_HOOKS+=(enable_demo_configuration_in_file) OVERLAY_MODIFY_HOOKS+=(enable_demo_configuration_in_file)

9
mender-convert-modify

@ -190,15 +190,6 @@ EOF
run_and_log_cmd "sudo cp work/mender.conf.data work/rootfs/data/mender/mender.conf" run_and_log_cmd "sudo cp work/mender.conf.data work/rootfs/data/mender/mender.conf"
run_and_log_cmd "sudo chmod 600 work/rootfs/data/mender/mender.conf" run_and_log_cmd "sudo chmod 600 work/rootfs/data/mender/mender.conf"
if [ -f input/resources/mender.conf ]; then
log_info "Installing the local mender.conf file"
run_and_log_cmd "mkdir -p work/rootfs/etc/mender"
run_and_log_cmd "cp input/resources/mender.conf work/rootfs/etc/mender"
run_and_log_cmd "sudo chmod 600 work/rootfs/etc/mender/mender.conf"
else
log_warn "No mender.conf file found in input/resources. Have you remembered to run the bootstrap script?"
fi
if [ -z "${MENDER_DEVICE_TYPE}" ]; then if [ -z "${MENDER_DEVICE_TYPE}" ]; then
# Observed systems who do not have this file, e.g images generated with mkosi # Observed systems who do not have this file, e.g images generated with mkosi
if [ -f work/rootfs/etc/hostname ]; then if [ -f work/rootfs/etc/hostname ]; then

11
scripts/bootstrap-rootfs-overlay-demo-server.sh

@ -16,12 +16,6 @@
# Exit if any command exits with a non-zero exit status. # Exit if any command exits with a non-zero exit status.
set -o errexit set -o errexit
root_dir=$( cd "$( dirname "${BASH_SOURCE[0]}")/../" && pwd)
if [ "${root_dir}" != "${PWD}" ]; then
echo "You must execute $(basename $0) from the root directory: ${root_dir}"
exit 1
fi
server_ip="" server_ip=""
output_dir="" output_dir=""
while (("$#")); do while (("$#")); do
@ -57,8 +51,7 @@ if [ -e ${output_dir} ]; then
fi fi
mkdir -p ${output_dir}/etc/mender mkdir -p ${output_dir}/etc/mender
mkdir -p ${root_dir}/input/resources cat <<- EOF > ${output_dir}/etc/mender/mender.conf
cat <<- EOF > ${root_dir}/input/resources/mender.conf
{ {
"ServerURL": "https://docker.mender.io", "ServerURL": "https://docker.mender.io",
"ServerCertificate": "/etc/mender/server.crt" "ServerCertificate": "/etc/mender/server.crt"
@ -80,4 +73,4 @@ wget -q "https://raw.githubusercontent.com/mendersoftware/mender/master/support/
sudo chown -R 0 ${output_dir} sudo chown -R 0 ${output_dir}
sudo chgrp -R 0 ${output_dir} sudo chgrp -R 0 ${output_dir}
echo "Configuration file for using Demo Mender Server written to: ${root_dir}/input/resources/mender.conf" echo "Configuration file for using Demo Mender Server written to: ${output_dir}/etc/mender/mender.conf"

12
scripts/bootstrap-rootfs-overlay-hosted-server.sh

@ -16,12 +16,6 @@
# Exit if any command exits with a non-zero exit status. # Exit if any command exits with a non-zero exit status.
set -o errexit set -o errexit
root_dir=$( cd "$( dirname "${BASH_SOURCE[0]}")/../" && pwd)
if [ "${root_dir}" != "${PWD}" ]; then
echo "You must execute $(basename $0) from the root directory: ${root_dir}"
exit 1
fi
tenant_token="" tenant_token=""
output_dir="" output_dir=""
while (("$#")); do while (("$#")); do
@ -56,8 +50,8 @@ if [ -e ${output_dir} ]; then
sudo chown -R $(id -u) ${output_dir} sudo chown -R $(id -u) ${output_dir}
sudo chgrp -R $(id -g) ${output_dir} sudo chgrp -R $(id -g) ${output_dir}
fi fi
mkdir -p ${root_dir}/input/resources mkdir -p ${output_dir}/etc/mender
cat <<- EOF > ${root_dir}/input/resources/mender.conf cat <<- EOF > ${output_dir}/etc/mender/mender.conf
{ {
"ServerURL": "https://hosted.mender.io/", "ServerURL": "https://hosted.mender.io/",
"TenantToken": "${tenant_token}" "TenantToken": "${tenant_token}"
@ -67,4 +61,4 @@ EOF
sudo chown -R 0 ${output_dir} sudo chown -R 0 ${output_dir}
sudo chgrp -R 0 ${output_dir} sudo chgrp -R 0 ${output_dir}
echo "Configuration file for using Hosted Mender written to: ${root_dir}/input/resources/mender.conf" echo "Configuration file for using Hosted Mender written to: ${output_dir}/etc/mender/mender.conf"

16
scripts/bootstrap-rootfs-overlay-production-server.sh

@ -16,12 +16,6 @@
# Exit if any command exits with a non-zero exit status. # Exit if any command exits with a non-zero exit status.
set -o errexit set -o errexit
root_dir=$( cd "$( dirname "${BASH_SOURCE[0]}")/../" && pwd)
if [ "${root_dir}" != "${PWD}" ]; then
echo "You must execute $(basename $0) from the root directory: ${root_dir}"
exit 1
fi
server_url="" server_url=""
output_dir="" output_dir=""
while (("$#")); do while (("$#")); do
@ -61,24 +55,24 @@ if [ -e ${output_dir} ]; then
sudo chgrp -R $(id -g) ${output_dir} sudo chgrp -R $(id -g) ${output_dir}
fi fi
mkdir -p ${root_dir}/input/resources mkdir -p ${output_dir}/etc/mender
cat <<- EOF > ${root_dir}/input/resources/mender.conf cat <<- EOF > ${output_dir}/etc/mender/mender.conf
{ {
"ServerURL": "${server_url}", "ServerURL": "${server_url}",
EOF EOF
if [ -n "${server_cert}" ]; then if [ -n "${server_cert}" ]; then
cat <<- EOF >> ${root_dir}/input/resources/mender.conf cat <<- EOF >> ${output_dir}/etc/mender/mender.conf
"ServerCertificate": "/etc/mender/server.crt" "ServerCertificate": "/etc/mender/server.crt"
EOF EOF
cp -f "${server_cert}" ${output_dir}/etc/mender/server.crt cp -f "${server_cert}" ${output_dir}/etc/mender/server.crt
fi fi
cat <<- EOF >> ${root_dir}/input/resources/mender.conf cat <<- EOF >> ${output_dir}/etc/mender/mender.conf
} }
EOF EOF
sudo chown -R 0 ${output_dir} sudo chown -R 0 ${output_dir}
sudo chgrp -R 0 ${output_dir} sudo chgrp -R 0 ${output_dir}
echo "Configuration file for using Production Mender Server written to: ${root_dir}/input/resources/mender.conf" echo "Configuration file for using Production Mender Server written to: ${output_dir}/etc/mender/mender.conf"

Loading…
Cancel
Save