Need help with gossm?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

gjbae1212
180 Stars 18 Forks MIT License 80 Commits 5 Opened issues

Description

đź’»Interactive CLI tool that you can connect to ec2 using commands same as start-session, ssh in AWS SSM Session Manager

Services available

!
?

Need anything else?

Contributors list

gossm

gossm
is interactive CLI tool that you should select server in AWS and then could connect or send files your AWS server using start-session, ssh, scp under AWS Systems Manger Session Manager.

license Go Report Card

Overview

gossm
is interactive CLI tool that is related AWS Systems Manger Session Manager. It can select a ec2 server installed aws-ssm-agent and then can connect its server using start-session, ssh. As well as files can send using scp.
If you will use
gossm
tool, this mean there will no need to open inbound 22 port in your ec2 server when is using ssh or scp command.
Because AWS Systems Manger Session Manager is using ssh protocol tunneling.

Additionally Features -
mfa
command has added. this command is to authenticate through AWS MFA, and then to save issued a temporary credentials in $HOME/.aws/credentialsmfa. (default expired time is after 6 hours)
You should export global environment, such as `export AWS
SHAREDCREDENTIALSFILE=$HOME/.aws/credentials_mfa`.
With completed, you can execute aws cli and gossm conveniently without mfa authenticated.
Refer to detail information below.

Prerequisite

  • [required] Your ec2 servers in aws are installed aws ssm agent. EC2 severs have to apply AmazonEC2RoleforSSM iam policy.
    If you would like to use ssh, scp command using gossm, aws ssm agent version 2.3.672.0 or later is installed on ec2.
  • [required] aws access key, aws secret key
  • [required] ec2:DescribeInstances, ssm:StartSession permission, ssm:DescribeInstanceInformation
  • [optional] It's better to possibly get to additional permission for ec2:DescribeRegions, ssm:TerminateSession

Install

Support x86_64 ```bash

homebrew

$ brew tap gjbae1212/gossm $ brew install gossm

mac

$ wget https://github.com/gjbae1212/gossm/releases/download/v1.3.0/gossm1.3.0Darwinx8664.tar.gz

linux

$ wget https://github.com/gjbae1212/gossm/releases/download/v1.3.0/gossm1.3.0Linuxx8664.tar.gz

window

$ wget https://github.com/gjbae1212/gossm/releases/download/v1.3.0/gossm1.3.0Windowsx8664.tar.gz ```

How to use

global command args

| args | Description | Default | | ---------------|-----------------------------------------------------------|------------------------| | -c | (optional) aws credentials file | $HOME/.aws/credentials | | -p | (optional) if you are having multiple aws profiles in credentials, it is name one of profiles | default | | -r | (optional) region in AWS that would like to connect | | | -t | (optional) instanceId of server in AWS that would like to connect | |

If your machine don't exist $HOME/.aws/.credentials, have to pass

-c
args.
```

credentials file format

[default] awsaccesskeyid = AWS ACCESS KEY awssecretaccesskey = AWS SECRET KEY ```

-r
or
-t
don't pass args, it can select through interactive CLI.

command

start

$ gossm start 

ssh, scp

-e
must pass args when is using scp.
-e
args is command and args when usually used to pass ssh or scp. ```bash

ssh(if pem is already registered using ssh-add)

$ gossm ssh -e '[email protected]'

ssh(if pem isn't registered)

$ gossm ssh -e '-i key.pem [email protected]'

ssh(if pem is already registered using ssh-add and don't pass -e option) -> select server using interactive cli

$ gossm ssh

ssh(if pem isn't registered and don't pass -e option) -> select server using interactive cli

$ gossm ssh -i key.pem

scp(if pem is already registered using ssh-add)

$ gossm scp -e 'file [email protected]:/home/blahblah'

scp(if pem isn't registered)

$ gossm scp -e '-i key.pem file [email protected]:/home/blahblah'

#### cmd 
`-e` required args, it is a parameter for execute to command on selected servers.

```bash

It is to execute a command("uptime") on selected multiple servers, waiting for a response on its result.

$ gossm cmd -e "uptime"

ex)

mfa

-deadline
it's to set expire time for temporary credentials. default is 6 hours.
-device
it's to set mfa device. default is your virtual mfa device.
bash
$ gossm mfa 
Must set to
export AWS_SHARED_CREDENTIALS_FILE=$HOME/.aws/credentials_mfa
in .bash_profile, .zshrc.

ex)

LICENSE

This project is following The MIT.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.