Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fujiwara/aswrap
AWS assume role credential wrapper
https://github.com/fujiwara/aswrap
aws perl
Last synced: 3 months ago
JSON representation
AWS assume role credential wrapper
- Host: GitHub
- URL: https://github.com/fujiwara/aswrap
- Owner: fujiwara
- License: other
- Created: 2017-12-12T15:13:11.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-10-30T03:09:13.000Z (about 1 year ago)
- Last Synced: 2024-10-11T21:12:47.109Z (3 months ago)
- Topics: aws, perl
- Language: Perl
- Size: 63.5 KB
- Stars: 21
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# aswrap
AWS assume role credential wrapper.
## Description
aswrap is useful for some commands which couldn't resolve an assume role credentials in ~/.aws/credentials and IAM Identity Center credentials cache.
For example,
- Implemented with [aws-sdk-go](https://github.com/aws/aws-sdk-go)
- [Terraform](https://www.terraform.io/)
- [Packer](https://www.packer.io/)
- etc.## Install
Place a `aswrap` command to your PATH and set an executable flag.
```console
$ curl -Lso path/to/aswrap https://github.com/fujiwara/aswrap/releases/download/v0.0.3/aswrap && chmod +x path/to/aswrap
```Or use Homebrew.
```console
$ brew install fujiwara/tap/aswrap
```## Usage
for Assume Role.
```ini
# ~/.aws/credentials[my-profile]
aws_access_key_id=XXX
aws_secret_access_key=YYY[foo]
region=ap-northeast-1
source_profile=my-profile
role_arn=arn:aws:iam::999999999999:role/MyRole
```for IAM Identity Center.
```ini
# ~/.aws/config[profile foo]
sso_start_url = https://example.awsapps.com/start
sso_region = ap-northeast-1
sso_account_id = 123456789012
sso_role_name = myrole
region = ap-northeast-1
```### As command wrapper
```console
$ AWS_PROFILE=foo aswrap some_command [arg1 arg2...]
````aswrap` works as below.
1. Find `AWS_PROFILE` section in ~/.aws/credentials and ~/.aws/config .
2.
- (For assume role) Call `aws sts assume-role` to a get temporary credentials.
- (For IAM Identity Center) Call `aws sso get-role-credentials` to a get temporary credentials.
3. Set the credentilas to environment variables.
- `AWS_ACCESS_KEY_ID`
- `AWS_SECRET_ACCESS_KEY`
- `AWS_SESSION_TOKEN`
- `AWS_REGION` if available in the section.
4. Execute `some_command` with args.### As env exporter
When aswrap is executed with no arguments, aswrap outputs shell script to export AWS credentials environment variables.
```console
$ export AWS_PROFILE=foo
$ aswrap
export AWS_ACCESS_KEY_ID=XXXXXXXXXXXXXXXX
export AWS_SECRET_ACCESS_KEY=eW8JjiLZk+mzNmEQJyORdzk....
export AWS_SESSION_TOKEN=2b0gN9qucmINvL8D4sgpLbzvJ31Es5/VBy9gYFpxKFWBrODYMBqcq5WksJGp9RW.....
export AWS_REGION=ap-northeast-1
```You can set the credentials in current shell by `eval`.
```console
$ eval "$(aswrap)"
```Temporary credentials has expiration time (about 1 hour).
## Requirements
- Perl (>= 5.14.0)
- required JSON::PP
- [aws-cli](https://github.com/aws/aws-cli)## LICENSE
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.## Author
Copyright (c) 2017 FUJIWARA Shunichiro