mirror of
https://github.com/ItsDrike/dotfiles.git
synced 2025-04-28 05:02:26 +00:00
237 lines
6.8 KiB
Bash
Executable file
237 lines
6.8 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
|
||
}
|
||
|
||
# Hide any file / directory in ls using .hidden file
|
||
#function ls () {
|
||
# if [ -f .hidden ]; then
|
||
# declare GLOBIGNORE="$GLOBIGNORE:.*:$(tr '\n' ':' < .hidden)"
|
||
# ls "$@"
|
||
# 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')";
|
||
}
|
||
|
||
# Start an HTTP server from a directory, optionally specifying the port
|
||
function server() {
|
||
local port="${1:-8000}";
|
||
sleep 1 && open "http://localhost:${port}/" &
|
||
# Set the default Content-Type to `text/plain` instead of `application/octet-stream`
|
||
# And serve everything as UTF-8 (although not technically correct, this doesn’t break anything for binary files)
|
||
python -c $'import SimpleHTTPServer;\nmap = SimpleHTTPServer.SimpleHTTPRequestHandler.extensions_map;\nmap[""] = "text/plain";\nfor key, value in map.items():\n\tmap[key] = value + ";charset=UTF-8";\nSimpleHTTPServer.test();' "$port";
|
||
}
|
||
|
||
# Start a PHP server from a directory, optionally specifying the port
|
||
# (Requires PHP 5.4.0+.)
|
||
function phpserver() {
|
||
local port="${1:-4000}";
|
||
local ip=$(ipconfig getifaddr en1);
|
||
sleep 1 && open "http://${ip}:${port}/" &
|
||
php -S "${ip}:${port}";
|
||
}
|
||
|
||
# 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";
|
||
}
|
||
|
||
# Run `dig` and display the most useful info
|
||
function digga() {
|
||
dig +nocmd "$1" any +multiline +noall +answer;
|
||
}
|
||
|
||
# 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;
|
||
}
|
||
|
||
# Normalize `open` across Linux, macOS, and Windows.
|
||
# This is needed to make the `o` function (see below) cross-platform.
|
||
if [ ! $(uname -s) = 'Darwin' ]; then
|
||
if grep -q Microsoft /proc/version; then
|
||
# Ubuntu on Windows using the Linux subsystem
|
||
alias open='explorer.exe';
|
||
else
|
||
alias open='xdg-open';
|
||
fi
|
||
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;
|
||
}
|
||
|
||
# Will update all git repositories found in current directory and its subdirectories
|
||
function update-git-repos() {
|
||
# store the current dir
|
||
CUR_DIR=$(pwd)
|
||
|
||
# Let the person running the script know what's going on.
|
||
echo -e "\n\033[1mPulling in latest changes for all repositories...\033[0m\n"
|
||
|
||
# Find all git repositories and update it to the master latest revision
|
||
for i in $(find . -name ".git" | cut -c 3-); do
|
||
echo "";
|
||
echo -e "\033[33m"+$i+"\033[0m";
|
||
|
||
# We have to go to the .git parent directory to call the pull command
|
||
cd "$i";
|
||
cd ..;
|
||
|
||
# finally pull
|
||
git pull origin master;
|
||
|
||
# lets get back to the CUR_DIR
|
||
cd $CUR_DIR
|
||
done
|
||
|
||
echo -e "\n\033[32mComplete!\033[0m\n"
|
||
}
|