Simplify `public_ip` segment
This commit is contained in:
parent
a58e8bdc8c
commit
6c352c8d5c
|
@ -475,6 +475,7 @@ prompt_public_ip() {
|
||||||
set_default POWERLEVEL9K_PUBLIC_IP_NONE ""
|
set_default POWERLEVEL9K_PUBLIC_IP_NONE ""
|
||||||
set_default POWERLEVEL9K_PUBLIC_IP_FILE "/tmp/p9k_public_ip"
|
set_default POWERLEVEL9K_PUBLIC_IP_FILE "/tmp/p9k_public_ip"
|
||||||
set_default POWERLEVEL9K_PUBLIC_IP_HOST "http://ident.me"
|
set_default POWERLEVEL9K_PUBLIC_IP_HOST "http://ident.me"
|
||||||
|
defined POWERLEVEL9K_PUBLIC_IP_METHODS || POWERLEVEL9K_PUBLIC_IP_METHODS=(wget curl dig)
|
||||||
|
|
||||||
# Do we need a fresh IP?
|
# Do we need a fresh IP?
|
||||||
local refresh_ip=false
|
local refresh_ip=false
|
||||||
|
@ -491,51 +492,33 @@ prompt_public_ip() {
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# grab a fresh IP if needed
|
# grab a fresh IP if needed
|
||||||
|
local fresh_ip
|
||||||
if [[ $refresh_ip =~ true && -w $POWERLEVEL9K_PUBLIC_IP_FILE ]]; then
|
if [[ $refresh_ip =~ true && -w $POWERLEVEL9K_PUBLIC_IP_FILE ]]; then
|
||||||
# if method specified, don't use fallback methods
|
for method in "${POWERLEVEL9K_PUBLIC_IP_METHODS[@]}"; do
|
||||||
if [[ -n $POWERLEVEL9K_PUBLIC_IP_METHOD ]] && [[ $POWERLEVEL9K_PUBLIC_IP_METHOD =~ 'wget|curl|dig' ]]; then
|
|
||||||
local method=$POWERLEVEL9K_PUBLIC_IP_METHOD
|
|
||||||
fi
|
|
||||||
if [[ -n $method ]]; then
|
|
||||||
case $method in
|
case $method in
|
||||||
'dig')
|
'dig')
|
||||||
if type -p dig >/dev/null; then
|
|
||||||
fresh_ip="$(dig +time=1 +tries=1 +short myip.opendns.com @resolver1.opendns.com 2> /dev/null)"
|
fresh_ip="$(dig +time=1 +tries=1 +short myip.opendns.com @resolver1.opendns.com 2> /dev/null)"
|
||||||
[[ "$fresh_ip" =~ ^\; ]] && unset fresh_ip
|
[[ "$fresh_ip" =~ ^\; ]] && unset fresh_ip
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
'curl')
|
'curl')
|
||||||
if [[ -z "$fresh_ip" ]] && type -p curl >/dev/null; then
|
|
||||||
fresh_ip="$(curl --max-time 10 -w '\n' "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
fresh_ip="$(curl --max-time 10 -w '\n' "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
'wget')
|
'wget')
|
||||||
if [[ -z "$fresh_ip" ]] && type -p wget >/dev/null; then
|
|
||||||
fresh_ip="$(wget -T 10 -qO- "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
fresh_ip="$(wget -T 10 -qO- "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
else
|
# If we found a fresh IP, break loop.
|
||||||
if type -p dig >/dev/null; then
|
if [[ -n "${fresh_ip}" ]]; then
|
||||||
fresh_ip="$(dig +time=1 +tries=1 +short myip.opendns.com @resolver1.opendns.com 2> /dev/null)"
|
break;
|
||||||
[[ "$fresh_ip" =~ ^\; ]] && unset fresh_ip
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$fresh_ip" ]] && type -p curl >/dev/null; then
|
|
||||||
fresh_ip="$(curl --max-time 10 -w '\n' "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$fresh_ip" ]] && type -p wget >/dev/null; then
|
|
||||||
fresh_ip="$(wget -T 10 -qO- "$POWERLEVEL9K_PUBLIC_IP_HOST" 2> /dev/null)"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
# write IP to tmp file or clear tmp file if an IP was not retrieved
|
# write IP to tmp file or clear tmp file if an IP was not retrieved
|
||||||
[[ -n $fresh_ip ]] && echo $fresh_ip > $POWERLEVEL9K_PUBLIC_IP_FILE || echo $POWERLEVEL9K_PUBLIC_IP_NONE > $POWERLEVEL9K_PUBLIC_IP_FILE
|
[[ -n $fresh_ip ]] && echo $fresh_ip > $POWERLEVEL9K_PUBLIC_IP_FILE || echo $POWERLEVEL9K_PUBLIC_IP_NONE > $POWERLEVEL9K_PUBLIC_IP_FILE
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# read public IP saved to tmp file
|
# read public IP saved to tmp file
|
||||||
local public_ip=$(cat $POWERLEVEL9K_PUBLIC_IP_FILE)
|
local public_ip="$(cat $POWERLEVEL9K_PUBLIC_IP_FILE)"
|
||||||
|
|
||||||
if [[ -n $public_ip ]]; then
|
if [[ -n $public_ip ]]; then
|
||||||
$1_prompt_segment "$0" "$2" "$DEFAULT_COLOR" "$DEFAULT_COLOR_INVERTED" "${public_ip}" 'PUBLIC_IP_ICON'
|
$1_prompt_segment "$0" "$2" "$DEFAULT_COLOR" "$DEFAULT_COLOR_INVERTED" "${public_ip}" 'PUBLIC_IP_ICON'
|
||||||
|
|
Loading…
Reference in New Issue