Go to file
2018-03-23 12:10:38 +01:00
cmd/ooni Add geoip command line tool 2018-03-23 12:10:38 +01:00
config Add functions to handling migration from legacy OONI Probe 2018-02-12 12:18:14 +02:00
data Update schema 2018-03-20 12:38:21 +01:00
internal Refactor how we create the context 2018-03-23 12:10:14 +01:00
nettests Add functions for structured progress logging 2018-03-22 15:22:29 +01:00
utils Add geoip command line tool 2018-03-23 12:10:38 +01:00
.gitignore Refactor directory structure 2018-03-22 15:58:10 +01:00
Gopkg.lock Implement geoip related functionality in gooni 2018-03-22 18:28:38 +01:00
Gopkg.toml Implement geoip related functionality in gooni 2018-03-22 18:28:38 +01:00
Makefile Refactor directory structure 2018-03-22 15:58:10 +01:00
ooni.go Refactor how we create the context 2018-03-23 12:10:14 +01:00
Readme.md Remove item from todo 2018-03-20 14:19:45 +01:00

gooni

An attempt at writing OONI Probe in golang.

This is heavy work in progress.

Development setup

This project uses dep with the vendor/ dir in .gitignore.

Once you have dep installed, run:

dep ensure

Next, you'll need a recent version of Measurement Kit. As this is a work in progress, you'll likely need to build a version of the library from source.

You should then be able to build a ooni binary by running:

make build

If you want to build gooni against a development version of MK without installing it to your system, you can explicitly specify the path where MK was built as

CGO_LDFLAGS="-L/path/to/measurement-kit/.libs/" CGO_CFLAGS="-I/path/to/measurement-kit/include" make build

Todo

  • Add support for outputing structured logging messages, while tests are running, to be consumed by the desktop app

  • Add support for the missing tests, namely:

  • HTTP Invalid Request Line
  • HTTP Header Field Manipulation
  • Facebook Messenger
  • Telegram
  • WhatsApp
  • WebConnectivity
  • Fix issue with the informed consent being bypassed on first run

  • Finish the config file implementation

  • Add support for listing results in the CLI