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
graphdna-1.2.2.tar.gz
(15.4 kB
view details)
Built Distribution
graphdna-1.2.2-py3-none-any.whl
(30.5 kB
view details)
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 |