Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tim-harding/community_chess
A moderator bot for /r/CommunityChess
https://github.com/tim-harding/community_chess
chess reddit reddit-bot
Last synced: about 2 months ago
JSON representation
A moderator bot for /r/CommunityChess
- Host: GitHub
- URL: https://github.com/tim-harding/community_chess
- Owner: tim-harding
- License: mit
- Created: 2022-09-22T16:38:57.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-01-27T05:07:25.000Z (almost 1 year ago)
- Last Synced: 2024-11-24T20:53:44.615Z (2 months ago)
- Topics: chess, reddit, reddit-bot
- Language: Python
- Homepage:
- Size: 78.1 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Community Chess Bot
A moderator bot for [Community Chess](https://www.reddit.com/r/CommunityChess/), a collaborative chess game on Reddit.
## Contributing
### Setup
Use [pyenv](https://github.com/pyenv/pyenv) to manage your Python installation. Create a virtual environment and install the package.
```sh
python -m venv .venv
source .venv/bin/activate # Run each time you open the project
pip install --editable .[dev]
```### Authentication
This bot uses Praw's [Code Flow](https://praw.readthedocs.io/en/stable/getting_started/authentication.html#code-flow) for authentication.
1. Create an application in your Reddit [application preferences](https://www.reddit.com/prefs/apps/). Note your `client_secret`, shown when your press *edit*, and your `client_id`, listed below *personal use script*.
2. Set up your `praw.ini` in the project root as follows:
```ini
[DEFAULT]
redirect_uri=http://localhost:8080
client_id=MY_CLIENT_ID
client_secret=MY_CLIENT_SECRET
user_agent=script:com.MY_NAME.communitychess:v0.1.0 (by /u/MY_USERNAME)
```3. Use `get_refresh_token` to generate a refresh token.
4. Add this line to your `praw.ini`:
```ini
refresh_token=MY_REFRESH_TOKEN
```### Testing
#### Type checking
```sh
mypy
```#### Unit tests
```sh
python -m unittest
```#### Running
If you wish to test the bot in a live environment, please do so over at [/r/testingground4bots](https://www.reddit.com/r/testingground4bots/) or somewhere else off the main sub.
```sh
# Show command documentation
chessbot --help# Enable verbose logging and
# check for moves on the current post every five seconds
chessbot --log INFO --timeout 5
```### Deployment
The bot is deployed with [Fly.io](https://fly.io/).
#### Secrets
Set [secrets](https://fly.io/docs/reference/secrets/) for the `CLIENT_ID`, `CLIENT_SECRET`, and `REFRESH_TOKEN` variables from `praw.ini`.
```sh
fly secrets set MY_VAR=xxxxxxxx --stage
```#### Volume
Create the [volume](https://fly.io/docs/apps/volume-storage/) `community_chess_db`.
```sh
fly volumes create community_chess_db -r sea -n 1 -s 1
```#### Publish
```sh
# High availability creates unnecessary extra machines
fly deploy --ha=false
```