[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:
parent
305bca4692
commit
92dbba6c11
7
README
7
README
@ -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.
|
||||||
|
@ -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}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user