Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/scalefactory/s3audit-ts
CLI tool for auditing S3 buckets
https://github.com/scalefactory/s3audit-ts
aws aws-s3 aws-s3-audit devops-tools s3 s3-bucket
Last synced: about 1 month ago
JSON representation
CLI tool for auditing S3 buckets
- Host: GitHub
- URL: https://github.com/scalefactory/s3audit-ts
- Owner: scalefactory
- License: apache-2.0
- Archived: true
- Created: 2019-10-01T11:23:21.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2023-08-02T13:28:33.000Z (over 1 year ago)
- Last Synced: 2024-07-01T13:53:13.950Z (6 months ago)
- Topics: aws, aws-s3, aws-s3-audit, devops-tools, s3, s3-bucket
- Language: TypeScript
- Size: 130 KB
- Stars: 109
- Watchers: 7
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
s3audit-ts
==================This is an archived an open source project published by [The Scale Factory](https://scalefactory.com).
For our replacement (implemented in Rust), see [`s3audit-rs`](https://github.com/scalefactory/s3audit-rs).
## Purpose
Checks the settings for all S3 buckets in an AWS account for public access
[![oclif](https://img.shields.io/badge/cli-oclif-brightgreen.svg)](https://oclif.io)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)## Table of contents
* [Install](#install)
* [Usage](#usage)For an introduction, read
[Securing S3 buckets with s3audit](https://scalefactory.com/blog/2019/10/03/securing-s3-buckets-with-s3audit/)# Install
Download and install the [latest release from GitHub](https://github.com/scalefactory/s3audit-ts/releases)
Or install the NPM package:
```sh-session
$ npm install -g s3audit
```# Usage
### Node
AWS credentials will be taken from environment variables.
It is recommended to run this in combination with [AWS Vault](https://github.com/99designs/aws-vault)### Arguments
```
s3audit --bucket=s3-bucket=name
s3audit --format=console
s3audit --format=csv
s3audit --enable-check=policy --enable-check=acl
s3audit --disable-check=logging --enable-check=logging
```### IAM Role
You should use a role which is allowed these actions for all buckets in your account:
```
s3:ListAllMyBuckets,
s3:GetBucketAcl,
s3:GetBucketLogging,
s3:GetBucketPolicy,
s3:GetBucketPublicAccessBlock,
s3:GetBucketVersioning,
s3:GetBucketWebsite,
s3:GetEncryptionConfiguration
``````sh-session
$ aws-vault exec -- s3audit❯ Checking 1 bucket
❯ s3audit-demo
❯ Bucket public access configuration
✖ BlockPublicAcls is set to false
✖ IgnorePublicAcls is set to false
✖ BlockPublicPolicy is set to false
✖ RestrictPublicBuckets is set to false
✖ Server side encryption is not enabled
✖ Object versioning is not enabled
✖ MFA Delete is not enabled
✔ Static website hosting is disabled
✔ Bucket policy doesn't allow a wildcard entity
✔ Bucket ACL doesn't allow access to "Everyone" or "Any authenticated AWS user"
✖ Logging is not enabled
```