Websocket client command line tool for nostr relay scripting, with docker and tor support
Using interactive input
shell
$ gnostr-cat wss://relay.damus.io <return>
["REQ", "RAND", {"kinds": [1], "limit": 8}] <return>
<ctrl-D>
Using stdin (supports multiple lines of commands)
```shell $ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' | gnostr-cat wss://relay.damus.io
$ cat commands.txt ["REQ", "RAND", {"kinds": [1], "limit": 2}] ["REQ", "RAND2", {"kinds": [2], "limit": 2}]
$ cat commands.txt | gnost-cat wss://relay.damus.io
```
Using jq to query Nostr JSON events and select the event JSON
```shell $ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' | gnostr-cat wss://relay.damus.io | jq '.[2]'
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' | gnostr-cat wss://relay.damus.io | jq '.[2].content' ```
Unique (dedupe) results as they come in (note: no longer applies sorting events - FIFO)
shell
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' |
gnostr-cat --unique wss://relay.damus.io wss://nostr.ono.re
With a websocket connection timeout in milliseconds
shell
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 2}]' |
gnostr-cat --connect-timeout 250 wss://relay.damus.io
Stream websocket data (like tail -f)
shell
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' |
gnostr-cat --stream wss://relay.damus.io
Output info log messages which can assist with debugging
shell
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 8}]' |
RUST_LOG=info gnostr-cat wss://relay.damus.io
Pipe events from one server to another (currently limited to 1 event at a time)
shell
$ echo '["REQ", "RAND", {"limit": 1}]' |
gnostr-cat wss://relay.damus.io |
jq -c 'del(.[1])' |
gnostr-cat wss://nostr.ono.re
Pipe events from one server to another (for multiple events, ctrl-C
when finished)
shell
$ echo '["REQ", "RAND", {"limit": 3}]' |
gnostr-cat wss://relay.damus.io |
jq -c 'del(.[1])' |
gnostr-cat --stream wss://nostr.ono.re
<ctrl-C>
Using Cargo to install (requires ~/.cargo/bin to be in PATH)
shell
$ cargo install gnostr-cat
Building from source (may be unstable)
shell
$ git clone https://github.com/gnostr-org/gnostr-cat && cd gnostr-cat
$ cargo build --release
Running inside a Docker image
```shell $ docker build -t gnostr-cat .
$ echo '["REQ", "RAND", {"kinds": [1], "limit": 2}]' | docker run --rm -i gnostr-cat wss://relay.damus.io ```