2011-04-26 21:39:44 +02:00
|
|
|
#!/bin/bash
|
|
|
|
# libnetwork.lib -- @package@ library to get info from internet repositories
|
2014-08-20 21:00:14 +02:00
|
|
|
# Copyright (C) 2008,2010,2012,2014 Davide Madrisan <davide.madrisan@gmail.com>
|
2011-04-26 21:39:44 +02:00
|
|
|
|
2012-11-25 15:54:34 +01:00
|
|
|
[ "$libnetwork_is_loaded" = 1 ] || {
|
|
|
|
libnetwork_is_loaded=1
|
|
|
|
|
2011-04-26 21:39:44 +02:00
|
|
|
[ -z "$BASH" ] || [ ${BASH_VERSION:0:1} -lt 3 ] &&
|
|
|
|
{ echo $"this script requires bash version 3 or better" >&2 && exit 1; }
|
|
|
|
|
|
|
|
[ -r @libdir@/libmsgmng.lib ] ||
|
2012-12-01 17:40:21 +01:00
|
|
|
{ echo "\
|
|
|
|
libnetwork.lib: "$"library not found"": @libdir@/libmsgmng.lib" 1>&2
|
2011-04-26 21:39:44 +02:00
|
|
|
exit 1; }
|
|
|
|
. @libdir@/libmsgmng.lib
|
|
|
|
|
2012-11-30 22:02:42 +01:00
|
|
|
[ -r @libdir@/libtranslate.lib ] ||
|
2012-12-01 17:40:21 +01:00
|
|
|
{ echo "\
|
|
|
|
libnetwork.lib: "$"library not found"": @libdir@/libtranslate.lib" 1>&2
|
2012-11-30 22:02:42 +01:00
|
|
|
exit 1; }
|
|
|
|
. @libdir@/libtranslate.lib
|
2011-04-26 21:39:44 +02:00
|
|
|
|
2012-12-01 17:54:46 +01:00
|
|
|
notify.debug $"loading"": \`libnetwork.lib'..."
|
|
|
|
|
2012-04-23 21:21:10 +02:00
|
|
|
# check if all the needed tools are available
|
2012-04-23 23:12:08 +02:00
|
|
|
for tool in curl mktemp; do
|
2012-04-23 21:21:10 +02:00
|
|
|
[ "$(type -p curl)" ] || notify.error $"utility not found"": \`curl'"
|
|
|
|
done
|
|
|
|
|
2012-04-25 23:07:55 +02:00
|
|
|
# function repository.get_srpm_pckname_from_site()
|
|
|
|
# get the list of SRPM packages by looking at the curl dump of the
|
|
|
|
# ftp or html site
|
|
|
|
# args:
|
|
|
|
# --ftp | --html
|
|
|
|
# $1 : package name or regexpr to look for
|
|
|
|
# $2 : a (temporary) file containing the curl dump
|
|
|
|
# return value:
|
|
|
|
# the list of srpm files
|
|
|
|
function repository.get_srpm_pckname_from_site() {
|
|
|
|
local ARGS
|
|
|
|
ARGS=`LC_ALL=C getopt \
|
|
|
|
-o fh --long ftp,html \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local is_html="0" is_ftp="0"
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-f|--ftp)
|
|
|
|
is_ftp="1"
|
|
|
|
;;
|
|
|
|
-h|--html)
|
|
|
|
is_html="1"
|
|
|
|
;;
|
|
|
|
--) shift; break ;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
[ "$is_ftp" != "$is_html" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"usage error (--ftp/--html)"
|
|
|
|
|
2012-04-29 00:10:30 +02:00
|
|
|
local pck_name="$1"
|
2011-04-26 21:39:44 +02:00
|
|
|
local infile="$2"
|
|
|
|
|
|
|
|
[ "$pck_name" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
[ "$infile" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#2)"
|
|
|
|
|
|
|
|
notify.debug "$FUNCNAME: pck_name = \"$pck_name\""
|
|
|
|
case "$pck_name" in */*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"'\\' characters detected in \$pck_name" ;; esac
|
|
|
|
|
|
|
|
notify.debug "$FUNCNAME: infile = \"$infile\""
|
|
|
|
|
2012-04-14 19:59:19 +02:00
|
|
|
local regexpr
|
2020-12-02 10:03:12 +01:00
|
|
|
[[ "$pck_name" =~ ^[+a-zA-Z0-9_-]+$ ]] && \
|
2012-04-14 19:59:19 +02:00
|
|
|
regexpr="^$pck_name-[^-]\+-[^-]\+$" || regexpr="$pck_name"
|
2012-04-14 22:08:51 +02:00
|
|
|
notify.debug "$FUNCNAME: regexpr = \"$regexpr\""
|
2012-04-14 19:59:19 +02:00
|
|
|
|
2012-04-25 23:07:55 +02:00
|
|
|
if [ "$is_html" = "1" ]; then
|
|
|
|
notify.debug "$FUNCNAME: parsing HTML dump..."
|
2012-04-29 00:10:30 +02:00
|
|
|
local pckname_from_HTML=($(sed -n "\
|
|
|
|
# remove HTML tags --> get a better input
|
2012-04-30 23:58:25 +02:00
|
|
|
/<[aA]\+ [hH]\+[rR]\+[eE]\+[fF]\+=\".*\.src\.rpm\"/{
|
2023-10-03 19:42:30 +02:00
|
|
|
s|%2B|+|g;
|
2012-04-29 00:10:30 +02:00
|
|
|
s|.*<[aA]\+ [hH]\+[rR]\+[eE]\+[fF]\+=\"\([^\"]*\)\".*|\1|
|
2012-04-30 23:58:25 +02:00
|
|
|
{/$regexpr/Ip}}" $infile))
|
2012-04-25 23:07:55 +02:00
|
|
|
echo "${pckname_from_HTML[*]}"
|
|
|
|
elif [ "$is_ftp" = "1" ]; then
|
|
|
|
notify.debug "$FUNCNAME: parsing FTP dump..."
|
2012-04-29 00:10:30 +02:00
|
|
|
local pckname_from_FTP=($(sed -n "s,.*\ ,,;{/$regexpr/p}" $infile))
|
2012-04-25 23:07:55 +02:00
|
|
|
echo "${pckname_from_FTP[*]}"
|
|
|
|
fi
|
2011-04-26 21:39:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# function repository.resolveURL()
|
|
|
|
# expand the given url according to the given arch
|
|
|
|
# args:
|
|
|
|
# $1 : url to expand
|
|
|
|
# $2 : current architecture
|
|
|
|
# return value:
|
|
|
|
# the expanded url
|
|
|
|
function repository.resolveURL() {
|
|
|
|
local ftpurl="$1" curr_arch="$2" resurl
|
|
|
|
|
|
|
|
[ "$ftpurl" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
[ "$curr_arch" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#2)"
|
|
|
|
|
|
|
|
case "$ftpurl" in
|
|
|
|
*@arch@*)
|
|
|
|
echo -n "$(echo $ftpurl | sed "s,@arch@,$curr_arch,g")" ;;
|
|
|
|
*) #echo -n "$ftpurl/$curr_arch/"
|
|
|
|
echo -n "$ftpurl/" ;;
|
|
|
|
esac
|
|
|
|
}
|
|
|
|
|
|
|
|
# function repository.get_SRPMS_name()
|
|
|
|
# get the full name of the first SRPMS package found using as
|
|
|
|
# package name '$@' and looking in the given list of repositories.
|
|
|
|
# The full names are saved in the vector 'got_SPEC_FILENAME[]'.
|
|
|
|
# The URL where the files have been found is saved in the variables
|
|
|
|
# 'got_SPEC_FILENAME_URL', and the index corresponding to this URL
|
|
|
|
# is saved in 'got_SPEC_FILENAME_URL_LEVEL' (eventually set via the
|
|
|
|
# '--urlnum' option)
|
|
|
|
# args:
|
|
|
|
# -r,--urllist : list of urls where to check for packages
|
|
|
|
# -n,--urlnum : the url number where to look at
|
|
|
|
# -p,--proxy : proxy server
|
|
|
|
# -u,--proxy-user : proxy user
|
|
|
|
# -l,--user : login user (for repositories that require authentication)
|
|
|
|
# $@ : list of package names to find for
|
|
|
|
# return value:
|
|
|
|
# 0 on success, 1 otherwise
|
|
|
|
function repository.get_SRPMS_name() {
|
|
|
|
local ARGS
|
2012-01-02 21:16:48 +01:00
|
|
|
ARGS=`LC_ALL=C getopt \
|
2011-04-26 21:39:44 +02:00
|
|
|
-o n:r:p:u: \
|
|
|
|
--long urlnum:,urllist:,proxy:,proxy-user:,user: \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local i urlnum urllist proxy proxy_user user
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-n|--urlnum)
|
|
|
|
urlnum="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: urlnum = \"$urlnum\""
|
|
|
|
;;
|
|
|
|
-r|--urllist)
|
|
|
|
urllist=($2); shift
|
|
|
|
for i in `seq 1 1 ${#urllist[*]}`; do
|
|
|
|
notify.debug "$FUNCNAME: urllist[$(($i-1))] = ${urllist[$i-1]}"
|
|
|
|
done
|
|
|
|
;;
|
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
-l|--user)
|
|
|
|
user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: user = \"$user\""
|
|
|
|
;;
|
|
|
|
--) shift; break ;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "$urlnum" ]; then
|
|
|
|
[[ "$urlnum" =~ ^[0-9]+$ ]] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: urlnum: "$"not a number"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# this can be the result of a buggy configuration file
|
|
|
|
# [ "$urllist" ] || notify.error $"\
|
|
|
|
#(bug)"" -- $FUNCNAME: urllist: "$"unset"
|
|
|
|
|
|
|
|
local pck_names="$@"
|
|
|
|
notify.debug "$FUNCNAME: pck_names = \"${pck_names[@]}\""
|
|
|
|
[ "$pck_names" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
# FIXME: 'curl_opts_netlink' is an external variable
|
|
|
|
local curlopts="\
|
|
|
|
-L --silent --list-only $curl_opts_netlink\
|
|
|
|
${user:+ --user $user}\
|
|
|
|
${proxy:+ --proxy $proxy}${proxy_user:+ --proxy-user $proxy_user}"
|
|
|
|
|
|
|
|
local curlopts_debug="\
|
|
|
|
-L --silent --list-only $curl_opts_netlink\
|
|
|
|
${user:+ --user ***}\
|
|
|
|
${proxy:+ --proxy ***}${proxy_user:+ --proxy-user ***}"
|
|
|
|
|
|
|
|
local flist currflist currurl
|
|
|
|
local errors=0
|
|
|
|
let "i = 0"
|
|
|
|
for currurl in ${urllist[*]}; do
|
|
|
|
# get the list of files from the repository
|
|
|
|
notify.note $"\
|
|
|
|
getting list of files from"" \`${NOTE}$currurl/${NORM}'..."
|
|
|
|
|
|
|
|
case $currurl in
|
2019-11-02 15:58:49 +01:00
|
|
|
ftp://*|http://*|https://*) ;;
|
2011-04-26 21:39:44 +02:00
|
|
|
*) notify.warning $"unsupported query type for this protocol"
|
|
|
|
let "errors += 1"
|
|
|
|
continue ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
currflist="$(mktemp -q -t flist.XXXXXXXX)" ||
|
|
|
|
notify.error $"can't create temporary files"
|
|
|
|
notify.debug "$FUNCNAME: currflist = $currflist"
|
|
|
|
|
|
|
|
# NOTE: the trailing slash is necessary, do not remove it
|
|
|
|
notify.debug "$FUNCNAME: curl $curlopts_debug --url $currurl/ -o $currflist"
|
|
|
|
curl $curlopts --url $currurl/ -o $currflist
|
|
|
|
let "retval = $?"
|
|
|
|
notify.debug "$FUNCNAME: curl return code: $retval"
|
|
|
|
|
|
|
|
case "$retval" in
|
2024-06-09 14:25:32 +02:00
|
|
|
0) sed -i 's/\x0D$//;/%2B/+/g' $currflist
|
2011-04-26 21:39:44 +02:00
|
|
|
flist[$i]="$currflist" ;;
|
|
|
|
6) notify.warning $"couldn't resolve host"
|
|
|
|
let "errors += 1" ;;
|
|
|
|
7) notify.warning $"failed to connect to host"
|
|
|
|
let "errors += 1" ;;
|
|
|
|
56) notify.warning $"failure in receiving network data"
|
|
|
|
let "errors += 1" ;;
|
|
|
|
*) notify.warning $"curl error (exit code: $retval)"
|
|
|
|
let "errors += 1" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
[ -s "$currflist" ] || notify.warning $"cannot get the list of files"
|
|
|
|
|
|
|
|
let "i += 1"
|
|
|
|
done
|
|
|
|
[ "$errors" = "${#urllist[@]}" ] && return 1
|
|
|
|
|
|
|
|
local pck_name level
|
|
|
|
for pck_name in ${pck_names[@]}; do
|
|
|
|
let "level = ${urlnum:-0}"
|
|
|
|
let "i = 0"
|
|
|
|
for currurl in ${urllist[*]}; do
|
|
|
|
notify.debug "$FUNCNAME: pck_name = $pck_name"
|
|
|
|
|
|
|
|
if [ -s "${flist[$i]}" ]; then
|
2012-04-25 23:07:55 +02:00
|
|
|
case $currurl in
|
|
|
|
ftp://*)
|
|
|
|
got_SPEC_FILENAME=($(\
|
|
|
|
repository.get_srpm_pckname_from_site --ftp "$pck_name" "${flist[$i]}"))
|
|
|
|
;;
|
2019-11-02 15:58:49 +01:00
|
|
|
http://*|https://*)
|
2012-04-25 23:07:55 +02:00
|
|
|
got_SPEC_FILENAME=($(\
|
|
|
|
repository.get_srpm_pckname_from_site --html "$pck_name" "${flist[$i]}"))
|
|
|
|
;;
|
|
|
|
esac
|
2011-04-26 21:39:44 +02:00
|
|
|
|
|
|
|
[ "$got_SPEC_FILENAME" ] &&
|
|
|
|
{ notify.debug "\
|
2012-04-14 17:29:56 +02:00
|
|
|
$FUNCNAME: got_SPEC_FILENAME = ${got_SPEC_FILENAME[*]}"
|
2011-04-26 21:39:44 +02:00
|
|
|
got_SPEC_FILENAME_URL_LEVEL="$level"
|
|
|
|
got_SPEC_FILENAME_URL="$currurl"
|
|
|
|
break 2; }
|
|
|
|
fi
|
|
|
|
let "level += 1"
|
|
|
|
let "i += 1"
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
|
|
|
for i in ${!flist[@]}; do
|
|
|
|
notify.debug "$FUNCNAME: removing temporary file '${flist[$i]}'"
|
|
|
|
rm -f ${flist[$i]}
|
|
|
|
done
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
# function repository.get_RPMS_name()
|
|
|
|
# get the full name of the RPMS package '$1' looking at the
|
|
|
|
# repository '$1'.
|
|
|
|
# The full names are saved in the vector 'got_RPM_FILENAME[]'.
|
|
|
|
# args:
|
|
|
|
# $1 : URL where to check
|
|
|
|
# $2 .. $n : package names to look at
|
|
|
|
# -a,--archlist : list of supported architectures in the specified url
|
|
|
|
# -x,--exclude : exclude packages that match a given regexpr
|
|
|
|
# -c,--target-cpu : set the build architecture
|
|
|
|
# -p,--proxy : proxy server
|
|
|
|
# -u,--proxy-user : proxy user
|
|
|
|
# -l,--user : login user (for repositories that require authentication)
|
|
|
|
# return value:
|
|
|
|
# 0 on success, >0 otherwise
|
|
|
|
# example of output:
|
|
|
|
# got_RPM_FILENAME = (
|
|
|
|
# i586:mbrowse-0.3.1-1qilnx.i586.rpm
|
|
|
|
# i586:mbrowse-contrib-0.3.1-1qilnx.noarch.rpm
|
|
|
|
# ppc:mbrowse-contrib-0.3.1-1qilnx.noarch.rpm )
|
|
|
|
function repository.get_RPMS_name() {
|
2012-01-02 21:16:48 +01:00
|
|
|
ARGS=`LC_ALL=C getopt \
|
2011-04-26 21:39:44 +02:00
|
|
|
-o a:x:c:p:u: \
|
|
|
|
--long archlist:,exclude:,target-cpu:,proxy:,proxy-user:,user: \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
|
|
|
|
local archlist excludeopt proxy proxy_user user target_cpu
|
|
|
|
while :; do
|
|
|
|
case $1 in
|
|
|
|
-a|--archlist)
|
|
|
|
archlist="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: archlist = \"$archlist\""
|
|
|
|
;;
|
|
|
|
-x|--exclude)
|
|
|
|
excludeopt="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: excludeopt = \"$excludeopt\""
|
|
|
|
;;
|
|
|
|
-c|--target-cpu)
|
|
|
|
target_cpu="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: target_cpu = \"$target_cpu\""
|
|
|
|
;;
|
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
-l|--user)
|
|
|
|
user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: user = \"$user\""
|
|
|
|
;;
|
|
|
|
--) shift; break ;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
local scanurl="$1"
|
|
|
|
[ "$scanurl" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
shift
|
|
|
|
|
|
|
|
local pck_names="$@"
|
|
|
|
notify.debug "$FUNCNAME: pck_names = \"${pck_names[@]}\""
|
|
|
|
[ "$pck_names" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#2)"
|
|
|
|
|
|
|
|
[ "$archlist" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"no list of architectures set"" (\$archlist)"
|
|
|
|
|
|
|
|
local flist=`mktemp -q -t flist.XXXXXXXX` ||
|
|
|
|
notify.error $"can't create temporary files"
|
|
|
|
|
|
|
|
local curr_arch errors pck_name curr_match
|
|
|
|
let "errors = 0"
|
|
|
|
|
|
|
|
local curr_arch_list
|
|
|
|
case "$target_cpu" in
|
|
|
|
"") curr_arch_list=( $archlist ) ;;
|
|
|
|
"noarch")
|
|
|
|
#curr_arch_list=( ${arch_noarch_upload[*]} )
|
|
|
|
# FIXME : if the noarch directory cannot be found a warning
|
|
|
|
# message is displayed
|
|
|
|
curr_arch_list=( $archlist noarch )
|
|
|
|
;;
|
|
|
|
*) # if the architecture is set by the user do ignore packages
|
|
|
|
# built for other architectures (aka: please do not remove
|
|
|
|
# packages built for other architectures!)
|
|
|
|
curr_arch_list="$target_cpu"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
notify.debug "\
|
|
|
|
$FUNCNAME: curr_arch_list = ( ${curr_arch_list[*]} )"
|
|
|
|
|
|
|
|
# FIXME: 'curl_opts_netlink' is an external variable
|
|
|
|
local curlopts="\
|
|
|
|
-L --silent --list-only $curl_opts_netlink -o $flist\
|
|
|
|
${user:+ --user $user}\
|
|
|
|
${proxy:+ --proxy $proxy}${proxy_user:+ --proxy-user $proxy_user}"
|
|
|
|
|
|
|
|
local curlopts_debug="\
|
|
|
|
-L --silent --list-only $curl_opts_netlink -o $flist\
|
|
|
|
${user:+ --user ***}\
|
|
|
|
${proxy:+ --proxy ***}${proxy_user:+ --proxy-user ***}"
|
|
|
|
|
|
|
|
got_RPM_FILENAME=
|
|
|
|
for curr_arch in ${curr_arch_list[*]}; do
|
|
|
|
currurl="$(repository.resolveURL "$scanurl" "$curr_arch")"
|
|
|
|
#[ "$currurl" ] || notify.error $"(bug)"" -- $FUNCNAME: currurl = \"\""
|
|
|
|
|
|
|
|
# get the list of files from the repository
|
|
|
|
notify.note $"getting list of files from"" \`${NOTE}$currurl/${NORM}'..."
|
|
|
|
|
|
|
|
> $flist
|
|
|
|
|
|
|
|
# NOTE: the trailing slash is necessary, do not remote it
|
|
|
|
notify.debug "$FUNCNAME: curl $curlopts_debug --url $currurl/"
|
|
|
|
curl $curlopts --url $currurl/
|
|
|
|
let "retval = $?"
|
|
|
|
notify.debug "$FUNCNAME: curl return code: $retval"
|
|
|
|
case "$retval" in
|
|
|
|
0) ;;
|
|
|
|
6) notify.warning $"couldn't resolve host" ;;
|
|
|
|
7) notify.warning $"failed to connect to host" ;;
|
|
|
|
56) notify.warning $"failure in receiving network data" ;;
|
|
|
|
*) notify.warning $"curl error (exit code: $retval)" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if [ -s "$flist" ]; then
|
2024-06-09 14:25:32 +02:00
|
|
|
sed -i 's/\x0D$//;s/%2B/+/g' $flist
|
2011-04-26 21:39:44 +02:00
|
|
|
case $currurl in
|
2019-11-02 15:58:49 +01:00
|
|
|
ftp://*|http://*|https://*)
|
2011-04-26 21:39:44 +02:00
|
|
|
for pck_name in ${pck_names[@]}; do
|
|
|
|
got_RPM_FILENAME=( ${got_RPM_FILENAME[@]} $(\
|
|
|
|
if [ -n "$excludeopt" ]; then
|
|
|
|
sed -n "\
|
|
|
|
/<a href=\"/{s|.*<a href=\"\([^\"]*\)\".*|\1|;bm;};
|
|
|
|
/<A HREF=\"/{s|.*<A HREF=\"\([^\"]*\)\".*|\1|;bm;};
|
|
|
|
/^$pck_name-[^-]*-[^-]*\.rpm/bm;be;
|
|
|
|
:m;/^$pck_name-[^-]*-[^-]*\.rpm/{s,.*,$curr_arch:&,p}
|
|
|
|
:e" $flist | grep -v -- "$excludeopt"
|
|
|
|
else
|
|
|
|
sed -n "\
|
|
|
|
/<a href=\"/{s|.*<a href=\"\([^\"]*\)\".*|\1|;bm;};
|
|
|
|
/<A HREF=\"/{s|.*<A HREF=\"\([^\"]*\)\".*|\1|;bm;};
|
|
|
|
/^$pck_name-[^-]*-[^-]*\.rpm/bm;be;
|
|
|
|
:m;/^$pck_name-[^-]*-[^-]*\.rpm/{s,.*,$curr_arch:&,p}
|
|
|
|
:e" $flist
|
|
|
|
fi ))
|
|
|
|
done
|
|
|
|
;;
|
|
|
|
*) notify.warning $"unsupported query type for this protocol" ;;
|
|
|
|
esac
|
|
|
|
else
|
|
|
|
notify.warning $"cannot get the list of files"" ($curr_arch)"
|
|
|
|
let "errors += 1"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
rm -f $flist
|
|
|
|
|
|
|
|
notify.debug "$FUNCNAME: got_RPM_FILENAME = ( ""$(
|
|
|
|
for pck_name in ${got_RPM_FILENAME[@]}; do
|
|
|
|
echo -en "\n $pck_name"
|
|
|
|
done ) )"
|
|
|
|
|
|
|
|
return $errors
|
|
|
|
}
|
|
|
|
|
|
|
|
# function curl.download
|
|
|
|
# download a file from an internet address using curl
|
|
|
|
#
|
|
|
|
# args:
|
|
|
|
# -d,--destdir : target directory
|
|
|
|
# -f,--force : force download (optional, default: false)
|
|
|
|
# -n,--filenum : number to display when executing this functions several times
|
|
|
|
# -o,--options : extra options to pass to curl
|
|
|
|
# -x,--exit-on-err : terminate the script if the download fails
|
|
|
|
# -p,--proxy : proxy
|
|
|
|
# -u,--proxy-user : proxy user
|
|
|
|
# --debug-unsecure : print private informations in debug mode
|
|
|
|
# $@ : list of files to be downloaded
|
|
|
|
# return value:
|
|
|
|
# 0 on success, 1 otherwise
|
|
|
|
|
|
|
|
function curl.download() {
|
|
|
|
local ARGS
|
2012-01-02 21:16:48 +01:00
|
|
|
ARGS=`LC_ALL=C getopt \
|
2011-04-26 21:39:44 +02:00
|
|
|
-o d:fn:o:xp:u: \
|
|
|
|
--long destdir:,force,filenum:,options:,exit-on-err,proxy:,proxy-user: \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local destdir
|
|
|
|
local curl_opts
|
|
|
|
local exitonerror="0"
|
|
|
|
local force_download="0"
|
|
|
|
local proxy proxy_user
|
|
|
|
local filenum="1"
|
|
|
|
local is_a_localfile
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-d|--destdir)
|
|
|
|
destdir="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: destdir = \"$destdir\""
|
|
|
|
;;
|
|
|
|
-f|--force)
|
|
|
|
force_download=1
|
|
|
|
notify.debug "$FUNCNAME: force download is enabled"
|
|
|
|
;;
|
|
|
|
-n|--filenum)
|
|
|
|
filenum="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: filenum = \"$filenum\""
|
|
|
|
;;
|
|
|
|
-o|--options)
|
|
|
|
curl_opts="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: curl_opts = \"$curl_opts\""
|
|
|
|
;;
|
|
|
|
-x|--exit-on-err)
|
|
|
|
exitonerror="1"
|
|
|
|
notify.debug "$FUNCNAME: exitonerror = \"$exitonerror\""
|
|
|
|
;;
|
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
--) shift; break;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
# FIXME: add support for list of files
|
|
|
|
local file_url="$1"
|
|
|
|
notify.debug "$FUNCNAME: file_url = \"$file_url\""
|
|
|
|
[ "$file_url" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
[ "$destdir" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--destdir)"
|
|
|
|
|
|
|
|
local file_name
|
|
|
|
case "$file_url" in
|
|
|
|
http://*|https://*|ftp://*)
|
|
|
|
file_name="${file_url##*/}"
|
|
|
|
is_a_localfile="0" ;;
|
|
|
|
*://*)
|
|
|
|
notify.error $"unsupported protocol"": \`${file_url//\:*}'"
|
|
|
|
;;
|
|
|
|
*) #notify.error $"not an internet address"": \`$file_url'"
|
|
|
|
# it's a local file
|
|
|
|
[ -e "$destdir/$file_url" ] ||
|
|
|
|
notify.error $"file not found"": \`$destdir/$file_url'"
|
|
|
|
notify.note "[${filenum:-*}] $NOTE$file_url$NORM ... "$"skipped"
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if [ -e $destdir/$file_name ]; then
|
|
|
|
if [ "$force_download" = "0" ]; then
|
|
|
|
notify.note "[${filenum:-*}] $NOTE$file_url$NORM ... "$"skipped"
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
rm -f $destdir/$file_name
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
notify.note $"downloading"" ${NOTE}$file_name${NORM} ..."
|
|
|
|
|
|
|
|
[ -d "$destdir" ] ||
|
|
|
|
if [ "$exitonerror" = 1 ]; then
|
|
|
|
notify.warning $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"no such directory"": \`$destdir'"
|
|
|
|
return 1
|
|
|
|
else
|
|
|
|
notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"no such directory"": \`$destdir'"
|
|
|
|
fi
|
|
|
|
|
|
|
|
notify.note "\
|
|
|
|
[${filenum:-*}] $NOTE$file_url$NORM
|
|
|
|
--> $destdir/$file_name"
|
|
|
|
|
|
|
|
pushd $destdir >/dev/null
|
|
|
|
|
|
|
|
local retval
|
2012-10-20 12:28:30 +02:00
|
|
|
notify.debug "curl $curl_opts\
|
2011-04-26 21:39:44 +02:00
|
|
|
${proxy:+ --proxy $proxy}${proxyuser:+ --proxy-user $proxy_user} $file_url"
|
|
|
|
|
2012-10-20 12:28:30 +02:00
|
|
|
curl $curl_opts \
|
2011-04-26 21:39:44 +02:00
|
|
|
${proxy:+ --proxy $proxy} ${proxyuser:+ --proxy-user $proxy_user} \
|
|
|
|
"$file_url"
|
|
|
|
retval=$?
|
|
|
|
|
|
|
|
notify.debug "$FUNCNAME: curl return code: $retval"
|
|
|
|
case "$retval" in
|
|
|
|
0) ;;
|
|
|
|
6) notify.warning $"couldn't resolve host" ;;
|
|
|
|
7) notify.warning $"failed to connect to host" ;;
|
|
|
|
56) notify.warning $"failure in receiving network data" ;;
|
|
|
|
*) notify.warning $"curl error (exit code: $retval)" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
[ -e $destdir/$file_name ] ||
|
|
|
|
if [ "$exitonerror" = 1 ]; then
|
|
|
|
notify.error $"cannot download"": \`$file_name'"
|
|
|
|
else
|
|
|
|
popd >/dev/null
|
|
|
|
notify.warning $"cannot download"": \`$file_name'"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
popd >/dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
# function curl.upload
|
|
|
|
# upload a file using curl
|
|
|
|
#
|
|
|
|
function curl.upload() {
|
|
|
|
local ARGS
|
2012-01-02 21:16:48 +01:00
|
|
|
ARGS=`LC_ALL=C getopt \
|
2011-04-26 21:39:44 +02:00
|
|
|
-o f:l:o:p:u:x \
|
|
|
|
--long upload-file:,user:,options:,proxy:,proxy-user:,\
|
|
|
|
repository-alias:,exit-on-err,debug-unsecure \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local upfile user options proxy proxy_user
|
|
|
|
local exitonerror=0
|
|
|
|
local debug_unsecure=0
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-f|--upload-file)
|
|
|
|
upfile="$2"; shift
|
|
|
|
;;
|
|
|
|
-l|--user)
|
|
|
|
user="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: user = \"$user\""
|
|
|
|
;;
|
|
|
|
-o|--options)
|
|
|
|
options="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: options = \"$options\""
|
|
|
|
;;
|
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
-x|--exit-on-err)
|
|
|
|
exitonerror="1"
|
|
|
|
#notify.debug "$FUNCNAME: exitonerror = \"$exitonerror\""
|
|
|
|
;;
|
|
|
|
--debug-unsecure)
|
|
|
|
debug_unsecure="1"
|
|
|
|
;;
|
|
|
|
--) shift; break;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
#notify.debug "$FUNCNAME: debug_unsecure = \"$debug_unsecure\""
|
|
|
|
|
|
|
|
local destfile="$1"
|
|
|
|
[ "$destfile" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
[ -e "$upfile" ] || notify.error $"package not found"": \`$upfile'"
|
|
|
|
|
2012-08-28 23:55:09 +02:00
|
|
|
# FIXED: add an extra newline to workaroung a bug in curl
|
|
|
|
notify.note "\
|
2011-04-26 21:39:44 +02:00
|
|
|
* ${NOTE}$upfile${NORM}
|
|
|
|
--> $destfile"
|
|
|
|
|
|
|
|
# option: --write-out [%{url_effective}]\\n
|
|
|
|
# the option '--progress-bar' is currently buggy in curl
|
|
|
|
local curr_curl_cmd="$options --progress-bar --fail -o /dev/null \
|
|
|
|
${proxy:+ --proxy $proxy}${proxyuser:+ --proxy-user $proxy_user} \
|
|
|
|
--upload-file $upfile $destfile"
|
|
|
|
|
|
|
|
if [ "$debug_unsecure" = "1" ]; then
|
|
|
|
notify.debug "curl --user $user $curr_curl_cmd"
|
|
|
|
else
|
|
|
|
notify.debug "curl --user ***:*** $curr_curl_cmd"
|
|
|
|
fi
|
|
|
|
|
|
|
|
curl --user $user $curr_curl_cmd
|
|
|
|
[ $? -eq 0 ] || { [ "$exitonerror" = 1 ] && exit 1 || return 1; }
|
|
|
|
}
|
|
|
|
|
|
|
|
# function curl.ftp_command
|
|
|
|
# execute an ftp command (creating a directory, renamig a file,
|
|
|
|
# deleting) using curl
|
|
|
|
#
|
|
|
|
function curl.ftp_command() {
|
|
|
|
local ARGS
|
2012-01-02 21:16:48 +01:00
|
|
|
ARGS=`LC_ALL=C getopt \
|
2011-04-26 21:39:44 +02:00
|
|
|
-o l:o:p:u:a: \
|
|
|
|
--long user:,options:,proxy:,proxy-user:,debug-unsecure,\
|
|
|
|
action:,directory:,rename-from:,rename-to:,delete:,ftp-passive \
|
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local user options proxy proxy_user ftp_passive
|
|
|
|
local action directory fromfile tofile deletefile
|
|
|
|
local exitonerror=0
|
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-l|--user)
|
|
|
|
user="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: user = \"$user\""
|
|
|
|
;;
|
|
|
|
-o|--options)
|
|
|
|
options="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: options = \"$options\""
|
|
|
|
;;
|
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
#notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
--debug-unsecure)
|
|
|
|
debug_unsecure="1"
|
|
|
|
;;
|
|
|
|
-a|--action)
|
|
|
|
action="$2"; shift
|
|
|
|
;;
|
|
|
|
--directory)
|
|
|
|
directory="$2"; shift
|
|
|
|
;;
|
|
|
|
--rename-from)
|
|
|
|
fromfile="$2"; shift
|
|
|
|
;;
|
|
|
|
--rename-to)
|
|
|
|
tofile="$2"; shift
|
|
|
|
;;
|
|
|
|
--delete)
|
|
|
|
deletefile="$2"; shift
|
|
|
|
;;
|
|
|
|
--ftp-passive)
|
|
|
|
ftp_passive="--ftp-pasv"
|
|
|
|
;;
|
|
|
|
-x|--exit-on-err)
|
|
|
|
exitonerror="1"
|
|
|
|
;;
|
|
|
|
--) shift; break;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
local backup_ftp_server="$1"
|
|
|
|
[ "$backup_ftp_server" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
[ "$ftp_passive" ] && options="$options $ftp_passive"
|
|
|
|
|
2022-06-10 16:13:34 +02:00
|
|
|
[ "${1:0:4}" == "http" ] && http_mode=1
|
|
|
|
|
2011-04-26 21:39:44 +02:00
|
|
|
# NOTE: see RFC959 for the sintax of the 'quote' commands
|
|
|
|
# curl --ftp-pasv --user user:password \
|
|
|
|
# -Q "MKD /devel/old/prova.dir" \
|
|
|
|
# -Q "RNFR /devel/old/prova.tmp" \
|
|
|
|
# -Q "RNTO /devel/old/prova.dir/prova.tmp" ftp.linuxdistro.org
|
|
|
|
case "$action" in
|
|
|
|
mkdir)
|
|
|
|
[ "$directory" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--directory)"
|
|
|
|
|
2022-06-10 16:13:34 +02:00
|
|
|
if [ "$http_mode" == "1" ]; then
|
|
|
|
notify.debug "\
|
|
|
|
curl $options --user \"***:***\" -X MKCOL $1${directory}/"
|
|
|
|
curl $options --user "$user" -X MKCOL $1${directory}/ &>/dev/null
|
|
|
|
else
|
|
|
|
notify.debug "\
|
|
|
|
curl $options --user \"***:***\" --quote \"MKD $directory\" $1"
|
|
|
|
curl $options --user "$user" --quote "MKD $directory" $1 &>/dev/null
|
|
|
|
fi
|
2011-04-26 21:39:44 +02:00
|
|
|
;;
|
|
|
|
rename-file)
|
|
|
|
[ "$fromfile" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--rename-from)"
|
|
|
|
[ "$tofile" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--rename-to)"
|
|
|
|
|
2022-06-10 16:13:34 +02:00
|
|
|
if [ "$http_mode" == "1" ]; then
|
|
|
|
notify.debug "curl $options --user \"***:***\" -X MOVE\
|
|
|
|
--header \"Destination:$1$tofile\" $1$fromfile"
|
|
|
|
curl $options --user "$user" -X MOVE \
|
|
|
|
--header "Destination:$1$tofile" $1$fromfile &>/dev/null
|
|
|
|
else
|
|
|
|
notify.debug "curl $options --user \"***:***\"\
|
|
|
|
--quote \"RNFR $fromfile\" --quote \"RNTO $tofile\" $1"
|
|
|
|
curl $options --user "$user" \
|
|
|
|
--quote "RNFR $fromfile" --quote "RNTO $tofile" $1 &>/dev/null
|
|
|
|
fi
|
2011-04-26 21:39:44 +02:00
|
|
|
;;
|
|
|
|
delete)
|
|
|
|
[ "$deletefile" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--delete)"
|
|
|
|
|
|
|
|
# example:
|
|
|
|
# curl -v --ftp-pasv --user "$user" \
|
|
|
|
# --quote "CWD SRPMS.base" \
|
|
|
|
# --quote "DELE filename-0.0.1-1distro.src.rpm" \
|
|
|
|
# ftp://ftpaccounts.openmamba.org
|
|
|
|
# -or-
|
|
|
|
# curl -v --ftp-pasv --user "$user" \
|
|
|
|
# --quote "DELE SRPMS.base/filename-0.0.1-1distro.src.rpm" \
|
|
|
|
# ftp://ftpaccounts.openmamba.org
|
2022-06-10 16:13:34 +02:00
|
|
|
if [ "$http_mode" == "1" ]; then
|
|
|
|
notify.debug "\
|
|
|
|
curl $options --user \"***:***\" -X DELETE $1$deletefile"
|
|
|
|
curl $options --user "$user" -X DELETE $1$deletefile &>/dev/null
|
|
|
|
else
|
|
|
|
notify.debug "\
|
2011-04-26 21:39:44 +02:00
|
|
|
curl $options --user \"***:***\" --quote \"DELE $deletefile\" $1"
|
2022-06-10 16:13:34 +02:00
|
|
|
curl $options --user "$user" --quote "DELE $deletefile" $1 &>/dev/null
|
|
|
|
fi
|
2011-04-26 21:39:44 +02:00
|
|
|
;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"unknown action"": ($action)"
|
|
|
|
esac
|
|
|
|
retval=$?
|
|
|
|
|
|
|
|
case "$retval" in
|
|
|
|
0) ;;
|
|
|
|
6) notify.warning $"couldn't resolve host" ;;
|
|
|
|
7) notify.warning $"failed to connect to host" ;;
|
|
|
|
*) notify.warning $"curl error (exit code: $retval)" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
[[ "$retval" != "0" && "$exitonerror" = 1 ]] && exit 1
|
|
|
|
}
|
2012-04-24 22:39:23 +02:00
|
|
|
|
2012-10-29 22:55:49 +01:00
|
|
|
# function git.download
|
|
|
|
# helper for creating a tarball from a git repository
|
|
|
|
# args:
|
|
|
|
# -d, --destdir : target directory
|
|
|
|
# -p, --proxy : proxy server
|
|
|
|
# -u, --proxy-user : proxy user
|
2020-06-22 11:00:33 +02:00
|
|
|
# --preserve-dot-git : do not remove .git files
|
2012-10-29 22:55:49 +01:00
|
|
|
# $@ : git repository
|
|
|
|
#
|
|
|
|
# return value:
|
|
|
|
# 0
|
|
|
|
|
|
|
|
function git.download() {
|
|
|
|
local ARGS
|
|
|
|
ARGS=`LC_ALL=C getopt \
|
2020-06-22 11:00:33 +02:00
|
|
|
-o d:v:p:u:k \
|
|
|
|
--long destdir:,pck-version:,proxy:,proxy-user:,preserve-dot-git: \
|
2012-10-29 22:55:49 +01:00
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local destdir
|
|
|
|
local proxy proxy_user
|
2012-10-30 23:17:59 +01:00
|
|
|
local pck_version
|
2020-06-22 11:00:33 +02:00
|
|
|
local preserve_dot_git=0
|
2012-10-29 22:55:49 +01:00
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-d|--destdir)
|
|
|
|
destdir="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: destdir = \"$destdir\""
|
|
|
|
;;
|
2012-10-30 23:17:59 +01:00
|
|
|
-v|--pck-version)
|
|
|
|
pck_version="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: pck_version = \"$pck_version\""
|
|
|
|
;;
|
2012-10-29 22:55:49 +01:00
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
2020-06-22 11:00:33 +02:00
|
|
|
--preserve-dot-git)
|
|
|
|
preserve_dot_git="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: preserve_dot_git = \"$preserve_dot_git\""
|
|
|
|
;;
|
2012-10-29 22:55:49 +01:00
|
|
|
--) shift; break;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
local giturl_and_branch="$1"
|
|
|
|
|
|
|
|
notify.debug "$FUNCNAME: giturl_and_branch = \"$giturl_and_branch\""
|
|
|
|
[ "$giturl_and_branch" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
[ "$destdir" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--destdir)"
|
|
|
|
|
|
|
|
local token_dirname="${giturl_and_branch%/*}"
|
|
|
|
local token_basename="${giturl_and_branch##*/}"
|
|
|
|
notify.debug "$FUNCNAME: token_dirname = \"$token_dirname\""
|
|
|
|
notify.debug "$FUNCNAME: token_basename = \"$token_basename\""
|
|
|
|
|
2015-09-26 15:00:22 +02:00
|
|
|
local git_branch="${token_dirname/*\/}"
|
2012-10-29 22:55:49 +01:00
|
|
|
notify.debug "$FUNCNAME: git_branch = \"$git_branch\""
|
|
|
|
|
|
|
|
git.create_tarball \
|
2012-10-30 23:17:59 +01:00
|
|
|
--pck-version "$pck_version" \
|
2012-10-29 22:55:49 +01:00
|
|
|
--destdir "$destdir" \
|
2020-06-22 11:00:33 +02:00
|
|
|
--preserve-dot-git "${preserve_dot_git}" --git-branch "$git_branch" \
|
2016-07-05 22:45:45 +02:00
|
|
|
"${token_dirname/\/$git_branch*}"
|
2012-10-29 22:55:49 +01:00
|
|
|
}
|
|
|
|
|
2022-01-06 14:20:26 +01:00
|
|
|
# function git.urldecode
|
|
|
|
# url decodes a given string
|
|
|
|
function git.urldecode() { : "${*//+/ }"; echo -e "${_//%/\\x}"; }
|
|
|
|
|
2012-04-24 22:39:23 +02:00
|
|
|
# function git.create_tarball
|
|
|
|
# clone a git repository and convert is into a tarball file
|
2022-01-06 14:20:26 +01:00
|
|
|
#
|
2012-04-24 22:39:23 +02:00
|
|
|
# args:
|
2012-09-19 19:27:50 +02:00
|
|
|
# -d,--destdir : target directory
|
2014-08-20 21:00:14 +02:00
|
|
|
# -v,--pck-version : package version
|
2012-09-19 19:27:50 +02:00
|
|
|
# --git-branch : git branch
|
|
|
|
# --preserve-dot-git : do not remove .git files
|
|
|
|
# $@ : git repository
|
2012-04-24 22:39:23 +02:00
|
|
|
#
|
|
|
|
# return value:
|
|
|
|
# 0
|
|
|
|
#
|
2012-10-30 23:17:59 +01:00
|
|
|
# set: spec_source, spec_source_comment, pck_tarball
|
2012-04-24 22:39:23 +02:00
|
|
|
|
|
|
|
function git.create_tarball() {
|
|
|
|
local ARGS
|
2012-10-30 23:17:59 +01:00
|
|
|
ARGS=`LC_ALL=C getopt -o d:v:p:u: \
|
|
|
|
--long destdir:,pck-version:,git-branch:,preserve-dot-git:,proxy:,proxy-user:\
|
2012-04-24 22:39:23 +02:00
|
|
|
-n "$FUNCNAME" -- "$@"`
|
|
|
|
[ $? = 0 ] || notify.error $"(bug)"" -- $FUNCNAME: "$"\`getopt' error"
|
|
|
|
|
|
|
|
local destdir
|
2012-04-25 23:07:55 +02:00
|
|
|
# FIXME: add support for proxy
|
2012-04-29 00:10:30 +02:00
|
|
|
# HINT: git config --global http.proxy http://user:pwd@proxy.srv.com:port
|
|
|
|
# see: http://bardofschool.blogspot.fr/2008/11/use-git-behind-proxy.html
|
2012-04-24 22:39:23 +02:00
|
|
|
local proxy proxy_user
|
2012-09-19 19:27:50 +02:00
|
|
|
local git_branch
|
2019-10-27 15:18:42 +01:00
|
|
|
local git_commit
|
2012-09-19 19:27:50 +02:00
|
|
|
local preserve_dot_git=0
|
2012-10-30 23:17:59 +01:00
|
|
|
local pck_version
|
2012-04-24 22:39:23 +02:00
|
|
|
|
|
|
|
eval set -- "$ARGS"
|
|
|
|
while :; do
|
|
|
|
case "$1" in
|
|
|
|
-d|--destdir)
|
|
|
|
destdir="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: destdir = \"$destdir\""
|
|
|
|
;;
|
2012-10-30 23:17:59 +01:00
|
|
|
-v|--pck-version)
|
|
|
|
pck_version="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: pck_version = \"$pck_version\""
|
|
|
|
;;
|
2012-09-19 19:27:50 +02:00
|
|
|
--git-branch)
|
2022-01-06 14:20:26 +01:00
|
|
|
git_branch="`git.urldecode "$2"`"; shift
|
2019-10-27 15:18:42 +01:00
|
|
|
if [ "${git_branch/@*}" != "${git_branch}" ]; then
|
|
|
|
git_commit="${git_branch/*@}"
|
|
|
|
git_branch="${git_branch/@*}"
|
2024-02-08 17:23:01 +01:00
|
|
|
if [ ! "${git_commit}" ]; then
|
|
|
|
notify.error "$FUNCNAME: cannot checkout empty commit"
|
|
|
|
fi
|
2019-10-27 15:18:42 +01:00
|
|
|
fi
|
2012-09-19 19:27:50 +02:00
|
|
|
notify.debug "$FUNCNAME: git_branch = \"$git_branch\""
|
2019-10-27 15:18:42 +01:00
|
|
|
if [ "${git_commit}" ]; then
|
|
|
|
notify.debug "$FUNCNAME: git_commit = \"$git_commit\""
|
|
|
|
fi
|
2012-09-19 19:27:50 +02:00
|
|
|
;;
|
|
|
|
--preserve-dot-git)
|
|
|
|
preserve_dot_git="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: preserve_dot_git = \"$preserve_dot_git\""
|
|
|
|
;;
|
2012-04-24 22:39:23 +02:00
|
|
|
-p|--proxy)
|
|
|
|
proxy="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy = \"$proxy\""
|
|
|
|
;;
|
|
|
|
-u|--proxy-user)
|
|
|
|
proxy_user="$2"; shift
|
|
|
|
notify.debug "$FUNCNAME: proxy_user = \"$proxy_user\""
|
|
|
|
;;
|
|
|
|
--) shift; break;;
|
|
|
|
*) notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"\`getopt' error: bad command \`$1'" ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
local git_repository="$1"
|
|
|
|
notify.debug "$FUNCNAME: git_repository = \"$git_repository\""
|
|
|
|
[ "$git_repository" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (#1)"
|
|
|
|
|
|
|
|
[ "$destdir" ] || notify.error $"\
|
|
|
|
(bug)"" -- $FUNCNAME: "$"missing mandatory arg"" (--destdir)"
|
|
|
|
|
2012-10-31 22:01:49 +01:00
|
|
|
local today="$(date "+%Y%m%d")"
|
|
|
|
if [ "$pck_version" ]; then
|
|
|
|
[ "$pck_version" = "${today}git" ] || notify.warning "\
|
2012-10-31 22:11:49 +01:00
|
|
|
${NOTE}${pck_version}${NORM}: "$"\
|
2012-10-31 22:01:49 +01:00
|
|
|
not the expected package version"" (${NOTE}${today}git${NORM})..."
|
|
|
|
else
|
|
|
|
pck_version="${today}git"
|
|
|
|
notify.debug "$FUNCNAME: pck_version = \"$pck_version\""
|
|
|
|
fi
|
2012-10-30 23:17:59 +01:00
|
|
|
|
2014-12-14 22:31:27 +01:00
|
|
|
type -p git &>/dev/null ||
|
2012-04-24 22:39:23 +02:00
|
|
|
notify.error $"utility not found"": \`git'"
|
|
|
|
|
|
|
|
local tmpgitdir=$(mktemp -q -d -t tmpgit.XXXXXXXX)
|
|
|
|
[ $? -eq 0 ] ||
|
|
|
|
notify.error $"can't create temporary files"
|
|
|
|
notify.debug "$FUNCNAME: tmpgitdir = $tmpgitdir"
|
|
|
|
|
|
|
|
pushd $tmpgitdir &>/dev/null
|
|
|
|
|
|
|
|
# create a tarball by cloning the git repository
|
|
|
|
notify.note \
|
2012-09-19 19:27:50 +02:00
|
|
|
"${NOTE}"$"cloning git repository""\
|
|
|
|
<$git_repository> ${git_branch:+($git_branch)}${NORM}""..."
|
2019-10-27 15:18:42 +01:00
|
|
|
if [ "$preserve_dot_git" = "0" -a "${git_repository:0:4}" != "http" -a ! "${git_commit}" ]; then
|
2017-10-31 16:57:10 +01:00
|
|
|
notify.debug "$FUNCNAME: git clone --recursive --depth=1 ${git_branch:+-b $git_branch} \"$git_repository\""
|
|
|
|
git clone --recursive --depth=1 ${git_branch:+-b $git_branch} "$git_repository"
|
2012-10-13 19:23:40 +02:00
|
|
|
else
|
2017-10-31 16:57:10 +01:00
|
|
|
notify.debug "$FUNCNAME: git clone --recursive ${git_branch:+-b $git_branch} \"$git_repository\""
|
|
|
|
git clone --recursive ${git_branch:+-b $git_branch} "$git_repository"
|
2012-10-13 19:23:40 +02:00
|
|
|
fi
|
2012-04-24 22:39:23 +02:00
|
|
|
[ $? -eq 0 ] ||
|
|
|
|
{ popd &>/dev/null
|
|
|
|
rm -fr $tmpgitdir
|
|
|
|
notify.error $"cannot clone git repository"; }
|
|
|
|
|
|
|
|
pck_tarball="$(find -mindepth 1 -maxdepth 1 -type d -printf "%f")"
|
|
|
|
|
2019-10-27 15:18:42 +01:00
|
|
|
if [ "${git_commit}" ]; then
|
|
|
|
cd ${pck_tarball}
|
2024-02-08 17:23:01 +01:00
|
|
|
git checkout ${git_commit} || {
|
|
|
|
popd &>/dev/null
|
|
|
|
rm -fr $tmpgitdir
|
|
|
|
notify.error $"cannot checkout the specified tag";
|
|
|
|
}
|
2019-10-27 15:18:42 +01:00
|
|
|
cd ..
|
|
|
|
fi
|
|
|
|
|
2012-09-19 19:27:50 +02:00
|
|
|
if [ "$preserve_dot_git" = "0" ]; then
|
|
|
|
# remove git files
|
|
|
|
rm -fr $pck_tarball/.git
|
|
|
|
rm -f $pck_tarball/.gitignore
|
|
|
|
rm -f $pck_tarball/.gitmodules
|
|
|
|
fi
|
2012-04-24 22:39:23 +02:00
|
|
|
|
|
|
|
mv $pck_tarball ${pck_tarball}-${pck_version}
|
|
|
|
pck_tarball="${pck_tarball}-${pck_version}"
|
|
|
|
|
|
|
|
# create a compressed tarball
|
2012-10-13 19:34:16 +02:00
|
|
|
# FIXME: why bzip2? The compression tool used here should be configurable
|
2012-10-13 19:43:58 +02:00
|
|
|
notify.note "${NOTE}"$"creating the compressed source tarball""${NORM}..."
|
2012-04-24 22:39:23 +02:00
|
|
|
tar -cvf ${pck_tarball}.tar $pck_tarball/ >/dev/null &&
|
|
|
|
bzip2 ${pck_tarball}.tar &&
|
|
|
|
mv ${pck_tarball}.tar.bz2 $destdir/
|
2012-10-30 23:17:59 +01:00
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
notify.note "\
|
|
|
|
...${NOTE}"$"done""${NORM}: \`${NOTE}${pck_tarball}.tar.bz2${NORM}'"
|
|
|
|
else
|
|
|
|
popd &>/dev/null
|
2012-04-24 22:39:23 +02:00
|
|
|
rm -fr $tmpgitdir
|
|
|
|
notify.error $"\
|
2012-10-30 23:17:59 +01:00
|
|
|
an error occurred while creating"": ${pck_tarball}.tar.bz2"
|
|
|
|
fi
|
2012-04-24 22:39:23 +02:00
|
|
|
|
|
|
|
spec_source="${pck_tarball}.tar.bz2"
|
2012-10-02 23:06:47 +02:00
|
|
|
notify.debug "$FUNCNAME: spec_source = $spec_source"
|
2012-09-19 19:27:50 +02:00
|
|
|
spec_source_comment="\
|
2012-10-02 21:14:04 +02:00
|
|
|
## GITSOURCE $git_repository${git_branch:+ $git_branch}"
|
2012-10-02 23:06:47 +02:00
|
|
|
notify.debug "$FUNCNAME: spec_source_comment = \"$spec_source_comment\""
|
2012-04-24 22:39:23 +02:00
|
|
|
pck_tarball="$destdir/${spec_source}"
|
2012-10-02 23:06:47 +02:00
|
|
|
notify.debug "$FUNCNAME: pck_tarball = $pck_tarball"
|
2012-04-24 22:39:23 +02:00
|
|
|
|
|
|
|
popd &>/dev/null
|
|
|
|
rm -fr $tmpgitdir
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
2012-11-25 15:54:34 +01:00
|
|
|
|
|
|
|
} # endif $libnetwork_is_loaded
|