|
| 1 | +# Enable Powerlevel10k instant prompt. Should stay close to the top of ~/.zshrc. |
| 2 | +# Initialization code that may require console input (password prompts, [y/n] |
| 3 | +# confirmations, etc.) must go above this block; everything else may go below. |
| 4 | +if [[ -r "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh" ]]; then |
| 5 | + source "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh" |
| 6 | +fi |
| 7 | + |
| 8 | +# Which plugins would you like to load? |
| 9 | +# Standard plugins can be found in $ZSH/plugins/ |
| 10 | +# Custom plugins may be added to $ZSH_CUSTOM/plugins/ |
| 11 | +# Example format: plugins=(rails git textmate ruby lighthouse) |
| 12 | +# Add wisely, as too many plugins slow down shell startup. |
| 13 | +plugins=(git) |
| 14 | + |
| 15 | +# User configuration |
| 16 | +# export MANPATH="/usr/local/man:$MANPATH" |
| 17 | +# You may need to manually set your language environment |
| 18 | +# export LANG=en_US.UTF-8 |
| 19 | + |
| 20 | +# Preferred editor for local and remote sessions |
| 21 | +# if [[ -n $SSH_CONNECTION ]]; then |
| 22 | +# export EDITOR='vim' |
| 23 | +# else |
| 24 | +# export EDITOR='nvim' |
| 25 | +# fi |
| 26 | +export EDITOR=vim |
| 27 | +export VISUAL=vim |
| 28 | +# Compilation flags |
| 29 | +# export ARCHFLAGS="-arch $(uname -m)" |
| 30 | +alias claude-e2e="CLAUDE_CONFIG_DIR=~/.claude-e2e claude" |
| 31 | + |
| 32 | +# Keep BSD ls colorized on macOS terminals (Ghostty/Starship only render these colors). |
| 33 | +export CLICOLOR=1 |
| 34 | +alias ls='ls -G' |
| 35 | + |
| 36 | +export PATH=$PATH:~/.local/bin |
| 37 | +export MYSQLCLIENT_CFLAGS=$(mysql_config --cflags) |
| 38 | +export MYSQLCLIENT_LDFLAGS=$(mysql_config --libs) |
| 39 | +export GOPATH="${HOME}/code/go" |
| 40 | + |
| 41 | +export GPG_KEY_ID=72980C0F4BF701C8 |
| 42 | + |
| 43 | +E2E_AGENT_PROFILES_DIR="${HOME}/.config/clawable" |
| 44 | +E2E_AGENT_ENV_FILE="${E2E_AGENT_PROFILES_DIR}/.env_mac" |
| 45 | + |
| 46 | +if [[ -f "${E2E_AGENT_ENV_FILE}" ]]; then |
| 47 | + set -a |
| 48 | + source "${E2E_AGENT_ENV_FILE}" |
| 49 | + set +a |
| 50 | + echo "\033[32m✔\033[0m Found ${E2E_AGENT_ENV_FILE}" |
| 51 | +elif command -v pass-cli >/dev/null 2>&1; then |
| 52 | + _pass_field() { |
| 53 | + pass-cli item view --vault-name AGENTS_BUFFET --item-title "$1" --field "$2" 2>/dev/null |
| 54 | + } |
| 55 | + _emit() { echo "export $1=\"$2\"" >> "${E2E_AGENT_ENV_FILE}"; export "$1=$2"; } |
| 56 | + |
| 57 | + mkdir -p "${E2E_AGENT_PROFILES_DIR}" |
| 58 | + : > "${E2E_AGENT_ENV_FILE}" |
| 59 | + chmod 600 "${E2E_AGENT_ENV_FILE}" |
| 60 | + |
| 61 | + _ok() { echo "\033[32m✔\033[0m $1"; } |
| 62 | + _warn() { echo "\033[33m⚠\033[0m $1"; } |
| 63 | + |
| 64 | + # Simple keys: vault title = env var, password field = value |
| 65 | + _simple_keys=( |
| 66 | + OLLAMA_CLOUD_API_KEY |
| 67 | + GITHUB_PERSONAL_ACCESS_TOKEN |
| 68 | + GITLAB_PERSONAL_ACCESS_TOKEN |
| 69 | + MODAL_API_KEY |
| 70 | + MOONSHOT_API_KEY |
| 71 | + OPENAI_API_KEY |
| 72 | + ZAI_API_KEY |
| 73 | + MINIMAX_API_KEY |
| 74 | + OPENROUTER_API_KEY |
| 75 | + NPM_TOKEN |
| 76 | + ) |
| 77 | + for _k in "${_simple_keys[@]}"; do |
| 78 | + _v="$(_pass_field "$_k" password)" |
| 79 | + if [[ -n "$_v" ]]; then |
| 80 | + _emit "$_k" "$_v" |
| 81 | + _ok "Pulled ${_k}" |
| 82 | + else |
| 83 | + _warn "Skipped ${_k} (not found)" |
| 84 | + fi |
| 85 | + done |
| 86 | + |
| 87 | + # Docker registries: pull credentials and login |
| 88 | + _docker_registries=(INFRA MARKETPLACE MYACCOUNT) |
| 89 | + for _name in "${_docker_registries[@]}"; do |
| 90 | + _url="$(_pass_field "DOCKER_REGISTRY_${_name}" url)" |
| 91 | + _u="$(_pass_field "DOCKER_REGISTRY_${_name}" username)" |
| 92 | + _p="$(_pass_field "DOCKER_REGISTRY_${_name}" password)" |
| 93 | + if [[ -n "$_u" && -n "$_p" ]]; then |
| 94 | + _emit "DOCKER_USER_${_name}" "$_u" |
| 95 | + _emit "DOCKER_PASSWORD_${_name}" "$_p" |
| 96 | + _ok "Pulled DOCKER_REGISTRY_${_name}" |
| 97 | + if command -v docker >/dev/null 2>&1 && [[ -n "$_url" ]]; then |
| 98 | + if ! echo "$_p" | docker login "$_url" -u "$_u" --password-stdin 2>&1 | grep -q "Login Succeeded"; then |
| 99 | + _warn "Docker login failed: $_url (check credentials and registry availability)" |
| 100 | + else |
| 101 | + _ok "Docker login: $_url" |
| 102 | + fi |
| 103 | + fi |
| 104 | + elif [[ -n "$_u" || -n "$_p" ]]; then |
| 105 | + _warn "Partial credentials for DOCKER_REGISTRY_${_name}" |
| 106 | + else |
| 107 | + _warn "Skipped DOCKER_REGISTRY_${_name}" |
| 108 | + fi |
| 109 | + done |
| 110 | + |
| 111 | + unset _k _v _u _p _url _name _simple_keys _docker_registries |
| 112 | + unset -f _pass_field _emit _ok _warn |
| 113 | +fi |
| 114 | +eval "$("${HOME}/.local/bin/mise" activate zsh)" |
| 115 | + |
| 116 | +export PATH="/opt/homebrew/opt/libxml2/bin:${HOME}/.local/share/mise/shims:${HOME}/.bun/bin:$PATH" |
| 117 | + |
| 118 | +eval "$(starship init zsh)" |
| 119 | + |
| 120 | +test -e "${HOME}/.iterm2_shell_integration.zsh" && source "${HOME}/.iterm2_shell_integration.zsh" |
| 121 | + |
| 122 | +# opencode |
| 123 | +export PATH="${HOME}/.opencode/bin:/usr/local/bin:${HOME}/bin:$PATH" |
| 124 | + |
| 125 | +# bun completions |
| 126 | +[ -s "${HOME}/.bun/_bun" ] && source "${HOME}/.bun/_bun" |
| 127 | + |
| 128 | +export PATH="/opt/homebrew/opt/trash/bin:$PATH" |
| 129 | + |
| 130 | +# Upgrade all AI coding tools in one shot |
| 131 | +upgrade-ai() { |
| 132 | + claude upgrade |
| 133 | + opencode upgrade |
| 134 | + kilo upgrade |
| 135 | + npm install -g @openai/codex @mariozechner/pi-coding-agent @indykish/oracle |
| 136 | +} |
0 commit comments