2023-05-25 13:37:49 +02:00
# Examples
## Compile
Make all examples.
```console
make example2
```
## basic2
2022-11-04 13:40:24 +01:00
TODO
2023-05-25 13:37:49 +02:00
## publisher/subscriber
2022-11-04 13:40:24 +01:00
2023-08-09 18:11:50 +01:00
Within `examples/` you can find a `publisher` and a `subscriber` . The first one publishes messages to the default pubsub topic on a given content topic, and the second one runs forever listening to that pubsub topic and printing the content it receives.
2022-11-04 13:40:24 +01:00
**Some notes:**
* These examples are meant to work even in if you are behind a firewall and you can't be discovered by discv5.
* You only need to provide a reachable bootstrap peer (see our [fleets ](https://fleets.status.im/ ))
* The examples are meant to work out of the box.
* Note that both services wait for some time until a given minimum amount of connections are reached. This is to ensure messages are gossiped.
**Run:**
Wait until the subscriber is ready.
```console
./build/subscriber
```
And run a publisher
```console
./build/publisher
```
2023-05-12 12:35:26 +02:00
See how the subscriber received the messages published by the publisher. Feel free to experiment from different machines in different locations.
2023-05-25 13:37:49 +02:00
## resource-restricted publisher/subscriber (lightpush/filter)
2023-05-12 12:35:26 +02:00
To illustrate publishing and receiving messages on a resource-restricted client,
`examples/v2` also provides a `lightpush_publisher` and a `filter_subscriber` .
The `lightpush_publisher` continually publishes messages via a lightpush service node
to the default pubsub topic on a given content topic.
The `filter_subscriber` subscribes via a filter service node
to the same pubsub and content topic.
It runs forever, maintaining this subscription
and printing the content it receives.
2023-05-25 13:37:49 +02:00
**Run**
Start the filter subscriber.
2023-05-12 12:35:26 +02:00
```console
2023-05-25 13:37:49 +02:00
./build/filter_subscriber
2023-05-12 12:35:26 +02:00
```
And run a lightpush publisher
```console
2023-05-25 13:37:49 +02:00
./build/lightpush_publisher
2023-05-12 12:35:26 +02:00
```
See how the filter subscriber receives messages published by the lightpush publisher.
Neither the publisher nor the subscriber participates in `relay` ,
but instead make use of service nodes to save resources.
Feel free to experiment from different machines in different locations.