Fast and powerful GraphQL engine fingerprinting tool
Project description
GraphDNA

GraphDNA is a tool that uses multiple heuristics to fingerprint GraphQL endpoints.
Getting Started
It takes only two simple steps to fingerprint an endpoint using GraphDNA.
pip install graphdna
graphdna -u https://example.com/graphql
Options
GraphDNA supports the following options:
graphdna \
# Url to fingerprint
--url/-u https://example.com/graphql \
# Header (chainable)
--header/-H "Authorization: Bearer token"
Supported engines
| Name | Supported | Name | Supported | Name | Supported | ||
|---|---|---|---|---|---|---|---|
| Agoo | ✅ | Apollo | ✅ | Ariadne | ✅ | ||
| AWS AppSync | ✅ | Caliban | ✅ | DGraph | ✅ | ||
| Dianajl | ✅ | Directus | ✅ | Flutter | ✅ | ||
| GQLGen | ✅ | Graphene | ✅ | GraphQLApiForWp | ✅ | ||
| GraphQL-Go | ✅ | gopher/GraphQL-Go | ✅ | GraphQL-Java | ✅ | ||
| GraphQL-PHP | ✅ | GraphQL Yoga | ✅ | Hasura | ✅ | ||
| HyperGraphQL | ✅ | Jaal | ✅ | Juniper | ✅ | ||
| Lacinia | ✅ | Lighthouse | ✅ | Mercurius | ✅ | ||
| MorpheusGraphQL | ✅ | GraphQL Ruby | ✅ | Sangria | ✅ | ||
| Shopify | ✅ | Stepzen | ✅ | Strawberry | ✅ | ||
| Tartiflette | ✅ | WPGraphQL | ✅ |
Environment Variables
Logger - No effect if you pass your own logger
| Name | Values | Default | Behavior |
|---|---|---|---|
LOG_FORMAT |
console, json |
console |
Change the log format accordingly |
DEBUG |
True, False |
False |
Enable debug logging |
Integration
import logging
from typing import Dict, Optional
from graphdna import detect_engine, detect_engine_async
from graphdna.entities import GraphQLEngine
def detect_engine(
url: str,
headers: Optional[Dict[str, str]] = None,
logger: Optional[logging.Logger] = None,
) -> Optional[GraphQLEngine]:
...
async def detect_engine_async(
url: str,
headers: Optional[Dict[str, str]] = None,
logger: Optional[logging.Logger] = None,
) -> Optional[GraphQLEngine]:
...
Local installation
git clone git@github.com:Escape-Technologies/graphdna.git
cd graphdna
chmod +x ./install-dev.sh
./install-dev.sh
Credits
Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.
License 
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file graphdna-1.2.2.tar.gz.
File metadata
- Download URL: graphdna-1.2.2.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.11.0 Linux/5.4.109+
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c637ef763bbaef61fcf4f83d6054a1e8a908ee4852955251c0eddb24f718c14a
|
|
| MD5 |
3670fc7b003ff9e166fbcffdba0ae957
|
|
| BLAKE2b-256 |
9a285b781f6afdf4a01f0962856d6438d3ac3b4c68265af54a99f334c24c59ad
|
File details
Details for the file graphdna-1.2.2-py3-none-any.whl.
File metadata
- Download URL: graphdna-1.2.2-py3-none-any.whl
- Upload date:
- Size: 30.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.11.0 Linux/5.4.109+
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3d491ccbbefa6a411bf2b7ce1bfdcf5f8d72adfe0f6c743ea22fefb783ac435a
|
|
| MD5 |
431e07687aaf0ac696082caf668a8643
|
|
| BLAKE2b-256 |
87faef6d076c95ad4191f019d172dbf9dddb3b9c33f8fe51f01b30601d68d88c
|