Auditing your Substrate-managed AWS organization

One of the very first things Substrate does is to configure AWS CloudTrail with a single trail that covers all organization accounts in all regions. To access this wealth of data, assume the Auditor role in your audit account.
On the command line: substrate assume-role -special audit
Or you can assume the role in the AWS Console via your Intranet's Accounts page.
In either case, the data you seek is in the <prefix>-cloudtrail (substituting your chosen prefix as stored in substrate.prefix) S3 bucket. You can download it to analyze locally or query it with Amazon Athena. The most straightforward way to proceed is by creating Athena tables for each AWS account; partition projection to cover the entire organization is unsolved.

Allowing third parties to audit your Substrate-managed AWS organization

Many tools have grown the ability to assume an IAM role in your AWS account to perform some auditing or monitoring feature on your behalf. To allow these into your AWS organization, create an assume role policy in substrate.Auditor.assume-role-policy.json with contents like this:
"Version": "2012-10-17",
"Statement": [
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"AWS": [
You can include as many principals as you'd like in the innermost list.
Every time you update this file, you'll need to re-run whichever of substrate bootstrap-management-account, substrate bootstrap-deploy-account, substrate bootstrap-network-account, substrate create-admin-account (for each of your admin accounts), and/or substrate create-account (for each of your service accounts) are relevant to your situation.
This will authorize third-party principals to sts:AssumeRole using the ARN of one of your Auditor roles and operate as you would there.
Note, too, that this pattern can be applied to the Administrator role using the substrate.Administrator.assume-role-policy.json file per adding administrators to your AWS organization.