Last active
December 10, 2015 01:23
-
-
Save iberianpig/6d41fc78bd31d23422a1 to your computer and use it in GitHub Desktop.
Connect to EC2 with adding/removing IP from Security Group
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/sh | |
if [ $# -lt 2 ]; then | |
echo "give HOST(~/.ssh/config), GROUP_ID(sg-xxxx) [, PROFILE(~/.aws/config)] as arguments" 1>&2 | |
echo "$ ssh_ec2 Hostname sg-groupid default" 1>&2 | |
exit 1 | |
fi | |
HOST=$1 | |
GROUP_ID=$2 | |
PROFILE="default" | |
if [ $# -gt 2 ]; then | |
PROFILE=$3 | |
fi | |
MY_WAN_IP=$(curl --max-time 2 -s http://whatismyip.akamai.com/) | |
echo "adding WAN-IP to security-group-ingress" 1>&2 | |
# NOTE: should use group-id instead of group-name with --profile(https://github.com/aws/aws-cli/issues/1207) | |
aws ec2 authorize-security-group-ingress --profile $PROFILE --group-id $GROUP_ID --protocol tcp --port 22 --cidr $MY_WAN_IP/32 | |
ret_auth=$? | |
if [ $ret_auth -ne 0 ]; then | |
echo "host in ~/.aws/config is configured and correct?" | |
echo "---------------~/.aws/config--------------------" | |
echo "[default]" | |
echo "aws_secret_access_key = xxxxxxxxxxxxxxxxxxxxxx" | |
echo "aws_access_key_id = XXXXXXXXXXXXXXXXXXXXXXXX" | |
echo "region = ap-northeast-1" | |
echo "output = json" | |
if [ $# -gt 4 ]; then | |
echo "" | |
echo "[profile $PROFILE]" | |
echo "aws_secret_access_key = xxxxxxxxxxxxxxxxx" | |
echo "aws_access_key_id = XXXXXXXXXXXXXXXXXXXXXXXX" | |
echo "region = us-west-2" | |
echo "output = json" | |
fi | |
echo "------------------------------------------------" | |
fi | |
echo "try ssh..." 1>&2 | |
ssh $HOST | |
ret_ssh=$? | |
if [ $ret_ssh -ne 0 ]; then | |
echo "host in ~/.ssh/config is configured and correct?" | |
echo "-------------~/.ssh/config--------------" | |
echo "Host $HOST" | |
echo " Hostname <IP or HOSTNAME>" | |
echo " User <LOGIN_USER>" | |
echo " IdentityFile ~/.ssh/<SSH_SECRET_KEY>" | |
echo "----------------------------------------" | |
fi | |
echo "revoke WAN-IP from security-group-ingress" 1>&2 | |
aws ec2 revoke-security-group-ingress --profile $PROFILE --group-id $GROUP_ID --protocol tcp --port 22 --cidr $MY_WAN_IP/32 |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment