a pretty basic websocket wrapper for reddit chatrooms
Project description
REDDIT IS KILLING COMMUNITY CHATS FEATURE. I WILL SEE WHAT CAN BE DONE FOR GROUP CHATS
Reddit ChatRoom
a pretty basic websocket wrapper for reddit chatrooms
no selenium no bullsh*t, just directly websocket
works either with reddit username & password or the api token (not a regular one you get from your registered app), so you wont have to expose your pass
Installation
pip install Reddit-ChatBot-Python
required packages:
websocket_client>=0.57.0
requests>=2.24.0
Usage
from Reddit_ChatBot_Python import ChatBot, RedditAuthentication
import random # for a basic dice rolling game
# create authentication with username and pass
reddit_authentication = RedditAuthentication.PasswordAuth(reddit_username="", reddit_password="", twofa="") # 2FA supported although not necessary obv..
# instantiate the chatbot
chatbot = ChatBot(print_chat=True, store_session=True, print_websocket_frames=False, # some parameters u might wanna know
authentication=reddit_authentication)
# grab the websocket
websock = chatbot.WebSocketClient
# you can add a rate limit like so:
websock.RateLimiter.is_enabled = True
websock.RateLimiter.max_calls = 23 # how many messages will be sent by the bot
websock.RateLimiter.period = 1.5 # in what period(in minutes)
# now you can add hooks to the websock object in order for them to be executed when a message is received like so:
# create a function and hook
@websock.after_message_hook
def roll(resp): # resp is a SimpleNamespace that carries all the data of the received frame
messg_s = resp.message.split()
if messg_s[0] == "!roll" and len(messg_s) == 3: # if received message says !roll
limit_bottom = int(messg_s[1])
limit_top = int(messg_s[2])
rolled_number = random.randint(limit_bottom, limit_top)
response_text = f"@{resp.user.name} {rolled_number}. Better luck next time!"
# a basic roll game
websock.send_message(response_text, resp.channel_url) # and send the message, always add resp.channel_url as the second argument
websock.send_snoomoji('partyparrot', resp.channel_url) # and send a snoomoji cuz why not
return True # return true if you want to be done with checking the other hooks, otherwise return None or False
# keep in mind that first added hooks gets executed first
# now everytime someone says "!roll 1 100", the bot will roll and send the result!
# or you can add a basic response hook directly like so:
websock.set_respond_hook(input_="Hi", response="Hello {nickname}! enjoy your time in my cozy chat group", limited_to_users=None, lower_the_input=False,
exclude_itself=True, must_be_equal=True, limited_to_channels=["my cozy chat group"])
# you can add a welcome message for newly joined users too:
websock.set_welcome_message("welcome to the my cozy chat group u/{nickname}!", limited_to_channels=["my cozy chat group"]) # you can limit by indicating chatroom's name
# and finally, run forever...
websock.run_4ever(auto_reconnect=True) # set auto_reconnect so as to re-connect in case remote server shuts down the connection after some period of time
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for Reddit_ChatBot_Python-1.1.7.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | d5f20756bf4cc3cfd9c79d927678ec222997cb8fb36d7f9a7d611ed02f498235 |
|
MD5 | e57ad98c0a69668c4e9501310dd0119e |
|
BLAKE2b-256 | 25d4767035b71be07038b697a81e74928638d58f03d1835a016a432cd83b242f |
Close
Hashes for Reddit_ChatBot_Python-1.1.7-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c81d1acda864647a8e95589ba2dbf415f2323f113bdc64d429fe3dd134d74165 |
|
MD5 | adfae45854e2ea36c8cb87c02379d0f1 |
|
BLAKE2b-256 | bf7506f98379c78b10ac4e6ac22bc6e1d100543547a5cc397747f7b5f2468a75 |