#!/bin/bash ################################################# # Title: mk-install-iso # # Date: 2014-11-26 # # Version: 1.0 # # Author: dthaluru@vmware.com # # Options: # ################################################# # Overview # Generates a photon iso # End # set +x # disable hashall source config.inc # configuration parameters source function.inc # commonn functions PRGNAME=${0##*/} # script name minus the path LOGFILE=/var/log/"${PRGNAME}-${LOGFILE}" # set log file name # Grab the name of the iso file if [ $# -lt 2 ] then echo "Usage : " $0 " " exit 1 fi ISO_OUTPUT_NAME=$1 RPMS_PATH=$2 PACKAGE_LIST_FILE=$3 RPM_LIST=$4 STAGE_PATH=$5 ADDITIONAL_FILES_TO_COPY_FROM_STAGE=$6 LIVE_CD=$7 OUTPUT_DATA_PATH=$8 PHOTON_COMMON_DIR=$(dirname "${PACKAGE_LIST_FILE}") PACKAGE_LIST_FILE_BASE_NAME=$(basename "${PACKAGE_LIST_FILE}") #- Step 3 Setting up the boot loader WORKINGDIR=${BUILDROOT} BUILDROOT=${BUILDROOT}/photon-chroot run_command "cp isolinux to working directory: ${WORKINGDIR}" "cp -r BUILD_DVD/isolinux ${WORKINGDIR}/" "${LOGFILE}" run_command "cp boot/grub2 to working directory: ${WORKINGDIR}" "cp -r BUILD_DVD/boot ${WORKINGDIR}/" "${LOGFILE}" run_command "# 1" "mkdir ${WORKINGDIR}/boot/grub2/fonts/" "${LOGFILE}" run_command "# 2" "cp boot/ascii.pf2 ${WORKINGDIR}/boot/grub2/fonts/" "${LOGFILE}" run_command "# 3" "mkdir -p ${WORKINGDIR}/boot/grub2/themes/photon/" "${LOGFILE}" run_command "# 4" "cp boot/splash.png ${WORKINGDIR}/boot/grub2/themes/photon/photon.png" "${LOGFILE}" run_command "# 5" "cp boot/terminal_*.tga ${WORKINGDIR}/boot/grub2/themes/photon/" "${LOGFILE}" run_command "# 6" "cp boot/theme.txt ${WORKINGDIR}/boot/grub2/themes/photon/" "${LOGFILE}" run_command "echo : ${WORKINGDIR}" "echo ${WORKINGDIR}" "${LOGFILE}" cp BUILD_DVD/isolinux/splash.png ${BUILDROOT}/installer/boot/. mkdir -p ${BUILDROOT}/installer/EFI/BOOT cp EFI/BOOT/bootx64.efi ${BUILDROOT}/installer/EFI/BOOT/bootx64.efi if [ "$LIVE_CD" = true ] ; then mv ${WORKINGDIR}/isolinux/live-menu.cfg ${WORKINGDIR}/isolinux/menu.cfg fi cp sample_ks.cfg ${WORKINGDIR}/isolinux/ find ${BUILDROOT} -name linux-[0-9]*.rpm | head -1 | xargs rpm2cpio | cpio -iv --to-stdout ./boot/vmlinuz* > ${WORKINGDIR}/isolinux/vmlinuz rm -f ${BUILDROOT}/installer/*.pyc rm -rf ${BUILDROOT}/installer/BUILD_DVD # Copy package list json files, dereference symlinks cp -rf -L $OUTPUT_DATA_PATH/*.json ${BUILDROOT}/installer/ #ID in the initrd.gz now is PHOTON_VMWARE_CD . This is how we recognize that the cd is actually ours. touch this file there. touch ${WORKINGDIR}/PHOTON_VMWARE_CD # Step 4.5 Create necessary devices mkfifo ${BUILDROOT}/dev/initctl mknod ${BUILDROOT}/dev/ram0 b 1 0 mknod ${BUILDROOT}/dev/ram1 b 1 1 mknod ${BUILDROOT}/dev/ram2 b 1 2 mknod ${BUILDROOT}/dev/ram3 b 1 3 mknod ${BUILDROOT}/dev/sda b 8 0 #- Step 5 - Creating the boot script mkdir -p ${BUILDROOT}/etc/systemd/scripts # Step 6 create fstab cp BUILD_DVD/fstab ${BUILDROOT}/etc/fstab mkdir -p ${BUILDROOT}/etc/yum.repos.d cat >> ${BUILDROOT}/etc/yum.repos.d/photon-iso.repo <> ${BUILDROOT}/bin/bootphotoninstaller << EOF #!/bin/bash cd /installer ./isoInstaller.py --json-file=$PACKAGE_LIST_FILE_BASE_NAME 2> /var/log/installer && shutdown -r now /bin/bash EOF chmod 755 ${BUILDROOT}/bin/bootphotoninstaller fi cat >> ${BUILDROOT}/init << EOF mount -t proc proc /proc /lib/systemd/systemd EOF chmod 755 ${BUILDROOT}/init #adding autologin to the root user # and set TERM=linux for installer sed -i "s/ExecStart.*/ExecStart=-\/sbin\/agetty --autologin root --noclear %I linux/g" ${BUILDROOT}/lib/systemd/system/getty@.service #- Step 7 - Create installer script if [ "$LIVE_CD" = false ] ; then sed -i "s/root:.*/root:x:0:0:root:\/root:\/bin\/bootphotoninstaller/g" ${BUILDROOT}/etc/passwd fi mkdir -p ${BUILDROOT}/mnt/photon-root/photon-chroot rm -rf ${BUILDROOT}/RPMS run_command " echo ${RPMS_PATH}" "echo ${RPMS_PATH}" "${LOGFILE}" #cp -r ${RPMS_PATH} ${WORKINGDIR}/ ( cd ${RPMS_PATH} mkdir ${WORKINGDIR}/RPMS for rpm_name in $RPM_LIST; do if [ -f "$rpm_name" ]; then cp --parent $rpm_name ${WORKINGDIR}/RPMS/; fi done ) # Work in sub-shell using ( ... ) to come back to original folder. ( cd $STAGE_PATH for file_name in $ADDITIONAL_FILES_TO_COPY_FROM_STAGE; do if [ -n "$file_name" ]; then cp $file_name ${WORKINGDIR}/; fi done ) #creating rpm repo in cd.. createrepo --database ${WORKINGDIR}/RPMS repodatadir=${WORKINGDIR}/RPMS/repodata if [ -d $repodatadir ]; then pushd $repodatadir metaDataFile=`find -type f -name "*primary.xml.gz"` ln -sfv $metaDataFile primary.xml.gz popd fi rm -rf ${BUILDROOT}/LOGS if [ "$LIVE_CD" = false ] ; then # Cleaning up #Remove our rpm database as it fills up the ramdisk for filename in ${BUILDROOT}/usr/lib/*; do #run_command " echo ${filename}" "echo ${filename}" "${LOGFILE}" if [[ -f ${filename} ]]; then file ${filename} | grep ELF >/dev/null 2>&1 #run_command " file ${filename}" "echo ${filename}" "${LOGFILE}" if [[ $? -eq 0 ]]; then run_command " strip ${filename}" "strip ${filename}" "${LOGFILE}" fi; fi; done #Remove our rpm database as it fills up the ramdisk for filename in $(find ${BUILDROOT}/usr/lib/modules); do #run_command " echo ${filename}" "echo ${filename}" "${LOGFILE}" if [[ -f ${filename} ]]; then file ${filename} | grep ELF >/dev/null 2>&1 #run_command " file ${filename}" "echo ${filename}" "${LOGFILE}" if [[ $? -eq 0 ]]; then run_command " strip ${filename}" "strip ${filename}" "${LOGFILE}" fi; fi; done rm -rf ${BUILDROOT}/home/* rm -rf ${BUILDROOT}/var/lib/rpm # Remove the boot directory rm -rf ${BUILDROOT}/boot #Remove the include files. rm -rf ${BUILDROOT}/usr/include rm ${BUILDROOT}/lib64/libmvec* rm ${BUILDROOT}/usr/sbin/grub2-bios-setup rm ${BUILDROOT}/usr/sbin/grub2-probe rm ${BUILDROOT}/usr/sbin/grub2-macbless rm ${BUILDROOT}/usr/sbin/grub2-reboot rm ${BUILDROOT}/usr/sbin/grub2-sparc64-setup rm ${BUILDROOT}/usr/sbin/sln rm ${BUILDROOT}/usr/bin/grub2-mkrescue rm ${BUILDROOT}/usr/bin/grub2-fstest rm ${BUILDROOT}/usr/bin/grub2-syslinux2cfg rm ${BUILDROOT}/usr/bin/grub2-mkstandalone rm ${BUILDROOT}/usr/bin/grub2-render-label rm ${BUILDROOT}/usr/bin/grub2-mkimage rm ${BUILDROOT}/usr/bin/grub2-file rm ${BUILDROOT}/usr/bin/grub2-mkrelpath rm ${BUILDROOT}/usr/bin/grub2-glue-efi rm ${BUILDROOT}/usr/bin/grub2-editenv rm ${BUILDROOT}/usr/bin/grub2-mklayout rm ${BUILDROOT}/usr/bin/grub2-mkpasswd-pbkdf2lsls rm ${BUILDROOT}/usr/bin/grub2-script-check rm ${BUILDROOT}/usr/bin/grub2-mknetdir rm ${BUILDROOT}/usr/bin/oldfind rm ${BUILDROOT}/usr/bin/localedef rm ${BUILDROOT}/usr/bin/systemd-nspawn rm ${BUILDROOT}/usr/bin/systemd-analyze rm -rf ${BUILDROOT}/usr/lib64/gconv rm ${BUILDROOT}/usr/bin/sqlite3 rm ${BUILDROOT}/usr/bin/bsdcpio rm ${BUILDROOT}/usr/bin/bsdtar rm ${BUILDROOT}/usr/bin/networkctl rm ${BUILDROOT}/usr/bin/machinectl rm ${BUILDROOT}/usr/bin/pkg-config rm ${BUILDROOT}/usr/bin/openssl rm ${BUILDROOT}/usr/bin/timedatectl rm ${BUILDROOT}/usr/bin/localectl rm ${BUILDROOT}/usr/bin/systemd-cgls rm ${BUILDROOT}/usr/bin/systemd-inhibit rm ${BUILDROOT}/usr/bin/systemd-studio-bridge rm ${BUILDROOT}/usr/bin/iconv rm -rf ${BUILDROOT}/usr/lib/python2.7/lib2to3 rm -rf ${BUILDROOT}/usr/lib/python2.7/lib-tk rm -rf ${BUILDROOT}/usr/lib/python2.7/ensurepip rm -rf ${BUILDROOT}/usr/lib/python2.7/distutils rm -rf ${BUILDROOT}/usr/lib/python2.7/pydoc_data rm -rf ${BUILDROOT}/usr/lib/python2.7/idlelib rm -rf ${BUILDROOT}/usr/lib/python2.7/unittest rm ${BUILDROOT}/usr/lib/librpmbuild.so* rm ${BUILDROOT}/usr/lib/libdb_cxx* rm ${BUILDROOT}/usr/lib/libnss_compat* rm ${BUILDROOT}/usr/lib/grub/i386-pc/mpi.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/net.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/regexp.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/grub-bios-setup rm ${BUILDROOT}/usr/lib/grub/i386-pc/file.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/bsd.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/efiemu.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/functional_test.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/gcry_*.module rm ${BUILDROOT}/usr/lib/grub/i386-pc/xnu.* rm ${BUILDROOT}/usr/lib/grub/i386-pc/zfs.* # TODO: mbassiouny, Find a clean way to do that for i in `ls ${BUILDROOT}/usr/share/`; do if [ $i != 'terminfo' -a $i != 'cracklib' -a $i != 'grub' -a $i != 'factory' ]; then rm -rf ${BUILDROOT}/usr/share/$i fi done fi # Set password max days to 99999 (disable aging) chage -R ${BUILDROOT} -M 99999 root # Generate the intird pushd $BUILDROOT (find . | cpio -o -H newc --quiet | gzip -9 ) > ${WORKINGDIR}/isolinux/initrd.img popd rm -rf $BUILDROOT #Step 9 Generate the ISO!!!! pushd $WORKINGDIR mkisofs -R -l -L -D -b isolinux/isolinux.bin -c isolinux/boot.cat \ -no-emul-boot -boot-load-size 4 -boot-info-table \ -eltorito-alt-boot -e boot/grub2/efiboot.img -no-emul-boot \ -V "PHOTON_$(date +%Y%m%d)" \ $WORKINGDIR >$ISO_OUTPUT_NAME popd