#! /usr/bin/env sed 2,5!d;s/^#.// # This script must be sourced from within a shell # and not executed. For instance with: # # . ~/.commonfunc # # {{@@ header() @@}} # ####################################### # Function description. # Globals: # None # Arguments: # None # Outputs: # None # Returns: # None ####################################### # eza - set aliasses for eza to use it as ls replacement if [[ $(command -v eza) ]]; then ####################################### # Run eza with a standard set of options. # Globals: # None # Arguments: # n arguments for using / configuring eza # Outputs: # Writes file and directory list to stdout # Returns: # None ####################################### ezafunc() { eza -l -F -g -h --git --group-directories-first --icons ${@:-} } ####################################### # Run eza in a ls -l style. # Globals: # None # Arguments: # Depth modifier, for how many level of directories should be shown # Outputs: # None # Returns: # None ####################################### ezafunc::l() { ezafunc -T -L ${@:-1} } ####################################### # Run eza in a ls -la style. # Globals: # None # Arguments: # Depth modifier, for how many level of directories should be shown # Outputs: # None # Returns: # None ####################################### ezafunc::la() { ezafunc -a -T -L ${@:-1} } ####################################### # Run eza in a ls -la style with extended information. # Globals: # None # Arguments: # Depth modifier, for how many level of directories should be shown # Outputs: # None # Returns: # None ####################################### ezafunc::le() { ezafunc -a -T -L ${@:-1} --extended } alias l='ezafunc::l' alias la='ezafunc::la' alias le='ezafunc::le' alias ll='ezafunc::l 2' alias lla='ezafunc::la 2' alias lle='ezafunc::le 2' fi ####################################### # wttr - show the weather forecast in Terminal. # Globals: # None # Arguments: # Location based on City, 3-letter airport code or '~Special+Location' # Outputs: # None # Returns: # None ####################################### wttr() { if [ -z "${1}" ]; then curl http://wttr.in elif [[ "${1}" == "help" ]]; then cat << EOF usage: wttr (City|3-letter airport code|'~Special+Location') City: Just write down the name of the city. e.G.: wttr London 3-letter airport code: Use 3-letter airport codes in order to get the weather information at a certain airport. e.G.: wttr muc #for Munich Internation Airpot, Germany Special Location: Let's say you'd like to get the weather for a geographical location other than a town or city - maybe an attraction in a city, a mountain name, or some special location. Add the character '~' before the name to look up that special location name before the weather is then retrieved. e.G.: wttr '~Eiffel+Tower' wttr '~Kilimanjaro' EOF else curl http://wttr.in/${1} fi } {%@@ if profile == 'WVDEWOBMC001307' or profile == 'susanoo.local' @@%} ####################################### # Shows a netstat -tulpn styled output on mac. # Globals: # None # Arguments: # None # Outputs: # None # Returns: # None ####################################### macnst() { netstat -Watnlv | grep LISTEN | awk '{"ps -o comm= -p " $9 | getline procname;colred="\033[01;31m";colclr="\033[0m"; print colred "proto: " colclr $1 colred " | addr.port: " colclr $4 colred " | pid: " colclr $9 colred " | name: " colclr procname; }' | column -t -s "|" } ####################################### # Get current active Hardware Port. # Globals: # None # Arguments: # None # Outputs: # Writes Network service, device and mac address to stdout, when not called by another function # Returns: # _currentservice ####################################### confv6::get_active_network_device() { local services=$(networksetup -listnetworkserviceorder | grep 'Hardware Port') while read line; do local sname=$(echo ${line} | awk -F "(, )|(: )|[)]" '{print $2}') local sdev=$(echo ${line} | awk -F "(, )|(: )|[)]" '{print $4}') #echo "Current service: $sname, $sdev, $currentservice" if [ -n "${sdev}" ]; then local ifout="$(ifconfig ${sdev} 2>/dev/null)" echo "${ifout}" | grep 'status: active' > /dev/null 2>&1 local rc="$?" if [ "$rc" -eq 0 ]; then _currentservice="${sname}" local _currentdevice="${sdev}" local _currentmac=$(echo "${ifout}" | awk '/ether/{print $2}') fi fi done <<< "$(echo "$services")" if [[ ${#funcstack[@]} -le 1 ]]; then if [ -n "${_currentservice}" ]; then echo "Network Service: ${_currentservice}" echo "Device: ${_currentdevice}" echo "Mac Address: ${_currentmac}" else >&2 echo "Could not find current service" return 1 fi elif [[ ${#funcstack[@]} -ge 2 ]]; then if [ -n "${_currentservice}" ]; then return else return 1 fi fi } ####################################### # Unsets used variabls. # Globals: # None # Arguments: # None # Outputs: # None # Returns: # None ####################################### confv6::unset() { unset service unset configuration unset address unset prefixlength unset router unset help unset show return } ####################################### # Enable IPv6 on a interface (by default it's using the active interface and setting the network service for IPv6 to automatic). # Globals: # None # Arguments: # None # Outputs: # Writes device status message to stdout or errors to stderr # Returns: # None ####################################### confv6() { # Brace expansions are great for specifying short and long # option names without duplicating any information. zparseopts -D -F -K -- \ {h,-help}=help \ {s,-show}=show \ {n,-network-service-name}:=service \ {c,-configuration}:=configuration \ {a,-address}:=address \ {p,-prefixlength}:=prefixlength \ {r,-router}:=router || return 1 # zparseopts prints an error message if it cannot parse # arguments, so we can simply return on error. if (( $#help )); then print -rC1 -- \ "$0 [-h|--help]" \ "$0 [-n|--network-service-name=] [-c|--configuration=] [-a|--address=
] [-p|--prefixlength=] [-r|--router=]" \ "E.g.:" \ " Set the IPv6 configuration to automatic for the current active network service:" \ " $0" \ " Set the IPv6 configuation to off for the current active network service:" \ " $0 -c=off" \ " Set the IPv6 configuration to manual for a specified network service:" \ " $0 -n='USB 10/100/1000 LAN' -c='manual -a fd00:c0de:cafe::2' -p='64' -r='fd00:c0de:cafe::1'" confv6::unset return fi if [[ -z ${service} ]]; then confv6::get_active_network_device if [[ ${?} -ne 0 ]]; then >&2 echo "Either no active Network service found nor specified via options" return 2 else service=${_currentservice} fi else service=${(q+)service[-1]/=} fi if [[ -n ${configuration} ]]; then configuration=${(q+)configuration[-1]/=} fi if [[ -n ${address} ]]; then address=${(q+)address[-1]/=} fi if [[ -n ${prefixlength} ]]; then prefixlength=${(q+)prefixlength[-1]/=} fi if [[ -n ${router} ]]; then router=${(q+)router[-1]/=} fi if (( $#show )); then networksetup -getinfo "${service}" confv6::unset return fi if [[ ${configuration} == "automatic" || -z ${configuration} ]]; then networksetup -setv6automatic "${service}" networksetup -getinfo "${service}" confv6::unset return fi if [[ ${configuration} == "manual" ]]; then if [[ -n ${address} && -n ${prefixlength} && -n ${router} ]]; then >&2 print -rC1 -- \ "-c='manual' requires the options:" \ " [-a|--address=
] [-p|--prefixlength=] [-r|--router=]" return 3 fi networksetup -setv6manual "${service}" "${address}" "${prefixlength}" "${router}" networksetup -getinfo "${service}" confv6::unset return fi if [[ ${configuration} == "link-local" ]]; then networksetup -setv6LinkLocal "${service}" networksetup -getinfo "${service}" confv6::unset return fi if [[ ${configuration} == "off" ]]; then networksetup -setv6off "${service}" networksetup -getinfo "${service}" confv6::unset return fi if [[ -n ${configuration} ]]; then print -rC1 -- \ >&2 "Wrong configuration option for [-c|--configuration=]." return 4 fi if [[ -z ${return_code} ]]; then return 5 fi confv6::unset >&2 echo "General error. Actually I don't know what went wrong ¯\_(ツ)_/¯" return 5 } ####################################### # Runs dotdrop installed by uv with the cfg option set to my dotdrop config file in my .files repo # Globals: # None # Arguments: # n arguments for using / configuring dotdrop # Outputs: # None # Returns: # None ####################################### dotdrop() { {{@@ env['HOME'] @@}}/.local/bin/dotdrop --cfg={{@@ env['HOME'] @@}}/.files/config.yaml ${@} } {%@@ endif @@%}{%@@ if profile == 'WVDEWOBMC001307' @@%} setProxyEnv() { local HIGHLIGHT='\033[36;1m' local RESET='\033[0;0m' local PROXY='127.0.0.1:9000' local PROXY_CFG_HTTP="${PROXY}" local PROXY_CFG_HTTPS="${PROXY}" local NO_PROXY_CFG="127.0.0.1,localhost,vw.vwg" export NO_PROXY="${NO_PROXY_CFG}" export no_proxy="${NO_PROXY_CFG}" export HTTP_PROXY="${PROXY_CFG_HTTP}" export HTTPS_PROXY="${PROXY_CFG_HTTPS}" export http_proxy="${PROXY_CFG_HTTP}" export https_proxy="${PROXY_CFG_HTTPS}" export GIT_SSH_COMMAND='ssh -o ProxyCommand="/opt/homebrew/bin/corkscrew localhost 9000 %h %p"' [[ -d "{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macsys/Data" ]] && local TAILSCALEPATH="{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macsys/Data/tailscaled-env.txt" || true [[ -d "{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macos.network-extension/Data" ]] && local TAILSCALEPATH="{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macos.network-extension/Data/tailscaled-env.txt" || true [[ -d "/etc/tailscale" ]] && local TAILSCALEPATH="/etc/tailscale/tailscaled-env.txt" || true if [[ -n ${TAILSCALEPATH} ]]; then cat < "${TAILSCALEPATH}" NO_PROXY="${NO_PROXY_CFG}" no_proxy="${NO_PROXY_CFG}" HTTP_PROXY="${PROXY_CFG_HTTP}" HTTPS_PROXY="${PROXY_CFG_HTTPS}" http_proxy="${PROXY_CFG_HTTP}" https_proxy="${PROXY_CFG_HTTPS}" EOF fi echo -e "\n✈️ exported zscaler proxy: ${HIGHLIGHT}http://${PROXY}${RESET}" } unsetProxyEnv() { unset NO_PROXY unset HTTP_PROXY unset HTTPS_PROXY unset no_proxy unset http_proxy unset https_proxy unset GIT_SSH_COMMAND [[ -d "{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macsys/Data" ]] && local TAILSCALEPATH="{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macsys/Data/tailscaled-env.txt" || true [[ -d "{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macos.network-extension/Data" ]] && local TAILSCALEPATH="{{@@ env['HOME'] @@}}/Library/Containers/io.tailscale.ipn.macos.network-extension/Data/tailscaled-env.txt" || true [[ -d "/etc/tailscale" ]] && local TAILSCALEPATH="/etc/tailscale/tailscaled-env.txt" || true if [[ -n ${TAILSCALEPATH} ]]; then rm "${TAILSCALEPATH}" fi echo -e "\n🔄 removed zscaler proxy cofiguration" } setVpnGitRemote() { local ORIGIN=vpn #e.g. local HIGHLIGHT='\033[36;1m' local RESET='\033[0;0m' local repo="ssh://git@vpn.github.com:443/${$(git config remote.origin.url)#*git@github.com:}" git remote add ${ORIGIN} "${repo}" 2> /dev/null echo -e "🔗 git remote (${HIGHLIGHT}${ORIGIN}${RESET}): ${HIGHLIGHT}${repo}${RESET}\n" } {%@@ endif @@%}