From 22fbd820b28b83e7d40e74f01a1f4018a19a2f4b Mon Sep 17 00:00:00 2001 From: Scott Prutton Date: Tue, 18 Jun 2024 11:41:26 -0400 Subject: [PATCH] feat: add toolbox for ops helper work --- component/toolbox/BUCK | 49 ++++++++++++++++++ component/toolbox/Dockerfile | 10 ++++ component/toolbox/awsi.sh | 3 ++ component/toolbox/scripts/ssm | 96 +++++++++++++++++++++++++++++++++++ 4 files changed, 158 insertions(+) create mode 100644 component/toolbox/BUCK create mode 100644 component/toolbox/Dockerfile create mode 100755 component/toolbox/awsi.sh create mode 100755 component/toolbox/scripts/ssm diff --git a/component/toolbox/BUCK b/component/toolbox/BUCK new file mode 100644 index 0000000000..2e9b3bbd24 --- /dev/null +++ b/component/toolbox/BUCK @@ -0,0 +1,49 @@ +load( + "@prelude-si//:macros.bzl", + "docker_image", + "filegroup", + "shellcheck", + "shfmt_check", + "test_suite", +) + +docker_image( + name = "toolbox", + srcs = { + "scripts": ".", + }, +) + +filegroup( + name = "src", + srcs = glob(["**/*"]), +) + +filegroup( + name = "shell_srcs", + srcs = glob(["**/*.sh"]), +) + +shfmt_check( + name = "check-format-shell", + srcs = [":shell_srcs"], +) + +shellcheck( + name = "check-lint-shell", + srcs = [":shell_srcs"], +) + +test_suite( + name = "check-format", + tests = [ + ":check-format-shell", + ], +) + +test_suite( + name = "check-lint", + tests = [ + ":check-lint-shell", + ], +) diff --git a/component/toolbox/Dockerfile b/component/toolbox/Dockerfile new file mode 100644 index 0000000000..f91a4d4932 --- /dev/null +++ b/component/toolbox/Dockerfile @@ -0,0 +1,10 @@ +FROM amazon/aws-cli:2.16.9 + +RUN set -eux; \ + yum update; \ + arch=$(arch | sed s/aarch64/arm64/ | sed s/x86_64/64bit/) && yum install -y \ + https://s3.amazonaws.com/session-manager-downloads/plugin/latest/linux_${arch}/session-manager-plugin.rpm; + +COPY ./scripts/* /usr/local/bin/ + +ENTRYPOINT ["sh", "-c"] diff --git a/component/toolbox/awsi.sh b/component/toolbox/awsi.sh new file mode 100755 index 0000000000..e046fbb687 --- /dev/null +++ b/component/toolbox/awsi.sh @@ -0,0 +1,3 @@ +#!/usr/bin/env bash + +docker run --rm -ti -v ~/.aws:/root/.aws -v "$(pwd)":/aws systeminit/toolbox:stable "$*" diff --git a/component/toolbox/scripts/ssm b/component/toolbox/scripts/ssm new file mode 100755 index 0000000000..3d53b198d4 --- /dev/null +++ b/component/toolbox/scripts/ssm @@ -0,0 +1,96 @@ +#!/bin/bash + +# Function to display usage message +usage() { + echo "Usage: $0 [-p profile] [-r region]" + echo " -p profile AWS profile to use" + echo " -r region AWS region to use" + exit 1 +} + +# Function to list EC2 instances with their Name tag +list_instances() { + aws ec2 describe-instances --query 'Reservations[*].Instances[?State.Name==`running`].[Tags[?Key==`Name`].Value | [0],InstanceId,InstanceType,PrivateIpAddress]' --output text +} + +# Function to start SSM session +start_ssm_session() { + instance_id=$1 + aws ssm start-session --target "$instance_id" --document-name AWS-StartInteractiveCommand --parameters command="bash -l" +} + +# Parse flags +while getopts ":p:r:" opt; do + case ${opt} in + p) + profile=$OPTARG + ;; + r) + region=$OPTARG + ;; + \?) + echo "Invalid option: -$OPTARG" >&2 + usage + ;; + :) + echo "Option -$OPTARG requires an argument." >&2 + usage + ;; + esac +done + +# Function to get input or use environment variable +get_param_or_env() { + local param=$1 + local env_var=$2 + local prompt=$3 + + if [ -z "$param" ]; then + if [ -z "${!env_var}" ]; then + read -p "$prompt: " value + echo "$value" + else + echo "${!env_var}" + fi + else + echo "$param" + fi +} + +# Main script +profile=$(get_param_or_env "$profile" "AWS_PROFILE" "Enter the AWS profile to use") +region=$(get_param_or_env "$region" "AWS_REGION" "Enter the AWS region (e.g., us-west-2)") + +export AWS_PROFILE="$profile" +export AWS_REGION="$region" + +# List instances with fixed-width columns +instances=$(list_instances) +if [ -z "$instances" ]; then + echo "No running instances found." + exit 1 +fi + +echo "Running instances in region $region:" +printf "%-5s %-20s %-20s %-20s %-20s\n" "Index" "Name" "InstanceId" "InstanceType" "PrivateIpAddress" +i=1 +while read -r line; do + name=$(echo "$line" | awk '{print $1}') + instance_id=$(echo "$line" | awk '{print $2}') + instance_type=$(echo "$line" | awk '{print $3}') + private_ip=$(echo "$line" | awk '{print $4}') + printf "%-5s %-20s %-20s %-20s %-20s\n" "$i" "$name" "$instance_id" "$instance_type" "$private_ip" + ((i++)) +done <<< "$instances" + +read -p "Select an instance by number: " selection +instance_id=$(echo "$instances" | sed -n "${selection}p" | awk '{print $2}') + +if [ -z "$instance_id" ]; then + echo "Invalid selection." + exit 1 +fi + +echo "Starting SSM session with instance $instance_id..." +start_ssm_session "$instance_id" +