Ralph
data:image/s3,"s3://crabby-images/dfab3/dfab370e6d244be54927185cba5611ff06f61fa3" alt="GH workflow build badge"
Ralph is a CLI tool that automates security incident response for AWS resources.
It's the tool you use when this happens:
data:image/s3,"s3://crabby-images/61ceb/61ceb78d78d2fc241cc4959c62dc7ee3a84f1998" alt="Ralph Ralph"
Features
Ralph loads and executes a collection of pre-defined runbook to
automate incident response.
EC2 Runbooks
-
Removing IAM Instance Profile - Detaches the current IAM Instance
Profile of an instance.
-
Enable Termination Protection - Enables termination protection for an instance.
This gives an extra step to prevent accidental termination of an instance.
-
Set Shutdown Behavior to Stop - Sets shutdown behavior to stop guarantees
that the shutting down the instance will not result to termination of the instance.
-
Taking EBS Snapshot and Export - Creates latest EBS snapshot from volumes
of an instance and possibly send it to a quarantine AWS account.
See Setup
section below on how to configure env variables for this runbook.
Installation
To install Ralph using NPM, run:
$ npm i @lendi/ralph
/usr/local/bin/ralph -> /usr/local/lib/node_modules/@lendi/ralph/lib/index.js
+ @lendi/ralph@1.0.3
added 125 packages from 126 contributors in 7.843s
See https://www.npmjs.com/package/@lendi/ralph.
Setup
$ export AWS_REGION="ap-southeast-2"
...
- Required environment variables.
Some runbooks require you to define certain env variables.
EBS Snapshot export runbook:
export QUARANTINE_AWS_REGION="ap-southeast-1"
export QUARANTINE_AWS_ACCOUNTS="0000,0001,0002"
export TRANSFER_ALL_SNAPSHOTS="false"
-
QUARANTINE_AWS_REGION
- the region used for the quarantine AWS
account. If not defined, this will use the AWS REGION of
the current AWS account.
-
QUARANTINE_AWS_ACCOUNTS
- list of quarantine AWS account
whom to share the snapshots to. If not defined,
the current AWS account will be treated as
the quarantine AWS account.
-
TRANSFER_ALL_SNAPSHOTS
- decides whether to
copy and share just the latest snapshot or all of them.
Usage
execute
command
- Runs each of the runbooks on selected AWS instance
- Loads the list of instances available for lock down.
$ ralph execute
? Which instance do you want to lock down?
i-00000000000000001 (kafka-instance)
i-00000000000000002
i-00000000000000003
❯ i-00000000000000004 (vulnerable-instance)
i-00000000000000005 (machine-learning-instance)
i-00000000000000006
i-00000000000000007
(Move up and down to reveal more choices)
? Which instance do you want to lock down? i-00000000000000004(vulnerable-instance)
{"level":30,"time":1574209361754,"pid":20037,"hostname":"","msg":"RemoveIamInstanceProfile:
This will disassociate the following Iam Instance Profiles: ['arn:aws:iam::000000000000:instance-profile/SampleIamInstanceProfile']
for i-00000000000000004","v":1}
{"level":30,"time":1574209361870,"pid":20037,"hostname":"",
"msg":"setShutdownBehaviorToTerminate: The attribute instanceInitiatedShutdownBehavior
will be changed from 'terminate' to 'stop' for i-00000000000000004.","v":1}
{"level":30,"time":1574209361987,"pid":20037,"hostname":"",
"msg":"enableTerminationProtection: The attribute disableApiTermination will be changed
from false to true for i-00000000000000004.","v":1}
? Do you want to proceed with the changes? Yes
{"level":30,"time":1574209377228,"pid":20037,"hostname":"","msg":"Disassociated IAM
Instance Profile for i-00000000000000004.","v":1}
{"level":30,"time":1574209377413,"pid":20037,"hostname":"","msg":"Changed shutdown
behavior to stop for i-00000000000000004.","v":1}
{"level":30,"time":1574209377547,"pid":20037,"hostname":"","msg":"Changed termination
protection to true for i-00000000000000004.","v":1}
Upcoming Features
-
Retrieving EBS snapshots and exporting to separate AWS account for quarantine.
-
Security Groups / VPC Lockdown
-
Retrieving EC2 Memory Acquisition and export options
-
Use more user-friendly logger