2013-11-07 04:25:34 +00:00
|
|
|
#!/bin/bash
|
2013-06-17 15:26:02 +00:00
|
|
|
|
|
|
|
# Copyright 2012 Hewlett-Packard Development Company, L.P.
|
|
|
|
# Copyright 2013 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
# not use this file except in compliance with the License. You may obtain
|
|
|
|
# a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
|
2014-04-03 02:24:15 +00:00
|
|
|
set -eu
|
|
|
|
set -o pipefail
|
2013-06-17 15:26:02 +00:00
|
|
|
|
|
|
|
# Download a URL to a local cache
|
|
|
|
# e.g. cache-url http://.../foo ~/.cache/image-create/foo
|
|
|
|
|
2014-04-16 21:09:02 +00:00
|
|
|
SCRIPT_NAME=$(basename $0)
|
|
|
|
SCRIPT_HOME=$(dirname $0)
|
|
|
|
FORCE_REVALIDATE=0
|
|
|
|
|
|
|
|
function show_options () {
|
|
|
|
echo "Usage: $SCRIPT_NAME [options] <url> <destination_file>"
|
|
|
|
echo
|
|
|
|
echo "Download a URL and cache it to a specified location."
|
|
|
|
echo "Subsequent requests will compare the last modified date"
|
|
|
|
echo "of the upstream file to determine whether it needs to be"
|
|
|
|
echo "downloaded again."
|
|
|
|
echo
|
|
|
|
echo "Options:"
|
|
|
|
echo " -f -- force upstream caches to fetch a new copy of the file"
|
|
|
|
echo " -h -- show this help"
|
|
|
|
echo
|
|
|
|
exit $1
|
|
|
|
}
|
|
|
|
|
|
|
|
TEMP=$(getopt -o hf -n $SCRIPT_NAME -- "$@")
|
|
|
|
if [ $? != 0 ] ; then echo "Terminating..." >&2 ; exit 1 ; fi
|
|
|
|
|
|
|
|
# Note the quotes around `$TEMP': they are essential!
|
|
|
|
eval set -- "$TEMP"
|
|
|
|
|
|
|
|
while true ; do
|
|
|
|
case "$1" in
|
|
|
|
-h|"-?") show_options 0;;
|
|
|
|
-f) FORCE_REVALIDATE=1; shift 1;;
|
|
|
|
--) shift; break;;
|
|
|
|
*) echo "Error: unsupported option $1." ; exit 1 ;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2013-06-17 15:26:02 +00:00
|
|
|
url=$1
|
|
|
|
dest=$2
|
2014-04-03 22:49:18 +00:00
|
|
|
time_cond=
|
2014-04-16 21:09:02 +00:00
|
|
|
curl_opts=""
|
|
|
|
|
|
|
|
if [ -z $url -o -z $dest ] ; then
|
|
|
|
show_options 1
|
|
|
|
fi
|
2013-06-17 15:26:02 +00:00
|
|
|
|
2014-04-04 03:04:24 +00:00
|
|
|
if [ -p $dest ]; then
|
2014-05-02 17:02:38 +00:00
|
|
|
type="fifo"
|
|
|
|
tmp=$(mktemp --tmpdir download.XXXXXXXX)
|
2014-04-04 03:04:24 +00:00
|
|
|
else
|
2014-05-02 17:02:38 +00:00
|
|
|
type="normal"
|
|
|
|
mkdir -p $(dirname $dest)
|
|
|
|
tmp=$(mktemp $(dirname $dest)/.download.XXXXXXXX)
|
2014-04-04 03:04:24 +00:00
|
|
|
fi
|
2013-06-17 15:26:02 +00:00
|
|
|
|
2014-04-16 21:09:02 +00:00
|
|
|
if [ "$FORCE_REVALIDATE" = "1" ]; then
|
|
|
|
curl_opts="-H 'Pragma: no-cache, must-revalidate' -H 'Cache-Control: no-cache, must-revalidate'"
|
|
|
|
success="Downloaded and cached $url, having forced upstream caches to revalidate"
|
|
|
|
elif [ -f $dest -a -s $dest ] ; then
|
2013-06-17 15:26:02 +00:00
|
|
|
time_cond="-z $dest"
|
|
|
|
success="Server copy has changed. Using server version of $url"
|
|
|
|
else
|
|
|
|
success="Downloaded and cached $url for the first time"
|
|
|
|
fi
|
|
|
|
|
2014-04-16 21:09:02 +00:00
|
|
|
rcode=$(eval curl -v -L -o $tmp -w '%{http_code}' $curl_opts $url $time_cond)
|
2014-02-12 15:11:03 +00:00
|
|
|
if [ "$rcode" == "200" -o "${url:0:7}" == "file://" ] ; then
|
2013-10-03 21:18:08 +00:00
|
|
|
# In cases where servers ignore the Modified time,
|
|
|
|
# curl cancels the download, outputs a 200 and leaves
|
|
|
|
# the output file untouched, we don't want this empty file.
|
|
|
|
if [ -n "$time_cond" -a ! -s $tmp ] ; then
|
|
|
|
echo "Ignoring empty file returned by curl. Using locally cached $url"
|
|
|
|
rm -f $tmp
|
|
|
|
else
|
|
|
|
echo $success
|
2014-04-04 03:04:24 +00:00
|
|
|
if [ "fifo" = "$type" ]; then
|
2014-05-02 17:02:38 +00:00
|
|
|
cp $tmp $dest
|
|
|
|
rm $tmp
|
2014-04-04 03:04:24 +00:00
|
|
|
else
|
2014-05-02 17:02:38 +00:00
|
|
|
mv $tmp $dest
|
2014-04-04 03:04:24 +00:00
|
|
|
fi
|
2013-10-03 21:18:08 +00:00
|
|
|
fi
|
2014-05-02 17:02:38 +00:00
|
|
|
# 213 is the response to a ftp MDTM command, curl outputs a 213 as the status
|
|
|
|
# if the url redirected to a ftp server and Not-Modified
|
2013-10-11 09:15:27 +00:00
|
|
|
elif [ "$rcode" = "304" -o "$rcode" = "213" ] ; then
|
2013-06-17 15:26:02 +00:00
|
|
|
echo "Server copy has not changed. Using locally cached $url"
|
|
|
|
rm -f $tmp
|
|
|
|
else
|
|
|
|
echo "Server returned an unexpected response code. [$rcode]"
|
|
|
|
rm -f $tmp
|
2013-10-22 23:44:37 +00:00
|
|
|
# expose some error codes so the calling process might know what happened
|
|
|
|
if [ "$rcode" = "404" ] ; then
|
|
|
|
exit 44
|
|
|
|
fi
|
2013-06-17 15:26:02 +00:00
|
|
|
exit 1
|
|
|
|
fi
|