mirror of
https://github.com/RGBCube/nu_scripts
synced 2025-08-01 06:37:46 +00:00
fix(aws): Fix select-aws-profile script functionality and style (#946)
### What - Rename main function to 'main' and add --env flag for environment modification - Fix region handling to properly check for null values ### Why The aws/select-aws-profile script syntax is outdated ```shell ➜ nu Error: nu::parser::named_as_module × Can't export command named same as the module. ╭─[~/.config/nushell/nu_scripts/modules/aws/select-aws-profile.nu:12:12] 11 │ # select-aws-profile 12 │ export def select-aws-profile [] { · ─────────┬──────── · ╰── can't export from module select-aws-profile 13 │ hide AWS_REGION; ╰──── help: Module select-aws-profile can't export command named the same as the module. Either change the module name, or export `main` command. ```
This commit is contained in:
parent
f74b2aa777
commit
fb8901e1e8
1 changed files with 31 additions and 31 deletions
|
@ -1,40 +1,40 @@
|
||||||
# This alias lets you choose your aws environment variables with ease.
|
# This alias lets you choose your aws environment variables with ease.
|
||||||
#
|
#
|
||||||
# Dependencies
|
# Dependencies:
|
||||||
# * fzf
|
# * fzf
|
||||||
#
|
#
|
||||||
# Installation
|
# Installation:
|
||||||
# 1. store in ~/.config/nushell/select-aws-profile.nu
|
# 1. store in ~/.config/nushell/select-aws-profile.nu
|
||||||
# 2. add to your config.nu: `use ~/.config/nushell/select-aws-profile.nu *`
|
# 2. add to your config.nu: `use ~/.config/nushell/select-aws-profile.nu *`
|
||||||
#
|
#
|
||||||
# Usage
|
# Usage:
|
||||||
# select-aws-profile
|
# select-aws-profile
|
||||||
export def select-aws-profile [] {
|
export def --env main [] {
|
||||||
hide AWS_REGION;
|
hide AWS_REGION
|
||||||
|
|
||||||
(do {
|
do {
|
||||||
let creds = (open ($env.HOME + "/.aws/credentials") | from toml)
|
let creds = open ($env.HOME + "/.aws/credentials") | from toml
|
||||||
let selectedProfile = (for it in ($creds | transpose name creds) {
|
let selected_profile = $creds
|
||||||
echo $it.name
|
| transpose name creds
|
||||||
})
|
| get name
|
||||||
|
| str join "\n"
|
||||||
selectedProfile = selectedProfile | str join "\n" | fzf | str trim
|
| fzf
|
||||||
|
|
||||||
if $selectedProfile != "" {
|
if $selected_profile != "" {
|
||||||
let out = {
|
let out = {
|
||||||
AWS_PROFILE: $selectedProfile,
|
AWS_PROFILE: $selected_profile,
|
||||||
AWS_ACCESS_KEY_ID: ($creds | get $selectedProfile | get "aws_access_key_id"),
|
AWS_ACCESS_KEY_ID: ($creds | get $selected_profile | get "aws_access_key_id"),
|
||||||
AWS_SECRET_ACCESS_KEY: ($creds | get $selectedProfile | get "aws_secret_access_key"),
|
AWS_SECRET_ACCESS_KEY: ($creds | get $selected_profile | get "aws_secret_access_key"),
|
||||||
}
|
|
||||||
|
|
||||||
let region = ($creds | get $selectedProfile | get -i "region")
|
|
||||||
if $region != "" {
|
|
||||||
$out | insert "AWS_REGION" $region
|
|
||||||
} else {
|
|
||||||
$out
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} | load-env);
|
|
||||||
|
let region = ($creds | get $selected_profile | get -i "region")
|
||||||
|
if $region != null {
|
||||||
|
$out | insert AWS_REGION $region
|
||||||
|
} else {
|
||||||
|
$out
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} | load-env
|
||||||
|
|
||||||
{
|
{
|
||||||
AWS_PROFILE: $env.AWS_PROFILE,
|
AWS_PROFILE: $env.AWS_PROFILE,
|
||||||
|
@ -42,4 +42,4 @@ export def select-aws-profile [] {
|
||||||
AWS_SECRET_ACCESS_KEY: $env.AWS_SECRET_ACCESS_KEY,
|
AWS_SECRET_ACCESS_KEY: $env.AWS_SECRET_ACCESS_KEY,
|
||||||
AWS_REGION: $env.AWS_REGION
|
AWS_REGION: $env.AWS_REGION
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue