Skip to content

ucbrise/aws-audit

Repository files navigation

aws-audit.py

Easily generate billing reports for organizations that use AWS Consolidated Billing.

By default, the script output will display a list of accounts, sorted by spend. If you use Organizational Units, you can set the output to list the OUs and spend for each project.

In addition to email/text-based reports, the script can create/update CSV reports for individual account, or OU/project-based spends.

Example (no-OU) output:

Current AWS totals:  $2,258.13 USD (only shown below: > $5.0)

User 1                   		$1,234.56
User 2                   		$789.01
User 3                   		$234.56

Example (with OU) output:

Current AWS totals:  $10,544.34 USD (only shown below: > $5.0)

ROOT: $10,544.34 USD

ROOT -> Organization 1: $2258.13 USD
==========
User 1                   		$1,234.56
User 2                   		$789.01

ROOT -> Organization 1 -> Project 1: $234.56 USD
==========
User 3                   		$234.56

ROOT -> Organization 2: $8,286.21 USD
==========
User 4                   		$2,468.02
User 5                   		$12.34

ROOT -> Organization 2 -> Project 1: $3.50 USD
==========

ROOT -> Organization 2 -> Project 2: $5,802.35 USD
==========
User 8                   		$5,678.90
User 9                   		$123.45

ROOT -> Organization 2 -> Project 3: $0.00 USD
==========

Notes about OU-based output:

  • Each OU's spend is a sum of all children (accounts) spends
  • All OUs, even those w/zero spend, are displayed

Example individual account (no-OU) CSV output:

year,month,person,spend
2018,04,User 1,"$17,005.04"
2018,04,User 2,"$11,828.53"
2018,04,User 3,"$9,516.19"
2018,04,User 4,"$9,003.63"
2018,04,User 5,"$8,028.62"
2018,04,User 6,"$6,775.01"
2018,04,User 7,"$6,726.66"
2018,04,User 8,"$6,640.03"
2018,04,User 9,"$6,255.92"

Example project-based (with OU) CSV output:

year,month,lab or PI,project,spend,num accounts
2018,04,ROOT,Research Lab 1,"$2,575.16",12
2018,04,ROOT,Research Lab 2,$0.72,2
2018,04,Research Lab 3,Stateless NoSQL Lambda ML,$132.46,2
2018,04,ROOT,Research Lab 4,"$1,589.87",5
2018,04,Research Lab 4,Not Hotdog,$119.46,1
2018,04,Research Lab 4,ML Cheezburger,$592.09,2
2018,04,Research Lab 4,AI Thesis Writer,$527.25,2
2018,04,Research Lab 4,Statistical Regression of Not Hotdog predictions in Berlin,$28.03,1
2018,04,ROOT,Researcher 1,$1.16,10

Notes about CSV output (and plots):

  • The script will check for the existence of the CSV(s) passed through the CLI arguments, and will either append to an existing file or create a new one.
  • If you automate execution of this tool via cron, you can use shell magic to autogenerate new CSV filenames based on things like the current date.
  • By default, all accounts and project spends will be displayed. This can be changed by adding limit=<some value> in the calls to generate_simple_csv() and root.generate_project_csv() in aws-audit.py:main().
  • The fields in the CSV, as well as the headers, can be customized. For non-OU CSV format changes, please look at the generate_simple_csv() function in aws-audit.py. For OU/project-based reports, look at the generate_project_csv() method in tree.py.
  • If you are using the --plot argument and change these fields, you will also need to update plots.py with the new field names.

Caveat(s):

  • Billing data for individual IAM roles is not displayed. This is because the detailed billing reports only show the spend for the account that the IAM roles are a member of, not for the individual roles themselves.

Installation

You need to have python 3 and the latest version of boto3 installed via your package manager of choice.

Setup

First, your root consolidated billing account needs to be set up to receive billing reports and save them in an S3 folder. More details on how to set this up are here

It is also strongly recommended to use an IAM role that has permission to access this S3 bucket, rather than the root account itself.

Your AWS credentials need to be in a location that boto3 can discover. Please refer to the boto3 documentation on configuring credentials.

If the reports will be sent via a cronjob, please take look at awsreport-crontab for ideas.

If you want to send email reports, please edit emailsettings.py and change the following variables:

MAIL_SERVER = "localhost"
EMAIL_TO_ADDR = "list@example.corp"
EMAIL_FROM_ADDR = "Your Corp's AWS Czar <aws-watcher@example.corp>"

You can also modify the email subject(s) and preamble(s).

AWS Organizational Units can be used to categorize your spends. After this has been set up in your root accounts billing page, just add the --ou flag to the script when run.

Usage

Print out the help message and exit: aws-audit.py --help

This will grab the most recent bill from S3, save a copy locally, and dump the report to STDOUT using OUs and showing account IDs: aws-audit.py -i <AWS_ID> -b <BILLING_BUCKET> --save --ou --display_ids

Create a report on a downloaded billing CSV, not using OUs, only displaying spends great than $5.00: aws-audit.py --local <LOCAL_BILLING_CSV> --limit 5.0

Grab the most recent bill from S3 and email a report with OUs using the monthly template: aws-audit.py -i <AWS_ID> -b <BILLING_BUCKET> --ou --email --monthly

In addition to the previous example, also update/create a CSV of project-based spends for later analysis: aws-audit.py -i <AWS_ID> -b <BILLING_BUCKET> --ou --email --monthly --orgcsv reports/project-spends.csv

Full output of --help:

usage: aws-audit.py [-h] [-i AWS_ID] [-b S3_BILLING_BUCKET]
                    [-L LOCAL_BILLING_CSV] [-s] [-q] [-o] [-l LIMIT] [-D] [-f]
                    [-e] [-O FILENAME] [-C FILENAME] [-p] [-w | -m]

Download, parse and create reports for general AWS spend, optionally sending
the report as an e-mail and/or output CSV-based spending data.

optional arguments:
  -h, --help            show this help message and exit
  -i AWS_ID, --id AWS_ID
                        AWS account ID for consolidated billing. Required
                        unless using the --local argument.
  -b S3_BILLING_BUCKET, --bucket S3_BILLING_BUCKET
                        S3 billing bucket name. Required unless using the
                        --local argument.
  -L LOCAL_BILLING_CSV, --local LOCAL_BILLING_CSV
                        Read a consolidated billing CSV from the filesystem
                        and bypass downloading from S3.
  -s, --save            Save the billing CSV to the local directory.
  -q, --quiet           Do not print to STDOUT.
  -o, --ou              Use AWS Organizational Units to group users. This
                        option will greatly increase the amount of time it
                        takes the script to run. If this option is specified,
                        but no OUs have been defined for this consolidated
                        billing group, the script will still run successfully
                        but will take much longer to complete.
  -l LIMIT, --limit LIMIT
                        Do not display spends less than this value on the
                        report. Any spends not displayed will still be counted
                        towards all totals. Default is 5.00.
  -D, --display_ids     Display AWS account IDs in the report.
  -f, --full            Generate a full report. This option is only useful
                        when using OUs in a consolidated billing setting, and
                        the --ou option is used. An additional section is
                        added at the end of the original report that lists all
                        users sorted by spend. If the --ou argument is not
                        set, this option will be ignored.
  -e, --email           Send the report as an email, using the settings
                        defined in emailsettings.py.
  -O FILENAME, --orgcsv FILENAME
                        Output org/project-based spends to a CSV. If FILENAME
                        exists, the script will append to the file instead of
                        creating a new one.
  -C FILENAME, --csv FILENAME
                        Output account-based spends to a CSV. If FILENAME
                        exists, the script will append to the file instead of
                        creating a new one.
  -p, --plot            Create plots of CSV data. Only useful if the --csv or
                        --orgcsv arguments are used. This will create PNG
                        plots that are saved in the directory where the CSV
                        data lives, and will share the filename of the CSV
                        file used to create the plot. If this argument is
                        specified with the --email argument, any images will
                        be attached to the resulting message.
  -w, --weekly          Formats the email subject and body to deonte a
                        "weekly" report on spend, from the start of the
                        current month to the present day.
  -m, --monthly         Formats the email subject and body to denote an "end
                        of month" report.

Please refer to README.md for more detailed usage instructions and examples.

Contributing/Support

Please feel free to open issues and pull requests, and we will get to them in a reasonable amount of time!

About

aws consolidated billing audit/reporting tool

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages