Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/galoisinc/haskell-tor

A Haskell implementation of the Tor protocol.
https://github.com/galoisinc/haskell-tor

Last synced: 2 months ago
JSON representation

A Haskell implementation of the Tor protocol.

Awesome Lists containing this project

README

        

# A Tor Implementation in Haskell

[![Build Status](https://secure.travis-ci.org/GaloisInc/haskell-tor.svg?branch=master)](http://travis-ci.org/GaloisInc/haskell-tor)

This version of haskell-tor is (C) 2015 Galois, Inc., and distributed under
a standard, three-clause BSD license. Please see the file LICENSE,
distributed with this software, for specific terms and conditions.

## What is Tor?

Tor is a secure onion routing network for providing anonymized access to both
the public Internet as well as a series of Tor-internal hidden services. Much
more information about Tor can be found at https://www.torproject.org.

Many thanks to all the hard work that project has put into developing and
evangelizing Tor.

## What is in this repository?

This repository contains a Tor implementation in Haskell. It is eventually
designed to be a fully-compliant Tor implementation, but at the moment lacks
some features:

* Support for finding or implementing hidden services.
* Proper flow-control support.
* Statistics updating.
* Directory server support.

Using this library as an entrance node (i.e., to create anonymized connections
to hosts on the Internet) is fairly well tested and should be functional. Relay
and exit node support is implemented but much less well tested. For whichever
use case you have, please report any problems you find to the GitHub issue
tracker.

## Building haskell-tor

This library uses cabal as its build system, and should work for Mac, Unix, and
HaLVM-based installations. Windows support may work ... we just haven't tested
it.

### Understanding Network Stacks

The haskell-tor library is built such that it can use one of two built-in
network stacks and/or a third-party network stack that you provide. How you get
each of these is governed by two flags that correspond to the two network
stacks:

* `network` ensures that haskell-tor includes defaults for the standard,
sockets-based network stack as described in the Haskell `network` library.

* `hans` ensures that haskell-tor includes defaults for the Haskell
Network stack, which is a clean-slate networks stack that runs off raw
Ethernet frames.

The defaults are a little complicated. To help try to sort things out, here is a
table that describes all the combinations of flags, and what the default is for
each platform:

| Default | Platform | `network` | `hans` | Meaning |
|---------|----------|-----------|--------|-----------------------------------------|
| | Normal | True | True | Support for both `hans` and `network` |
| * | Normal | True | False | Support only `network` |
| | Normal | False | True | Support only `hans` |
| | Normal | False | False | No network stack support (BYONS) |
| | HaLVM | True | True | Support only `hans` (`network` ignored) |
| | HaLVM | True | False | No network stack support (see prev.) |
| * | HaLVM | False | True | Support only `hans` |
| | HaLVM | False | False | No network stack support (BYONS) |

### Standard Cabal Constraints

If you're building with the HaLVM, please add the constraints `--constraint "tls
+hans"`, `--constraint "tls -network"`, and `-f-network` to your build flags,
and if you're using the `integer-simple` library (for example, to avoid GPL
entanglements with unikernels), you should add the constraints `--constraint
"cryptonite -integer-gmp"`, `--constraint "scientific +integer-simple"` and
`--constraint "scientific < 0.3.4.1"`.

In either case, we strongly suggest using sandboxes to keep everything nice and
tidy.

## Important Note

This is an early implementation of Tor that has not been peer-reviewed. Those
with a true, deep need for anonymity should strongly consider using the mainline
Tor client until and unless this version receives appropriate extensions,
testing, and review.

## Usage

As with most Haskell packages, this package can either be used as a library or
as a binary package. Currently, the executable binary will simply perform an
example get from whatismyip.com. Extending this to support a wider range of
features is an open issue.