mirror of https://github.com/yandex/gixy
91 lines
3.0 KiB
Markdown
91 lines
3.0 KiB
Markdown
GIXY
|
|
====
|
|
[data:image/s3,"s3://crabby-images/6f1e5/6f1e5140fc4cb032e835b78ddb44df934c8fe4cd" alt="Mozilla Public License 2.0"](https://github.com/yandex/gixy/blob/master/LICENSE)
|
|
[data:image/s3,"s3://crabby-images/b9984/b9984a6155a61ecf112ffaf5cc73ed6abe37cc46" alt="Build Status"](https://travis-ci.org/yandex/gixy)
|
|
[data:image/s3,"s3://crabby-images/67580/6758054f367fc412dbacda49a4a8e725efe531ce" alt="Your feedback is greatly appreciated"](https://github.com/yandex/gixy/issues/new)
|
|
[data:image/s3,"s3://crabby-images/5b6c3/5b6c36b736adf5dc13de1441251fdb7d5f924f51" alt="GitHub issues"](https://github.com/yandex/gixy/issues)
|
|
[data:image/s3,"s3://crabby-images/9be70/9be70e0ed25fe3f7c0fae48df5ce7d36addaffbe" alt="GitHub pull requests"](https://github.com/yandex/gixy/pulls)
|
|
|
|
# Overview
|
|
<img align="right" width="192" height="192" src="/docs/logo.png">
|
|
|
|
Gixy is a tool to analyze Nginx configuration.
|
|
The main goal of Gixy is to prevent misconfiguration and automate flaw detection.
|
|
|
|
Currently supported Python versions are 2.7 and 3.5+.
|
|
|
|
Disclaimer: Gixy is well tested only on GNU/Linux, other OSs may have some issues.
|
|
|
|
# Installation
|
|
Gixy is distributed on [PyPI](https://pypi.python.org/pypi/gixy). The best way to install it is with pip:
|
|
```bash
|
|
pip install gixy
|
|
```
|
|
|
|
Run Gixy and check results:
|
|
```bash
|
|
gixy
|
|
```
|
|
|
|
# Usage
|
|
By default Gixy will try to analyze Nginx configuration placed in `/etc/nginx/nginx.conf`.
|
|
|
|
But you can always specify needed path:
|
|
```
|
|
$ gixy /etc/nginx/nginx.conf
|
|
|
|
==================== Results ===================
|
|
|
|
Problem: [http_splitting] Possible HTTP-Splitting vulnerability.
|
|
Description: Using variables that can contain "\n" may lead to http injection.
|
|
Additional info: https://github.com/yandex/gixy/blob/master/docs/ru/plugins/httpsplitting.md
|
|
Reason: At least variable "$action" can contain "\n"
|
|
Pseudo config:
|
|
include /etc/nginx/sites/default.conf;
|
|
|
|
server {
|
|
|
|
location ~ /v1/((?<action>[^.]*)\.json)?$ {
|
|
add_header X-Action $action;
|
|
}
|
|
}
|
|
|
|
|
|
==================== Summary ===================
|
|
Total issues:
|
|
Unspecified: 0
|
|
Low: 0
|
|
Medium: 0
|
|
High: 1
|
|
```
|
|
|
|
Or skip some tests:
|
|
```
|
|
$ gixy --skips http_splitting /etc/nginx/nginx.conf
|
|
|
|
==================== Results ===================
|
|
No issues found.
|
|
|
|
==================== Summary ===================
|
|
Total issues:
|
|
Unspecified: 0
|
|
Low: 0
|
|
Medium: 0
|
|
High: 0
|
|
```
|
|
|
|
Or something else, you can find all other `gixy` arguments with the help command: `gixy --help`
|
|
|
|
# Documentation
|
|
Full documentation and recommendations can be found [here](https://github.com/yandex/gixy/blob/master/docs/ru/README.md) (sorry, but Russian language only so far)
|
|
|
|
# Contributing
|
|
Contributions to Gixy are always welcome! You can help us in different ways:
|
|
* Open an issue with suggestions for improvements and errors you're facing;
|
|
* Fork this repository and submit a pull request;
|
|
* Improve the documentation.
|
|
|
|
Code guidelines:
|
|
* Python code style should follow [pep8](https://www.python.org/dev/peps/pep-0008/) standards whenever possible;
|
|
* Pull requests with new plugins must have unit tests for it.
|