2018-08-01 12:16:11 +02:00
|
|
|
# OONI Probe CLI
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2020-12-08 17:46:24 +01:00
|
|
|
[![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
|
|
|
|
2018-08-01 12:16:11 +02:00
|
|
|
The next generation OONI Probe Command Line Interface.
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2019-12-09 16:36:17 +01:00
|
|
|
## User setup
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
1. Go [into the releases](https://github.com/ooni/probe-cli/releases) and download the
|
|
|
|
release for your architecture and platform
|
2019-12-09 16:36:17 +01:00
|
|
|
|
|
|
|
2. Extract the tarball with `tar xvzf ooniprobe_*.tar.gz`
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
3. Copy the `ooniprobe` binary into a location in your `$PATH`, for example
|
|
|
|
`/usr/local/bin/ooniprobe`
|
2019-12-09 16:36:17 +01:00
|
|
|
|
|
|
|
4. Run `ooniprobe run` to perform all the tests
|
|
|
|
|
|
|
|
Optional:
|
|
|
|
|
|
|
|
Add a crontab entry (on linux) to run `ooniprobe` daily at a random time:
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```bash
|
2019-12-09 16:36:17 +01:00
|
|
|
(crontab -l 2>/dev/null; echo "$(( ( RANDOM % 60 ) + 1 )) $(( ( RANDOM % 24 ) + 1 )) * * * ooniprobe run") | crontab -
|
|
|
|
```
|
|
|
|
|
2020-01-29 09:43:39 +01:00
|
|
|
On macOS you can configure OONI Probe to run automatically using launchd.
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
Below is a sample launchd script, that should be placed inside of
|
|
|
|
`~/Library/LaunchAgents/org.ooni.probe.cli.plist`.
|
2020-01-29 09:43:39 +01:00
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
Be sure to replace `/PATH/TO/BINARY/ooniprobe` with the actual install location of the
|
|
|
|
`ooniprobe` binary and `/PATH/TO/CONFIG/config-100sites.json` with the location of a file
|
|
|
|
which limits the testing to 100 URLs.
|
2020-01-29 09:43:39 +01:00
|
|
|
|
|
|
|
You may also want to adjust the locations of the logs.
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```xml
|
2020-01-29 09:43:39 +01:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
|
|
<plist version="1.0">
|
|
|
|
<dict>
|
2020-12-09 12:51:28 +01:00
|
|
|
<key>Label</key>
|
|
|
|
<string>#{plist_name}</string>
|
|
|
|
|
|
|
|
<key>KeepAlive</key>
|
|
|
|
<false/>
|
|
|
|
<key>RunAtLoad</key>
|
|
|
|
<true/>
|
|
|
|
|
|
|
|
<key>ProgramArguments</key>
|
|
|
|
<array>
|
|
|
|
<string>/PATH/TO/BINARY/ooniprobe</string>
|
|
|
|
<string>--log-handler=syslog</string>
|
|
|
|
<string>run</string>
|
|
|
|
<string>unattended</string>
|
|
|
|
</array>
|
|
|
|
|
|
|
|
<key>StartInterval</key>
|
|
|
|
<integer>86400</integer>
|
|
|
|
|
2020-01-29 09:43:39 +01:00
|
|
|
</dict>
|
|
|
|
</plist>
|
|
|
|
```
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
Once you have written the file, you can enable `ooniprobe` to run automatically by
|
|
|
|
doing: `launchctl load org.ooni.probe.cli.plist`.
|
2020-01-29 09:45:51 +01:00
|
|
|
|
2020-12-08 17:39:50 +01:00
|
|
|
## Reporting issues
|
|
|
|
|
2020-12-08 17:45:10 +01:00
|
|
|
Please, report issues with this codebase at https://github.com/ooni/probe. Please, make
|
|
|
|
sure you tag such issues using the `ooni/probe-cli` label.
|
2020-12-08 17:39:50 +01:00
|
|
|
|
2018-02-12 17:33:13 +01:00
|
|
|
## Development setup
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
Be sure you have golang >= 1.14 and a C compiler (when developing for Windows, you
|
|
|
|
need Mingw-w64 installed). The most basic build command is:
|
2018-02-12 17:33:13 +01:00
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
```bash
|
|
|
|
go build -v ./cmd/ooniprobe
|
2019-11-14 10:14:25 +01:00
|
|
|
```
|
2020-08-22 11:20:50 +02:00
|
|
|
|
|
|
|
To compile a release used the `build.sh` script. For more information
|
|
|
|
|
|
|
|
```bash
|
2019-05-15 14:48:06 +02:00
|
|
|
./build.sh help
|
2018-02-12 17:33:13 +01:00
|
|
|
```
|
|
|
|
|
2020-08-22 11:20:50 +02:00
|
|
|
The output generated by this command should provide you with updated information
|
|
|
|
regarding the pre-requisites for building (and cross-building) `ooniprobe` as well
|
|
|
|
as useful information regarding cross compiling.
|
|
|
|
|
|
|
|
To update bundled binary data use:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
./updatebindata.sh
|
|
|
|
```
|
2019-11-13 18:31:19 +01:00
|
|
|
|
2020-01-28 10:05:54 +01:00
|
|
|
## Updating dependencies
|
|
|
|
|
2020-11-13 06:58:39 +01:00
|
|
|
`go get -u -v ./... && go mod tidy`
|
2020-01-28 10:05:54 +01: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
|
|
|
|
2020-11-13 17:37:06 +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.
|