# Path to your oh-my-zsh installation. export ZSH="$HOME/.oh-my-zsh" export DOTNET_CLI_TELEMETRY_OPTOUT=1 export POWERSHELL_TELEMETRY_OPTOUT=1 export PROMPT_EOL_MARK='' export FZF_DEFAULT_OPTS="--preview 'bat --color=always {}'" export EDITOR='nvim' export GEM_HOME="$HOME/gems" export PATH="$HOME/.local/bin:$HOME/gems/bin:/usr/local/go/bin:$HOME/go/bin:/home/linuxbrew/.linuxbrew/bin:$PATH" export GOBIN=~/go/bin export BAT_THEME="Catppuccin Mocha" export LS_COLORS="$(vivid generate catppuccin-mocha)" export HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND="bg=none,fg=white,bold" #eval $(thefuck --alias) alias tf=tofu alias terraform=tofu alias k=kubectl alias ls='ls --color' alias vim='nvim' alias c='clear' alias pwsh='pwsh -NoLogo' alias pbpaste='xclip -selection clipboard -o' alias ls='eza' alias ll='eza -l' alias lg='lazygit' alias tree='eza -T' alias cat='bat -P' alias network='nmtui' alias docker='podman' alias sudo='sudo ' alias grep='rg' alias connectvpn='sudo openvpn ~/Documents/openvpn/openvpn.ovpn' eval "$(oh-my-posh init zsh --config ~/.config/ohmyposh/config.toml)" if command -v tmux &> /dev/null && [[ "$TERMINAL_EMULATOR" == "JetBrains-JediTerm" ]] && [[ ! "$TERM" =~ tmux ]] && [ -z "$TMUX" ]; then cwd=$(pwd) session_name="goland-$(basename "$cwd" | tr -d '.')" if tmux has-session -t $session_name; then tmux attach -t $session_name else tmux new -s $session_name fi fi #if command -v tmux &> /dev/null && [ -n "$PS1" ] && [[ ! "$TERM" =~ screen ]] && [[ ! "$TERM" =~ tmux ]] && [ -z "$TMUX" ]; then # exec tmux attach #fi if [[ -f "/opt/homebrew/bin/brew" ]] then # If you're using macOS, you'll want this enabled eval "$(/opt/homebrew/bin/brew shellenv)" fi # Set the directory we want to store zinit and plugins ZINIT_HOME="${XDG_DATA_HOME:-${HOME}/.local/share}/zinit/zinit.git" # Download Zinit, if it's not there yet if [ ! -d "$ZINIT_HOME" ]; then mkdir -p "$(dirname $ZINIT_HOME)" git clone https://github.com/zdharma-continuum/zinit.git "$ZINIT_HOME" fi # Source/Load zinit source "${ZINIT_HOME}/zinit.zsh" # Add in zsh plugins zinit light zsh-users/zsh-syntax-highlighting zinit light zsh-users/zsh-completions zinit light zsh-users/zsh-autosuggestions zinit light Aloxaf/fzf-tab # Add in snippets zinit snippet OMZP::git zinit snippet OMZP::sudo zinit snippet OMZP::archlinux zinit snippet OMZP::aws zinit snippet OMZP::kubectl zinit snippet OMZP::kubectx zinit snippet OMZP::command-not-found zinit snippet OMZP::web-search zinit snippet OMZP::jsontools zinit snippet OMZP::copypath zinit snippet OMZP::copyfile zinit snippet OMZP::copybuffer zinit snippet OMZP::dirhistory zinit snippet OMZP::history-substring-search # Load completions autoload -Uz compinit && compinit zinit cdreplay -q # Keybindings bindkey -e bindkey '^p' history-search-backward bindkey '^n' history-search-forward bindkey '^[w' kill-region bindkey "^[[1~" beginning-of-line bindkey "^[[4~" end-of-line bindkey '^[[3~' delete-char # History HISTSIZE=5000 HISTFILE=~/.zsh_history SAVEHIST=$HISTSIZE HISTDUP=erase setopt appendhistory setopt sharehistory setopt hist_ignore_space setopt hist_ignore_all_dups setopt hist_save_no_dups setopt hist_ignore_dups setopt hist_find_no_dups # Completion styling zstyle ':completion:*' matcher-list 'm:{a-z}={A-Za-z}' zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" zstyle ':completion:*' menu no zstyle ':fzf-tab:complete:cd:*' fzf-preview 'ls --color $realpath' zstyle ':fzf-tab:complete:__zoxide_z:*' fzf-preview 'ls --color $realpath' # Shell integrations #eval "$(fzf --zsh)" #eval "$(zoxide init --cmd cd zsh)" #eval "$(bw completion --shell zsh); compdef _bw bw;" source ~/.fzf.completion.zsh source ~/.fzf.key-bindings.zsh source ~/.zoxide.completions.zsh source ~/.bw.completions.zsh runinti () { fzf --zsh > ~/.fzf.completion.zsh zoxide init --cmd cd zsh > ~/.zoxide.completions.zsh bw completion --shell zsh > ~/.bw.completions.zsh } unlockbw () { export BW_SESSION="$(bw unlock --raw)" export GITLAB_TOKEN="$(bw get password cli-gitlab)" export VAULT_UNSEAL="$(bw get password cli-vault-unseal)" export VAULT_TOKEN="$(bw get password vault.internal.durp.info)" } lockbw () { unset BW_SESSION unset GITLAB_TOKEN unset VAULT_UNSEAL unset VAULT_TOKEN } unlockvault() { local POD_NAME="vault-0" local NAMESPACE="vault" local UNSEAL_KEY=$VAULT_UNSEAL local PASSWORD=$VAULT_TOKEN local K8S_API_SERVER=$(kubectl exec -it $POD_NAME -n $NAMESPACE -- printenv | grep KUBERNETES_SERVICE_HOST | cut -d "=" -f2) local JWT=$(kubectl exec -it $POD_NAME -n $NAMESPACE -- cat /var/run/secrets/kubernetes.io/serviceaccount/token) kubectl exec -it $POD_NAME -n $NAMESPACE -- /bin/sh << EOF vault operator unseal $UNSEAL_KEY vault login $PASSWORD vault write auth/kubernetes/config \ token_reviewer_jwt="${JWT}" \ kubernetes_host="https://${K8S_API_SERVER}:443" \ kubernetes_ca_cert=@/var/run/secrets/kubernetes.io/serviceaccount/ca.crt EOF } load-profile () { ansible-playbook /home/user/.dotfiles/ansible/.config/ansible/local.yml -K } function omz_urlencode() { emulate -L zsh local -a opts zparseopts -D -E -a opts r m P local in_str="$@" local url_str="" local spaces_as_plus if [[ -z $opts[(r)-P] ]]; then spaces_as_plus=1; fi local str="$in_str" # URLs must use UTF-8 encoding; convert str to UTF-8 if required local encoding=$langinfo[CODESET] local safe_encodings safe_encodings=(UTF-8 utf8 US-ASCII) if [[ -z ${safe_encodings[(r)$encoding]} ]]; then str=$(echo -E "$str" | iconv -f $encoding -t UTF-8) if [[ $? != 0 ]]; then echo "Error converting string from $encoding to UTF-8" >&2 return 1 fi fi # Use LC_CTYPE=C to process text byte-by-byte # Note that this doesn't work in Termux, as it only has UTF-8 locale. # Characters will be processed as UTF-8, which is fine for URLs. local i byte ord LC_ALL=C export LC_ALL local reserved=';/?:@&=+$,' local mark='_.!~*''()-' local dont_escape="[A-Za-z0-9" if [[ -z $opts[(r)-r] ]]; then dont_escape+=$reserved fi # $mark must be last because of the "-" if [[ -z $opts[(r)-m] ]]; then dont_escape+=$mark fi dont_escape+="]" # Implemented to use a single printf call and avoid subshells in the loop, # for performance (primarily on Windows). local url_str="" for (( i = 1; i <= ${#str}; ++i )); do byte="$str[i]" if [[ "$byte" =~ "$dont_escape" ]]; then url_str+="$byte" else if [[ "$byte" == " " && -n $spaces_as_plus ]]; then url_str+="+" elif [[ "$PREFIX" = *com.termux* ]]; then # Termux does not have non-UTF8 locales, so just send the UTF-8 character directly url_str+="$byte" else ord=$(( [##16] #byte )) url_str+="%$ord" fi fi done echo -E "$url_str" } function open_command() { local open_cmd # define the open command case "$OSTYPE" in darwin*) open_cmd='open' ;; cygwin*) open_cmd='cygstart' ;; linux*) [[ "$(uname -r)" != *icrosoft* ]] && open_cmd='nohup xdg-open' || { open_cmd='cmd.exe /c start ""' [[ -e "$1" ]] && { 1="$(wslpath -w "${1:a}")" || return 1 } } ;; msys*) open_cmd='start ""' ;; *) echo "Platform $OSTYPE not supported" return 1 ;; esac # If a URL is passed, $BROWSER might be set to a local browser within SSH. # See https://github.com/ohmyzsh/ohmyzsh/issues/11098 if [[ -n "$BROWSER" && "$1" = (http|https)://* ]]; then "$BROWSER" "$@" return fi ${=open_cmd} "$@" &>/dev/null } if [ -e /home/user/.nix-profile/etc/profile.d/nix.sh ]; then . /home/user/.nix-profile/etc/profile.d/nix.sh; fi # added by Nix installer # Install Ruby Gems to ~/gems export GEM_HOME="$HOME/gems" export PATH="$HOME/gems/bin:$PATH"