2021-03-04 11:36:41 +01:00
|
|
|
# OONI Probe Client Library and CLI
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
* Documentation: [![GoDoc](https://godoc.org/github.com/ooni/probe-cli?status.svg)](https://godoc.org/github.com/ooni/probe-cli)
|
|
|
|
|
|
|
|
* `go test -race -short ./...` status: [![Short Tests Status](https://github.com/ooni/probe-cli/workflows/shorttests/badge.svg)](https://github.com/ooni/probe-cli/actions?query=workflow%3Ashorttests)
|
|
|
|
|
|
|
|
* `go test -race ./...` status: [![All Tests Status](https://github.com/ooni/probe-cli/workflows/alltests/badge.svg)](https://github.com/ooni/probe-cli/actions?query=workflow%3Aalltests)
|
|
|
|
|
|
|
|
* Code coverage for `-short` tests: [![Coverage Status](https://coveralls.io/repos/github/ooni/probe-cli/badge.svg?branch=master)](https://coveralls.io/github/ooni/probe-cli?branch=master)
|
|
|
|
|
|
|
|
* Go Report Card: [![Go Report Card](https://goreportcard.com/badge/github.com/ooni/probe-cli)](https://goreportcard.com/report/github.com/ooni/probe-cli)
|
|
|
|
|
|
|
|
* Debian package builds: [![linux-debian-packages](https://github.com/ooni/probe-cli/workflows/linux-debian-packages/badge.svg)](https://github.com/ooni/probe-cli/actions?query=workflow%3Alinux-debian-packages)
|
|
|
|
|
|
|
|
* Open issues: [![GitHub issues by-label](https://img.shields.io/github/issues/ooni/probe/ooni/probe-cli?style=plastic)](https://github.com/ooni/probe/labels/ooni%2Fprobe-cli)
|
2020-11-13 09:59:30 +01:00
|
|
|
|
2021-03-04 11:36:41 +01:00
|
|
|
The next generation OONI Probe: client library and Command Line Interface.
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2019-12-09 16:36:17 +01:00
|
|
|
## User setup
|
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
Please, follow the instructions at [ooni.org/install/cli](https://ooni.org/install/cli)
|
2021-08-20 13:18:39 +02:00
|
|
|
to install `ooniprobe`. If we do not support your use case, please let us know. Once
|
|
|
|
`ooniprobe` is installed, try `ooniprobe help` to get interactive help.
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
## Reporting issues
|
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
Report issues at [github.com/ooni/probe](
|
2021-02-03 19:29:12 +01:00
|
|
|
https://github.com/ooni/probe/issues/new?labels=ooni/probe-cli&assignee=bassosimone).
|
2021-08-20 13:18:39 +02:00
|
|
|
Please, make sure you add the `ooni/probe-cli` label.
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
## Repository organization
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
Every top-level directory contains an explanatory README file.
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
## ooniprobe
|
2021-02-03 19:29:12 +01:00
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
Be sure you have golang >= 1.16 and a C compiler (Mingw-w64 for Windows). You
|
|
|
|
can build using:
|
2020-01-29 09:43:39 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
```bash
|
2021-03-02 12:08:24 +01:00
|
|
|
go build -v ./cmd/ooniprobe
|
2021-02-03 19:29:12 +01:00
|
|
|
```
|
2020-12-09 12:51:28 +01:00
|
|
|
|
2021-03-02 12:08:24 +01:00
|
|
|
This will generate a binary called `ooniprobe` in the current directory.
|
2020-12-09 12:51:28 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
## Android bindings
|
2020-12-09 12:51:28 +01:00
|
|
|
|
2021-05-11 16:15:13 +02:00
|
|
|
Make sure you have GNU make installed, then run:
|
2021-04-29 19:24:25 +02:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
```bash
|
2021-05-11 16:15:13 +02:00
|
|
|
./mk android
|
2020-01-29 09:43:39 +01:00
|
|
|
```
|
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
to build bindings for Android. (Add `OONI_PSIPHON_TAGS=""` if you
|
2021-04-28 10:10:10 +02:00
|
|
|
cannot clone private repositories in the https://github.com/ooni namespace.)
|
2020-01-29 09:45:51 +01:00
|
|
|
|
2021-04-28 10:10:10 +02:00
|
|
|
The generated bindings are (manually) pushed to the Maven Central package
|
|
|
|
repository. The instructions explaining how to integrate these bindings
|
|
|
|
are published along with the release notes.
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
## iOS bindings
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2021-05-11 16:15:13 +02:00
|
|
|
Make sure you have GNU make installed, then run:
|
2021-04-29 19:24:25 +02:00
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```bash
|
2021-05-11 16:15:13 +02:00
|
|
|
./mk ios
|
2019-11-14 10:14:25 +01:00
|
|
|
```
|
2020-08-22 11:20:50 +02:00
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
to build bindings for iOS. (Add `OONI_PSIPHON_TAGS=""` if you
|
2021-04-28 10:10:10 +02:00
|
|
|
cannot clone private repositories in the https://github.com/ooni namespace.)
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2021-04-28 10:10:10 +02:00
|
|
|
The generated bindings are (manually) added to GitHub releases. The instructions
|
|
|
|
explaining how to integrate these bindings are published along with the release notes.
|
2020-08-22 11:20:50 +02:00
|
|
|
|
2021-04-29 19:24:25 +02:00
|
|
|
## miniooni
|
|
|
|
|
|
|
|
Miniooni is the experimental OONI client used for research. Compile using:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
go build -v ./internal/cmd/miniooni
|
|
|
|
```
|
|
|
|
|
|
|
|
This will generate a binary called `miniooni` in the current directory.
|
|
|
|
|
2021-08-20 13:18:39 +02:00
|
|
|
## Specification
|
|
|
|
|
|
|
|
Every nettest (aka experiment) implemented in this repository has a companion
|
|
|
|
spec in the [ooni/spec](https://github.com/ooni/spec) repository.
|
|
|
|
|
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
## Updating dependencies
|
2020-08-22 11:20:50 +02:00
|
|
|
|
|
|
|
```bash
|
2021-02-03 19:29:12 +01:00
|
|
|
go get -u -v ./... && go mod tidy
|
2020-08-22 11:20:50 +02:00
|
|
|
```
|
2019-11-13 18:31:19 +01:00
|
|
|
|
|
|
|
## Releasing
|
|
|
|
|
2021-03-31 16:40:58 +02:00
|
|
|
Create an issue according to [the routine release template](
|
|
|
|
https://github.com/ooni/probe/blob/master/.github/ISSUE_TEMPLATE/routine-sprint-releases.md)
|
|
|
|
and perform any item inside the check-list.
|
2021-04-29 19:24:25 +02:00
|
|
|
|
2021-05-11 16:15:13 +02:00
|
|
|
We build releases using `./mk`, which requires GNU make. Try
|
|
|
|
the `./mk help|less` command for detailed usage.
|