Compare commits
14 Commits
Author | SHA1 | Date | |
---|---|---|---|
b8640997ee | |||
b0d56bc0ea | |||
f940ec6905 | |||
85cf56afc5 | |||
795078cb2b | |||
30ff0776d6 | |||
d0c5fdfcae | |||
71f6a3e256 | |||
9695ac5418 | |||
909fc31f46 | |||
fcb4c6bdb0 | |||
94a38ffd73 | |||
03d29593f5 | |||
a1f8c5b55f |
2
LICENSE
2
LICENSE
@@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2014, Jack L. Frost <fbt@fleshless.org>
|
Copyright (c) 2012-2014, Jack L. Frost <fbt@fleshless.org>
|
||||||
|
|
||||||
|
|
||||||
Permission to use, copy, modify, and/or distribute this software for any purpose with or without
|
Permission to use, copy, modify, and/or distribute this software for any purpose with or without
|
||||||
|
99
sup
99
sup
@@ -4,18 +4,20 @@
|
|||||||
# About:
|
# About:
|
||||||
# A simple upload script for ZFH (http://zerofiles.org)
|
# A simple upload script for ZFH (http://zerofiles.org)
|
||||||
|
|
||||||
|
_self="${0##*/}"
|
||||||
|
|
||||||
cfg_url_regex='^[A-Za-z]([A-Za-z0-9+.-]+)?://.+'
|
cfg_url_regex='^[A-Za-z]([A-Za-z0-9+.-]+)?://.+'
|
||||||
cfg_tmp_dir="/tmp/$USER/sup"; TEMPDIR="$cfg_tmp_dir"
|
cfg_tmp_dir="/tmp/$USER/sup"; TEMPDIR="$cfg_tmp_dir"
|
||||||
cfg_script_url='https://zfh.so/upload'
|
cfg_script_url='https://zfh.so/upload'
|
||||||
cfg_screenshot_ext='png'
|
cfg_screenshot_ext='png'
|
||||||
|
|
||||||
[[ -f $HOME/.suprc ]] && { source $HOME/.suprc; }
|
[[ -f $HOME/.suprc ]] && { source "$HOME/.suprc"; }
|
||||||
|
|
||||||
sup.msg() { echo "[sup] $1"; }
|
sup.msg() { printf '%s\n' "[sup] $1"; }
|
||||||
sup.err() { sup.msg "(error) $1" >&2; }
|
sup.err() { sup.msg "(error) $1" >&2; }
|
||||||
|
|
||||||
sup.usage() {
|
sup.usage() {
|
||||||
echo "Usage: `basename $0` [-RsF] [-D num] [file/url]"
|
printf '%s\n' "Usage: ${_self} [-RsF] [-D num] [file/url]"
|
||||||
}
|
}
|
||||||
|
|
||||||
sup.env() {
|
sup.env() {
|
||||||
@@ -32,7 +34,7 @@ sup.upload() {
|
|||||||
-F submit="" \
|
-F submit="" \
|
||||||
"$cfg_script_url" -sL -A 'zerofiles.org upload script' || { return 1; }
|
"$cfg_script_url" -sL -A 'zerofiles.org upload script' || { return 1; }
|
||||||
|
|
||||||
[[ "$flag_rm" ]] && { rm "$file"; }
|
(( "$flag_rm" )) && { rm "$file"; }
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
@@ -43,19 +45,19 @@ sup.mktemp() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "$1"
|
printf '%s\n' "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
sup.scrot() {
|
sup.scrot() {
|
||||||
local tmp_file
|
declare tmp_file
|
||||||
|
|
||||||
[[ "$scrot_exec" ]] || { scrot_exec=`which scrot`; }
|
[[ "$scrot_exec" ]] || { scrot_exec=$(type -P scrot); }
|
||||||
[[ "$scrot_exec" ]] || {
|
[[ "$scrot_exec" ]] || {
|
||||||
sup.err "Please install scrot to use this function"
|
sup.err "Please install scrot to use this function"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
[[ "$flag_scrot_fullscreen" ]] || { scrot_args+=( '-s' ); }
|
(( "$flag_scrot_fullscreen" )) || { scrot_args+=( '-s' ); }
|
||||||
[[ "$cfg_scrot_delay" ]] && { scrot_args+=( "-d $cfg_scrot_delay" ); }
|
[[ "$cfg_scrot_delay" ]] && { scrot_args+=( "-d $cfg_scrot_delay" ); }
|
||||||
|
|
||||||
tmp_file="$(sup.mktemp "${cfg_tmp_dir}" ".${cfg_screenshot_ext}")"
|
tmp_file="$(sup.mktemp "${cfg_tmp_dir}" ".${cfg_screenshot_ext}")"
|
||||||
@@ -65,18 +67,13 @@ sup.scrot() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "$tmp_file"
|
printf '%s\n' "$tmp_file"
|
||||||
}
|
}
|
||||||
|
|
||||||
sup.exclude() {
|
sup.if_url() { printf '%s\n' "$1" | grep -oE "$cfg_url_regex" &>/dev/null; }
|
||||||
[[ "$2" ]] && { echo "$1"; return 1; }
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
sup.if_url() { echo "$1" | grep -oE "$cfg_url_regex" &>/dev/null; }
|
|
||||||
|
|
||||||
sup.mktemp() {
|
sup.mktemp() {
|
||||||
local tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1"
|
declare tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1"
|
||||||
|
|
||||||
[[ -d "$tmp_dir" ]] || {
|
[[ -d "$tmp_dir" ]] || {
|
||||||
sup.err "${tmp_dir} does not exist or is not a directory."
|
sup.err "${tmp_dir} does not exist or is not a directory."
|
||||||
@@ -87,35 +84,46 @@ sup.mktemp() {
|
|||||||
tmp_file_name="${RANDOM}${RANDOM}${tmp_file_name_extra}"
|
tmp_file_name="${RANDOM}${RANDOM}${tmp_file_name_extra}"
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "${tmp_dir}/${tmp_file_name}"
|
printf '%s\n' "${tmp_dir}/${tmp_file_name}"
|
||||||
}
|
}
|
||||||
|
|
||||||
sup.getopt() {
|
sup.set_argv() {
|
||||||
local keys
|
declare arg opt c
|
||||||
|
declare -g argv
|
||||||
|
|
||||||
for i in "$@"; do
|
while (( $# )); do
|
||||||
case "$i" in
|
unset -v arg opt c
|
||||||
--*) echo "$i";;
|
|
||||||
|
|
||||||
-*)
|
case "$1" in
|
||||||
keys=( `echo "${i##*-}" | fold -w1` )
|
(--) argv+=( "$1" ); break;;
|
||||||
|
|
||||||
[[ "${#keys[@]}" -gt 1 ]] && {
|
(--*)
|
||||||
for k in ${keys[@]}; do
|
IFS='=' read arg opt <<< "$1"
|
||||||
echo "-${k}"
|
argv+=( "$arg" )
|
||||||
done
|
|
||||||
} || {
|
[[ "$opt" ]] && {
|
||||||
echo "$i"
|
argv+=( "$opt" )
|
||||||
}
|
}
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*) echo "$i";;
|
(-*)
|
||||||
|
while read -n1 c
|
||||||
|
do
|
||||||
|
case "$c" in
|
||||||
|
-|'') :;;
|
||||||
|
*) argv+=( "-$c" );;
|
||||||
esac
|
esac
|
||||||
|
done <<< "$1"
|
||||||
|
;;
|
||||||
|
|
||||||
|
(*) argv+=( "$1" );;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
local args file target flag_private flag_rm flag_scrot flag_scrot_fullscreen cfg_scrot_delay
|
declare args file target flag_private flag_rm flag_scrot flag_scrot_fullscreen cfg_scrot_delay
|
||||||
|
|
||||||
while [[ "$1" ]]; do
|
while [[ "$1" ]]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
@@ -128,33 +136,44 @@ main() {
|
|||||||
|
|
||||||
-h|--help|--usage) sup.usage; return;;
|
-h|--help|--usage) sup.usage; return;;
|
||||||
|
|
||||||
--) break;;
|
--) shift; break;;
|
||||||
|
|
||||||
*) args+=( "$1" );;
|
*) break;;
|
||||||
esac
|
esac
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
sup.env
|
sup.env
|
||||||
|
|
||||||
if [[ "$flag_scrot" ]]; then
|
if (( flag_scrot )); then
|
||||||
file="$(sup.scrot)" || { return 1; }
|
file=$(sup.scrot) || { return 1; }
|
||||||
else
|
else
|
||||||
target="${args[0]}"; [[ "$target" ]] || { sup.usage; exit 1; }
|
(( $# )) || {
|
||||||
|
sup.usage
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
target="$1"
|
||||||
|
|
||||||
if sup.if_url "$target"; then
|
if sup.if_url "$target"; then
|
||||||
file=`sup.mktemp "$cfg_tmp_dir"`
|
file=$(sup.mktemp "$cfg_tmp_dir")
|
||||||
|
|
||||||
curl -s "$target" > "$file" || {
|
curl -skL "$target" > "$file" || {
|
||||||
sup.err "Could not download file."
|
sup.err "Could not download file."
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
file="$target"
|
file="$target"
|
||||||
|
|
||||||
|
[[ -f "$file" ]] || {
|
||||||
|
sup.err "No such file: ${file}"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sup.upload
|
sup.upload
|
||||||
}
|
}
|
||||||
|
|
||||||
main $(sup.getopt "$@")
|
sup.set_argv "$@"
|
||||||
|
main "${argv[@]}"
|
||||||
|
Reference in New Issue
Block a user