From a9c4a754b683bbae48707db87fd94235fd43e692 Mon Sep 17 00:00:00 2001 From: Chris Titus Date: Tue, 27 Sep 2022 00:24:29 -0500 Subject: [PATCH] initial commit --- .bashrc | 596 ++++++++++++++++++++++++++++++++++++++++++++++++++ setup.sh | 6 + starship.toml | 130 +++++++++++ 3 files changed, 732 insertions(+) create mode 100644 .bashrc create mode 100755 setup.sh create mode 100644 starship.toml diff --git a/.bashrc b/.bashrc new file mode 100644 index 0000000..8bea452 --- /dev/null +++ b/.bashrc @@ -0,0 +1,596 @@ +#!/bin/bash +iatest=$(expr index "$-" i) + +####################################################### +# SOURCED ALIAS'S AND SCRIPTS BY zachbrowne.me +####################################################### + +# Source global definitions +if [ -f /etc/bashrc ]; then + . /etc/bashrc +fi + +# Enable bash programmable completion features in interactive shells +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 + +####################################################### +# EXPORTS +####################################################### + +# Disable the bell +if [[ $iatest > 0 ]]; then bind "set bell-style visible"; fi + +# Expand the history size +export HISTFILESIZE=10000 +export HISTSIZE=500 + +# Don't put duplicate lines in the history and do not add lines that start with a space +export HISTCONTROL=erasedups:ignoredups:ignorespace + +# Check the window size after each command and, if necessary, update the values of LINES and COLUMNS +shopt -s checkwinsize + +# Causes bash to append to history instead of overwriting it so if you start a new terminal, you have old session history +shopt -s histappend +PROMPT_COMMAND='history -a' + +# Allow ctrl-S for history navigation (with ctrl-R) +stty -ixon + +# Ignore case on auto-completion +# Note: bind used instead of sticking these in .inputrc +if [[ $iatest > 0 ]]; then bind "set completion-ignore-case on"; fi + +# Show auto-completion list automatically, without double tab +if [[ $iatest > 0 ]]; then bind "set show-all-if-ambiguous On"; fi + +# Set the default editor +export EDITOR=nano +export VISUAL=nano +alias pico='edit' +alias spico='sedit' +alias nano='edit' +alias snano='sedit' + +# To have colors for ls and all grep commands such as grep, egrep and zgrep +export CLICOLOR=1 +export LS_COLORS='no=00:fi=00:di=00;34:ln=01;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.avi=01;35:*.fli=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.ogg=01;35:*.mp3=01;35:*.wav=01;35:*.xml=00;31:' +#export GREP_OPTIONS='--color=auto' #deprecated +alias grep="/usr/bin/grep $GREP_OPTIONS" +unset GREP_OPTIONS + +# Color for manpages in less makes manpages a little easier to read +export LESS_TERMCAP_mb=$'\E[01;31m' +export LESS_TERMCAP_md=$'\E[01;31m' +export LESS_TERMCAP_me=$'\E[0m' +export LESS_TERMCAP_se=$'\E[0m' +export LESS_TERMCAP_so=$'\E[01;44;33m' +export LESS_TERMCAP_ue=$'\E[0m' +export LESS_TERMCAP_us=$'\E[01;32m' + +####################################################### +# MACHINE SPECIFIC ALIAS'S +####################################################### + +# Alias's for SSH +# alias SERVERNAME='ssh YOURWEBSITE.com -l USERNAME -p PORTNUMBERHERE' + +# Alias's to change the directory +alias web='cd /var/www/html' + +# Alias's to mount ISO files +# mount -o loop /home/NAMEOFISO.iso /home/ISOMOUNTDIR/ +# umount /home/NAMEOFISO.iso +# (Both commands done as root only.) + +####################################################### +# GENERAL ALIAS'S +####################################################### +# To temporarily bypass an alias, we preceed the command with a \ +# EG: the ls command is aliased, but to use the normal ls command you would type \ls + +# 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$//'\'')"' + +# Edit this .bashrc file +alias ebrc='edit ~/.bashrc' + +# Show help for this .bashrc file +alias hlp='less ~/.bashrc_help' + +# alias to show the date +alias da='date "+%Y-%m-%d %A %T %Z"' + +# Alias's to modified commands +alias cp='cp -i' +alias mv='mv -i' +alias rm='rm -iv' +alias mkdir='mkdir -p' +alias ps='ps auxf' +alias ping='ping -c 10' +alias less='less -R' +alias cls='clear' +alias apt-get='sudo apt-get' +alias multitail='multitail --no-repeat -c' +alias freshclam='sudo freshclam' +alias vi='vim' +alias svi='sudo vi' +alias vis='vim "+set si"' + +# Change directory aliases +alias home='cd ~' +alias cd..='cd ..' +alias ..='cd ..' +alias ...='cd ../..' +alias ....='cd ../../..' +alias .....='cd ../../../..' + +# cd into the old directory +alias bd='cd "$OLDPWD"' + +# Remove a directory and all files +alias rmd='/bin/rm --recursive --force --verbose ' + +# Alias's for multiple directory listing commands +alias la='ls -Alh' # show hidden files +alias ls='ls -aFh --color=always' # add colors and file type extensions +alias lx='ls -lXBh' # sort by extension +alias lk='ls -lSrh' # sort by size +alias lc='ls -lcrh' # sort by change time +alias lu='ls -lurh' # sort by access time +alias lr='ls -lRh' # recursive ls +alias lt='ls -ltrh' # sort by date +alias lm='ls -alh |more' # pipe through 'more' +alias lw='ls -xAh' # wide listing format +alias ll='ls -Fls' # long listing format +alias labc='ls -lap' #alphabetical sort +alias lf="ls -l | egrep -v '^d'" # files only +alias ldir="ls -l | egrep '^d'" # directories only + +# alias chmod commands +alias mx='chmod a+x' +alias 000='chmod -R 000' +alias 644='chmod -R 644' +alias 666='chmod -R 666' +alias 755='chmod -R 755' +alias 777='chmod -R 777' + +# Search command line history +alias h="history | grep " + +# Search running processes +alias p="ps aux | grep " +alias topcpu="/bin/ps -eo pcpu,pid,user,args | sort -k 1 -r | head -10" + +# Search files in the current folder +alias f="find . | grep " + +# Count all files (recursively) in the current folder +alias countfiles="for t in files links directories; do echo \`find . -type \${t:0:1} | wc -l\` \$t; done 2> /dev/null" + +# To see if a command is aliased, a file, or a built-in command +alias checkcommand="type -t" + +# Show current network connections to the server +alias ipview="netstat -anpl | grep :80 | awk {'print \$5'} | cut -d\":\" -f1 | sort | uniq -c | sort -n | sed -e 's/^ *//' -e 's/ *\$//'" + +# Show open ports +alias openports='netstat -nape --inet' + +# Alias's for safe and forced reboots +alias rebootsafe='sudo shutdown -r now' +alias rebootforce='sudo shutdown -r -n now' + +# Alias's to show disk space and space used in a folder +alias diskspace="du -S | sort -n -r |more" +alias folders='du -h --max-depth=1' +alias folderssort='find . -maxdepth 1 -type d -print0 | xargs -0 du -sk | sort -rn' +alias tree='tree -CAhF --dirsfirst' +alias treed='tree -CAFd' +alias mountedinfo='df -hT' + +# Alias's for archives +alias mktar='tar -cvf' +alias mkbz2='tar -cvjf' +alias mkgz='tar -cvzf' +alias untar='tar -xvf' +alias unbz2='tar -xvjf' +alias ungz='tar -xvzf' + +# Show all logs in /var/log +alias logs="sudo find /var/log -type f -exec file {} \; | grep 'text' | cut -d' ' -f1 | sed -e's/:$//g' | grep -v '[0-9]$' | xargs tail -f" + +# SHA1 +alias sha1='openssl sha1' + +####################################################### +# SPECIAL FUNCTIONS +####################################################### + +# Use the best version of pico installed +edit () +{ + if [ "$(type -t jpico)" = "file" ]; then + # Use JOE text editor http://joe-editor.sourceforge.net/ + jpico -nonotice -linums -nobackups "$@" + elif [ "$(type -t nano)" = "file" ]; then + nano -c "$@" + elif [ "$(type -t pico)" = "file" ]; then + pico "$@" + else + vim "$@" + fi +} +sedit () +{ + if [ "$(type -t jpico)" = "file" ]; then + # Use JOE text editor http://joe-editor.sourceforge.net/ + sudo jpico -nonotice -linums -nobackups "$@" + elif [ "$(type -t nano)" = "file" ]; then + sudo nano -c "$@" + elif [ "$(type -t pico)" = "file" ]; then + sudo pico "$@" + else + sudo vim "$@" + fi +} + +# Extracts any archive(s) (if unp isn't installed) +extract () { + for archive in $*; do + if [ -f $archive ] ; then + case $archive in + *.tar.bz2) tar xvjf $archive ;; + *.tar.gz) tar xvzf $archive ;; + *.bz2) bunzip2 $archive ;; + *.rar) rar x $archive ;; + *.gz) gunzip $archive ;; + *.tar) tar xvf $archive ;; + *.tbz2) tar xvjf $archive ;; + *.tgz) tar xvzf $archive ;; + *.zip) unzip $archive ;; + *.Z) uncompress $archive ;; + *.7z) 7z x $archive ;; + *) echo "don't know how to extract '$archive'..." ;; + esac + else + echo "'$archive' is not a valid file!" + fi + done +} + +# Searches for text in all files in the current folder +ftext () +{ + # -i case-insensitive + # -I ignore binary files + # -H causes filename to be printed + # -r recursive search + # -n causes line number to be printed + # optional: -F treat search term as a literal, not a regular expression + # optional: -l only print filenames and not the matching lines ex. grep -irl "$1" * + grep -iIHrn --color=always "$1" . | less -r +} + +# Copy file with a progress bar +cpp() +{ + set -e + strace -q -ewrite cp -- "${1}" "${2}" 2>&1 \ + | awk '{ + count += $NF + if (count % 10 == 0) { + percent = count / total_size * 100 + printf "%3d%% [", percent + for (i=0;i<=percent;i++) + printf "=" + printf ">" + for (i=percent;i<100;i++) + printf " " + printf "]\r" + } + } + END { print "" }' total_size=$(stat -c '%s' "${1}") count=0 +} + +# Copy and go to the directory +cpg () +{ + if [ -d "$2" ];then + cp $1 $2 && cd $2 + else + cp $1 $2 + fi +} + +# Move and go to the directory +mvg () +{ + if [ -d "$2" ];then + mv $1 $2 && cd $2 + else + mv $1 $2 + fi +} + +# Create and go to the directory +mkdirg () +{ + mkdir -p $1 + cd $1 +} + +# Goes up a specified number of directories (i.e. up 4) +up () +{ + local d="" + limit=$1 + for ((i=1 ; i <= limit ; i++)) + do + d=$d/.. + done + d=$(echo $d | sed 's/^\///') + if [ -z "$d" ]; then + d=.. + fi + cd $d +} + +#Automatically do an ls after each cd +# cd () +# { +# if [ -n "$1" ]; then +# builtin cd "$@" && ls +# else +# builtin cd ~ && ls +# fi +# } + +# Returns the last 2 fields of the working directory +pwdtail () +{ + pwd|awk -F/ '{nlast = NF -1;print $nlast"/"$NF}' +} + +# Show the current distribution +distribution () +{ + local dtype + # Assume unknown + dtype="unknown" + + # First test against Fedora / RHEL / CentOS / generic Redhat derivative + if [ -r /etc/rc.d/init.d/functions ]; then + source /etc/rc.d/init.d/functions + [ zz`type -t passed 2>/dev/null` == "zzfunction" ] && dtype="redhat" + + # Then test against SUSE (must be after Redhat, + # I've seen rc.status on Ubuntu I think? TODO: Recheck that) + elif [ -r /etc/rc.status ]; then + source /etc/rc.status + [ zz`type -t rc_reset 2>/dev/null` == "zzfunction" ] && dtype="suse" + + # Then test against Debian, Ubuntu and friends + elif [ -r /lib/lsb/init-functions ]; then + source /lib/lsb/init-functions + [ zz`type -t log_begin_msg 2>/dev/null` == "zzfunction" ] && dtype="debian" + + # Then test against Gentoo + elif [ -r /etc/init.d/functions.sh ]; then + source /etc/init.d/functions.sh + [ zz`type -t ebegin 2>/dev/null` == "zzfunction" ] && dtype="gentoo" + + # For Mandriva we currently just test if /etc/mandriva-release exists + # and isn't empty (TODO: Find a better way :) + elif [ -s /etc/mandriva-release ]; then + dtype="mandriva" + + # For Slackware we currently just test if /etc/slackware-version exists + elif [ -s /etc/slackware-version ]; then + dtype="slackware" + + fi + echo $dtype +} + +# Show the current version of the operating system +ver () +{ + local dtype + dtype=$(distribution) + + if [ $dtype == "redhat" ]; then + if [ -s /etc/redhat-release ]; then + cat /etc/redhat-release && uname -a + else + cat /etc/issue && uname -a + fi + elif [ $dtype == "suse" ]; then + cat /etc/SuSE-release + elif [ $dtype == "debian" ]; then + lsb_release -a + # sudo cat /etc/issue && sudo cat /etc/issue.net && sudo cat /etc/lsb_release && sudo cat /etc/os-release # Linux Mint option 2 + elif [ $dtype == "gentoo" ]; then + cat /etc/gentoo-release + elif [ $dtype == "mandriva" ]; then + cat /etc/mandriva-release + elif [ $dtype == "slackware" ]; then + cat /etc/slackware-version + else + if [ -s /etc/issue ]; then + cat /etc/issue + else + echo "Error: Unknown distribution" + exit 1 + fi + fi +} + +# Automatically install the needed support files for this .bashrc file +install_bashrc_support () +{ + local dtype + dtype=$(distribution) + + if [ $dtype == "redhat" ]; then + sudo yum install multitail tree joe + elif [ $dtype == "suse" ]; then + sudo zypper install multitail + sudo zypper install tree + sudo zypper install joe + elif [ $dtype == "debian" ]; then + sudo apt-get install multitail tree joe + elif [ $dtype == "gentoo" ]; then + sudo emerge multitail + sudo emerge tree + sudo emerge joe + elif [ $dtype == "mandriva" ]; then + sudo urpmi multitail + sudo urpmi tree + sudo urpmi joe + elif [ $dtype == "slackware" ]; then + echo "No install support for Slackware" + else + echo "Unknown distribution" + fi +} + +# Show current network information +netinfo () +{ + echo "--------------- Network Information ---------------" + /sbin/ifconfig | awk /'inet addr/ {print $2}' + echo "" + /sbin/ifconfig | awk /'Bcast/ {print $3}' + echo "" + /sbin/ifconfig | awk /'inet addr/ {print $4}' + + /sbin/ifconfig | awk /'HWaddr/ {print $4,$5}' + echo "---------------------------------------------------" +} + +# IP address lookup +alias whatismyip="whatsmyip" +function whatsmyip () +{ + # Dumps a list of all IP addresses for every device + # /sbin/ifconfig |grep -B1 "inet addr" |awk '{ if ( $1 == "inet" ) { print $2 } else if ( $2 == "Link" ) { printf "%s:" ,$1 } }' |awk -F: '{ print $1 ": " $3 }'; + + # Internal IP Lookup + echo -n "Internal IP: " ; /sbin/ifconfig eth0 | grep "inet addr" | awk -F: '{print $2}' | awk '{print $1}' + + # External IP Lookup + echo -n "External IP: " ; wget http://smart-ip.net/myip -O - -q +} + +# View Apache logs +apachelog () +{ + if [ -f /etc/httpd/conf/httpd.conf ]; then + cd /var/log/httpd && ls -xAh && multitail --no-repeat -c -s 2 /var/log/httpd/*_log + else + cd /var/log/apache2 && ls -xAh && multitail --no-repeat -c -s 2 /var/log/apache2/*.log + fi +} + +# Edit the Apache configuration +apacheconfig () +{ + if [ -f /etc/httpd/conf/httpd.conf ]; then + sedit /etc/httpd/conf/httpd.conf + elif [ -f /etc/apache2/apache2.conf ]; then + sedit /etc/apache2/apache2.conf + else + echo "Error: Apache config file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate httpd.conf && locate apache2.conf + fi +} + +# Edit the PHP configuration file +phpconfig () +{ + if [ -f /etc/php.ini ]; then + sedit /etc/php.ini + elif [ -f /etc/php/php.ini ]; then + sedit /etc/php/php.ini + elif [ -f /etc/php5/php.ini ]; then + sedit /etc/php5/php.ini + elif [ -f /usr/bin/php5/bin/php.ini ]; then + sedit /usr/bin/php5/bin/php.ini + elif [ -f /etc/php5/apache2/php.ini ]; then + sedit /etc/php5/apache2/php.ini + else + echo "Error: php.ini file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate php.ini + fi +} + +# Edit the MySQL configuration file +mysqlconfig () +{ + if [ -f /etc/my.cnf ]; then + sedit /etc/my.cnf + elif [ -f /etc/mysql/my.cnf ]; then + sedit /etc/mysql/my.cnf + elif [ -f /usr/local/etc/my.cnf ]; then + sedit /usr/local/etc/my.cnf + elif [ -f /usr/bin/mysql/my.cnf ]; then + sedit /usr/bin/mysql/my.cnf + elif [ -f ~/my.cnf ]; then + sedit ~/my.cnf + elif [ -f ~/.my.cnf ]; then + sedit ~/.my.cnf + else + echo "Error: my.cnf file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate my.cnf + fi +} + +# For some reason, rot13 pops up everywhere +rot13 () { + if [ $# -eq 0 ]; then + tr '[a-m][n-z][A-M][N-Z]' '[n-z][a-m][N-Z][A-M]' + else + echo $* | tr '[a-m][n-z][A-M][N-Z]' '[n-z][a-m][N-Z][A-M]' + fi +} + +# Trim leading and trailing spaces (for scripts) +trim() +{ + local var=$@ + var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters + var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters + echo -n "$var" +} +# GitHub Titus Additions + +gcom() { + git add . + git commit -m "$1" + } +lazyg() { + git add . + git commit -m "$1" + git push +} + +####################################################### +# Set the ultimate amazing command prompt +####################################################### + +alias cpu="grep 'cpu ' /proc/stat | awk '{usage=(\$2+\$4)*100/(\$2+\$4+\$5)} END {print usage}' | awk '{printf(\"%.1f\n\", \$1)}'" + +export PATH=$PATH:"/home/titus/.local/bin" + +# Install Starship - curl -sS https://starship.rs/install.sh | sh + +eval "$(starship init bash)" diff --git a/setup.sh b/setup.sh new file mode 100755 index 0000000..2f6cc84 --- /dev/null +++ b/setup.sh @@ -0,0 +1,6 @@ +#!/bin/bash + +gitpath=`pwd` + +ln -s $gitpath/.bashrc $HOME/.bashrc +ln -s $gitpath/starship.toml $HOME/.config/starship.toml diff --git a/starship.toml b/starship.toml new file mode 100644 index 0000000..bae42fe --- /dev/null +++ b/starship.toml @@ -0,0 +1,130 @@ +# Don't print a new line at the start of the prompt +# add_newline = false + +format = """ +[╭─accounts─➜⇉❯>](bold blue) $username$gcloud$aws$kubernetes +[┣─system───➜⇉❯>](bold yellow) $time$status$cmd_duration$hostname$memory_usage$jobs$battery +[┣─project──➜⇉❯>](bold red) $directory$rust$package$git_branch$git_status$golang$terraform$docker_context +[╰─cmd─➜⇉❯>](bold green) +""" + +# Replace the "❯" symbol in the prompt with "➜" +[character] # The name of the module we are configuring is "character" +success_symbol = "[➜](bold green)" # The "success_symbol" segment is being set to "➜" with the color "bold green" + +[cmd_duration] +show_milliseconds = true +# format = "took [$duration](bold yellow) " + +[kubernetes] +format = 'context: [⎈ $context \($namespace\)](bold cyan) ' +disabled = false +# [kubernetes.context_aliases] +# "dev.local.cluster.k8s" = "dev" + +[memory_usage] +format = "with$symbol [${ram} ${ram_pct}( | ${swap} ${swap_pct})]($style) " +disabled = false +threshold = -1 +symbol = " " +style = "bold dimmed green" + +[gcloud] +style = "blue" +format = '[$symbol$account(\($project\))]($style) ' +symbol = "️G⅁:☁️" +[gcloud.region_aliases] +us-central1 = "uc1" +asia-northeast1 = "an1" + +[aws] +format = '[$symbol$profile(\($region\))]($style) ' +style = "bold yellow" +symbol = "∀⍵₷☁️☁️" +[aws.region_aliases] +ap-southeast-2 = "au" +us-east-1 = "va" + +[package] +format = " package: [🎁 $version](208 bold) " + +[docker_context] +format = "docker: [🐋 $context](blue bold)" +disabled = false + +[directory] +truncation_length = 7 +truncation_symbol = "…/" + +[username] +style_user = "blue bold" +style_root = "red bold" +format = "user: [$user]($style) " +disabled = false +show_always = true + +[time] +disabled = false +format = '[\[ $time \]]($style) ' + +[hostname] +ssh_only = false +format = 'on [$hostname](bold red) ' +trim_at = "." +disabled = false + +[status] +style = "red" +symbol = "💥 " +format = '[\[$symbol$status\]]($style) ' +disabled = false + +[git_branch] +symbol = "🌱 " + +[git_status] +ahead = "⇡🏎💨${count}" +diverged = "⇕⇡😵${ahead_count}⇣${behind_count}" +behind = "⇣😰${count}" +conflicted = "🏳" +untracked = "🤷‍" +stashed = "📦" +modified = "📝" +staged = '[++\($count\)](green)' +renamed = "👅" +deleted = "🗑" + +[rust] +format = "rust: [🦀 $version](red bold)" + +[golang] +format = "go: [🏎💨 $version](bold cyan) " + +[helm] +format = "helm: [⎈ $version](bold white) " + +[jobs] +symbol = "+ " +threshold = 4 +format = "background [$symbol$number]($style) " + +[terraform] +format = "[🏎💨 $version$workspace]($style) " + +[battery] +full_symbol = "🔋" +charging_symbol = "⚡️" +discharging_symbol = "💀" + +[[battery.display]] # "bold red" style when capacity is between 0% and 10% +threshold = 10 +style = "bold red" + +[[battery.display]] # "bold yellow" style when capacity is between 10% and 30% +threshold = 30 +style = "bold yellow" + +[[battery.display]] +threshold = 100 +style = "bold green" +