Skip to main content

Obtain GraphQL API Schema even if the introspection is not enabled

Project description

Clairvoyance

Obtain GraphQL API Schema even if the introspection is disabled.

PyPI PyPI - Python Version PyPI - Downloads GitHub

Introduction

Some GraphQL APIs have disabled introspection. For example, Apollo Server disables introspection automatically if the NODE_ENV environment variable is set to production.

Clairvoyance allows us to get GraphQL API schema when introspection is disabled. It produces schema in JSON format suitable for other tools like GraphQL Voyager, InQL or graphql-path-enum.

Contributors

Thanks to the contributers for their work.

Getting started

pip install clairvoyance
clairvoyance https://rickandmortyapi.com/graphql -o schema.json
# should take about 2 minute

Docker Image

docker run --rm nikitastupin/clairvoyance --help

Advanced Usage

Which wordlist should I use?

There are at least two approaches:

  • Use general English words (e.g. google-10000-english).
  • Create target specific wordlist by extracting all valid GraphQL names from application HTTP traffic, from mobile application static files, etc. Regex for GraphQL name is [_A-Za-z][_0-9A-Za-z]*.

Environment Variables

LOG_FMT=`%(asctime)s \t%(levelname)s\t| %(message)s` # A string format for logging.
LOG_DATEFMT=`%Y-%m-%d %H:%M:%S` # A string format for logging date.
LOG_LEVEL=`INFO` # A string level for logging.

Support

Due to time constraints @nikitastupin won't be able to answer all the issues for some time but he'll do his best to review & merge PRs

In case of question or issue with clairvoyance please refer to wiki or issues. If this doesn't solve your problem feel free to open a new issue.

Contributing

Pull requests are welcome! For major changes, please open an issue first to discuss what you would like to change. For more information about tests, internal project structure and so on refer to Development wiki page.

Documentation

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

clairvoyancenext-2.5.1.tar.gz (55.3 kB view details)

Uploaded Source

Built Distribution

clairvoyancenext-2.5.1-py3-none-any.whl (57.7 kB view details)

Uploaded Python 3

File details

Details for the file clairvoyancenext-2.5.1.tar.gz.

File metadata

  • Download URL: clairvoyancenext-2.5.1.tar.gz
  • Upload date:
  • Size: 55.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for clairvoyancenext-2.5.1.tar.gz
Algorithm Hash digest
SHA256 288ec17e6387b8e837971ee8d26f5e7ebac8aad3d188628d60a8593f3d25fa4d
MD5 6976c61c687fed826e2866145bdcafbb
BLAKE2b-256 8a5c17bb0908defb34e8962255be33fcb80e6965d606f8d8d7fe076700c6a715

See more details on using hashes here.

File details

Details for the file clairvoyancenext-2.5.1-py3-none-any.whl.

File metadata

File hashes

Hashes for clairvoyancenext-2.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d1e7dd9cd4e84b7e6cfb88e6cbd6bf2a232142bb8ca7ad0b3dae0926a1bd71fc
MD5 affa04009f96f0d4a05acf851d0560e3
BLAKE2b-256 41283af62e53c210b85f402500507dbe3aa44ad8a5d103f581dc156d5191aae1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page