diff --git a/tools/consumedir/consumedir.sh b/tools/consumedir/consumedir.sh
index 22f336d1..3ee9f916 100755
--- a/tools/consumedir/consumedir.sh
+++ b/tools/consumedir/consumedir.sh
@@ -22,7 +22,7 @@ if [[ ${PIPESTATUS[0]} -ne 4 ]]; then
fi
OPTIONS=omhdp:vrmi
-LONGOPTS=once,distinct,help,delete,path:,verbose,recursive,dry,integration,iuser:,iheader:,poll:
+LONGOPTS=once,distinct,help,delete,path:,verbose,recursive,dry,integration,iuser:,iheader:,poll:,exclude:,include:
! PARSED=$(getopt --options=$OPTIONS --longoptions=$LONGOPTS --name "$0" -- "$@")
if [[ ${PIPESTATUS[0]} -ne 0 ]]; then
@@ -36,7 +36,7 @@ eval set -- "$PARSED"
declare -a watchdir
help=n verbose=n delete=n once=n distinct=n recursive=n dryrun=n
-integration=n iuser="" iheader="" poll=""
+integration=n iuser="" iheader="" poll="" exclude="" include=""
while true; do
case "$1" in
-h|--help)
@@ -88,6 +88,14 @@ while true; do
poll="$2"
shift 2
;;
+ --exclude)
+ exclude="$2"
+ shift 2
+ ;;
+ --include)
+ include="$2"
+ shift 2
+ ;;
--)
shift
break
@@ -106,29 +114,32 @@ showUsage() {
echo "Usage: $0 [options] url url ..."
echo
echo "Options:"
- echo " -v | --verbose Print more to stdout. (value: $verbose)"
- echo " -d | --delete Delete the file if successfully uploaded. (value: $delete)"
- echo " -p | --path
The directories to watch. This is required. (value: ${watchdir[@]})"
- echo " -h | --help Prints this help text. (value: $help)"
- echo " -m | --distinct Optional. Upload only if the file doesn't already exist. (value: $distinct)"
- echo " -o | --once Instead of watching, upload all files in that dir. (value: $once)"
- echo " --poll Run the script periodically instead of watching a directory. This can be"
- echo " used if watching via inotify is not possible."
- echo " -r | --recursive Traverse the directory(ies) recursively (value: $recursive)"
- echo " -i | --integration Upload to the integration endpoint. It implies -r. This puts the script in"
- echo " a different mode, where the first subdirectory of any given starting point"
- echo " is read as the collective name. The url(s) are completed with this name in"
- echo " order to upload files to the respective collective. So each directory"
- echo " given is expected to contain one subdirectory per collective and the urls"
- echo " are expected to identify the integration endpoint, which is"
- echo " /api/v1/open/integration/item/. (value: $integration)"
- echo " --iheader The header name and value to use with the integration endpoint. This must be"
- echo " in form 'headername:value'. Only used if '-i' is supplied."
- echo " (value: $iheader)"
- echo " --iuser The username and password for basic auth to use with the integration"
- echo " endpoint. This must be of form 'user:pass'. Only used if '-i' is supplied."
- echo " (value: $iuser)"
- echo " --dry Do a 'dry run', not uploading anything only printing to stdout (value: $dryrun)"
+ echo " -v | --verbose Print more to stdout. (value: $verbose)"
+ echo " -d | --delete Delete the file if successfully uploaded. (value: $delete)"
+ echo " -p | --path The directories to watch. This is required. (value: ${watchdir[@]})"
+ echo " -h | --help Prints this help text. (value: $help)"
+ echo " -m | --distinct Optional. Upload only if the file doesn't already exist. (value: $distinct)"
+ echo " -o | --once Instead of watching, upload all files in that dir. (value: $once)"
+ echo " --poll Run the script periodically instead of watching a directory. This can be"
+ echo " used if watching via inotify is not possible. (value: $poll)"
+ echo " -r | --recursive Traverse the directory(ies) recursively (value: $recursive)"
+ echo " -i | --integration Upload to the integration endpoint. It implies -r. This puts the script in"
+ echo " a different mode, where the first subdirectory of any given starting point"
+ echo " is read as the collective name. The url(s) are completed with this name in"
+ echo " order to upload files to the respective collective. So each directory"
+ echo " given is expected to contain one subdirectory per collective and the urls"
+ echo " are expected to identify the integration endpoint, which is"
+ echo " /api/v1/open/integration/item/. (value: $integration)"
+ echo " --iheader The header name and value to use with the integration endpoint. This must be"
+ echo " in form 'headername:value'. Only used if '-i' is supplied."
+ echo " (value: $iheader)"
+ echo " --iuser The username and password for basic auth to use with the integration"
+ echo " endpoint. This must be of form 'user:pass'. Only used if '-i' is supplied."
+ echo " (value: $iuser)"
+ echo " --exclude A shell glob pattern that is used to skip files that match (value: $exclude)."
+ echo " --include A shell glob pattern that is used to find files to upload (value: $include)."
+ echo " If --exclude and --include is given, both apply."
+ echo " --dry Do a 'dry run', not uploading anything only printing to stdout (value: $dryrun)"
echo ""
echo "Arguments:"
echo " A list of URLs to upload the files to."
@@ -367,13 +378,33 @@ runOnce() {
if [ "$recursive" = "y" ]; then
MD=""
fi
+ EXCL=""
+ if [ -n "$exclude" ]; then
+ EXCL="-not -name $exclude"
+ fi
+ INCL=""
+ if [ -n "$include" ]; then
+ INCL="-name $include"
+ fi
for dir in "${watchdir[@]}"; do
- find "$dir" $MD -type f -not -name ".*" -print0 | while IFS= read -d '' -r file; do
+ find "$dir" $MD -type f $INCL $EXCL -not -name ".*" -print0 | while IFS= read -d '' -r file; do
process "$file" "$dir"
done
done
}
+includeFile() {
+ file="$1"
+ if [ -n "$include" ] && [[ $file != $include ]]; then
+ trace "Skip $file due to include filter"
+ return 1
+ elif [ -n "$exclude" ] && [[ $file == $exclude ]]; then
+ trace "Skip $file due to exclude filter"
+ return 1
+ else
+ [[ "$file" != .* ]]
+ fi
+}
# warn if something seems not correctly configured
checkSetup
@@ -388,13 +419,13 @@ else
if [ -z "$poll" ]; then
$INOTIFY_CMD $REC -m --format '%w%f' -e close_write -e moved_to "${watchdir[@]}" |
while read pathfile; do
- if [[ "$(basename "$pathfile")" != .* ]]; then
+ if includeFile "$(basename "$pathfile")"; then
dir=$(findDir "$pathfile")
trace "The file '$pathfile' appeared below '$dir'"
sleep 1
process "$(realpath "$pathfile")" "$dir"
else
- trace "Skip hidden file $(realpath "$pathfile")"
+ trace "Skip file $(realpath "$pathfile")"
fi
done
else