Structured inventory and cataloging across your AWS data landscape: Glue Data Catalog with S3 Tables, Redshift-federated, and remote Iceberg catalogs.
Overview
Maps data in an AWS account. Starts with catalog landscape (Glue, S3 Tables, federated), then drills into databases and tables. Read-only — no query execution.
Constraints for parameter acquisition:
- You MUST ask for the target AWS region upfront if not provided
- You MUST support a single optional argument: search term, catalog name, database name, S3 path, or table name
- You MUST accept the argument as direct input or a pointer to a file containing the spec
- You MUST confirm the scope (full landscape vs. targeted deep dive) before making API calls
- You MUST respect the user's decision to abort at any step
Common Tasks
Pagination: All list and search calls in this workflow may return paginated results. You MUST pass
from the previous response until no more tokens are returned. You MUST NOT assume a single page contains all results.
1. Verify Dependencies
Check for required tools and AWS access before discovery.
Constraints:
- You MUST verify AWS MCP server tools are available (,
aws___search_documentation
) and fall back to AWS CLI if not
- You MUST confirm credentials are valid:
aws sts get-caller-identity
- You MUST inform the user about any missing tools and ask whether to proceed
2. Discover Catalogs
List catalogs in account:
bash
aws glue get-catalogs --recursive --include-root
Classify each catalog by type:
| Field Present | Catalog Type | What It Contains |
|---|
| Neither nor | Default (Glue) | Standard Glue databases and tables |
FederatedCatalog.ConnectionName
= | S3 Tables | Managed Iceberg table buckets |
| Redshift-federated | Redshift databases exposed as Glue catalogs |
| with ≠ | Remote Iceberg | External catalogs (Snowflake, Databricks, Iceberg REST) |
Constraints:
- You MUST include to capture default account catalog
- You MUST present summary of catalog counts by type
- If only default catalog exists, You SHOULD skip catalog overview and go to step 3
3. Enumerate Databases and Tables
For each catalog (or the user-specified one):
bash
aws glue get-databases --catalog-id <catalog-id>
aws glue get-tables --database-name <db> --catalog-id <catalog-id>
For S3 Tables catalogs, also enumerate via the S3 Tables API:
bash
aws s3tables list-table-buckets
aws s3tables list-namespaces --table-bucket-arn <arn>
aws s3tables list-tables --table-bucket-arn <arn> --namespace <ns>
Constraints:
- You MUST flag S3 Tables not registered in Glue; You SHOULD suggest registration
- For sub-catalogs, accepts the catalog name (not the ARN)
- For the default catalog, omit or pass the account ID
4. Capture Details and Analyze
For each database, capture table count, formats, partitioning, and S3 locations. For each table of interest, capture column schemas, types, partition keys, SerDe format, and last access time.
You MUST report data formats in human-readable terms (Parquet, CSV, JSON), not raw SerDe class names.
See discovery-checklist.md for analysis framework.
Argument Routing
Resolve the argument in this order; stop at the first match:
- Starts with — S3 path (explore unregistered data, detect formats)
- Matches a known catalog from step 2 () — deep dive into that catalog
- Matches a known database () — deep dive into that database
- Matches a known table () — detailed table analysis with schema and partitions
- No match — treat as search term (Glue )
- No args — full landscape discovery (catalogs, then databases and tables)
Principles
- Start with catalog landscape, then narrow based on user interest
- Always report catalog types — users need to know where data lives
- Always report data formats — they drive cost and performance decisions
- Flag stale tables and missing descriptions
- Suggest partitioning for large unpartitioned tables
- Summary first, details on request
- You MUST NOT execute Athena queries () during discovery; query execution belongs to
Troubleshooting
| Error | Cause | Fix |
|---|
| Only sub-catalogs returned, default missing | omitted | Re-run with |
| Federated catalog query slow or failing | Network call to remote source; connection misconfigured | Report connection errors clearly rather than silently skipping |
| S3 Tables not queryable via Athena | Tables exist in S3 Tables API but not registered in Glue | Flag as "not queryable"; suggest registration |
| / fails with catalog-id | Default catalog requires omit or account ID | Omit or pass account ID for the default catalog |
Additional Resources