asciimoo / Morty
Licence: agpl-3.0
Privacy aware web content sanitizer proxy as a service
Stars: ✭ 282
Programming Languages
go
31211 projects - #10 most used programming language
Morty
Web content sanitizer proxy as a service
Morty rewrites web pages to exclude malicious HTML tags and attributes. It also replaces external resource references to prevent third party information leaks.
The main goal of morty is to provide a result proxy for searx, but it can be used as a standalone sanitizer service too.
Features:
- HTML sanitization
- Rewrites HTML/CSS external references to locals
- JavaScript blocking
- No Cookies forwarded
- No Referrers
- No Caching/Etag
- Supports GET/POST forms and IFrames
- Optional HMAC URL verifier key to prevent service abuse
Installation and setup
Requirement: Go version 1.10 or higher.
$ go get github.com/asciimoo/morty
$ "$GOPATH/bin/morty" --help
Environment variables
Morty can be configured using the following environment variables:
-
MORTY_ADDRESS
: Listen address (default to127.0.0.1:3000
) -
MORTY_KEY
: HMAC url validation key (base64 encoded) to prevent direct URL opening. Leave blank to disable validation. Useopenssl rand -base64 33
to generate. -
DEBUG
: Enable/disable proxy and redirection logs (default totrue
). Set tofalse
to disable.
Docker
docker run -e DEBUG=false -e MORTY_ADDRESS=0.0.0.0:3000 -v ./rules.json:/etc/filtron/rules.json:rw dalf/morty
docker run -e DEBUG=false -v ./rules.json:/etc/filtron/rules.json:rw dalf/morty -listen 0.0.0.0:3000
Test
$ cd "$GOPATH/src/github.com/asciimoo/morty"
$ go test
Benchmark
$ cd "$GOPATH/src/github.com/asciimoo/morty"
$ go test -benchmem -bench .
Bugs
Bugs or suggestions? Visit the issue tracker.
Note that the project description data, including the texts, logos, images, and/or trademarks,
for each open source project belongs to its rightful owner.
If you wish to add or remove any projects, please contact us at [email protected].