116 lines
2.6 KiB
Bash
116 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'
|