Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/QuokkaStake/cosmos-proposals-checker
A tool to notify you if you miss a proposal vote on any cosmos-sdk chain
https://github.com/QuokkaStake/cosmos-proposals-checker
Last synced: 3 months ago
JSON representation
A tool to notify you if you miss a proposal vote on any cosmos-sdk chain
- Host: GitHub
- URL: https://github.com/QuokkaStake/cosmos-proposals-checker
- Owner: QuokkaStake
- License: gpl-3.0
- Created: 2022-05-31T22:27:55.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-13T23:50:00.000Z (10 months ago)
- Last Synced: 2024-04-21T00:59:38.592Z (9 months ago)
- Language: Go
- Size: 354 KB
- Stars: 9
- Watchers: 2
- Forks: 22
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-ccamel - QuokkaStake/cosmos-proposals-checker - A tool to notify you if you miss a proposal vote on any cosmos-sdk chain (Go)
README
# cosmos-proposals-checker
![Latest release](https://img.shields.io/github/v/release/QuokkaStake/cosmos-proposals-checker)
[![Actions Status](https://github.com/QuokkaStake/cosmos-proposals-checker/workflows/test/badge.svg)](https://github.com/QuokkaStake/cosmos-proposals-checker/actions)
[![codecov](https://codecov.io/gh/QuokkaStake/cosmos-proposals-checker/graph/badge.svg?token=3C1TDJAHZ0)](https://codecov.io/gh/QuokkaStake/cosmos-proposals-checker)cosmos-proposals-checker is a tool that checks all configured chains for new proposals in voting period,
then notifies you if one or more of the configured wallets haven't voted on it. Like that:![Telegram](https://raw.githubusercontent.com/QuokkaStake/cosmos-proposals-checker/main/images/telegram.png)
## How can I set it up?
Download the latest release from [the releases page](https://github.com/QuokkaStake/cosmos-proposals-checker/releases/). After that, you should unzip it, and you are ready to go:
```sh
wget
tar
./cosmos-proposals-checker --config
```Alternatively, install `golang` (>1.18), clone the repo and build it:
```
git clone https://github.com/QuokkaStake/cosmos-proposals-checker
cd cosmos-proposals-checker
# This will generate a `cosmos-proposals-checker` binary file in the repository folder
make build
# This will generate a `cosmos-proposals-checker` binary file in $GOPATH/bin
```To run it detached, first we have to copy the file to the system apps folder:
```sh
sudo cp ./cosmos-proposals-checker /usr/bin
```Then we need to create a systemd service for our app:
```sh
sudo nano /etc/systemd/system/cosmos-proposals-checker.service
```You can use this template (change the user to whatever user you want this to be executed from.
It's advised to create a separate user for that instead of running it from root):```
[Unit]
Description=Cosmos Proposals Checker
After=network-online.target[Service]
User=
TimeoutStartSec=0
CPUWeight=95
IOWeight=95
ExecStart=cosmos-proposals-checker --config
Restart=always
RestartSec=2
LimitNOFILE=800000
KillSignal=SIGTERM[Install]
WantedBy=multi-user.target
```Then we'll add this service to autostart and run it:
```sh
sudo systemctl daemon-reload # reload config to reflect changed
sudo systemctl enable cosmos-proposals-checker # put service to autostart
sudo systemctl start cosmos-proposals-checker # start the service
sudo systemctl status cosmos-proposals-checker # validate it's running
```If you need to, you can also see the logs of the process:
```sh
sudo journalctl -u cosmos-proposals-checker -f --output cat
```## How does it work?
It queries LCD nodes for the proposals list in voting period, then for each wallet it queries its vote.
If you haven't voted, it spawns an alert and sends it to configured notifiers.## How can I configure it?
All configuration is done via `.toml` config file, which is mandatory.
Run the app with `--config ` to specify config.
Check out `config.example.toml` to see the params that can be set.## Notifiers
Currently, this program supports the following notifications channels:
1) TelegramGo to @BotFather in Telegram and create a bot. After that, there are two options:
- you want to send messages to a user. This user should write a message to @getmyid_bot, then copy
the `Your user ID` number. Also keep in mind that the bot won't be able to send messages unless you contact it first,
so write a message to a bot before proceeding.
- you want to send messages to a channel. Write something to a channel, then forward it to @getmyid_bot and copy
the `Forwarded from chat` number. Then add the bot as an admin.To have fancy commands auto-suggestion, go to @BotFather again, select your bot -> Edit bot -> Edit description
and paste the following:
```
proposals - List proposals and wallets' votes on them
proposals_mute - Mutes notifications on a chain/proposal
proposals_unmute - Unmutes notifications on a chain/proposal
proposals_mutes - List active proposal mutes
tally - Show the tally for proposals that are in voting period
params - Show chains params related to governance
help - Displays help
```Then add a Telegram config to your config file (see `config.example.toml` for reference).
2) PagerDuty
Go to your PagerDuty page, then go to Services. Create a service if you haven't created one already.
Select this service, then go to "Integrations" tab, add an integration there. Copy the integration key
and add it to the `pagerduty` part in config (see `config.example.toml` for reference).
Additionally, override PagerDuty URL in config if you are using EU version.## Which networks this is guaranteed to work?
In theory, it should work on a Cosmos-based blockchains that expose a REST server, and also on Neutron.
## How can I contribute?
Bug reports and feature requests are always welcome! If you want to contribute, feel free to open issues or PRs.