Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
97701825bd | |||
c6e43448ca | |||
9b3516951c | |||
91a5d9bec2 | |||
40c1767aae | |||
7c9d85e8c0 |
35
README.md
35
README.md
@@ -13,38 +13,13 @@ Scripts
|
|||||||
ufw
|
ufw
|
||||||
---
|
---
|
||||||
|
|
||||||
ufw is the main one, it uploads shit.
|
ufw can upload files to 8fw.me, shorten urls and show you your ip.
|
||||||
|
Call ufw -h for help.
|
||||||
|
|
||||||
|
Dependencies: curl, jshon
|
||||||
Usage: ufw [-RsF] [-D num] [file/url]"
|
|
||||||
Flags:
|
|
||||||
-R # Remove the file after uploading.
|
|
||||||
-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.
|
|
||||||
-d # Supply a dexcription.
|
|
||||||
-D <num> # Delay the shot by <num> seconds.
|
|
||||||
-p # Make the file public.
|
|
||||||
-u # Generate a shortlink from URL.
|
|
||||||
-m # Maximum filesize (takes K, M and G suffixes).
|
|
||||||
-a # Add the file to an album.
|
|
||||||
-A # API response format.
|
|
||||||
|
|
||||||
Config options (~/.config/ufw):
|
|
||||||
secret # Your personal token. Get it at https://zfh.so/settings_form
|
|
||||||
cfg_screenshot_ext # Screenshot file type, used by scrot.
|
|
||||||
cfg_max_filesize # Maximum filesize in megabytes.
|
|
||||||
# Others are self-explanatory:
|
|
||||||
cfg_url_regex
|
|
||||||
cfg_tmp_dir
|
|
||||||
cfg_service_url
|
|
||||||
|
|
||||||
ufwd
|
ufwd
|
||||||
----
|
----
|
||||||
|
|
||||||
ufwd periodically checks a directory of your choosing (defaults to $XDG_RUNTIME DIR/ufwd) and invokes ufw to upload the files and remove them.
|
ufwd periodically checks a directory of your choosing (defaults to $XDG_RUNTIME DIR/ufwd) and invokes ufw to upload the files and remove them.
|
||||||
|
Call ufwd -h for help.
|
||||||
Usage: ufwd [-hn] [-d workdir] -D [check delay] -- [ufw flags]
|
|
||||||
-h # Show this message.
|
|
||||||
-n # Enable notifications with notify-send. Must be installed.
|
|
||||||
-d [path] # Set the dir that is to be watched.
|
|
||||||
-D [sec] # Set the check interval.
|
|
||||||
|
112
ufw
112
ufw
@@ -28,17 +28,17 @@ usage() {
|
|||||||
-d|--description # Supply a description.
|
-d|--description # Supply a description.
|
||||||
-D|--screenshot-delay <num> # Delay the shot by <num> seconds.
|
-D|--screenshot-delay <num> # Delay the shot by <num> seconds.
|
||||||
-p|--public # Make the file public.
|
-p|--public # Make the file public.
|
||||||
-u|--short # Generate a shortlink from URL.
|
-u|--shorten <URL> # Generate a shortlink from URL.
|
||||||
-m|--max-filesize # Maximum filesize (takes K, M and G suffixes).
|
-S|--short-url # Get a shortlink when uploading a file.
|
||||||
|
-P|--page-url # Get a link to the file page instead of a direct one.
|
||||||
|
-m|--max-filesize <num>[suf] # Maximum filesize (takes K, M and G suffixes).
|
||||||
-a|--album-id # Add the file to an album.
|
-a|--album-id # Add the file to an album.
|
||||||
-A|--album-name # Add the file to an album by name. The album will be crated, if necessary.
|
-A|--album-name # Add the file to an album by name. The album will be crated, if necessary.
|
||||||
-M|--api-format # API response format.
|
|
||||||
|
|
||||||
Config options (~/.config/ufw):
|
Config options (~/.config/ufw):
|
||||||
secret # Your personal token. Get it at https://zfh.so/settings_form
|
secret # Your personal token. Get it at https://zfh.so/settings_form
|
||||||
cfg_screenshot_ext # Screenshot file type, used by scrot.
|
cfg_screenshot_ext # Screenshot file type, used by scrot.
|
||||||
cfg_max_filesize # Maximum filesize (takes K, M and G suffixes).
|
cfg_max_filesize # Maximum filesize (takes K, M and G suffixes).
|
||||||
cfg_api_format # Set the api response format. Supports json or plain (default).
|
|
||||||
# Others are self-explanatory:
|
# Others are self-explanatory:
|
||||||
cfg_url_regex
|
cfg_url_regex
|
||||||
cfg_tmp_dir
|
cfg_tmp_dir
|
||||||
@@ -73,7 +73,25 @@ get_max_filesize() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get_album_id() {
|
||||||
|
declare api_response api_status api_status_message
|
||||||
|
|
||||||
|
api_response=$( curl -fsL "$cfg_service_url/$cfg_api_path/album?a=new&name=$1&format=json&secret=$secret" )
|
||||||
|
|
||||||
|
get_api_status <<< "$api_response"
|
||||||
|
|
||||||
|
if (( api_status == 200 )); then
|
||||||
|
album_id=$( jshon -e data -e album -e id -u <<< "$api_response" )
|
||||||
|
misc_curl_args+=( -F album_id="$album_id" )
|
||||||
|
else
|
||||||
|
printf 'Error [album]: %s %s\n' "$api_status" "$api_status_message"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
upload() {
|
upload() {
|
||||||
|
declare api_response api_status api_status_message
|
||||||
|
|
||||||
if (( flag_scrot )); then
|
if (( flag_scrot )); then
|
||||||
flag_rm=1
|
flag_rm=1
|
||||||
file=$(take_screenshot) || { return 1; }
|
file=$(take_screenshot) || { return 1; }
|
||||||
@@ -115,40 +133,65 @@ upload() {
|
|||||||
get_file_hash "$file"
|
get_file_hash "$file"
|
||||||
|
|
||||||
if [[ "$album_name" ]]; then
|
if [[ "$album_name" ]]; then
|
||||||
if album_id=$( curl -fsL "$cfg_service_url/$cfg_api_path/album?a=new&name=$album_name&format=plain&secret=$secret" ); then
|
get_album_id "$album_name"
|
||||||
misc_curl_args+=( -F album_id="$album_id" )
|
|
||||||
else
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
curl -sL \
|
api_response=$( curl -sL \
|
||||||
-F file="@$file" \
|
-F file="@$file" \
|
||||||
-F api_format="$cfg_api_format" \
|
-F api_format='json' \
|
||||||
-F flag_private="$flag_private" \
|
-F flag_private="$flag_private" \
|
||||||
-F short="$flag_shortlink" \
|
|
||||||
-F secret="$secret" \
|
-F secret="$secret" \
|
||||||
-F submit="" \
|
-F submit="" \
|
||||||
"${misc_curl_args[@]}" \
|
"${misc_curl_args[@]}" \
|
||||||
-A 'zerofiles.org upload script' \
|
-A 'zerofiles.org upload script' \
|
||||||
"$cfg_service_url/$cfg_api_path/upload"
|
"$cfg_service_url/$cfg_api_path/upload" )
|
||||||
|
|
||||||
if (( $? )); then
|
if (( flag_shortlink )); then
|
||||||
err 'Something has gone wrong with the upload.'
|
if (( flag_directlink )); then
|
||||||
return 7
|
file_url_request='short_url_direct'
|
||||||
|
else
|
||||||
|
file_url_request='short_url'
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
|
if (( flag_directlink )); then
|
||||||
|
file_url_request='direct_url'
|
||||||
|
else
|
||||||
|
file_url_request='page_url'
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
get_api_status <<< "$api_response"
|
||||||
|
|
||||||
|
if (( api_status == 200 )); then
|
||||||
|
file_link=$( jshon -e data -e file -e "$file_url_request" -u <<< "$api_response" )
|
||||||
|
|
||||||
|
printf '%s\n' "$file_link"
|
||||||
|
|
||||||
if (( flag_rm )); then
|
if (( flag_rm )); then
|
||||||
msg "Removing file: $file"
|
msg "Removing file: $file"
|
||||||
rm "$file"
|
rm "$file"
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
printf 'Error: %s %s\n' "$api_status" "$api_status_message"
|
||||||
|
return 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
get_shortlink() {
|
get_shortlink() {
|
||||||
declare url=$1
|
declare url=$1 api_response api_status api_status_message
|
||||||
|
|
||||||
if ! curl -fsL "$cfg_service_url/api?mode=url_add&url=${url}&raw=1"; then
|
api_response=$( curl -sL "$cfg_service_url/$cfg_api_path/url?a=add&url=${url}&format=json&secret=$secret" )
|
||||||
err 'Something went wrong!'
|
|
||||||
|
get_api_status <<< "$api_response"
|
||||||
|
|
||||||
|
if (( api_status == 200 )); then
|
||||||
|
read -r short_url real_url < <(
|
||||||
|
jshon -e data -e URL -e shorturl -u <<< "$api_response"
|
||||||
|
)
|
||||||
|
|
||||||
|
printf '%s\n' "$short_url"
|
||||||
|
else
|
||||||
|
printf 'Error: %s %s\n' "$api_status" "$api_status_message"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -174,6 +217,12 @@ take_screenshot() {
|
|||||||
printf '%s\n' "$tmp_file"
|
printf '%s\n' "$tmp_file"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get_api_status() {
|
||||||
|
read -d '' -r api_status api_status_message < <(
|
||||||
|
jshon -e status -e code -u -p -e message -u
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
_mktemp() {
|
_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"
|
||||||
|
|
||||||
@@ -190,10 +239,17 @@ _mktemp() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
get_my_ip() {
|
get_my_ip() {
|
||||||
my_ip=$( curl -fsL https://zfh.so/ip )
|
declare api_response api_status api_status_message my_ip
|
||||||
|
|
||||||
if ! (( $? )); then
|
api_response=$( curl -sl "$cfg_service_url/$cfg_api_path/ip?format=json" )
|
||||||
printf '%s\n' $my_ip
|
|
||||||
|
get_api_status <<< "$api_response"
|
||||||
|
|
||||||
|
if (( api_status == 200 )); then
|
||||||
|
my_ip=$( jshon -e data -e ip -u <<< "$api_response" )
|
||||||
|
printf '%s\n' "$my_ip"
|
||||||
|
else
|
||||||
|
printf 'Error: %s %s\n' "$api_status" "$api_status_message"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -250,9 +306,11 @@ main() {
|
|||||||
cfg_service_url='https://8fw.me'
|
cfg_service_url='https://8fw.me'
|
||||||
cfg_screenshot_ext='png'
|
cfg_screenshot_ext='png'
|
||||||
cfg_max_filesize='200M'
|
cfg_max_filesize='200M'
|
||||||
cfg_api_format='plain'
|
|
||||||
cfg_api_path='/api/2'
|
cfg_api_path='/api/2'
|
||||||
|
|
||||||
|
flag_shortlink=0
|
||||||
|
flag_directlink=1
|
||||||
|
|
||||||
if [[ -f "$HOME/.suprc" ]]; then
|
if [[ -f "$HOME/.suprc" ]]; then
|
||||||
printf 'Found legacy configfile, moving...\n' >&2
|
printf 'Found legacy configfile, moving...\n' >&2
|
||||||
mv "$HOME/.suprc" "$XDG_CONFIG_DIR/ufw"
|
mv "$HOME/.suprc" "$XDG_CONFIG_DIR/ufw"
|
||||||
@@ -279,12 +337,12 @@ main() {
|
|||||||
|
|
||||||
-m|--max-filesize) cfg_max_filesize=$2; shift;;
|
-m|--max-filesize) cfg_max_filesize=$2; shift;;
|
||||||
|
|
||||||
-M|--api-format) cfg_api_format=$2; shift;;
|
|
||||||
|
|
||||||
-i|--my-ip) action='getmyip';;
|
-i|--my-ip) action='getmyip';;
|
||||||
|
|
||||||
-S|--short) flag_shortlink='1';;
|
-u|--shorten) action='url';;
|
||||||
-u|--url) action='url';;
|
|
||||||
|
-S|--short-url) flag_shortlink=1;;
|
||||||
|
-P|--page-url) flag_directlink=0;;
|
||||||
|
|
||||||
-a|--album-id)
|
-a|--album-id)
|
||||||
misc_curl_args+=( -F "album_id=$2" )
|
misc_curl_args+=( -F "album_id=$2" )
|
||||||
|
Reference in New Issue
Block a user