ooni-probe-cli/Readme.md

88 lines
3.4 KiB
Markdown
Raw Normal View History

# OONI Probe Client Library and CLI
2018-02-12 17:33:13 +01:00
[![GoDoc](https://godoc.org/github.com/ooni/probe-cli?status.svg)](https://godoc.org/github.com/ooni/probe-cli) [![Short Tests Status](https://github.com/ooni/probe-cli/workflows/shorttests/badge.svg)](https://github.com/ooni/probe-cli/actions?query=workflow%3Ashorttests) [![All Tests Status](https://github.com/ooni/probe-cli/workflows/alltests/badge.svg)](https://github.com/ooni/probe-cli/actions?query=workflow%3Aalltests) [![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](https://goreportcard.com/badge/github.com/ooni/probe-cli)](https://goreportcard.com/report/github.com/ooni/probe-cli) [![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) [![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)
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
Please, follow the instructions at [ooni.org/install/cli](https://ooni.org/install/cli)
to install `ooniprobe`. If we do not support your use case, please let us know.
2019-12-09 16:36:17 +01:00
Once `ooniprobe` is installed, try `ooniprobe help` to get interactive help.
2019-12-09 16:36:17 +01:00
## Reporting issues
Please, report issues with this codebase at [github.com/ooni/probe](
https://github.com/ooni/probe/issues/new?labels=ooni/probe-cli&assignee=bassosimone).
Please, make sure you tag such issues using the `ooni/probe-cli` label.
2019-12-09 16:36:17 +01:00
## Repository organization
2019-12-09 16:36:17 +01:00
Every top-level directory contains an explanatory README file.
2019-12-09 16:36:17 +01:00
## OONIProbe
Be sure you have golang >= 1.16 and a C compiler (when developing for Windows, you
need Mingw-w64 installed). You can build using:
2020-01-29 09:43:39 +01:00
```bash
go build -v ./cmd/ooniprobe
```
2020-12-09 12:51:28 +01:00
This will generate a binary called `ooniprobe` in the current directory.
2020-12-09 12:51:28 +01:00
## Android bindings
2020-12-09 12:51:28 +01:00
Make sure you have GNU make installed, then run:
```bash
./mk android
2020-01-29 09:43:39 +01:00
```
Builds bindings for Android. (Add `OONI_PSIPHON_TAGS=""` if you
cannot clone private repositories in the https://github.com/ooni namespace.)
2020-01-29 09:45:51 +01: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
## iOS bindings
2018-02-12 17:33:13 +01:00
Make sure you have GNU make installed, then run:
```bash
./mk ios
```
Builds bindings for iOS. (Add `OONI_PSIPHON_TAGS=""` if you
cannot clone private repositories in the https://github.com/ooni namespace.)
2018-02-12 17:33:13 +01: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.
## 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.
## Updating dependencies
```bash
go get -u -v ./... && go mod tidy
```
## Releasing
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.
We build releases using `./mk`, which requires GNU make. Try
the `./mk help|less` command for detailed usage.