mirror of
https://github.com/ItsDrike/dotfiles.git
synced 2025-01-04 08:24:35 +00:00
170 lines
4.7 KiB
Bash
Executable file
170 lines
4.7 KiB
Bash
Executable file
#!/usr/bin/env bash
|
||
|
||
function extract {
|
||
if [ -z "$1" ]; then
|
||
# display usage if no parameters given
|
||
echo "Usage: extract <path/file_name>.<zip|rar|bz2|gz|tar|tbz2|tgz|Z|7z|xz|ex|tar.bz2|tar.gz|tar.xz>"
|
||
echo " extract <path/file_name_1.ext> [path/file_name_2.ext] [path/file_name_3.ext]"
|
||
return 1
|
||
else
|
||
for n in $@
|
||
do
|
||
if [ -f "$n" ] ; then
|
||
case "${n%,}" in
|
||
*.tar.bz2|*.tar.gz|*.tar.xz|*.tbz2|*.tgz|*.txz|*.tar)
|
||
tar xvf "$n" ;;
|
||
*.lzma) unlzma ./"$n" ;;
|
||
*.bz2) bunzip2 ./"$n" ;;
|
||
*.rar) unrar x -ad ./"$n" ;;
|
||
*.gz) gunzip ./"$n" ;;
|
||
*.zip) unzip ./"$n" ;;
|
||
*.z) uncompress ./"$n" ;;
|
||
*.7z|*.arj|*.cab|*.chm|*.deb|*.dmg|*.iso|*.lzh|*.msi|*.rpm|*.udf|*.wim|*.xar)
|
||
7z x ./"$n" ;;
|
||
*.xz) unxz ./"$n" ;;
|
||
*.exe) cabextract ./"$n" ;;
|
||
*)
|
||
echo "extract: '$n' - unknown archive method"
|
||
return 1
|
||
;;
|
||
esac
|
||
else
|
||
echo "'$n' - file does not exist"
|
||
return 1
|
||
fi
|
||
done
|
||
fi
|
||
}
|
||
|
||
# Create a new directory and enter it
|
||
function mkd() {
|
||
mkdir -p "$@" && cd "$_";
|
||
}
|
||
|
||
# Create a .tar.gz archive, using `zopfli`, `pigz` or `gzip` for compression
|
||
function targz() {
|
||
local tmpFile="${@%/}.tar";
|
||
tar -cvf "${tmpFile}" "${@}" || return 1;
|
||
|
||
size=$(
|
||
stat -f"%z" "${tmpFile}" 2> /dev/null; # macOS `stat`
|
||
stat -c"%s" "${tmpFile}" 2> /dev/null; # GNU `stat`
|
||
);
|
||
|
||
local cmd="";
|
||
if (( size < 52428800 )) && hash zopfli 2> /dev/null; then
|
||
# the .tar file is smaller than 50 MB and Zopfli is available; use it
|
||
cmd="zopfli";
|
||
else
|
||
if hash pigz 2> /dev/null; then
|
||
cmd="pigz";
|
||
else
|
||
cmd="gzip";
|
||
fi;
|
||
fi;
|
||
|
||
echo "Compressing .tar ($((size / 1000)) kB) using \`${cmd}\`…";
|
||
"${cmd}" -v "${tmpFile}" || return 1;
|
||
[ -f "${tmpFile}" ] && rm "${tmpFile}";
|
||
|
||
zippedSize=$(
|
||
stat -f"%z" "${tmpFile}.gz" 2> /dev/null; # macOS `stat`
|
||
stat -c"%s" "${tmpFile}.gz" 2> /dev/null; # GNU `stat`
|
||
);
|
||
|
||
echo "${tmpFile}.gz ($((zippedSize / 1000)) kB) created successfully.";
|
||
}
|
||
|
||
# Determine size of a file or total size of a directory
|
||
function dir-size() {
|
||
if du -b /dev/null > /dev/null 2>&1; then
|
||
local arg=-sbh;
|
||
else
|
||
local arg=-sh;
|
||
fi
|
||
if [[ -n "$@" ]]; then
|
||
\du $arg -- "$@";
|
||
else
|
||
\du $arg .[^.]* ./*;
|
||
fi;
|
||
}
|
||
|
||
# Use Git’s colored diff when available
|
||
hash git &>/dev/null;
|
||
if [ $? -eq 0 ]; then
|
||
function diff() {
|
||
git diff --no-index --color-words "$@";
|
||
}
|
||
fi;
|
||
|
||
# Create a data URL from a file
|
||
function dataurl() {
|
||
local mimeType=$(file -b --mime-type "$1");
|
||
if [[ $mimeType == text/* ]]; then
|
||
mimeType="${mimeType};charset=utf-8";
|
||
fi
|
||
echo "data:${mimeType};base64,$(openssl base64 -in "$1" | tr -d '\n')";
|
||
}
|
||
|
||
# Compare original and gzipped file size
|
||
function gz() {
|
||
local origsize=$(wc -c < "$1");
|
||
local gzipsize=$(gzip -c "$1" | wc -c);
|
||
local ratio=$(echo "$gzipsize * 100 / $origsize" | bc -l);
|
||
printf "orig: %d bytes\n" "$origsize";
|
||
printf "gzip: %d bytes (%2.2f%%)\n" "$gzipsize" "$ratio";
|
||
}
|
||
|
||
# Show all the names (CNs and SANs) listed in the SSL certificate
|
||
# for a given domain
|
||
function getcertnames() {
|
||
if [ -z "${1}" ]; then
|
||
echo "ERROR: No domain specified.";
|
||
return 1;
|
||
fi;
|
||
|
||
local domain="${1}";
|
||
echo "Testing ${domain}…";
|
||
echo ""; # newline
|
||
|
||
local tmp=$(echo -e "GET / HTTP/1.0\nEOT" \
|
||
| openssl s_client -connect "${domain}:443" -servername "${domain}" 2>&1);
|
||
|
||
if [[ "${tmp}" = *"-----BEGIN CERTIFICATE-----"* ]]; then
|
||
local certText=$(echo "${tmp}" \
|
||
| openssl x509 -text -certopt "no_aux, no_header, no_issuer, no_pubkey, \
|
||
no_serial, no_sigdump, no_signame, no_validity, no_version");
|
||
echo "Common Name:";
|
||
echo ""; # newline
|
||
echo "${certText}" | grep "Subject:" | sed -e "s/^.*CN=//" | sed -e "s/\/emailAddress=.*//";
|
||
echo ""; # newline
|
||
echo "Subject Alternative Name(s):";
|
||
echo ""; # newline
|
||
echo "${certText}" | grep -A 1 "Subject Alternative Name:" \
|
||
| sed -e "2s/DNS://g" -e "s/ //g" | tr "," "\n" | tail -n +2;
|
||
return 0;
|
||
else
|
||
echo "ERROR: Certificate not found.";
|
||
return 1;
|
||
fi;
|
||
}
|
||
|
||
# `o` with no arguments opens the current directory, otherwise opens the given
|
||
# location
|
||
function o() {
|
||
if [ $# -eq 0 ]; then
|
||
open .;
|
||
else
|
||
open "$@";
|
||
fi;
|
||
}
|
||
|
||
# `tre` is a shorthand for `tree` with hidden files and color enabled, ignoring
|
||
# the `.git` directory, listing directories first. The output gets piped into
|
||
# `less` with options to preserve color and line numbers, unless the output is
|
||
# small enough for one screen.
|
||
function tre() {
|
||
tree -aC -I '.git|node_modules|bower_components' --dirsfirst "$@" | less -FRNX;
|
||
}
|
||
|