summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoman Perepelitsa <roman.perepelitsa@gmail.com>2021-05-28 15:53:50 +0300
committerRoman Perepelitsa <roman.perepelitsa@gmail.com>2021-05-28 15:55:27 +0300
commitc7ad00b5a5ec92c9b6edf8051502f42659f820b5 (patch)
tree2a6528a6e17e70dc4850ee35a1d0bad8892a6238
parent10918387b3b82f912938aff4e0bfcc923e52cc75 (diff)
add P9K_AWS_PROFILE and P9K_AWS_REGION and use it in default configs
-rw-r--r--config/p10k-classic.zsh12
-rw-r--r--config/p10k-lean-8colors.zsh12
-rw-r--r--config/p10k-lean.zsh12
-rw-r--r--config/p10k-rainbow.zsh12
-rw-r--r--internal/p10k.zsh71
5 files changed, 71 insertions, 48 deletions
diff --git a/config/p10k-classic.zsh b/config/p10k-classic.zsh
index 20d1e5b6..a3013932 100644
--- a/config/p10k-classic.zsh
+++ b/config/p10k-classic.zsh
@@ -1291,12 +1291,6 @@
# Tip: Remove the next line to always show aws.
typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt'
- # Include AWS region in prompt. (default: false)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION=false
-
- # Shorten AWS region. (default: true)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION_SHORT=true
-
# POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element
# in each pair defines a pattern against which the current AWS profile gets matched.
# More specifically, it's P9K_CONTENT prior to the application of context expansion (see below)
@@ -1327,6 +1321,12 @@
typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=208
# typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐'
+ # AWS segment format. The following parameters are available within the expansion.
+ #
+ # - P9K_AWS_PROFILE The name of the current AWS profile.
+ # - P9K_AWS_REGION The region associated with the current AWS profile.
+ typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}'
+
#[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]#
# AWS Elastic Beanstalk environment color.
typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=70
diff --git a/config/p10k-lean-8colors.zsh b/config/p10k-lean-8colors.zsh
index b2825b8d..57f1bd12 100644
--- a/config/p10k-lean-8colors.zsh
+++ b/config/p10k-lean-8colors.zsh
@@ -1272,12 +1272,6 @@
# Tip: Remove the next line to always show aws.
typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt'
- # Include AWS region in prompt. (default: false)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION=false
-
- # Shorten AWS region. (default: true)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION_SHORT=true
-
# POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element
# in each pair defines a pattern against which the current AWS profile gets matched.
# More specifically, it's P9K_CONTENT prior to the application of context expansion (see below)
@@ -1308,6 +1302,12 @@
typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=3
# typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐'
+ # AWS segment format. The following parameters are available within the expansion.
+ #
+ # - P9K_AWS_PROFILE The name of the current AWS profile.
+ # - P9K_AWS_REGION The region associated with the current AWS profile.
+ typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}'
+
#[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]#
# AWS Elastic Beanstalk environment color.
typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=2
diff --git a/config/p10k-lean.zsh b/config/p10k-lean.zsh
index 30a3a274..f843f99a 100644
--- a/config/p10k-lean.zsh
+++ b/config/p10k-lean.zsh
@@ -1268,12 +1268,6 @@
# Tip: Remove the next line to always show aws.
typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt'
- # Include AWS region in prompt. (default: false)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION=false
-
- # Shorten AWS region. (default: true)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION_SHORT=true
-
# POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element
# in each pair defines a pattern against which the current AWS profile gets matched.
# More specifically, it's P9K_CONTENT prior to the application of context expansion (see below)
@@ -1304,6 +1298,12 @@
typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=208
# typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐'
+ # AWS segment format. The following parameters are available within the expansion.
+ #
+ # - P9K_AWS_PROFILE The name of the current AWS profile.
+ # - P9K_AWS_REGION The region associated with the current AWS profile.
+ typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}'
+
#[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]#
# AWS Elastic Beanstalk environment color.
typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=70
diff --git a/config/p10k-rainbow.zsh b/config/p10k-rainbow.zsh
index 9411b090..722acbdd 100644
--- a/config/p10k-rainbow.zsh
+++ b/config/p10k-rainbow.zsh
@@ -1360,12 +1360,6 @@
# Tip: Remove the next line to always show aws.
typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt'
- # Include AWS region in prompt. (default: false)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION=false
-
- # Shorten AWS region. (default: true)
- # typeset -g POWERLEVEL9K_AWS_SHOW_REGION_SHORT=true
-
# POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element
# in each pair defines a pattern against which the current AWS profile gets matched.
# More specifically, it's P9K_CONTENT prior to the application of context expansion (see below)
@@ -1397,6 +1391,12 @@
typeset -g POWERLEVEL9K_AWS_DEFAULT_BACKGROUND=1
# typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐'
+ # AWS segment format. The following parameters are available within the expansion.
+ #
+ # - P9K_AWS_PROFILE The name of the current AWS profile.
+ # - P9K_AWS_REGION The region associated with the current AWS profile.
+ typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}'
+
#[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]#
# AWS Elastic Beanstalk environment color.
typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=2
diff --git a/internal/p10k.zsh b/internal/p10k.zsh
index 424eb9b3..ea0f25ff 100644
--- a/internal/p10k.zsh
+++ b/internal/p10k.zsh
@@ -1127,37 +1127,62 @@ _p9k_prompt_anaconda_init() {
typeset -g "_p9k__segment_cond_${_p9k__prompt_side}[_p9k__segment_index]"='${CONDA_PREFIX:-$CONDA_ENV_PATH}'
}
-################################################################
-# AWS Profile
-prompt_aws() {
- local aws_profile="${AWS_VAULT:-${AWSUME_PROFILE:-${AWS_PROFILE:-$AWS_DEFAULT_PROFILE}}}"
- local text="${aws_profile//\%/%%}"
- if (( _POWERLEVEL9K_AWS_SHOW_REGION )); then
- local region_full
- if [[ -v $AWS_DEFAULT_REGION ]]; then
- region_full=$AWS_DEFAULT_REGION
- else
- if ! _p9k_cache_get "$0-$aws_profile-full"; then
- _p9k_cache_set $(aws configure get region)
+# Populates array `reply` with "$#profile:$profile:$region" where $profile and $region
+# come from the AWS config (~/.aws/config).
+function _p9k_parse_aws_config() {
+ local cfg=$1
+ typeset -ga reply=()
+ [[ -f $cfg && -r $cfg ]] || return
+
+ local -a lines
+ lines=(${(f)"$(<$cfg)"}) || return
+
+ local line profile
+ local -a match mbegin mend
+ for line in $lines; do
+ if [[ $line == [[:space:]]#'[default]'[[:space:]]#(|'#'*) ]]; then
+ # example: [default]
+ profile=default
+ elif [[ $line == (#b)'[profile'[[:space:]]##([^[:space:]]|[^[:space:]]*[^[:space:]])[[:space:]]#']'[[:space:]]#(|'#'*) ]]; then
+ # example: [profile prod]
+ profile=${(Q)match[1]}
+ elif [[ $line == (#b)[[:space:]]#region[[:space:]]#=[[:space:]]#([^[:space:]]|[^[:space:]]*[^[:space:]])[[:space:]]# ]]; then
+ # example: region = eu-west-1
+ if [[ -n $profile ]]; then
+ reply+=$#profile:$profile:$match[1]
+ profile=
fi
- region_full=$_p9k__cache_val[1]
fi
- if (( _POWERLEVEL9K_AWS_SHOW_REGION_SHORT )); then
- local region_short=${${${${${${region_full//-}//north/n}//south/s}//east/e}//west/w}//gov/g}
- text="$text ($region_short)"
- else
- text="$text ($region_full)"
- fi
- fi
+ done
+}
+################################################################
+# AWS Profile
+prompt_aws() {
+ typeset -g P9K_AWS_PROFILE="${AWS_VAULT:-${AWSUME_PROFILE:-${AWS_PROFILE:-$AWS_DEFAULT_PROFILE}}}"
local pat class
for pat class in "${_POWERLEVEL9K_AWS_CLASSES[@]}"; do
- if [[ $aws_profile == ${~pat} ]]; then
+ if [[ $P9K_AWS_PROFILE == ${~pat} ]]; then
[[ -n $class ]] && state=_${${(U)class}//İ/I}
break
fi
done
- _p9k_prompt_segment "$0$state" red white 'AWS_ICON' 0 '' "$text"
+
+ if [[ -n $AWS_DEFAULT_REGION ]]; then
+ typeset -g P9K_AWS_REGION=$AWS_DEFAULT_REGION
+ else
+ local cfg=${AWS_CONFIG_FILE:-~/.aws/config}
+ if ! _p9k_cache_stat_get $0 $cfg; then
+ local -a reply
+ _p9k_parse_aws_config $cfg
+ _p9k_cache_stat_set $reply
+ fi
+ local prefix=$#P9K_AWS_PROFILE:$P9K_AWS_PROFILE:
+ local kv=$_p9k__cache_val[(r)${(b)prefix}*]
+ typeset -g P9K_AWS_REGION=${kv#$prefix}
+ fi
+
+ _p9k_prompt_segment "$0$state" red white 'AWS_ICON' 0 '' "${P9K_AWS_PROFILE//\%/%%}"
}
_p9k_prompt_aws_init() {
@@ -7398,8 +7423,6 @@ _p9k_init_params() {
# POWERLEVEL9K_KUBECONTEXT_OTHER_BACKGROUND=yellow
_p9k_declare -a POWERLEVEL9K_KUBECONTEXT_CLASSES --
_p9k_declare -a POWERLEVEL9K_AWS_CLASSES --
- _p9k_declare -b POWERLEVEL9K_AWS_SHOW_REGION 0
- _p9k_declare -b POWERLEVEL9K_AWS_SHOW_REGION_SHORT 1
_p9k_declare -a POWERLEVEL9K_AZURE_CLASSES --
_p9k_declare -a POWERLEVEL9K_TERRAFORM_CLASSES --
_p9k_declare -b POWERLEVEL9K_TERRAFORM_SHOW_DEFAULT 0