6 Commits
1.4 ... 1.6.2

Author SHA1 Message Date
fbt
ee819a8629 8fw.eu 2015-10-19 00:35:04 +03:00
fbt
af0b52e575 always remove temporary files 2015-10-13 13:57:56 +03:00
fbt
1809fde7c9 use XDG! 2015-10-13 13:52:26 +03:00
fbt
e3d642a730 /ip support 2015-10-12 17:59:33 +03:00
fbt
b118e40f72 rm didn't work if the file was already uploaded 2015-07-05 17:14:27 +03:00
fbt
76952ee309 description support 2015-06-23 23:25:48 +03:00
2 changed files with 44 additions and 15 deletions

46
sup
View File

@@ -6,9 +6,14 @@
_self="${0##*/}" _self="${0##*/}"
# Defaults for XDG
if ! [[ "$XDG_RUNTIME_DIR" ]]; then
XDG_RUNTIME_DIR="/run/user/$UID"
fi
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="$XDG_RUNTIME_DIR/sup"; TEMPDIR="$cfg_tmp_dir"
cfg_service_url='https://zfh.so' cfg_service_url='https://8fw.eu'
cfg_screenshot_ext='png' cfg_screenshot_ext='png'
[[ -f $HOME/.suprc ]] && { source "$HOME/.suprc"; } [[ -f $HOME/.suprc ]] && { source "$HOME/.suprc"; }
@@ -19,6 +24,10 @@ _cat() {
done done
} }
is_url() {
[[ "$1" =~ $cfg_url_regex ]]
}
sup.msg() { printf '%s\n' "[sup] $1"; } sup.msg() { printf '%s\n' "[sup] $1"; }
sup.err() { sup.msg "(error) $1" >&2; } sup.err() { sup.msg "(error) $1" >&2; }
@@ -29,6 +38,7 @@ sup.usage() {
-R # Remove the file after uploading. -R # Remove the file after uploading.
-s # Make a screenshot and upload it instead of a file. -s # Make a screenshot and upload it instead of a file.
-F # Make a fullscreen shot instead of prompting for a window/area. Implies -s. -F # Make a fullscreen shot instead of prompting for a window/area. Implies -s.
-d # Supply a dexcription.
-D <num> # Delay the shot by <num> seconds. -D <num> # Delay the shot by <num> seconds.
-p # Make the file private. Requires \$secret to be set in the config. -p # Make the file private. Requires \$secret to be set in the config.
-u # Generate a shortlink from URL. -u # Generate a shortlink from URL.
@@ -55,6 +65,7 @@ sup.get_hash() {
sup.upload() { sup.upload() {
if (( flag_scrot )); then if (( flag_scrot )); then
flag_rm=1
file=$(sup.scrot) || { return 1; } file=$(sup.scrot) || { return 1; }
else else
(( $# )) || { (( $# )) || {
@@ -64,7 +75,8 @@ sup.upload() {
target="$1" target="$1"
if sup.if_url "$target"; then if is_url "$target"; then
flag_rm=1
file=$(sup.mktemp "$cfg_tmp_dir") file=$(sup.mktemp "$cfg_tmp_dir")
curl -skL "$target" > "$file" || { curl -skL "$target" > "$file" || {
@@ -87,24 +99,26 @@ sup.upload() {
if ! (( $? )); then if ! (( $? )); then
printf '%s\n' "$file_url" printf '%s\n' "$file_url"
else else
if curl -sL \ curl -sL \
-F file="@$file" \ -F file="@$file" \
-F upload_mode='api' \ -F upload_mode='api' \
-F flag_private="$flag_private" \ -F flag_private="$flag_private" \
-F short="$flag_shortlink" \ -F short="$flag_shortlink" \
-F description="$description" \
-F secret="$secret" \ -F secret="$secret" \
-F submit="" \ -F submit="" \
-A 'zerofiles.org upload script' \ -A 'zerofiles.org upload script' \
"$cfg_service_url/upload" "$cfg_service_url/upload"
then fi
if (( $? )); then
sup.err 'Something has gone wrong with the upload.'
return 7
else
if (( flag_rm )); then if (( flag_rm )); then
sup.msg "Removing file: $file" sup.msg "Removing file: $file"
rm "$file" rm "$file"
fi fi
else
sup.err 'Something has gone wrong with the upload.'
return 7
fi
fi fi
} }
@@ -147,8 +161,6 @@ sup.scrot() {
printf '%s\n' "$tmp_file" printf '%s\n' "$tmp_file"
} }
sup.if_url() { printf '%s\n' "$1" | grep -oE "$cfg_url_regex" &>/dev/null; }
sup.mktemp() { sup.mktemp() {
declare tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1" declare tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1"
@@ -164,6 +176,14 @@ sup.mktemp() {
printf '%s\n' "${tmp_dir}/${tmp_file_name}" printf '%s\n' "${tmp_dir}/${tmp_file_name}"
} }
sup.get_my_ip() {
my_ip=$( curl -fsL https://zfh.so/ip )
if ! (( $? )); then
printf '%s\n' $my_ip
fi
}
sup.set_argv() { sup.set_argv() {
declare arg opt c declare arg opt c
declare -g argv declare -g argv
@@ -209,12 +229,15 @@ main() {
-R|--remove-file) flag_rm='1';; -R|--remove-file) flag_rm='1';;
-s|--screenshot) flag_scrot='1';; -s|--screenshot) flag_scrot='1';;
-d|--description) description="$2"; shift;;
-D|--screenshot-delay) cfg_scrot_delay="$2"; shift;; -D|--screenshot-delay) cfg_scrot_delay="$2"; shift;;
-F|--fullscreen) -F|--fullscreen)
flag_scrot='1' flag_scrot='1'
flag_scrot_fullscreen='1' flag_scrot_fullscreen='1'
;; ;;
-i|--my-ip) action='getmyip';;
-S|--short) flag_shortlink='1';; -S|--short) flag_shortlink='1';;
-u|--url) action='url';; -u|--url) action='url';;
@@ -232,6 +255,7 @@ main() {
case "${action:-upload}" in case "${action:-upload}" in
upload) sup.upload "$1";; upload) sup.upload "$1";;
url) sup.url "$1";; url) sup.url "$1";;
getmyip) sup.get_my_ip;;
esac esac
} }

7
supd
View File

@@ -1,8 +1,13 @@
#!/usr/bin/env bash #!/usr/bin/env bash
shopt -s nullglob shopt -s nullglob
# Defaults for XDG
if ! [[ "$XDG_RUNTIME_DIR" ]]; then
XDG_RUNTIME_DIR="/run/user/$UID"
fi
# Defaults # Defaults
cfg_workdir="/tmp/$USER/supd" cfg_workdir="$XDG_RUNTIME_DIR/supd"
cfg_scan_delay='30' cfg_scan_delay='30'
msg() { printf '%s\n' "$*"; } msg() { printf '%s\n' "$*"; }