Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/denniskniep/GQLRaider

GQL Burp Extension
https://github.com/denniskniep/GQLRaider

burp burp-extensions burp-plugin burpsuite-extender gql graphql

Last synced: 2 months ago
JSON representation

GQL Burp Extension

Awesome Lists containing this project

README

        

# GraphQL Raider - GQL Burp Extension
[![Build status](https://dev.azure.com/kniepdennis/GQL%20Raider/_apis/build/status/GQL%20Raider?branchName=master)](https://dev.azure.com/kniepdennis/GQL%20Raider/_build/latest?definitionId=1)

## Description
GraphQL Raider is a Burp Suite Extension for testing endpoints implementing GraphQL.

## Features
### Display and Editor
The gql query and variables are extracted from the unreadable json body and displayed in separate tabs.

While intercepting or resending you can manipulate the gql query and variables inside the gql tab and the message will be correctly send.

![Display and Editor](doc/editor-gql.png)

### Scanner Insertion Points
Not only the variables are extracted as insertion point for the scanner. Furthermore the values inside the query are also extracted as insertion point for the scanner.

The detected insertion points are displayed for information and better transparency inside the qgl tab of a message
![Insertion Points](doc/injectionpoints-gql.png)

Insertion points are used by active scanner to insert the payloads for detecting vulnerabilities.
The custom gql insertion points helps the active scanner to position the payloads at the correct place inside of a gql query.

## GraphQL
> GraphQL is a query language for APIs and a runtime for fulfilling those queries with your existing data

https://graphql.org/

### Serving over HTTP
https://graphql.org/learn/serving-over-http/

#### HTTP GET
GraphQL query should be specified in the "query" query string.

`http://myapi/graphql?query={me{name}}`

#### HTTP POST
JSON-encoded body
```
{
"query": "...",
"operationName": "...",
"variables": { "myVariable": "someValue", ... }
}
```

## Develop

## Release
A GitHub Release is triggered by AzureDevOps if commits are added to the branch `master`