A GroupMe bot written in Python that uses GroupMe's REST API to provide like and kick stats, as well as posting random images. Messages are stored using SQLite. Only image/video URLs are saved rather than the actual media to use minimal space. Ext is short for Extras :)
This has only been tested in Python 3.7
- Return Like and Kick data for users
- Rank users in order of likes and return a leaderboard
- Return a random image previously posted, either from all time or specific year
- Return group metadata such as total messages, group creator, and date created
- Hourly refresh of message data
- Tested in a 7 year old group with over 100 partitipants and over 250k messages.
-
Install required python libraries in requirements.txt (schedule, requests)
-
In the data folder, create a copy or rename the example config file to config.json
-
Sign into dev.groupme.com with your GroupMe account
-
In the "Bots" tab create a bot in your group, set your callback url with the IP:port you will be hosting the bot on, also a name and optional photo
-
Copy the Bot ID and Group ID into the config file, also set the listening port
-
At the top of the dev.groupme.com page click "Access Token" and copy it to the config file
-
Run rebuild_database.py to create the local database of your groups messages (this may take some time! downloading 250k messages takes around 30 minutes!)
-
Edit the config file as you see fit, though the default settings are what worked best in my group.
-
Run run.py to start the bot :)
NOTE: you may need to rerun rebuild_database every once in a great while, messages older than the "refresh_days" will not be seen, but this should be very marginal.
bot_id : Your bot id from dev.groupme.com bots tab
listening_port : The port you are hosting the bot on
api_key : your api key from dev.groupme.com
group_id : the group id the bot is in from dev.groupme.com bots tab
disable_image : enable/disable the !image function
like_threshold : when !image is ran, this is the minimim number of likes for the image it picks
year_like_threshold : when !image [year] is ran, this is the minimim number of likes for the image it picks
limit_image : limit !image to one per day per user (this prevents so much spam)
refresh_days : the bot refreshes messages every hour, this is the amount of days back it checks,refreshing too many messages can use a lot of API calls and take much longer, though there is no documented API limit my calls started failing around ~2,500 within one hour, this days limit reduces the API calls to less than a dozen per hour usually
Command | Function |
---|---|
!image | Post a random image previously posted in the chat, along with the original poster and message text |
!image [year] | !image, randomly picks from a specified year, ignores the year if there are no posts for that year |
!likes | Posts the total number of likes and rank for that user |
!likes [tag user] | Posts the total number of likes and rank for the tagged user |
!rank | Posts a leaderboard of the top 12 users in terms of likes |
!kicks | Posts the total number of times kicked/times kicker for that user, might not be intresting for Locked groups as only the owner can kick |
!kicks [tag user] | Posts the total number of times kicked/times kicker for the tagged user, might not be intresting for Locked groups as only the owner can kick |
!info | Posts group info such as total number of messages, group creation date, group creator, and minimum likes for image from the config file |
!info
!likes
!rank
!kicks
!image
-
You can not DM bots, but GroupMe has a sort of bug in its app (possibly just on Android). If you view an image posted by a bot, you are able to tap the profile and there is an option to DM the bot or add to another group. This actually just DMs or adds a user with the same user ID as the bot's ID.
-
This project was made possible by Chomps Bot and GroupMe Analytics, which were used to learn GroupMe's bot and application APIs accordingly.
I'll document how to add your own functionality later