mirror of
https://github.com/d0zingcat/dotfiles.git
synced 2026-05-13 15:09:34 +00:00
260 lines
8.7 KiB
Bash
260 lines
8.7 KiB
Bash
export GOPATH=$HOME/.go
|
|
export PNPM_HOME="$HOME/.pnpm"
|
|
export CARGO_HOME=$HOME/.cargo
|
|
|
|
export PATH="/opt/homebrew/sbin:/opt/homebrew/bin:/usr/local/bin:/usr/bin:/usr/sbin:/bin:/sbin"
|
|
export PATH="/opt/homebrew/opt/rustup/bin:$PATH"
|
|
export PATH="$CARGO_HOME/bin:$GOPATH/bin:$PATH"
|
|
export PATH="$HOME/.local/bin:${HOME}/.krew/bin:$PATH"
|
|
export PATH="$PNPM_HOME:$PATH"
|
|
export PATH="$HOME/.docker/bin:$PATH"
|
|
export PATH="$PATH:$HOME/.spicetify"
|
|
|
|
export LC_ALL=en_US.UTF-8
|
|
export EDITOR=vim
|
|
export LANG=en_US.UTF-8
|
|
export MANPAGER="sh -c \"col -b | vim -c 'set ft=man ts=8 nomod nolist nonu' \
|
|
-c 'nnoremap i <nop>' \
|
|
-c 'nnoremap <Space> <C-f>' \
|
|
-c 'noremap q :quit<CR>' -\""
|
|
export KUBECONFIG=$(echo `ls ~/.kube/*config*` | sed 's/ /:/g')
|
|
export HELM_CACHE_HOME=$HOME/.cache/helm
|
|
export FZF_DEFAULT_OPTS="--height=50% --layout=reverse"
|
|
export GPG_TTY=$(tty)
|
|
|
|
arch=$(uname -m)
|
|
if [ $arch = "x86_64" ]; then
|
|
brew_opt="/usr/local/opt"
|
|
elif [ $arch = "arm64" ]; then
|
|
brew_opt="/opt/homebrew/opt"
|
|
fi
|
|
LDFLAGS="-L$brew_opt/zlib/lib -L$brew_opt/openssl@3/lib"
|
|
CPPFLAGS="-I$brew_opt/zlib/include -I$brew_opt/openssl@3/include"
|
|
export LDFLAGS=$LDFLAGS
|
|
export CPPFLAGS=$CPPFLAGS
|
|
export ZSH_HIGHLIGHT_MAXLENGTH=60
|
|
export GIT_EXTERNAL_DIFF=difft
|
|
|
|
|
|
FPATH="$brew_opt/share/zsh/site-functions:${ASDF_DIR}/completions:${FPATH}"
|
|
DISABLE_MAGIC_FUNCTIONS=true
|
|
|
|
|
|
source $HOME/.antigen/antigen.zsh
|
|
antigen use oh-my-zsh
|
|
antigen bundle zsh-users/zsh-autosuggestions
|
|
antigen bundle zsh-users/zsh-syntax-highlighting
|
|
antigen bundle zsh-users/zsh-completions
|
|
antigen bundle git
|
|
antigen bundle kubectl
|
|
antigen bundle autojump
|
|
antigen bundle pip
|
|
antigen bundle asdf
|
|
antigen bundle nvim
|
|
antigen bundle darvid/zsh-poetry
|
|
antigen bundle Aloxaf/fzf-tab
|
|
antigen bundle vi-mode
|
|
#antigen bundle MichaelAquilina/zsh-autoswitch-virtualenv
|
|
# antigen bundle jeffreytse/zsh-vi-mode
|
|
antigen apply
|
|
|
|
|
|
# menu
|
|
function m() {
|
|
if [[ -n "$TMUX" ]]; then
|
|
exit 0
|
|
fi
|
|
tmux ls -F '#{session_name}' | fzf --bind=enter:replace-query+print-query | xargs echo | read session && tmux attach -t ${session:-default} || tmux new -s ${session:-default}
|
|
}
|
|
|
|
# find network ports
|
|
function macnst (){
|
|
netstat -Watnlv | grep LISTEN | awk '{"ps -o comm= -p " $9 | getline procname;colred="\033[01;31m";colclr="\033[0m"; print colred "proto: " colclr $1 colred " | addr.port: " colclr $4 colred " | pid: " colclr $9 colred " | name: " colclr procname; }' | column -t -s "|"
|
|
}
|
|
|
|
# As clash for windows provides TUN mode/ClashX provides enhance mode, there's no necessity to set proxy munally(which proxy all traffix transparently)
|
|
# proxy by clashx function clashproxy() {
|
|
# local proxy=http://127.0.0.1:7890
|
|
# export https_proxy=$proxy http_proxy=$proxy all_proxy=socks5://127.0.0.1:7891;
|
|
# echo "proxy all set!"
|
|
#}
|
|
#
|
|
## unset proxy
|
|
#function clashproxy_unset() {
|
|
# unset http_proxy
|
|
# unset https_proxy
|
|
# unset all_proxy
|
|
# echo "proxy all unset!"
|
|
#}
|
|
|
|
function klogs() {
|
|
keyword=$1
|
|
k get pods --sort-by=.metadata.creationTimestamp | grep "$keyword" | head -n 1 | awk '{print $1}' | xargs kubectl logs -f
|
|
}
|
|
|
|
function replace_remote() {
|
|
if (( $# != 1 ));
|
|
then
|
|
echo 'Invalid parameter!'
|
|
else
|
|
url=$(git remote -v | head -n 1 | cut -d $'\t' -f 2 | cut -d ' ' -f 1)
|
|
suffix=$(echo $url | cut -d ':' -f 2)
|
|
case $1 in
|
|
ops)
|
|
new_url=opsgit:$suffix
|
|
git remote set-url origin $new_url
|
|
;;
|
|
work)
|
|
new_url=workgit:$suffix
|
|
git remote set-url origin $new_url
|
|
;;
|
|
play)
|
|
new_url=personalgit:$suffix
|
|
git remote set-url origin $new_url
|
|
;;
|
|
*)
|
|
echo 'Invalid parameter'
|
|
;;
|
|
esac
|
|
fi
|
|
}
|
|
|
|
function rsync_work() {
|
|
remote_dir="/root"
|
|
local_work=`pwd`
|
|
local_dir=${PWD##*/}
|
|
local_dir=${local_dir:-/}
|
|
if [ $# -eq 0 ]; then
|
|
remote_work="devops-cloud-1:$remote_dir/$local_dir"
|
|
elif [ $# -eq 1 ]; then
|
|
remote_work="devops-cloud-$1:$remote_dir/$local_dir"
|
|
elif [ $# -eq 2 ]; then
|
|
remote_work="devops-cloud-$1:$remote_dir/$local_dir"
|
|
if [ "$2" = "back" ]; then
|
|
# swap local and remote
|
|
t=$local_work
|
|
local_work=$remote_work
|
|
remote_work=$t
|
|
else
|
|
echo "Invalid argument! should be 'back'"
|
|
exit(1)
|
|
fi
|
|
else
|
|
echo "invalid argument!"
|
|
exit(1)
|
|
fi
|
|
rsync_exclude="$local_work/rsync_exclude.txt"
|
|
if [ -f $rsync_exclude ]; then
|
|
rsync -avhti --exclude-from=$rsync_exclude --exclude=/venv --exclude=/.vscode --exclude=/.git $local_work/ $remote_work
|
|
else
|
|
rsync -avhti --exclude=/venv --exclude=/.vscode --exclude=/.git $local_work/ $remote_work
|
|
fi
|
|
}
|
|
|
|
function git_clean() {
|
|
if [[ $# != 1 || ! $1 =~ 'main|master|develop' ]]
|
|
then
|
|
echo 'Invalid parameter, should based on develop/main/master'
|
|
else
|
|
git fetch --all --prune
|
|
git checkout $1 && \
|
|
git config pull.rebase false && \
|
|
git pull && \
|
|
git branch --merged | grep -v $1 | cat | xargs git branch -d
|
|
fi
|
|
}
|
|
|
|
function git_config() {
|
|
git config user.name $1
|
|
git config user.email $2
|
|
git config gpg.format ssh
|
|
git config user.signingkey "$3"
|
|
}
|
|
|
|
function git_config_work() {
|
|
if [ ! $# -eq 2 ]; then
|
|
echo 'should be like git_config_work {name} {email}'
|
|
fi
|
|
git_config $1 $2 'ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIF23DQtdH5PODF9fYUHr49I1J3lfKLAPk4LG54MVUTcg'
|
|
}
|
|
|
|
function git_config_play() {
|
|
if [ ! $# -eq 1 ]; then
|
|
echo 'should be like gait_config_play {email}'
|
|
fi
|
|
git_config d0zingcat $1 'ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPaVruhhL4O9BiAncnW1wH3jc7/hsqsXLknA8Xtnjjee'
|
|
}
|
|
|
|
function bitnami_seal() {
|
|
if [[ $# != 2 ]]
|
|
then
|
|
echo 'Invalid parameter, should be like bitnami_seal <namespace> <filename>'
|
|
else
|
|
if [[ ! -f $2 ]]
|
|
then
|
|
echo "The file does not exist"
|
|
exit 1
|
|
fi
|
|
if [[ $2 != *".raw.yaml" ]]; then
|
|
echo "The variable does not have the .raw.yaml extension"
|
|
exit 1
|
|
fi
|
|
# parse *.raw.yaml to *.yaml
|
|
newname=${2//.raw/}
|
|
kubeseal --controller-namespace sealed-secrets --controller-name sealed-secrets -oyaml -n $1 -f $2 > $newname
|
|
fi
|
|
}
|
|
|
|
zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS}
|
|
eval "$(starship init zsh)"
|
|
eval "$(direnv hook zsh)"
|
|
|
|
alias ta='tmux a'
|
|
alias tl='tmux ls && read session && tmux attach -t ${session:-default} || tmux new -s ${session:-default}'
|
|
alias ls='lsd'
|
|
alias l='ls -l'
|
|
alias la='ls -a'
|
|
alias lla='ls -la'
|
|
alias lt='ls --tree'
|
|
alias kns='kubens'
|
|
alias kctx='kubectx'
|
|
alias kd='kubectl debug'
|
|
alias kk='kubectl krew'
|
|
alias kzeus='kubectl --context zeus '
|
|
alias khybrid='kubectl --context hybrid'
|
|
alias kget='kubectl get'
|
|
alias kdesc='kubectl describe'
|
|
alias klog='kubectl logs'
|
|
alias kapply='kubectl apply'
|
|
alias gce='gh copilot explain'
|
|
alias gcs='gh copilot suggest'
|
|
alias vi='nvim'
|
|
#alias wol_xps8940="host home.d0zingcat.xyz | cut -d ' ' -f 4 | cat | xargs -I {} wakeonlan -i {} -p 200 'FC:44:82:13:BA:0F'"
|
|
alias batc='bat --paging=never'
|
|
alias batcp='bat --plain --paging=never'
|
|
alias fixscreen='sudo launchctl unload -w /System/Library/LaunchDaemons/com.apple.screensharing.plist && sudo launchctl load -w /System/Library/LaunchDaemons/com.apple.screensharing.plist'
|
|
# do not use -r as it skips the non-regular files
|
|
alias tf_push='rsync -avhti . devops-cloud-1:~/meex-deploy/ --exclude=.terraform/ --exclude=.terraform.lock.hcl --exclude=terraform.tfstate'
|
|
alias tf_push_state='rsync -avhti . devops-cloud-1:~/meex-deploy/ --exclude=.terraform/ --exclude=.terraform.lock.hcl'
|
|
alias tf_pull_state='rsync -avhti devops-cloud-1:~/meex-deploy/terraform/terraform.tfstate terraform/.'
|
|
alias git_branch="git for-each-ref --sort=committerdate refs/heads/ --format='%(HEAD) %(color:yellow)%(refname:short)%(color:reset) - %(color:red)%(objectname:short)%(color:reset) - %(contents:subject) - %(authorname) (%(color:green)%(committerdate:relative)%(color:reset))'"
|
|
alias clean_tmux_session='ls ~/.tmux/resurrect/* -1dtr | head -n 100 | xargs rm -v'
|
|
alias pn='pnpm'
|
|
alias python='python3'
|
|
alias pip='pip3'
|
|
|
|
[[ $commands[kubectl] ]] && source <(kubectl completion zsh) && compdef __start_kubectl k
|
|
[[ $commands[helm] ]] && source <(helm completion zsh)
|
|
|
|
[ -f /usr/local/etc/profile.d/autojump.sh ] && . /usr/local/etc/profile.d/autojump.sh
|
|
[ -f /usr/local/Caskroom/google-cloud-sdk/latest/google-cloud-sdk/completion.zsh.inc ] && . /usr/local/Caskroom/google-cloud-sdk/latest/google-cloud-sdk/completion.zsh.inc
|
|
|
|
source <(fzf --zsh)
|
|
|
|
bindkey -M viins '^b' vi-backward-char
|
|
bindkey -M viins '^f' vi-forward-char
|
|
bindkey -M viins '^d' vi-delete-char
|
|
[ -f ~/.env ] && source ~/.env
|
|
|
|
|