2018-08-01 12:16:11 +02:00
|
|
|
# OONI Probe CLI
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2021-02-03 19:29:12 +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)
|
2020-11-13 09:59:30 +01:00
|
|
|
|
2021-03-01 18:14:21 +01:00
|
|
|
The next generation OONI Probe: 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)
|
|
|
|
to install `ooniprobe`. If we do not support your use case, please let us know.
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
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
|
|
|
|
|
|
|
|
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
|
|
|
|
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-02-03 19:29:12 +01:00
|
|
|
## Development setup
|
|
|
|
|
2021-03-02 12:08:24 +01:00
|
|
|
Be sure you have golang >= 1.16 and a C compiler (when developing for Windows, you
|
|
|
|
need Mingw-w64 installed).
|
|
|
|
|
|
|
|
You need to download assets first using:
|
2019-12-09 16:36:17 +01:00
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```bash
|
2021-03-02 12:08:24 +01:00
|
|
|
go run ./internal/cmd/getresources
|
2019-12-09 16:36:17 +01:00
|
|
|
```
|
|
|
|
|
2021-03-02 12:08:24 +01:00
|
|
|
Then 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-02-03 19:29:12 +01:00
|
|
|
```bash
|
|
|
|
./build-android.bash
|
2020-01-29 09:43:39 +01:00
|
|
|
```
|
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
We automatically build Android bindings whenever commits are pushed to the
|
|
|
|
`mobile-staging` branch. Such builds could be integrated by using:
|
2020-01-29 09:45:51 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
```Groovy
|
|
|
|
implementation "org.ooni:oonimkall:VERSION"
|
|
|
|
```
|
2020-12-08 17:39:50 +01:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
Where VERSION is like `2020.03.30-231914` corresponding to the
|
|
|
|
time when the build occurred.
|
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
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```bash
|
2021-02-03 19:29:12 +01:00
|
|
|
./build-ios.bash
|
2019-11-14 10:14:25 +01:00
|
|
|
```
|
2020-08-22 11:20:50 +02:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
We automatically build iOS bindings whenever commits are pushed to the
|
|
|
|
`mobile-staging` branch. Such builds could be integrated by using:
|
2020-08-22 11:20:50 +02:00
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
```ruby
|
|
|
|
pod 'oonimkall', :podspec => 'https://dl.bintray.com/ooni/ios/oonimkall-VERSION.podspec'
|
2018-02-12 17:33:13 +01:00
|
|
|
```
|
|
|
|
|
2021-02-03 19:29:12 +01:00
|
|
|
Where VERSION is like `2020.03.30-231914` corresponding to the
|
|
|
|
time when the build occurred.
|
2020-08-22 11:20:50 +02:00
|
|
|
|
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
|
|
|
|
|
2020-09-30 10:54:58 +02:00
|
|
|
1. update binary data as described above;
|
2020-02-17 11:38:59 +01:00
|
|
|
|
2021-02-12 20:00:45 +01:00
|
|
|
2. update `internal/version/version.go`;
|
2020-09-30 10:54:58 +02:00
|
|
|
|
|
|
|
3. make sure you have updated dependencies;
|
2019-11-13 18:31:19 +01:00
|
|
|
|
2020-09-30 10:54:58 +02:00
|
|
|
4. run `./build.sh release` and follow instructions.
|