Ultimate Pollbot (@ultimate_pollbot)
Deciding where you and your friends are going for lunch today can be a real hassle... Or, for instance, deciding which games should be played at the next LAN-Party.
Since no other telegram poll/vote bot offered the full feature set my friends and I needed, I decided to write the ULTIMATE pollbot. A bot which combines all good features of all existing bots and even stuff beyond that.
Check the official Trello board for the status of planned features. There's also a list of regularly requested "won't implement" features.
The Ultimate Pollbot delivers a full set of well-tested and battle proven features. It's capable of handling hundreds of voters for a single poll, while offering a high customizability and a wide range of different poll types to choose from.
Here is a list of the most important features:
Poll types
This bot has 6 different vote modi. Each mode is useful for various scenarios. Choose wisely.
- Single vote: User get a single vote to allot
- Doodle: Users can vote with
yes
,no
andmaybe
for each option. - Block vote: Users can vote without restriction, but only one vote per option.
- Limited vote: Each user gets X votes for distribution, but only one vote per option.
- Cumulative vote: Every user gets X votes they can distribute as they like.
- Unlimited votes (Also called the shopping list): Every user can vote as often as they like, pretty much like a distributed shopping list.
Anonymity settings:
Polls can be configured to be anonymous, with the result that names of users are not visible. Polls can be made anonymous subsequently, but as soon as a poll is anonymous it stays that way forever!
Further it's possible to hide the results of the poll until it gets closed. As soon as such a poll is closed, the results will be visible. Beware!: such a poll cannot be reopened.
Poll Management:
- Addition and removal of options
- Allow other users to add new options
- Polls can be closed
- Polls can be reopened unless the poll is configured to hide the results until it has been closed.
- Polls can be completely deleted, which means that all non-forwarded occurrences of the poll will be removed.
- Polls can be reseted (Delete all votes). Poll needs to be closed first
- Polls can be cloned (New poll with same options, but without votes). Poll needs to be closed first
Misc:
- Internationalization
- Polls sync between groups in real time.
- Polls can be shared via link. This allows other users to spread the poll to arbitrary groups.
- A date picker for easier creation of poll options
- Specify a due date, at which the poll will be automatically closed.
- Activate notifications in chats to notify users that the poll will close soon.
Sorting and Appearance:
- Results can be displayed in a detailed or summarized manner.
- The percentage bar in the vote message can be disabled.
- The bot allows to configure the sorting of the option list and the user list for each option.
- Users can be sorted by vote date or username. Options can be sorted by highest percentage, name or by the order they've been added.
The project is still actively maintained. However, since my focus shifted to other projects, I most likely won't add new features myself.
I'll still discuss and accept new feature requests and review feature PR's. Happy coding ;)
First of all, thanks to Lokalise for providing my projects with a free license for open-source development!
Thanks to the Turkish translator:
Thanks to the Polish translator:
Thanks to all Italian translators:
- FedericoAntoniazzi
- LBindustries for providing italian translations.
Thanks to all Spanish translators:
- balboag
- davidgfnet
- Miguel Antunez
Thanks to all Brazilian Portuguese translators:
- gui258
- Leonardo Frazao
Thanks to all German translators:
- Thorsten Schlaberg
- KnorpelSenf
Thanks to the Catalan translator:
Thanks to the Czech translator:
- Ignac (IgnacRR)
Thanks to my patreons:
/start Start the bot
/settings Open the user settings menu
/create Create a new poll
/list List all active polls and manage them
/list_closed List all closed polls and manage them
/notify Activate notifications in a external chats
/help Display the help
/donations Get me a coffee
Dependencies:
- Poetry to manage and install dependencies.
- Ultimate Pollbot uses Postgres. Make sure the user has write/read rights. You can use the provided docker-compose file to set up a local development environment.
-
Clone the repository:
% git clone git@github.com:nukesor/ultimate-poll-bot pollbot && cd pollbot
-
Execute
poetry install
to install all dependencies. -
Either start the poll bot once with
poetry run python main.py
or copy thepollbot.toml
manually to~/.config /pollbot.toml
and adjust all necessary values. On Windows, the tilde (~
) will substitute to your home directory , usually atC:\Users\your.name\.config\pollbot.toml
. -
Run
poetry run python initdb.py
to initialize the database (or recreate it, if necessary). -
Start the bot by running
poetry run python main.py
. -
If you plan to keep your database schema up-to-date, you need to set the current alembic revision manually with
poetry run alembic stamp head
. -
Double-check if you are on the right revision
(head)
withpoetry run alembic current
and comparing it topoetry run alembic history
.
If you did Step 7 in the previous section, this is how you upgrade
- Stop the bot
git pull
poetry run alembic upgrade head
to run migrations on your database- Start the bot