[archiso] Cleanup: pxe_curl: Remove download-iso-loopback support.

This was the first implementation that downloads the complete ISO,
but now we have the posibility of download only needed *.sfs files.

Signed-off-by: Gerardo Exequiel Pozzi <vmlinuz386@yahoo.com.ar>
This commit is contained in:
Gerardo Exequiel Pozzi 2011-12-03 17:45:45 -03:00
parent 305bca4692
commit 92dbba6c11
2 changed files with 23 additions and 40 deletions

7
README
View File

@ -89,10 +89,9 @@ INDEX
** hooks/archiso_pxe_curl ** hooks/archiso_pxe_curl
* archiso_curl_url= Set an HTTP/FTP URL of an ISO file (first form), * archiso_curl_url= Set an HTTP/FTP URL (must end with /) where ${archisobasedir}
or a path (must end with /) where ${archisobasedir} is found with all *.sfs files.
is found with all *.sfs files (second form). In the IP/domain part if ${pxeserver} is used, use PXE IP.
In the IP part if ${pxeserver} is used, PXE IP will be used.
Default: (unset) Default: (unset)
* curlspace_size= Set the size of tmpfs of "curlspace" where the specified * curlspace_size= Set the size of tmpfs of "curlspace" where the specified
ISO image or *.sfs files are downloaded. ISO image or *.sfs files are downloaded.

View File

@ -13,13 +13,13 @@ run_hook() {
# Fetch a file with CURL # Fetch a file with CURL
# #
# $1 URL # $1 URL
# $2 Destination directory inside curlspace # $2 Destination directory inside curlspace/${archisobasedir}
_curl_get() { _curl_get() {
local _url="${1}" local _url="${1}"
local _dst="${2}" local _dst="${2}"
msg ":: Downloading '${_url}'" msg ":: Downloading '${_url}'"
if ! curl -f -o "/run/archiso/curlspace/${_dst}/${_url##*/}" --create-dirs "${_url}"; then if ! curl -f -o "/run/archiso/curlspace/${archisobasedir}${_dst}/${_url##*/}" --create-dirs "${_url}"; then
echo "ERROR: Downloading '${_url}'" echo "ERROR: Downloading '${_url}'"
echo " Falling back to interactive prompt" echo " Falling back to interactive prompt"
echo " You can try to fix the problem manually, log out when you are finished" echo " You can try to fix the problem manually, log out when you are finished"
@ -34,44 +34,28 @@ archiso_pxe_curl_mount_handler () {
mkdir -p "/run/archiso/curlspace" mkdir -p "/run/archiso/curlspace"
mount -t tmpfs -o size="${curlspace_size}",mode=0755 curlspace "/run/archiso/curlspace" mount -t tmpfs -o size="${curlspace_size}",mode=0755 curlspace "/run/archiso/curlspace"
# Check if URL ends in / local _aitab_url="${archiso_curl_url}${aitab#/run/archiso/bootmnt/}"
if [[ "${archiso_curl_url}" != "${archiso_curl_url%/}" ]]; then local _aitab_file="/run/archiso/curlspace/${aitab#/run/archiso/bootmnt/}"
local _aitab_url="${archiso_curl_url}${aitab#/run/archiso/bootmnt/}" _curl_get "${_aitab_url}" "/"
local _aitab_file="/run/archiso/curlspace/${aitab#/run/archiso/bootmnt/}"
_curl_get "${_aitab_url}" "${archisobasedir}" local aitab_img aitab_mnt aitab_arch aitab_sfs_comp aitab_fs_type aitab_fs_size
while read aitab_img aitab_mnt aitab_arch aitab_sfs_comp aitab_fs_type aitab_fs_size; do
local aitab_img aitab_mnt aitab_arch aitab_sfs_comp aitab_fs_type aitab_fs_size [[ "${aitab_img#\#}" != "${aitab_img}" ]] && continue
while read aitab_img aitab_mnt aitab_arch aitab_sfs_comp aitab_fs_type aitab_fs_size; do [[ "${aitab_arch}" != "any" && "${aitab_arch}" != "${arch}" ]] && continue
[[ "${aitab_img#\#}" != "${aitab_img}" ]] && continue if [[ "${aitab_fs_type}" != "none" ]]; then
[[ "${aitab_arch}" != "any" && "${aitab_arch}" != "${arch}" ]] && continue _curl_get "${archiso_curl_url}${archisobasedir}/${aitab_arch}/${aitab_img}.fs.sfs" "/${aitab_arch}"
if [[ "${aitab_fs_type}" != "none" ]]; then else
_curl_get "${archiso_curl_url}${archisobasedir}/${aitab_arch}/${aitab_img}.fs.sfs" "${archisobasedir}/${aitab_arch}" _curl_get "${archiso_curl_url}${archisobasedir}/${aitab_arch}/${aitab_img}.sfs" "/${aitab_arch}"
else
_curl_get "${archiso_curl_url}${archisobasedir}/${aitab_arch}/${aitab_img}.sfs" "${archisobasedir}/${aitab_arch}"
fi
done < "${_aitab_file}"
if [[ "${checksum}" == "y" ]]; then
_curl_get "${archiso_curl_url}${archisobasedir}/checksum.${arch}.md5" "${archisobasedir}"
fi fi
done < "${_aitab_file}"
mkdir -p "/run/archiso/bootmnt" if [[ "${checksum}" == "y" ]]; then
mount -o bind /run/archiso/curlspace /run/archiso/bootmnt _curl_get "${archiso_curl_url}${archisobasedir}/checksum.${arch}.md5" "/"
else
local _dev_loop
_curl_get "${archiso_curl_url}" "/"
_dev_loop=$(losetup -f)
if ! losetup "${_dev_loop}" "/run/archiso/curlspace/${archiso_curl_url##*/}"; then
echo "ERROR: Setting loopback device '${_dev_loop}'"
echo " for file '/run/archiso/curlspace/${archiso_curl_url##*/}'"
echo " Falling back to interactive prompt"
echo " You can try to fix the problem manually, log out when you are finished"
launch_interactive_shell
fi
fi fi
mkdir -p "/run/archiso/bootmnt"
mount -o bind /run/archiso/curlspace /run/archiso/bootmnt
archiso_mount_handler ${newroot} archiso_mount_handler ${newroot}
} }