Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
96 changes: 96 additions & 0 deletions examples/s3-remote-state/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
# Example: S3 remote state with multi-cloud attacks

This example stores all state (Terraform tfstate, technique lifecycle, outputs, variables) in an S3 bucket, while running attacks against a separate AWS account and a GCP project.

Three sets of credentials are involved:

| Purpose | Source | Account/Project |
| ----------------------------------- | ---------------------------------------- | --------------------------------------- |
| State bucket (S3) | Explicit (`STATE_*` env vars) | AWS account hosting the bucket |
| AWS target (Terraform + detonation) | Environment (`AWS_*` env vars) | AWS account where resources are created |
| GCP target (Terraform + detonation) | Environment (`gcloud auth` / `GOOGLE_*`) | GCP project where resources are created |

## 1. Create the state bucket

Authenticate against the AWS account that will host the state bucket:

```bash
# Replace with your auth method
aws-vault exec <state-bucket-account-admin>

aws s3 mb s3://<your-org>-stratus-state --region us-east-1
```

## 2. Get state bucket credentials

Export credentials for the bucket account as `STATE_*` variables. If using aws-vault, it already injects session credentials:

```bash
eval "$(aws-vault exec <state-bucket-account-admin> -- env | grep ^AWS_ | sed 's/^AWS_/export STATE_AWS_/')"

# Verify
echo $STATE_AWS_ACCESS_KEY_ID
```

Or with an explicit assume-role (useful when not using aws-vault):

```bash
CREDS=$(aws sts assume-role \
--role-arn arn:aws:iam::<bucket-account-id>:role/<role-name> \
--role-session-name stratus-state \
--query Credentials --output json)

export STATE_AWS_ACCESS_KEY_ID=$(echo $CREDS | jq -r .AccessKeyId)
export STATE_AWS_SECRET_ACCESS_KEY=$(echo $CREDS | jq -r .SecretAccessKey)
export STATE_AWS_SESSION_TOKEN=$(echo $CREDS | jq -r .SessionToken)
```

## 3. Set target credentials

**AWS target** — authenticate against the account where attack resources will be deployed:

```bash
# Replace with your auth method
aws-vault exec <target-aws-account-admin>

# Verify
aws sts get-caller-identity
```

**GCP target** — authenticate against the project where attack resources will be deployed:

```bash
gcloud auth application-default login
export GOOGLE_PROJECT=<your-gcp-project-id>
```

## 4. Run

```bash
export STATE_BUCKET_NAME=<your-org>-stratus-state
go run main.go
```

Expected output:

```
State bucket identity: arn:aws:sts::111111111111:assumed-role/...
=== AWS technique ===
Technique: aws.defense-evasion.cloudtrail-stop (correlation: ...)
Warming up (target credentials from environment)
...
Warmup complete
Press enter to detonate aws.defense-evasion.cloudtrail-stop
...
=== GCP technique ===
Technique: gcp.defense-evasion.delete-logging-sink (correlation: ...)
...
```

## 6. Cleanup

```bash
# Remove the state bucket (after all techniques are cleaned up)
aws-vault exec <state-bucket-account-admin>
aws s3 rb s3://<your-org>-stratus-state --force
```
165 changes: 165 additions & 0 deletions examples/s3-remote-state/go.mod
Original file line number Diff line number Diff line change
@@ -0,0 +1,165 @@
module github.com/datadog/stratus-red-team/example/s3-remote-state

go 1.23.0

replace github.com/datadog/stratus-red-team/v2 => ../../v2

require (
github.com/aws/aws-sdk-go-v2/config v1.29.6
github.com/aws/aws-sdk-go-v2/credentials v1.17.59
github.com/aws/aws-sdk-go-v2/service/sts v1.33.14
github.com/datadog/stratus-red-team/v2 v2.0.0-00010101000000-000000000000
github.com/google/uuid v1.6.0
)

require (
cloud.google.com/go/auth v0.14.0 // indirect
cloud.google.com/go/auth/oauth2adapt v0.2.7 // indirect
cloud.google.com/go/compute v1.31.1 // indirect
cloud.google.com/go/compute/metadata v0.6.0 // indirect
cloud.google.com/go/iam v1.3.1 // indirect
cloud.google.com/go/secretmanager v1.14.4 // indirect
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.20.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/azidentity v1.13.1 // indirect
github.com/Azure/azure-sdk-for-go/sdk/internal v1.11.2 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/authorization/armauthorization/v2 v2.2.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/compute/armcompute/v4 v4.2.1 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/keyvault/armkeyvault v1.5.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6 v6.1.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/resources/armlocks v1.2.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/resources/armresources v1.2.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/storage/armstorage v1.8.1 // indirect
github.com/Azure/azure-sdk-for-go/sdk/security/keyvault/azkeys v1.4.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/security/keyvault/internal v1.2.0 // indirect
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.6.3 // indirect
github.com/AzureAD/microsoft-authentication-library-for-go v1.6.0 // indirect
github.com/ProtonMail/go-crypto v1.1.0-alpha.2 // indirect
github.com/PuerkitoBio/purell v1.1.1 // indirect
github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578 // indirect
github.com/apparentlymart/go-textseg/v15 v15.0.0 // indirect
github.com/aws/aws-sdk-go-v2 v1.40.1 // indirect
github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.6.8 // indirect
github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.16.28 // indirect
github.com/aws/aws-sdk-go-v2/feature/s3/manager v1.17.61 // indirect
github.com/aws/aws-sdk-go-v2/internal/configsources v1.4.15 // indirect
github.com/aws/aws-sdk-go-v2/internal/endpoints/v2 v2.7.15 // indirect
github.com/aws/aws-sdk-go-v2/internal/ini v1.8.2 // indirect
github.com/aws/aws-sdk-go-v2/internal/v4a v1.3.32 // indirect
github.com/aws/aws-sdk-go-v2/service/bedrockruntime v1.24.4 // indirect
github.com/aws/aws-sdk-go-v2/service/cloudtrail v1.47.4 // indirect
github.com/aws/aws-sdk-go-v2/service/ec2 v1.202.4 // indirect
github.com/aws/aws-sdk-go-v2/service/ec2instanceconnect v1.27.15 // indirect
github.com/aws/aws-sdk-go-v2/service/eks v1.58.0 // indirect
github.com/aws/aws-sdk-go-v2/service/iam v1.39.1 // indirect
github.com/aws/aws-sdk-go-v2/service/internal/accept-encoding v1.12.2 // indirect
github.com/aws/aws-sdk-go-v2/service/internal/checksum v1.6.0 // indirect
github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.12.13 // indirect
github.com/aws/aws-sdk-go-v2/service/internal/s3shared v1.18.13 // indirect
github.com/aws/aws-sdk-go-v2/service/lambda v1.69.12 // indirect
github.com/aws/aws-sdk-go-v2/service/organizations v1.37.8 // indirect
github.com/aws/aws-sdk-go-v2/service/rds v1.93.12 // indirect
github.com/aws/aws-sdk-go-v2/service/rolesanywhere v1.16.15 // indirect
github.com/aws/aws-sdk-go-v2/service/route53resolver v1.34.13 // indirect
github.com/aws/aws-sdk-go-v2/service/s3 v1.76.1 // indirect
github.com/aws/aws-sdk-go-v2/service/sagemaker v1.228.0 // indirect
github.com/aws/aws-sdk-go-v2/service/secretsmanager v1.34.18 // indirect
github.com/aws/aws-sdk-go-v2/service/ses v1.29.10 // indirect
github.com/aws/aws-sdk-go-v2/service/ssm v1.56.12 // indirect
github.com/aws/aws-sdk-go-v2/service/sso v1.24.15 // indirect
github.com/aws/aws-sdk-go-v2/service/ssooidc v1.28.14 // indirect
github.com/aws/smithy-go v1.24.0 // indirect
github.com/cenkalti/backoff/v4 v4.2.1 // indirect
github.com/cjlapao/common-go v0.0.39 // indirect
github.com/cloudflare/circl v1.6.1 // indirect
github.com/davecgh/go-spew v1.1.1 // indirect
github.com/emicklei/go-restful/v3 v3.8.0 // indirect
github.com/felixge/httpsnoop v1.0.4 // indirect
github.com/fsnotify/fsnotify v1.9.0 // indirect
github.com/go-logr/logr v1.4.2 // indirect
github.com/go-logr/stdr v1.2.2 // indirect
github.com/go-openapi/jsonpointer v0.19.5 // indirect
github.com/go-openapi/jsonreference v0.19.5 // indirect
github.com/go-openapi/swag v0.19.14 // indirect
github.com/go-viper/mapstructure/v2 v2.4.0 // indirect
github.com/gogo/protobuf v1.3.2 // indirect
github.com/golang-jwt/jwt/v4 v4.5.2 // indirect
github.com/golang-jwt/jwt/v5 v5.3.0 // indirect
github.com/golang/protobuf v1.5.4 // indirect
github.com/google/gnostic v0.5.7-v3refs // indirect
github.com/google/gofuzz v1.1.0 // indirect
github.com/google/s2a-go v0.1.9 // indirect
github.com/googleapis/enterprise-certificate-proxy v0.3.4 // indirect
github.com/googleapis/gax-go/v2 v2.14.1 // indirect
github.com/hashicorp/go-cleanhttp v0.5.2 // indirect
github.com/hashicorp/go-version v1.6.0 // indirect
github.com/hashicorp/hc-install v0.6.4 // indirect
github.com/hashicorp/terraform-exec v0.21.0 // indirect
github.com/hashicorp/terraform-json v0.22.1 // indirect
github.com/imdario/mergo v0.3.15 // indirect
github.com/josharian/intern v1.0.0 // indirect
github.com/json-iterator/go v1.1.12 // indirect
github.com/kylelemons/godebug v1.1.0 // indirect
github.com/mailru/easyjson v0.7.6 // indirect
github.com/microsoft/kiota-abstractions-go v1.7.0 // indirect
github.com/microsoft/kiota-authentication-azure-go v1.1.0 // indirect
github.com/microsoft/kiota-http-go v1.4.4 // indirect
github.com/microsoft/kiota-serialization-form-go v1.0.0 // indirect
github.com/microsoft/kiota-serialization-json-go v1.0.8 // indirect
github.com/microsoft/kiota-serialization-multipart-go v1.0.0 // indirect
github.com/microsoft/kiota-serialization-text-go v1.0.0 // indirect
github.com/microsoftgraph/msgraph-beta-sdk-go v0.108.0 // indirect
github.com/microsoftgraph/msgraph-sdk-go v1.47.0 // indirect
github.com/microsoftgraph/msgraph-sdk-go-core v1.2.1 // indirect
github.com/moby/spdystream v0.2.0 // indirect
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
github.com/modern-go/reflect2 v1.0.2 // indirect
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
github.com/pelletier/go-toml/v2 v2.2.4 // indirect
github.com/pkg/browser v0.0.0-20240102092130-5ac0b6a4141c // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
github.com/sagikazarmark/locafero v0.11.0 // indirect
github.com/santhosh-tekuri/jsonschema/v6 v6.0.2 // indirect
github.com/sourcegraph/conc v0.3.1-0.20240121214520-5f936abd7ae8 // indirect
github.com/spf13/afero v1.15.0 // indirect
github.com/spf13/cast v1.10.0 // indirect
github.com/spf13/pflag v1.0.10 // indirect
github.com/spf13/viper v1.21.0 // indirect
github.com/std-uritemplate/std-uritemplate/go v0.0.57 // indirect
github.com/stretchr/testify v1.11.1 // indirect
github.com/subosito/gotenv v1.6.0 // indirect
github.com/zclconf/go-cty v1.14.4 // indirect
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.58.0 // indirect
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.58.0 // indirect
go.opentelemetry.io/otel v1.34.0 // indirect
go.opentelemetry.io/otel/metric v1.34.0 // indirect
go.opentelemetry.io/otel/trace v1.34.0 // indirect
go.yaml.in/yaml/v3 v3.0.4 // indirect
golang.org/x/crypto v0.41.0 // indirect
golang.org/x/mod v0.26.0 // indirect
golang.org/x/net v0.43.0 // indirect
golang.org/x/oauth2 v0.27.0 // indirect
golang.org/x/sync v0.16.0 // indirect
golang.org/x/sys v0.35.0 // indirect
golang.org/x/term v0.34.0 // indirect
golang.org/x/text v0.28.0 // indirect
golang.org/x/time v0.9.0 // indirect
google.golang.org/api v0.218.0 // indirect
google.golang.org/genproto v0.0.0-20250122153221-138b5a5a4fd4 // indirect
google.golang.org/genproto/googleapis/api v0.0.0-20250124145028-65684f501c47 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20250115164207-1a7da9e5054f // indirect
google.golang.org/grpc v1.70.0 // indirect
google.golang.org/protobuf v1.36.4 // indirect
gopkg.in/inf.v0 v0.9.1 // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
gopkg.in/yaml.v3 v3.0.1 // indirect
k8s.io/api v0.25.3 // indirect
k8s.io/apimachinery v0.25.3 // indirect
k8s.io/client-go v0.25.3 // indirect
k8s.io/klog/v2 v2.70.1 // indirect
k8s.io/kube-openapi v0.0.0-20220803162953-67bda5d908f1 // indirect
k8s.io/utils v0.0.0-20220728103510-ee6ede2d64ed // indirect
sigs.k8s.io/json v0.0.0-20220713155537-f223a00ba0e2 // indirect
sigs.k8s.io/structured-merge-diff/v4 v4.2.3 // indirect
sigs.k8s.io/yaml v1.2.0 // indirect
)
Loading
Loading