Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Trax-retail/url-protector-nginx-module
This module allow nginx to decrypt strings encrypted with xxtea algorithm. This is useful to hide actual URLs from client.
https://github.com/Trax-retail/url-protector-nginx-module
Last synced: about 2 months ago
JSON representation
This module allow nginx to decrypt strings encrypted with xxtea algorithm. This is useful to hide actual URLs from client.
- Host: GitHub
- URL: https://github.com/Trax-retail/url-protector-nginx-module
- Owner: trax-retail
- License: mit
- Created: 2017-09-19T07:40:05.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-09-19T07:45:27.000Z (over 7 years ago)
- Last Synced: 2024-08-03T21:02:33.856Z (5 months ago)
- Language: C
- Size: 27.3 KB
- Stars: 9
- Watchers: 38
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-nginx - url-protector-nginx-module - Nginx module which adds ability to decrypt strings encrypted with xxtea algorithm. (Third Party Modules / C Modules)
README
# URL Protector
This module allow [nginx](https://www.nginx.com/) to decrypt strings encrypted with [xxtea](https://en.wikipedia.org/wiki/XXTEA) algorithm. This is useful to hide actual URLs from client.
![](images/flow.png)
## Installation
```bash
git clone [email protected]:traxtechnology/url-protector-nginx-module.git
git submodule update --init --recursive
sudo apt-get install build-essential zlib1g-dev libpcre3-dev libssl-dev libxslt1-dev libxml2-dev libgd2-xpm-dev libgeoip-dev libgoogle-perftools-dev libperl-dev
sudo ./install.sh
```If you want to use your custom nginx configuration you need to copy `nginx_configure.sh.default` to `nginx_configure.sh` and modify it as you wish. By default we use almost copy of prebuild configuration of nginx-1.12.0 for debian, but without additional dynamic modules.
## Usage
Load modules in `nginx.conf`:
```
load_module /usr/lib/nginx/modules/ndk_http_module.so;
load_module /usr/lib/nginx/modules/ngx_http_url_protector_module.so;
load_module /usr/lib/nginx/modules/ngx_http_set_misc_module.so;
```Add to server config:
```
location = /test {
set_unescape_uri $arg_url_unescaped $arg_url;set_decryption_key 1234567890;
set_decrypted_str $arg_decrypted_url $arg_url_unescaped;resolver 8.8.8.8;
proxy_pass $arg_decrypted_url;
}
```__Note:__
- Path `/usr/lib/nginx/modules/` may be different in your system.
- Usually, path to your `nginx.conf` is `/etc/nginx/nginx.conf`.
- Use your own resolver to avoid [DNS spoofing attack](http://blog.zorinaq.com/nginx-resolver-vulns/#attack-scenarios). Use `nm-tool | grep DNS` to determine which one you use.
- `ngx_http_set_misc_module` is used only to decode URI, but it's important for this example.## Encryption Example
```javascript
const xxtea = require('xxtea-node');const url = 'https://en.wikipedia.org/wiki/XXTEA';
const key = '1234567890';
const encryptedData = xxtea.encrypt(xxtea.toBytes(url), xxtea.toBytes(key));
const encryptedStr = new Buffer(encryptedData).toString('base64');console.log(`http://localhost/test?url=${encodeURIComponent(encryptedStr)}`);
// http://localhost/test?url=Xhy4HUCNVpWRG4dDN1KS9Y8mrHoz6IhJBirn2qcDtl9lBGz6OiFwgA%3D%3D
```__Note:__
- We use [xxtea-node](https://www.npmjs.com/package/xxtea-node) npm package in this example.
- Decryption key length should be not less what average URL size.
- If your URLs are predictable, add random part to avoid [chosen-plaintext attack](https://en.wikipedia.org/wiki/Chosen-plaintext_attack).## Tests
```bash
sudo TEST=true ./install.sh
```## Dependencies
- [nginx](https://www.nginx.com/) version 1.11.5 or greater.
- [Nginx Development Kit](https://github.com/simpl/ngx_devel_kit)
- [XXTEA for C](https://github.com/xxtea/xxtea-c)