ooni-probe-cli/Readme.md

129 lines
3.5 KiB
Markdown
Raw Normal View History

2018-08-01 12:16:11 +02:00
# OONI Probe CLI
2018-02-12 17:33:13 +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
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`
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:
```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.
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
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.
```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>
<key>Label</key>
<string>org.ooni.probe.daily-run</string>
<key>KeepAlive</key>
<false/>
<key>RunAtLoad</key>
<true/>
<key>Program</key>
<string>/PATH/TO/BINARY/ooniprobe</string>
<key>ProgramArguments</key>
<array>
<string>--config="/PATH/TO/CONFIG/config-100sites.json"</string>
<string>--batch</string>
<string>run</string>
</array>
<key>StartInterval</key>
<integer>3600</integer>
<key>StandardErrorPath</key>
<string>/tmp/ooniprobe-cli.err</string>
<key>StandardOutPath</key>
<string>/tmp/ooniprobe-cli.out</string>
</dict>
</plist>
```
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
2018-02-12 17:33:13 +01:00
## Development setup
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
```bash
go build -v ./cmd/ooniprobe
```
To compile a release used the `build.sh` script. For more information
```bash
./build.sh help
2018-02-12 17:33:13 +01: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
```
## Updating dependencies
1. update every direct dependency in `go.mod` except `probe-engine`
using `go get -u -v $dependency`:
```bash
for name in `grep -v indirect go.mod | grep -v probe-engine | awk '/^\t/{print $1}'`; do \
go get -u -v $name; \
done
```
2. pin to the latest version of the `probe-engine` with
`go get -v github.com/ooni/probe-engine@TAG`
3. remove all indirect dependencies from `go.mod` and merge the
content of `probe-engine`'s `go.mod` into our `go.mod`
4. `go mod tidy`
The rationale of this procedure is that we want to pin exactly to
a specific version of psiphon and of its dependencies.
## Releasing
1. update binary data as described above;
2. update `version/version.go`;
3. make sure you have updated dependencies;
4. run `./build.sh release` and follow instructions.