You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hari Sekhon 3eaaaf07d5 updated .bash.d/aliases.sh 5 years ago
..
Makefile added Makefile 5 years ago
README.md updated README.md 5 years ago
aliases.sh updated .bash.d/aliases.sh 5 years ago
ansible.sh updated ansible.sh 5 years ago
apple.sh updated apple.sh 5 years ago
aws.sh updated aws.sh 5 years ago
colors.sh added colors.sh 5 years ago
docker.sh replaced which with type -P 5 years ago
env.sh replaced which with type -P 5 years ago
functions.sh replaced which with type -P 5 years ago
git.sh replaced which with type -P 5 years ago
gpg-agent.sh replaced which with type -P 5 years ago
java.sh updated java.sh 5 years ago
kafka.sh updated kafka.sh 5 years ago
kubernetes.sh updated kubernetes.sh 5 years ago
linux.sh updated linux.sh 5 years ago
mercurial.sh updated mercurial.sh 5 years ago
network.sh replaced which with type -P 5 years ago
os_detection.sh added os_detection.sh 5 years ago
paths.sh added ~/perl5/bin to $PATH 5 years ago
prompt.sh updated prompt.sh 5 years ago
rancid.sh replaced command -v with which as command -v picks up aliases which is not what we want to use in tests 5 years ago
screen.sh updated screen.sh 5 years ago
spinner.sh added spinner.sh 5 years ago
ssh-agent.sh updated ssh-agent.sh 5 years ago
ssh.sh replaced which with type -P 5 years ago
svn.sh updated svn.sh 5 years ago
title.sh updated title.sh 5 years ago
travis_ci.sh updated travis_ci.sh 5 years ago
vagrant.sh updated vagrant.sh 5 years ago
virtualbox.sh updated virtualbox.sh 5 years ago
welcome.sh updated welcome.sh 5 years ago
when.sh updated when.sh 5 years ago

README.md

Advanced Bashrc Code - Interactive Functions, Aliases and Shell Customizations

Advanced bashrc code I've been using for ~15 years, I've ported nearly 5000 lines to this public repo so far.

All *.sh files in this directory are automatically sourced by .bashrc at the top level which is itself designed to be sourced in your $HOME/.bashrc.

To disable any these source files, simply rename them to not match the *.sh glob, eg. => *.sh.disabled.

  • aliases.sh - general aliases
  • functions.sh - general functions
  • env.sh - general environment variables and var/unvar functions for setting environment variables for the current and all new shell sessions
  • paths.sh - deduplicated adding to $PATH for lots of common places (eg. /usr/sbin, /usr/local/bin, ~/bin) and commands to clearly print one path per line for Bash $PATH, Perl @INC and Python sys.path. Also contains technology specific paths when there is no <technology>.sh file. All other includes use add_PATH() function defined here.
  • <technology>.sh - aliases, functions and environment variables to make interactive day-to-day use of a specific technologies easier
    • Cloud / Containerization / Virtualization:
      • aws.sh - AWS functions:
        • aws_env - populates credentials from ~/.aws/credentials / ~/.boto section given as an argument to $AWS_ACCESS_KEY and $AWS_SECRET_KEY environment variables and sets $AWS_PROFILE to the profile name (defaults to the 'default' profile and creds if no argument is specified)
        • awk_token - generates a 24-hour MFA session token, exports it as $AWS_SESSION_TOKEN for use with AWS CLI, and saves it to ~/.aws/token for loading to other shells that call aws_env
      • docker.sh - Docker convenient aliases and functions like clearing old containers and dangling image layers to clean up space
      • kubernetes.sh - Kubernetes aliases and functions, managing contexts and namespaces even for periodically regenerated .kube/config with refreshed embedded certificates, switching between open source Kubernetes and Redhat OpenShift kubectl and oc commands, automating getting authentication token and Kubernetes API endpoints
      • vagrant.sh - Vagrant aliases and functions
    • Automation / Distributed Systems:
      • ansible.sh - Ansible aliases and environment variables
      • kafka.sh - Kafka environment variables for Kerberos security and CLI appropriate heap size (avoids heap allocation failures on VMs that otherwise default to using larger server configured heap size), avoiding need for common broker and zookeeper arguments when using kafka_wrappers/ scripts by setting your Kafka broker and zookeeper addresses once instead of in every command
    • Coding:
      • git.sh - Git aliases and functions
      • mercurial.sh - Mercurial aliases and functions
      • svn.sh - Svn aliases and functions
      • java.sh - Java detection and setting of $JAVA_HOME for Linux and Mac environments
    • OS:
      • apple.sh - Apple Mac OS X / macOS specific tricks
      • linux.sh - Linux specific miscellaneous bits like X.org
      • network.sh - network aliases and functions
      • ssh.sh - SSH convenience functions and key management
      • ssh-agent.sh / gpg-agent.sh - auto-starts SSH and GPG agents if not already running, stores and auto-sources their details for new shells to automatically use them
      • title.sh - auto-title tricks for Screen and Terminals

More script related functions can be found in the lib/ directory at the top level.