dotfiles/home/.bash_aliases

117 lines
2.6 KiB
Bash

# some more ls aliases
alias ll='ls -l'
alias la='ls -A'
alias lla='ll -A'
alias l='ls -CF'
alias ..='cd ..'
alias ...='cd ../..'
alias rm='rm -I'
alias mv='mv -i'
alias cp='cp -i'
alias psa='ps aux'
alias psag='ps aux | grep'
alias ka=killall
alias g=git
alias k=kubectl
alias a=ansible
alias c=code-insiders
alias e=$EDITOR
# Completion for aliases
# See: https://github.com/cykerway/complete-alias
complete -F _complete_alias g
complete -F _complete_alias k
complete -F _complete_alias a
complete -F _complete_alias c
complete -F _complete_alias e
# Some shortcuts for me
function moby() {
[ -f ~/.bash_env ] && source ~/.bash_env
MACHINE=${1:-"default"}
docker-machine start $MACHINE
eval $(docker-machine env $MACHINE)
}
function jumphost() {
DEST=$1
while read PATTERN JUMPHOST; do
echo $DEST | grep -q $PATTERN && echo $JUMPHOST
done <~/.ssh/jumphosts
}
function tunnel() {
IFS=: read DEST PORT <<<$1
PORT_LOCAL=${2:-$PORT}
HOP=${3:-$(jumphost $DEST)}
[ -z "$HOP" ] || [ -z "$PORT" ] || [ -z "$PORT_LOCAL" ] && \
{ echo "usage: $FUNCNAME destination:port [local_port [tunnel_host]]"; return 1; }
ssh $HOP -L $PORT_LOCAL:$DEST:$PORT -N -o ExitOnForwardFailure=yes -f
PID=$(ssh $HOP -O check 2>&1 | sed -re "s/.*\(pid=(.*)\)+/\1/")
echo "Destination: $DEST:$PORT"
echo "Tunnelhost: $HOP"
echo "Local port: $PORT_LOCAL"
echo "SSH Tunnel PID: $PID"
}
function rdp-tunnel() {
IFS=: read DEST PORT <<<$1
HOP=${2:-$(jumphost $DEST)}
PORT=${PORT:-3389}
PORT_LOCAL=$((RANDOM%100+42325))
[ -z "$DEST" ] || [ -z "$HOP" ] && \
{ echo "usage: $FUNCNAME destination[:port] [tunnel_host]"; return 1; }
tunnel $DEST:$PORT $PORT_LOCAL $HOP && rdp localhost:$PORT_LOCAL
}
function rdp() {
PORT=3389
IFS=: read DEST PORT <<<$1
[ -n "$DEST" ] || \
{ echo "usage: $FUNCNAME destination:port"; return 1; }
if [[ "$OSTYPE" == "darwin"* ]]; then
open rdp://full%20address=s:$DEST:$PORT
else
rdesktop -P -k de -a 32 -z $DEST:$PORT
fi
}
function aws() {
local PASS=$(pass providers/aws)
local AWS=$(which aws)
# Start original aws executable with short-lived keys
AWS_ACCESS_KEY_ID=$(sed -En 's/^Access-Key: (.*)/\1/p' <<< "$PASS") \
AWS_SECRET_ACCESS_KEY=$(sed -En 's/^Secret-Key: (.*)/\1/p' <<< "$PASS") \
$AWS $@
}
function restic() {
local RESTIC=$(which restic)
# Start original restic executable with short-lived keys
RESTIC_PASSWORD="$(pass restic/macbook)" \
$RESTIC $@
}
alias acs-pass='PASSWORD_STORE_DIR=~/workspace/rwth/acs/Passwords pass'
alias chaos-family-invite='ssh -t root@chaos.family /root/sbot invite.create 1 | jq -r . | pbcopy'