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
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`
4. Run `ooniprobe run` to perform all the tests
Optional:
Add a crontab entry (on linux) to run `ooniprobe` daily at a random time:
```
(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` .
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.
You may also want to adjust the locations of the logs.
```
<?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 >
```
2020-01-29 09:45:51 +01:00
Once you have written the file, you can enable to run automatically by doing: `launchctl load org.ooni.probe.cli.plist` .
2018-02-12 17:33:13 +01:00
## Development setup
2020-03-10 12:02:30 +01:00
Be sure you have golang >= 1.14. We use golang modules. Run
2018-02-12 17:33:13 +01:00
2019-11-14 10:14:25 +01:00
```
2019-05-15 14:48:06 +02:00
./build.sh help
2018-02-12 17:33:13 +01:00
```
2019-05-15 14:48:06 +02:00
to get information on the supported systems as well as to get
instructions on how to install dependencies.
2019-11-13 18:31:19 +01:00
2020-01-28 10:05:54 +01:00
## Updating dependencies
1. update every direct dependency in `go.mod` except `probe-engine`
2020-06-15 14:57:00 +02:00
using `go get -u -v $dependency` :
```
for name in `grep -v indirect go.mod | grep -v probe-engine | awk '/^\t/{print $1}'` ; do \
go get -u -v $name; \
done
```
2020-01-28 10:05:54 +01:00
2. pin to the latest version of the `probe-engine` with
2020-06-15 14:57:00 +02:00
`go get -v github.com/ooni/probe-engine@TAG`
2020-01-28 10:05:54 +01:00
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.
2019-11-13 18:31:19 +01:00
## Releasing
2020-02-17 11:38:59 +01:00
Make sure you have updated dependencies. Specifically, make sure
you update homebrew to get the latest Measurement Kit. Then:
2019-11-14 10:14:25 +01:00
```
2019-11-13 18:31:19 +01:00
./build.sh release
```
and follow instructions.