Cleaned up repo and separated both bots into their respective folders

This commit is contained in:
Sid 2023-04-14 15:54:26 +02:00
parent 5414de60ca
commit a9fda1fcb7
3134 changed files with 382980 additions and 31 deletions

30
sidBot-py/README.md Normal file
View file

@ -0,0 +1,30 @@
# 🤖sidBot-py
A simple Discord bot made in Python 3.8 using [discord.py](https://github.com/Rapptz/discord.py)
**NOT ACTIVE!!!**
[![Add sidBot](https://img.shields.io/badge/-Add%20Bot-141B2E?style=for-the-badge&logo=discord)](https://discord.com/oauth2/authorize?client_id=921786935662477412&permissions=274881309760&scope=bot) <br>
**Add the bot to your Discord server and use these awesome features! :sparkles:**
## List of features/commands
:volcano: Commands:
```
!help - List of commands
!hello - Bot responds with "Hello!"
!ping - Bot responds with "Pong!" and botlatency + a gif from Ping Pong The Animation
!github - Flexes github link
!coinflip - Heads or Tails!
!inspire - Bot inspires user with a quote from zenquotes.io
!plsmeme - Bot supplies with premium memes from subreddits across Reddit from Huge RedditMemesAPI
!plsdog - Bot supplies with pictures of cute doggos across the whole internet through Dog API
!invbot - Bot sends invite link for itself
```
:speech_balloon: Auto Responds:
```
"merry christmas" - Someone writes "merry christmas" and bot responds w/ legendary vine quote selected from an array
```

15
sidBot-py/keep_alive.py Normal file
View file

@ -0,0 +1,15 @@
from flask import Flask
from threading import Thread
app = Flask('')
@app.route('/')
def home():
return "Hello. I am alive!"
def run():
app.run(host='0.0.0.0',port=8080)
def keep_alive():
t = Thread(target=run)
t.start()

127
sidBot-py/main.py Normal file
View file

@ -0,0 +1,127 @@
import os
import discord
import requests
import json
import random
import asyncio
from keep_alive import keep_alive
client=discord.Client()
TOKEN = 'REMOVED FOR SECURITY REASONS'
# arrays containing answers
xmasAnswers = ['Happy Chrismis!', 'Its Chrismin!', 'Merry Chrisis!', 'Merry Chrysler!']
coinflip = ['```Heads```', '```Tails```']
dogTitles = ['Who let the dogs out?:dog:', 'woof:dog:', 'Whos a good boy!:dog:', 'meow:cat:', 'Mr. GoodBoy:dog:', 'Bork Bork!:dog:']
############ APIs ################
# gets a quote from zenquotes.io
def get_quote():
response = requests.get('https://zenquotes.io/api/random')
json_data = json.loads(response.text)
quote = json_data[0]['q'] + ' \n-' + json_data[0]['a']
return('```' + quote + '```')
# gets a meme from Huge RedditMemesAPI
def get_meme():
response = requests.get('https://memes.blademaker.tv/api?lang=en')
res = response.json()
title = res['title']
ups = res['ups']
sub = res['subreddit']
meme = discord.Embed(title = f'{title}\nSubreddit: {sub}')
meme.set_image(url = res['image'])
meme.set_footer(text=f"👍:{ups}")
return meme
# gets a dog from Dog API
def get_dog():
response = requests.get('https://dog.ceo/api/breeds/image/random')
res = response.json()
dog = discord.Embed(title = random.choice(dogTitles))
dog.set_image(url = res['message'])
return dog
################ BOT READY ####################
@client.event # Register an event
async def on_ready():
print('We have logged in as {0.user}'.format(client))
activity = discord.Game(name = "!help") # sets bot activity
await client.change_presence(status = discord.Status.online, activity = activity)
############## MESSAGE RESPONSES ################
# bot senses a message & responds
@client.event
async def on_message(message):
# if message is from bot, return nothing
if message.author == client.user:
return
# user sends "!hello", bot responds w/ "Hello!"
if message.content.lower().startswith('!hello'):
await message.channel.send('Hello!')
# user sends "!ping", bot responds w/ "Pong" + bot latency and a gif
elif message.content.lower().startswith('!ping'):
await message.channel.send(f'Pong :ping_pong: (Bot latency: **{round(client.latency * 1000)}ms**)')
await message.channel.send(file=discord.File('resources/pingpong.gif'))
# user sends "!coinflip", bot returns result
elif message.content.lower().startswith("!coinflip"):
await message.channel.send(file=discord.File('resources/coinspin.gif'))
await asyncio.sleep(1)
await message.channel.send(random.choice(coinflip))
# user sends "!github", bot responds w/ my GitHub profile
elif message.content.lower().startswith("!github"):
await message.channel.send('https://github.com/SindreKjelsrud')
# someone writes "merry christmas", bot responds w/ legendary vine quote
elif "merry christmas" in message.content.lower():
await message.channel.send(random.choice(xmasAnswers) + ':santa:')
# user sends "!inspire", bot inspires user
elif message.content.lower().startswith("!inspire"):
quote = get_quote()
await message.channel.send(quote)
# user sends "!plsmeme", bot sends meme from random subreddit
elif message.content.lower().startswith("!plsmeme"):
meme = get_meme()
await message.channel.send(embed = meme)
# user sends "!plsdog", bot sends picture of dog from Dog API
elif message.content.lower().startswith("!plsdog"):
dog = get_dog()
await message.channel.send(embed = dog)
# user sends "!invbot", bot responds w/ invite link for bot
elif message.content.lower().startswith("!invbot"):
embedVar = discord.Embed(color=0x7B64FF)
embedVar.add_field(name="Bot Invite Link", value="https://discord.com/oauth2/authorize?client_id=921786935662477412&permissions=274881309760&scope=bot", inline=False)
await message.channel.send(embed=embedVar)
# user sends "!help", bot sends commandsfile
elif message.content.lower().startswith("!help"):
embedVar = discord.Embed(title="List of sidBots features/commands:", description="", color=0x7B64FF)
embedVar.add_field(name=":volcano: Commands:",
value='!help \n - List of commands \n\n!hello \n - Bot responds with "Hello!" \n\n!ping \n- Bot responds with "Pong!" and botlatency + a gif from Ping Pong The Animation \n\n!github \n- Flexes github link \n\n!coinflip\n- Heads or Tails! \n\n!inspire\n- Bot inspires user with a quote from zenquotes.io \n\n!plsmeme\n- Bot supplies with premium memes from subreddits across Reddit from Huge RedditMemesAPI \n\n!plsdog\n- Bot supplies with pictures of cute doggos across the whole internet through Dog API \n\n!invbot\n- Bot sends invite link for itself', inline=True)
embedVar.add_field(name=":speech_balloon: Auto Responds:", value='"merry christmas"\n- Someone writes "merry christmas" and bot responds w/ legendary vine quote selected from an array', inline=True)
await message.channel.send(embed=embedVar)
# keeps bot alive
keep_alive()
# run bot
client.run(TOKEN)

Binary file not shown.

After

Width:  |  Height:  |  Size: 254 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB