-
Notifications
You must be signed in to change notification settings - Fork 0
/
.bashrc
357 lines (305 loc) · 10.1 KB
/
.bashrc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
# ~/.bashrc: executed by bash(1) for non-login shells.
# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
# for examples
# If not running interactively, don't do anything
cd ~
export SSH_OPTS="-o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null"
export ssh="ssh ${SSH_OPTS}"
alias python=python3
alias pip=pip3
alias clip='xclip -sel clip'
alias gbr="git branch | egrep -v "master" | xargs git branch -D"
alias ee="explorer.exe ."
alias k=kubectl
export K8S_NAMESPACE=kimi450
# Eternal bash history.
# ---------------------
# Enable history appending instead of overwriting. #139609
shopt -s histappend
# don't put duplicate lines or lines starting with space in the history.
# See bash(1) for more options
# HISTCONTROL=ignoreboth
# Undocumented feature which sets the size to "unlimited".
# http://stackoverflow.com/questions/9457233/unlimited-bash-history
export HISTFILESIZE=-1
export HISTSIZE=-1
export HISTTIMEFORMAT="[%F %T] "
# Change the file location because certain bash sessions truncate .bash_history file upon close.
# http://superuser.com/questions/575479/bash-history-truncated-to-500-lines-on-each-login
#
export HISTFILE=~/.bash_eternal_history
# Force prompt to write history after every command.
# http://superuser.com/questions/20900/bash-history-loss
# PROMPT_COMMAND="history -a; history -c; history -r; $PROMPT_COMMAND"
# Python
# ------------------
# auto activate/deactivate venv called `.env` when moving between dirs
# https://stackoverflow.com/questions/45216663/how-to-automatically-activate-virtualenvs-when-cding-into-a-directory
function cd() {
builtin cd "$@"
if [[ -z "$VIRTUAL_ENV" ]] ; then
## If env folder is found then activate the vitualenv
if [[ -d ./.env ]] ; then
source ./.env/bin/activate
fi
else
## check the current folder belong to earlier VIRTUAL_ENV folder
# if yes then do nothing
# else deactivate
parentdir="$(dirname "$VIRTUAL_ENV")"
if [[ "$PWD"/ != "$parentdir"/* ]] ; then
deactivate
fi
fi
}
# get logs for pod where only 1 pod is expected
logs() {
local container_data
if [ -n "$2" ]; then
container_data="-c $2"
fi
kubectl logs -f $(kubectl get pods | egrep "$1" | awk '{print $1}') ${container_data}
}
# delete resource based on the pattern provided
# default resource is pod
delete() {
if [[ -z "$2" && -z "$1" ]]; then
echo "usage: delete <POD_PATTERN>"
echo "usage: delete <KUBERNETES_RESOURCE> <RESOURCE_PATTERN>"
echo "Provide pattern to delete pod, or resource and pattern"
return
fi
resource="pod"
pattern="$1"
if [ -n "$2" ]; then
resource="$1"
pattern="$2"
fi
kubectl delete ${resource} $(kubectl get ${resource} | egrep "${pattern}" | awk '{print $1}')
}
# kubectl exec into pod matching the pattern with given command, default command is bash
execit() {
local container_data
command="bash"
pattern="$1"
if [ -n "$2" ]; then
container_data="-c $2"
fi
if [ -n "$3" ]; then
command="$3"
fi
kubectl exec -it $(kubectl get pod | egrep "${pattern}" | awk '{print $1}') ${container_data} -- ${command}
}
# remove docker images with string in name
rmi () {
docker rmi $(docker images | egrep "$1")
}
# patch service to nodeport
# usage: patch <service>
# usage: patch <service> <nodeport to use>
patch () {
if [ -z "$2" ]; then
# plain patch to nodeport
kubectl patch service $1 --type='json' -p "[{'op':'replace','path':'/spec/type','value':'NodePort'}]"
else
# patch to nodeport with specific port
kubectl patch service $1 --type='json' -p "[{'op':'replace','path':'/spec/type','value':'NodePort'},{'op':'replace','path':'/spec/ports/0/nodePort','value':$2}]"
fi
}
# switch namespace
kn() {
kubens $1
if [ $? -ne 0 ]; then
if [ $# -eq 0 ]; then
echo -e "Missing namespace...\nusage: kn NAMESPACE"
return 1
fi
kubectl config set-context --current --namespace=$1
fi
}
# get current namespace
kcn() {
kubectl config view --minify --output 'jsonpath={..namespace}'; echo
}
# switch context
alias kk=kubectx
# current context
kcc() {
kubectl config view --minify --output 'jsonpath={..current-context}'; echo
}
# get every single resource available on the cluster
# or provide a list of resources you are interested in
# eg: "kall pods service"
kall() {
lst=$@
if [ -z $1 ]; then
lst=`kubectl api-resources --no-headers | awk '{print $1}'`
fi
for resource in $lst; do
echo -e "***${resource}***";
kubectl get $resource;
done
}
# monitor given namespace (or K8S_NAMESPACE) services and pods
monitor() {
NAMESPACE=$1
if [ -z "$1" ]; then
NAMESPACE=$(kcn)
fi
watch "kubectl get pods,svc -n $NAMESPACE"
}
# uninstall everything and reset namespace
# usage: reset
# Defaults to resetting $K8S_NAMESPACE
# usage: reset <namespace>
function reset {
if [ -z "$1" ]; then
NAMESPACE=$K8S_NAMESPACE
else
NAMESPACE=$1
fi
kn $NAMESPACE > /dev/null && echo "On $(kcc):$(kcn)"
helm delete $(helm ls --all --short --namespace $NAMESPACE) --namespace $NAMESPACE
kubectl delete namespace $NAMESPACE && kubectl create namespace $NAMESPACE || kubectl create namespace $NAMESPACE
}
# use fzf for ^r history searches in the terminal
# source: https://github.com/junegunn/fzf/wiki/examples#command-history
if [ "$PS1" ]; then
bind '"\C-r": "\C-x1\e^\er"'
bind -x '"\C-x1": __fzf_history';
fi
__fzf_history ()
{
__ehc $(history | fzf --tac --tiebreak=index | perl -ne 'm/^\s*([0-9]+)/ and print "!$1"')
}
__ehc()
{
if
[[ -n $1 ]]
then
bind '"\er": redraw-current-line'
bind '"\e^": magic-space'
READLINE_LINE=${READLINE_LINE:+${READLINE_LINE:0:READLINE_POINT}}${1}${READLINE_LINE:+${READLINE_LINE:READLINE_POINT}}
READLINE_POINT=$(( READLINE_POINT + ${#1} ))
else
bind '"\er":'
bind '"\e^":'
fi
}
# better command prompt
PROMPT_COMMAND=__prompt_command # Func to gen PS1 after CMDs
parse_git_branch() {
git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/ (\1)/'
}
__prompt_command() {
local EXIT="$?" # This needs to be first
local RCol='\[\e[0m\]'
local Red='\[\e[0;31m\]'
local Gre='\[\e[0;32m\]'
local BYel='\[\e[1;33m\]'
local BBlu='\[\e[1;34m\]'
local Pur='\[\e[0;35m\]'
dashes="--"
if [ ${#EXIT} -eq 3 ]; then
dashes=""
elif [ ${#EXIT} -eq 2 ]; then
dashes="-"
fi
PS1="${Gre}[$(cat /sys/class/power_supply/BAT0/capacity)%] $(kcc):$(kcn) ${BYel}\t ${RCol}"
# PS1="${Gre}$(kcc):$(kcn) ${BYel}\t ${RCol}"
if [ $EXIT != 0 ]; then
PS1+="[${Red}${dashes}${EXIT}${RCol}]" # Add red if exit code non 0
else
PS1+="[${Gre}${dashes}${EXIT}${RCol}]"
fi
PS1+="${Pur} \w ${BYel}$(parse_git_branch) $ ${RCol}"
}
# Colors for git stuff
export GIT_PS1_SHOWCOLORHINTS="true"
export GIT_PS1_SHOWUPSTREAM="auto"
export GIT_PS1_SHOWDIRTYSTATE="true"
#PROMPT_COMMAND='__git_ps1 "\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]" " > "'
case $- in
*i*) ;;
*) return;;
esac
# check the window size after each command and, if necessary,
# update the values of LINES and COLUMNS.
shopt -s checkwinsize
# If set, the pattern "**" used in a pathname expansion context will
# match all files and zero or more directories and subdirectories.
#shopt -s globstar
# make less more friendly for non-text input files, see lesspipe(1)
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
# set variable identifying the chroot you work in (used in the prompt below)
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
debian_chroot=$(cat /etc/debian_chroot)
fi
# set a fancy prompt (non-color, unless we know we "want" color)
case "$TERM" in
xterm-color|*-256color) color_prompt=yes;;
esac
# uncomment for a colored prompt, if the terminal has the capability; turned
# off by default to not distract the user: the focus in a terminal window
# should be on the output of commands, not on the prompt
#force_color_prompt=yes
if [ -n "$force_color_prompt" ]; then
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
# We have color support; assume it's compliant with Ecma-48
# (ISO/IEC-6429). (Lack of such support is extremely rare, and such
# a case would tend to support setf rather than setaf.)
color_prompt=yes
else
color_prompt=
fi
fi
if [ "$color_prompt" = yes ]; then
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
else
PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
fi
unset color_prompt force_color_prompt
# If this is an xterm set the title to user@host:dir
case "$TERM" in
xterm*|rxvt*)
PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
;;
*)
;;
esac
# enable color support of ls and also add handy aliases
if [ -x /usr/bin/dircolors ]; then
test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
alias ls='ls --color=auto'
#alias dir='dir --color=auto'
#alias vdir='vdir --color=auto'
alias grep='grep --color=auto'
alias fgrep='fgrep --color=auto'
alias egrep='egrep --color=auto'
fi
# colored GCC warnings and errors
#export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'
# some more ls aliases
alias ll='ls -alF'
alias la='ls -A'
alias l='ls -CF'
# Add an "alert" alias for long running commands. Use like so:
# sleep 10; alert
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'
# Alias definitions.
# You may want to put all your additions into a separate file like
# ~/.bash_aliases, instead of adding them here directly.
# See /usr/share/doc/bash-doc/examples in the bash-doc package.
if [ -f ~/.bash_aliases ]; then
. ~/.bash_aliases
fi
# enable programmable completion features (you don't need to enable
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
if [ -f /usr/share/bash-completion/bash_completion ]; then
. /usr/share/bash-completion/bash_completion
elif [ -f /etc/bash_completion ]; then
. /etc/bash_completion
fi
fi