workstation/roles/home-cli/files/profile

435 lines
13 KiB
Text
Raw Normal View History

#!/bin/sh
2023-03-29 12:28:53 +00:00
# Set up XDG variables. See:
# https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html
2024-03-18 19:43:43 +00:00
export XDG_DATA_DIRS=${XDG_DATA_DIRS:-/usr/local/share:/usr/share:/usr/pkg/share}
export XDG_CONFIG_DIRS=${XDG_CONFIG_DIRS:-/usr/local/etc/xdg:/etc/xdg}
export XDG_DATA_HOME="${XDG_DATA_HOME:-$HOME/.local/share}"
export XDG_CACHE_HOME="${XDG_CACHE_HOME:-$HOME/.cache}"
export XDG_CONFIG_HOME="${XDG_CONFIG_HOME:-$HOME/.config}"
export XDG_STATE_HOME="${XDG_STATE_HOME:-$HOME/.local/state}"
2024-03-28 14:38:40 +00:00
export XDG_RUNTIME_DIR="${XDG_RUNTIME_DIR:-$HOME/.run}"
# Set up XDG variables. See:
# https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html
if [ ! -d "$XDG_DATA_HOME" ] ; then install -d -m 0700 "$XDG_DATA_HOME" ; fi
if [ ! -d "$XDG_CACHE_HOME" ] ; then install -d -m 0700 "$XDG_CACHE_HOME" ; fi
if [ ! -d "$XDG_CONFIG_HOME" ] ; then install -d -m 0700 "$XDG_CONFIG_HOME" ; fi
if [ ! -d "$XDG_STATE_HOME" ] ; then install -d -m 0700 "$XDG_STATE_HOME" ; fi
2024-03-28 14:38:40 +00:00
if [ ! -d "$XDG_RUNTIME_DIR" ] ; then install -d -m 0700 "$XDG_RUNTIME_DIR" ; fi
if [ ! -d "$HOME/.local/bin" ] ; then install -d -m 0700 "$HOME/.local/bin" ; fi
# Locale and language.
export TZ=Europe/London # Can override this elsewhere if needed.
2025-01-03 11:11:55 +00:00
if [ -r "$XDG_CONFIG_HOME/locale.conf" ]
then
2022-11-28 22:45:54 +00:00
. "$XDG_CONFIG_HOME/locale.conf"
fi
2023-03-29 12:28:53 +00:00
export ANSIBLE_NOCOWS=1
export BLOCKSIZE=K
2023-06-02 13:11:33 +00:00
export DOTNET_CLI_TELEMETRY_OPTOUT=1
2023-06-29 10:10:14 +00:00
export DOTNET_NOLOGO=1
export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1
2023-03-29 12:28:53 +00:00
export ENV="$HOME/.shrc"
2024-05-21 08:37:44 +00:00
export FOSSIL_USER=${USER:-${LOGNAME:-${USERNAME:-root}}}
2023-03-29 12:28:53 +00:00
export GOTELEMETRY=off
export HISTCONTROL=ignorespace:ignoredups
export PAGER=less
export PAPERSIZE=a4
export POWERSHELL_TELEMETRY_OPTOUT=1
2023-06-21 18:29:07 +00:00
export POWERSHELL_UPDATE_CHECK=LTS
2023-03-29 12:28:53 +00:00
export PYTHONWARNINGS=ignore::UserWarning
export VIRSH_DEFAULT_CONNECT_URI=qemu:///session
2024-07-01 15:38:19 +00:00
if [ -d /usr/lib64/dotnet ]
then
export DOTNET_ROOT="/usr/lib64/dotnet" # DNF package
else
export DOTNET_ROOT="$HOME/.dotnet" # https://aka.ms/dotnet/download
fi
2023-03-29 14:00:32 +00:00
if ! [ -x "$HOME/data" ]
2023-03-29 12:28:53 +00:00
then
2023-03-29 14:00:32 +00:00
install -d -m 0700 "$HOME/data"
fi
# Desktop files (used by desktop environments within both X11 and Wayland) are
# looked for in XDG_DATA_DIRS; make sure it includes the relevant directory for
# snappy applications' desktop files.
_snap_xdg_path=/var/lib/snapd/desktop
if [ -x /usr/lib/snapd/snapd ] && [ -n "${XDG_DATA_DIRS##*${_snap_xdg_path}}" ] && [ -n "${XDG_DATA_DIRS##*${_snap_xdg_path}:*}" ]
then
2022-11-28 22:45:54 +00:00
XDG_DATA_DIRS="${XDG_DATA_DIRS}:${_snap_xdg_path}"
fi
unset _snap_xdg_path
2022-12-11 20:18:26 +00:00
# Same as above for Flatpak.
_flatpak_xdg_path="$XDG_DATA_HOME/flatpak/exports/share"
if [ -x /usr/bin/flatpak ] && [ -n "${XDG_DATA_DIRS##*${_flatpak_xdg_path}}" ] && [ -n "${XDG_DATA_DIRS##*${_flatpak_xdg_path}:*}" ]
then
XDG_DATA_DIRS="${XDG_DATA_DIRS}:${_flatpak_xdg_path}"
fi
unset _flatpak_xdg_path
2023-08-31 22:07:36 +00:00
# Basic exports.
export HISTFILE=""
2024-11-19 12:18:03 +00:00
export PS1='\$ '
2023-08-31 22:07:36 +00:00
export TIME_STYLE=long-iso # Used by GNU 'ls'.
# Bash-specific settings that will not work in other Bourne-compatible shells.
if [ -n "$BASH_VERSION" ]
then
2022-11-28 22:45:54 +00:00
set -o emacs
set -o noclobber
shopt -s histappend
bind '"\e[1;5C": forward-word'
bind '"\e[1;5D": backward-word'
bind '"\e[A": history-search-backward'
bind '"\e[B": history-search-forward'
bind 'set bell-style none'
bind 'set completion-ignore-case on'
2024-09-23 15:51:28 +00:00
bind 'set disable-completion on' # Masochist mode.
2022-11-28 22:45:54 +00:00
bind 'set enable-bracketed-paste off'
export BASH_ENV="$HOME/.bashrc"
elif [ -n "$ZSH_VERSION" ]
then
2022-11-28 22:45:54 +00:00
autoload -Uz compinit && compinit
autoload -Uz history-search-end
zstyle ':completion:*' matcher-list 'm:{a-z}={A-Za-z}'
zle -N history-beginning-search-backward-end history-search-end
zle -N history-beginning-search-forward-end history-search-end
bindkey -e
bindkey "^[[1;5C" forward-word
bindkey "^[[1;5D" backward-word
bindkey "^[[3~" delete-char
bindkey "^[[A" history-beginning-search-backward-end
bindkey "^[[B" history-beginning-search-forward-end
bindkey "^[OA" history-beginning-search-backward-end
bindkey "^[OB" history-beginning-search-forward-end
else
2022-11-28 22:45:54 +00:00
# POSIX-compatible prompt.
if [ "$(uname -s)" = FreeBSD ]
then
bind "^W" ed-delete-prev-word
bind "^[[1;5C" em-next-word
bind "^[[1;5D" ed-prev-word
fi
2024-03-16 20:38:55 +00:00
( set -o tabcomplete 2>/dev/null ) && set -o tabcomplete
fi
2023-09-20 20:40:37 +00:00
if [ "$(uname -s)" = NetBSD ]
then
export PKG_PATH="https://cdn.NetBSD.org/pub/pkgsrc/packages/NetBSD/$(uname -p)/$(uname -r|cut -f '1 2' -d.|cut -f 1 -d_)/All"
2023-09-20 20:40:37 +00:00
fi
_acp_add_path () {
2022-11-28 22:45:54 +00:00
if [ -n "$1" ] && [ -d "$1" ]
then
case ":$PATH:" in
*:"$1":*)
return
;;
*)
PATH="$PATH:$1"
export PATH
return
;;
esac
fi
}
2022-10-13 10:18:39 +00:00
# First in the list means first in the path.
# Flatpak extensions are named `org.freedesktop.Sdk.Extension.NAME` and get
# installed to `/usr/lib/sdk/NAME/bin`.
2022-10-13 10:18:39 +00:00
PATH=/usr/bin
for dir in "$HOME/.local/bin" \
2023-02-18 10:38:27 +00:00
"$ACP/bin" \
2023-05-24 09:13:19 +00:00
"$XDG_DATA_HOME/JetBrains/Toolbox/scripts" \
2023-05-16 15:16:29 +00:00
/ucrt64/bin \
/usr/lib/sdk/texlive/bin \
/usr/lib/sdk/texlive/bin/x86_64-linux \
/usr/lib/sdk/rust-nightly/bin \
/usr/lib/sdk/rust-stable/bin \
/usr/lib/sdk/golang/bin \
2023-02-18 10:38:27 +00:00
"$XDG_DATA_HOME/flatpak/exports/bin" \
2023-06-13 18:05:37 +00:00
"$HOME/.dotnet/tools" \
2023-02-18 10:38:27 +00:00
"$HOME/.cargo/bin" \
2023-05-01 20:52:46 +00:00
"$HOME/opt/go/bin" \
2023-02-18 10:38:27 +00:00
"$XDG_DATA_HOME/gem/ruby/bin" \
2023-03-09 20:38:41 +00:00
"$HOME/opt/node/bin" \
2023-09-22 08:04:49 +00:00
/usr/games \
2023-02-18 10:38:27 +00:00
/usr/local/bin \
/usr/local/sbin \
/opt/local/bin \
/opt/local/sbin \
/var/lib/flatpak/exports/bin \
/app/bin \
2024-03-16 20:38:55 +00:00
/usr/pkg/bin \
/usr/pkg/sbin \
/usr/X11R7/bin \
2023-08-24 01:03:46 +00:00
/usr/X11R6/bin \
2023-02-18 10:38:27 +00:00
/usr/sbin \
/bin \
/sbin
do
2022-11-28 22:45:54 +00:00
_acp_add_path "$dir"
done
2023-05-02 10:31:21 +00:00
if [ "$XDG_SESSION_TYPE" = "wayland" ]
then
export MOZ_ENABLE_WAYLAND=1
fi
if [ "$(uname -s)" = Darwin ]
then
2022-11-28 22:45:54 +00:00
# MacOS warns about switching from bash to zsh. Silence this.
export BASH_SILENCE_DEPRECATION_WARNING=1
fi
2022-11-28 22:45:54 +00:00
if [ -x /usr/bin/tty ]
then
2022-11-28 22:45:54 +00:00
GPG_TTY=$(tty)
export GPG_TTY
fi
2024-02-29 11:13:35 +00:00
# Set up vi/nvi/vim/nvim.
unalias nvim 2> /dev/null
unalias vim 2> /dev/null
unalias nvi 2> /dev/null
unalias vi 2> /dev/null
if command -v nvim > /dev/null
then
2024-02-29 11:13:35 +00:00
EDITOR="nvim -f"
alias vi=nvim
2024-12-17 13:12:37 +00:00
elif command -v io.neovim.nvim > /dev/null
2024-12-17 13:14:25 +00:00
then
2024-12-17 13:22:29 +00:00
# If you get the following error:
# unix_listener: cannot bind to path /run/user/XXXX/keyring/ssh: No such file or directory
# Run the following to grant NeoVim access to the SSH Agent:
2025-01-17 10:29:34 +00:00
# flatpak --user override --socket=ssh-auth io.neovim.nvim
2024-12-17 13:12:37 +00:00
EDITOR="io.neovim.nvim -f"
alias vi=io.neovim.nvim
2024-02-29 11:13:35 +00:00
elif command -v vim > /dev/null
then
EDITOR="vim -f"
2022-11-28 22:45:54 +00:00
alias vi=vim
2024-02-29 11:13:35 +00:00
elif command -v nvi > /dev/null
then
EDITOR="nvi"
alias vi=nvi
else
2024-02-29 11:13:35 +00:00
EDITOR=vi
fi
2024-02-29 11:13:35 +00:00
export EDITOR
# Use root's cache instead of having one for root and one for the user.
if [ "$(id -u)" -ne 0 ] && [ -x /usr/bin/dnf ]
then
2022-11-28 22:45:54 +00:00
alias dnf="dnf --cacheonly --nogpgcheck"
fi
# Old RHEL releases still have the original yum (not DNF).
if [ -x /usr/bin/yum ] && [ ! -x /usr/bin/dnf ]
then
2022-11-28 22:45:54 +00:00
alias dnf=yum
fi
alias 7zencrypt="7z a -t7z -p -mhe"
alias alu="apt list --upgradable"
alias asdo="apt source --download-only"
alias aurmake="makepkg -irs"
2023-09-24 20:26:16 +00:00
alias clogout="clear && logout"
alias cexit="clear && exit"
alias ip="ip -c"
alias isocal="cal --iso --reform=iso --monday --week"
2023-01-15 15:28:33 +00:00
alias isodate="date +'Date: %Y-%m-%d%nTime: %H:%M:%S%nZone: %:z%n%nWeek: %G-W%V-%u%nDay: %Y-%j'"
alias la="ls -a"
alias ll="ls -l"
alias ls="command ls -F"
alias now="date +%Y%m%dT%H%M%S%z"
2023-02-09 13:30:48 +00:00
alias nowh="date +%Y-%m-%dT%H:%M:%S%:z"
alias nowu="date -u +%Y%m%dT%H%M%SZ"
2022-10-13 10:25:03 +00:00
alias sdk="flatpak run --command=/bin/bash --share=network --filesystem=home:rw org.freedesktop.Sdk"
2022-10-12 12:19:43 +00:00
alias sdk-gnome="flatpak run --command=/bin/bash --share=network --filesystem=home:rw org.gnome.Sdk"
2024-04-15 11:04:01 +00:00
alias sl="ls -r"
alias streamenc="openssl aes-256-cbc -pbkdf2 -in - -out - -e"
alias streamdec="openssl aes-256-cbc -pbkdf2 -in - -out - -d"
2024-08-20 09:29:19 +00:00
alias tm="tmux new-session -A"
2024-08-19 08:15:30 +00:00
alias txt2pdf="soffice --infilter='Text (encoded):UTF8,,Berkeley Mono,en-GB' --convert-to pdf"
2024-10-01 14:13:44 +00:00
alias u16to8="iconv -f UTF-16 -t UTF-8"
alias wgr=wordgrinder
alias ytmp3="youtube-dl -q -x --audio-format=mp3"
alias zlu="zypper list-updates"
2024-06-22 19:27:31 +00:00
if ! command -v run0 > /dev/null
then
2024-06-22 19:34:21 +00:00
alias run0="systemd-run --service-type=exec --quiet --wait --expand-environment=false --pty --send-sighup --same-dir"
2024-06-22 19:27:31 +00:00
fi
# Language aliases.
## Fedora/RHEL/CentOS: dnf install glibc-langpack-{en,fr}
2022-09-19 12:14:30 +00:00
alias C="LANG=C.UTF-8"
alias fr="LANG=fr_FR.UTF-8"
2024-03-04 20:44:37 +00:00
alias en="LANG=en_GB.UTF-8"
# Alias dig to drill if dig is not installed.
if [ -x /usr/bin/drill ]
then
2022-11-28 22:45:54 +00:00
alias dig=drill
fi
# Set up Go.
if [ -x "$ACP/opt/go/bin/go" ] || [ -x /usr/bin/go ] || [ -x /usr/local/bin/go ]
then
2022-11-28 22:45:54 +00:00
export GOPROXY=https://proxy.golang.org
export GOPATH="$XDG_DATA_HOME/go"
if [ ! -d "$GOPATH" ]
then
mkdir -p "$GOPATH/bin"
mkdir -p "$GOPATH/pkg"
mkdir -p "$GOPATH/src"
fi
if [ -x "$ACP/opt/go/bin/go" ]
then
export GOROOT="$ACP/opt/go"
_acp_add_path "$GOROOT/bin"
fi
_acp_add_path "$GOPATH/bin"
fi
2023-03-21 14:51:42 +00:00
# Basic and extra prun (podman run) aliases.
alias prun='podman run --rm --interactive --tty --security-opt label=disable'
2023-04-03 15:11:56 +00:00
alias prunx='prun --volume "$HOME":/root --volume "$XDG_RUNTIME_DIR":"$XDG_RUNTIME_DIR" --env XDG_RUNTIME_DIR="$XDG_RUNTIME_DIR" --env XDG_SESSION_TYPE=wayland --ipc host'
2023-03-21 14:51:42 +00:00
# Tool-specific podman aliases.
alias pruncerts='prunx --volume /etc/pki/ca-trust:/etc/pki/ca-trust:ro --volume /etc/ssl/certs:/etc/ssl/certs:ro'
alias padoc='prun --volume "$(pwd)":/documents docker.io/asciidoctor/docker-asciidoctor:latest'
alias pgo='prun --volume "$(pwd)":/devel --workdir /devel docker.io/library/golang:latest'
alias prust='prun --volume "$(pwd)":/devel --workdir /devel docker.io/library/rust:latest'
# Set up SSH agent if it's not already running.
if command -v ssh-agent > /dev/null
then
2023-08-19 21:37:47 +00:00
export SSH_AUTH_SOCK="${SSH_AUTH_SOCK:-${XDG_RUNTIME_DIR:-$XDG_CONFIG_HOME}/ssh-agent.socket}"
export SSH_AGENT_PID="${SSH_AGENT_PID:-${XDG_RUNTIME_DIR:-$XDG_CONFIG_HOME}/ssh-agent.pid}"
2022-11-28 22:45:54 +00:00
ssh-add -l > /dev/null 2>&1
_acp_ssh_agent_exists=$?
if [ -S "$SSH_AUTH_SOCK" ] && [ $_acp_ssh_agent_exists -eq 2 ]
then
# Remove stale ssh-agent socket.
rm -f "$SSH_AUTH_SOCK"
fi
unset _acp_ssh_agent_exists
if [ ! -S "$SSH_AUTH_SOCK" ]
then
ssh-agent -a "$SSH_AUTH_SOCK" > /dev/null
fi
fi
# Make a directory and immediately change to it.
mkcd () {
2022-11-28 22:45:54 +00:00
if [ $# -ne 1 ]
then
echo "mkcd: incorrect arguments (one directory required)." >&2
return 1
else
mkdir -p "$1"
cd "$1" || return
fi
}
linapm () {
2022-11-28 22:45:54 +00:00
cat /sys/class/power_supply/BAT0/status
cat /sys/class/power_supply/BAT0/capacity
}
xa () {
2022-11-28 22:45:54 +00:00
out=$(xrandr --listactivemonitors | awk 'NR!=1{print " "$NF" "}')
for monitor in $out
do
m=$(echo "$monitor" | sed 's/ //g')
xrandr --output "$m" --auto
done
}
emacsro () {
2022-11-28 22:45:54 +00:00
emacs "$1" -f view-mode
}
usermotd () {
2022-11-28 22:45:54 +00:00
# OS (kernel) name and version in reverse video.
2023-02-16 21:11:41 +00:00
printf '\033[7m%s\033[0m\n' "$(uname -sr)"
2022-11-28 22:45:54 +00:00
# Distro name and version on Linux and macOS.
if [ -r /etc/os-release ]
then
2023-02-15 15:31:13 +00:00
echo " $(. /etc/os-release; echo "${PRETTY_NAME:-${NAME:-${ID:-unknown}} ${VERSION:-${VERSION_ID:-??}}}")"
2022-11-28 22:45:54 +00:00
fi
if [ "$(uname -s)" = "Darwin" ]
then
echo " $(sw_vers -productName) $(sw_vers -productVersion)"
fi
# System uptime and load averages.
uptime
# SSH keys.
if command -v ssh-add > /dev/null
then
ssh-add -l
fi
# Language for the shell.
echo "LANG=$LANG"
# Timezone.
if [ -n "$TZ" ]
then
echo "TZ=$TZ"
elif [ -x /usr/bin/timedatectl ] && [ "$(systemctl is-system-running)" != offline ]
then
timedatectl show --property=Timezone | sed 's/Timezone=/TZ=/'
fi
# Shell name and version.
if [ -n "$BASH_VERSION" ]
then
echo "bash $BASH_VERSION"
elif [ -n "$ZSH_VERSION" ]
then
echo "zsh $ZSH_VERSION"
else
echo "SHELL=$SHELL"
fi
}
simpletls () {
2022-11-28 22:45:54 +00:00
# Create a self-signed certificate with:
# openssl req -new -x509 \
# -keyout $ACP/openssl/$(hostname)-key.pem \
# -out $ACP/openssl/$(hostname-cert.pem
if [ "$1" = "-l" ]
then
openssl s_server -cert "$ACP/openssl/$(hostname)-cert.pem" -key "$HOME/data/openssl/$(hostname)-key.pem" -tls1_3 -port "$2"
else
openssl s_client -CAfile "$ACP/openssl/$1-cert.pem" -tls1_3 -connect "$1":"$2"
fi
}
tlscheck () {
2022-11-28 22:45:54 +00:00
if [ -z "$1" ]
then
echo "Usage: tlscheck hostname:port" >&2
else
openssl s_client -connect "$1" </dev/null | openssl x509 -text
fi
}
if [ -r "$XDG_CONFIG_HOME/profile.local" ]
then
2022-11-28 22:45:54 +00:00
. "$XDG_CONFIG_HOME/profile.local"
fi