Compare commits
No commits in common. "1507b0c3c4b41cac171c761d8cebfb5998a3473e" and "5de5edca67db1d742aefb88a23454bc4e03d37c0" have entirely different histories.
1507b0c3c4
...
5de5edca67
|
@ -75,7 +75,6 @@ history = 10000
|
||||||
|
|
||||||
[window]
|
[window]
|
||||||
dynamic_title = true
|
dynamic_title = true
|
||||||
option_as_alt = "Both"
|
|
||||||
|
|
||||||
[window.dimensions]
|
[window.dimensions]
|
||||||
columns = 150
|
columns = 150
|
||||||
|
|
|
@ -14,5 +14,3 @@
|
||||||
|
|
||||||
[init]
|
[init]
|
||||||
defaultBranch = main
|
defaultBranch = main
|
||||||
[alias]
|
|
||||||
blame = "!f() { [ -f .git-blame-ignore-revs ] && git blame --ignore-revs-file .git-blame-ignore-revs \"$@\" || git blame \"$@\"; }; f"
|
|
||||||
|
|
|
@ -3,27 +3,18 @@
|
||||||
if [[ $# -eq 1 ]]; then
|
if [[ $# -eq 1 ]]; then
|
||||||
selected=$1
|
selected=$1
|
||||||
else
|
else
|
||||||
selected=$(ggman exec pwd 2>&1 >/dev/null \
|
if ! [[ -f "$GGROOT/compiled" ]]; then
|
||||||
| fzf --cycle \
|
find -L $GGROOT -mindepth 1 -maxdepth 5 -type d -name .git -prune | xargs -n 1 dirname > "$GGROOT/compiled"
|
||||||
--bind 'tab:toggle-up,btab:toggle-down' \
|
fi
|
||||||
--header "Navigate with ARROW KEYS or TAB/S-TAB. Select with ENTER." \
|
selected=$(cat "$GGROOT/compiled" | fzf --cycle --bind 'tab:toggle-up,btab:toggle-down')
|
||||||
--border "double" \
|
|
||||||
--border-label "tmux-sessionizer" \
|
|
||||||
--ansi \
|
|
||||||
--highlight-line \
|
|
||||||
)
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z $selected ]]; then
|
if [[ -z $selected ]]; then
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
path=$selected
|
|
||||||
while [[ "$path" != "" && ! -e "$path/.sessionizer" ]]; do
|
|
||||||
path=${path%/*}
|
|
||||||
done
|
|
||||||
|
|
||||||
selected_name="$(cat $path/.sessionizer)_$(basename $selected | tr . _ | head -c 10)_$(echo $selected | shasum -a 256 | head -c 4)"
|
selected_name=$(basename "$selected" | tr . _)
|
||||||
tmux_running=$(pgrep tmux)
|
tmux_running=$(pgrep tmux)
|
||||||
|
|
||||||
if [[ -z $TMUX ]] && [[ -z $tmux_running ]]; then
|
if [[ -z $TMUX ]] && [[ -z $tmux_running ]]; then
|
||||||
|
|
|
@ -1,77 +1,25 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
function _preview {
|
if [[ $# -eq 1 ]]; then
|
||||||
file=$1; shift
|
selected=$1
|
||||||
host=$1; shift
|
else
|
||||||
|
selected="$(grep 'Host .*' ~/.ssh/config | grep -v '*' | sed 's/Host \(.*\)/\1/' | fzf --cycle --bind 'tab:toggle-up,btab:toggle-down')"
|
||||||
|
fi
|
||||||
|
|
||||||
j=$(cat $file \
|
if [[ -z $selected ]]; then
|
||||||
| jc --ssh-conf \
|
exit 0
|
||||||
| jq -r ".[] \
|
fi
|
||||||
| select(.host == \"$host\") \
|
|
||||||
| .jumps = (if (.proxyjump | type == \"array\" and length > 0) then (.proxyjump | join(\",\")) else \"null\" end)" \
|
|
||||||
)
|
|
||||||
|
|
||||||
user=$(jq -r '.user' <<<$j)
|
selected_name="ssh_$selected"
|
||||||
port=$(jq -r '.port' <<<$j)
|
tmux_running=$(pgrep tmux)
|
||||||
hostname=$(jq -r '.hostname' <<<$j)
|
|
||||||
jumps=$(jq -r '.jumps' <<<$j)
|
|
||||||
|
|
||||||
|
if [[ -z $TMUX ]] && [[ -z $tmux_running ]]; then
|
||||||
|
tmux new-session -s $selected_name -c $selected ssh "$selected"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
echo "$(cat <<EOF
|
if ! tmux has-session -t=$selected_name 2> /dev/null; then
|
||||||
User $user
|
tmux new-session -ds $selected_name -c $selected ssh "$selected"
|
||||||
HostName $hostname\
|
fi
|
||||||
$([[ $port != "null" ]] && echo -e "\nPort $port")\
|
|
||||||
$([[ $jumps != "null" ]] && echo -e "\nProxyJump $jumps")
|
|
||||||
|
|
||||||
command:
|
tmux switch-client -t $selected_name
|
||||||
ssh $user@$hostname$([[ $port != "null" ]] && echo -n " -p $port")$([[ $jumps != "null" ]] && echo -n " -J $jumps")
|
|
||||||
EOF)"
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
host $hostname
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
ping -c 1 -W 1 $hostname &>/dev/null \
|
|
||||||
&& echo "Host is reachable!" \
|
|
||||||
|| echo "Host is not reachable!"
|
|
||||||
}
|
|
||||||
|
|
||||||
export -f _preview
|
|
||||||
|
|
||||||
function main() {
|
|
||||||
if [[ $# -eq 1 ]]; then
|
|
||||||
selected=$1
|
|
||||||
else
|
|
||||||
selected="$(rg -N --no-heading 'Host .*' ~/.ssh \
|
|
||||||
| sed 's/Host \(.*\)/\1/' \
|
|
||||||
| SHELL=$(which bash) fzf --cycle \
|
|
||||||
--bind 'tab:toggle-up,btab:toggle-down' \
|
|
||||||
--delimiter ':' \
|
|
||||||
--with-nth 2 \
|
|
||||||
--preview "_preview {1} {2}" \
|
|
||||||
| cut -d ":" -f2
|
|
||||||
)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z $selected ]]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
selected_name="ssh_$selected"
|
|
||||||
tmux_running=$(pgrep tmux)
|
|
||||||
|
|
||||||
if [[ -z $TMUX ]] && [[ -z $tmux_running ]]; then
|
|
||||||
tmux new-session -s $selected_name -c $selected ssh "$selected"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! tmux has-session -t=$selected_name 2> /dev/null; then
|
|
||||||
tmux new-session -ds $selected_name -c $selected ssh "$selected"
|
|
||||||
fi
|
|
||||||
|
|
||||||
tmux switch-client -t $selected_name
|
|
||||||
}
|
|
||||||
|
|
||||||
main "$@"
|
|
||||||
|
|
|
@ -4,9 +4,6 @@ export XDG_CACHE_HOME="$HOME/.cache"
|
||||||
export XDG_DATA_HOME="$HOME/.local/share"
|
export XDG_DATA_HOME="$HOME/.local/share"
|
||||||
export XDG_STATE_HOME="$HOME/.local/state"
|
export XDG_STATE_HOME="$HOME/.local/state"
|
||||||
|
|
||||||
# ~/.local/bin
|
|
||||||
export PATH="$HOME/.local/bin:$PATH"
|
|
||||||
|
|
||||||
# brew sbin
|
# brew sbin
|
||||||
export PATH="/opt/homebrew/sbin:$PATH"
|
export PATH="/opt/homebrew/sbin:$PATH"
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
alias z="exec zsh"
|
alias z="exec zsh"
|
||||||
alias t="tmux a || ~/.config/tmux/tmux-sessionizer ~"
|
alias t="tmux a || tmux new-session -s $(whoami) -c ~"
|
||||||
alias n=nvim_ve
|
alias n=nvim_ve
|
||||||
# alias vim=nvim_ve
|
# alias vim=nvim_ve
|
||||||
alias s="ssh-menu"
|
alias s="ssh-menu"
|
||||||
|
@ -22,9 +22,3 @@ alias ci="glab ci list"
|
||||||
alias bm=batman
|
alias bm=batman
|
||||||
alias grow="~/.local/bin/cbonsai -liWC -M 15 -t 2 -w 60 -s $(date +%s)"
|
alias grow="~/.local/bin/cbonsai -liWC -M 15 -t 2 -w 60 -s $(date +%s)"
|
||||||
alias clean_ds_store='find . -name ".DS_Store" -type f -delete -print'
|
alias clean_ds_store='find . -name ".DS_Store" -type f -delete -print'
|
||||||
|
|
||||||
# ruff
|
|
||||||
alias ruffme="ruff format && ruff check --fix"
|
|
||||||
|
|
||||||
# clipboard
|
|
||||||
alias xcp="xclip -selection c"
|
|
||||||
|
|
|
@ -10,6 +10,23 @@ function nvim_ve {
|
||||||
|
|
||||||
alias nvim=nvim_ve
|
alias nvim=nvim_ve
|
||||||
|
|
||||||
|
function ffb {
|
||||||
|
if ! [[ -f package.json ]]; then
|
||||||
|
echo "no package.json"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -f yarn.lock ]]; then
|
||||||
|
PACKAGE_MANAGER=yarn
|
||||||
|
else
|
||||||
|
PACKAGE_MANAGER=npm
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n $(grep "react-scripts" package.json) ]]; then
|
||||||
|
BROWSER=none FORCE_COLOR=true "$PACKAGE_MANAGER" start | cat
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
function afm {
|
function afm {
|
||||||
RES=$(curl -s "https://$1/api/monitoring/requirements")
|
RES=$(curl -s "https://$1/api/monitoring/requirements")
|
||||||
COUNT=$(echo "$RES" | grep -c $2)
|
COUNT=$(echo "$RES" | grep -c $2)
|
||||||
|
@ -54,7 +71,7 @@ function pyinit {
|
||||||
|
|
||||||
function lh {
|
function lh {
|
||||||
if [[ -z $1 ]]; then
|
if [[ -z $1 ]]; then
|
||||||
PORT=7999
|
PORT=8000
|
||||||
else
|
else
|
||||||
PORT=$1
|
PORT=$1
|
||||||
fi
|
fi
|
||||||
|
@ -70,6 +87,32 @@ function dps {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function get_dump {
|
||||||
|
if [[ -z $1 ]]; then
|
||||||
|
echo "provide ssh host"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z $2 ]]; then
|
||||||
|
echo "provide dump destination"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
selected=$(ssh "$1" docker ps --format "{{.Names}}" | fzf)
|
||||||
|
|
||||||
|
if [[ -z $selected ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
ssh "$1" docker exec "$selected" pg_dump -U db --format=c db >"$2$(date +'%Y-%m-%dT%H.%M.%S%z')"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function ggcompile {
|
||||||
|
find -L "$GGROOT" -mindepth 1 -maxdepth 5 -type d -name .git -prune \
|
||||||
|
-exec dirname {} \; >"$GGROOT/compiled"
|
||||||
|
}
|
||||||
|
|
||||||
function tssh {
|
function tssh {
|
||||||
if [[ -z $1 ]]; then
|
if [[ -z $1 ]]; then
|
||||||
echo "provide ssh host"
|
echo "provide ssh host"
|
||||||
|
@ -79,3 +122,17 @@ function tssh {
|
||||||
ssh -t "$@" "command -v tmux && (tmux a || tmux new-session -s gorazd -c ~) || bash"
|
ssh -t "$@" "command -v tmux && (tmux a || tmux new-session -s gorazd -c ~) || bash"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function ssh-menu {
|
||||||
|
selected=$(
|
||||||
|
grep 'Host .*' ~/.ssh/config \
|
||||||
|
| grep -v '*' \
|
||||||
|
| sed 's/Host \(.*\)/\1/' \
|
||||||
|
| fzf --cycle --bind 'tab:toggle-up,btab:toggle-down'
|
||||||
|
)
|
||||||
|
|
||||||
|
if [[ -z $selected ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
ssh "$selected"
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue