Skip to main content

polling-bot is a Discord bot to conduct basic polling functions in a Discord server

Project description

polling-bot

polling-bot is a Discord bot to conduct basic polling functions in a Discord server

Build Status codecov License GitHub issues PyPI Docs

Overview

Often times, reaching a consensus can be difficult without an organized method in place, and so this polling bot can be added to a Discord server to solve that need in a simple and efficient manner. Use cases could include deciding with friends on a place to eat, what video game should be played, when to schedule a party, etc.

The bot supports starting a poll and adding options for choices by the users. It will then keep track of responses made to the poll, and surface the winner of the poll when called upon.

Details

This project is a pure python project using modern tooling. It uses a Makefile as a command registry, with the following commands:

  • make: list available commands
  • make develop: install and build this library and its dependencies using pip
  • make build: build the library using setuptools
  • make lint: perform static analysis of this library with flake8 and black
  • make format: autoformat this library using black
  • make annotate: run type checking using mypy
  • make test: run automated tests with pytest
  • make coverage: run automated tests with pytest and collect coverage information
  • make dist: package library for distribution

Setup

To setup the Discord bot, follow the steps below:

  1. Navigate to http://discordapp.com/developers/applications and create an account, or login if you already have a Discord account.
  2. Select "New Application" and give it a name ie. "polling-bot"
  3. Navigate to the Bot tab on the left side menu, and click "Add Bot" and confirm.
  4. Under the TOKEN section, click "Copy" and copy the token.
  5. To add the bot to your Discord server, select the OAuth2 tab from the left side menu. From the SCOPES section, select bot option and from the BOT PERMISSIONS section, select Administrator. Copy and navigate to the generated URL and select the server you want to add the bot to from the dropdown, then click "Authorize."

Next, install polling-bot with pip: pip install polling-bot.

Finally, to run the bot, import and run it as follows:

import discord
pollingbot = __import__("polling-bot")
   
bot = pollingbot.PollingBot(intents=discord.Intents.all(), command_prefix="/")
bot.run('TOKEN')

Where token is the token copied from the Developer Portal above.

The bot will now be responsive to commands in your Discord server.

Available Commands

/poll - Starts a poll in the server

/add choice <content> - Add choices to the poll

/edit <option> <content> - Edit the content of the poll

  • Options are 'name', 'description', 'choice', and 'duration' (to alter how long the poll is open for [default is 5 mins])

/vote <choice #> - Vote for a choice in the poll

  • Choice # is the # corresponding to the desired choice, viewable with /view choices or /view poll

/view <option> - View the contents and results of the poll

  • Options are 'name', 'description', 'choices', 'poll', and 'results'

Usage

Start by executing /poll to create a poll. Edit the name and description of the poll using the /edit command. Next, add choices to the poll using the /add command. Have users then vote on the choices by running /view poll to see the current state of the poll, and then voting on their desired selection using the /vote command. Once all users have voted and the poll has concluded, run /view results to view the results and winner of the poll.

Quick demo using polling-bot in a Discord server

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polling-bot-0.2.0.tar.gz (13.2 kB view details)

Uploaded Source

File details

Details for the file polling-bot-0.2.0.tar.gz.

File metadata

  • Download URL: polling-bot-0.2.0.tar.gz
  • Upload date:
  • Size: 13.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.10

File hashes

Hashes for polling-bot-0.2.0.tar.gz
Algorithm Hash digest
SHA256 2de9ca51348481442aca765700585ac61947e88089ec5b25732f846b5b76ecf0
MD5 c96040e5c80044457237fbd80db1e9b8
BLAKE2b-256 95b74ccb933db73651c3f83cfa2fbc3a14bed26eedfec6b5992a128d3bdb8ed2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page