mirror of
https://github.com/MrDetonia/Maki.git
synced 2024-11-25 20:47:57 -05:00
Initial commit, v0.4
This commit is contained in:
commit
e05b3f5286
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
secret.py
|
||||
__pycache__
|
28
LICENSE.md
Normal file
28
LICENSE.md
Normal file
@ -0,0 +1,28 @@
|
||||
Modified BSD License
|
||||
====================
|
||||
|
||||
_Copyright © 2015, Zac Herd_
|
||||
_All rights reserved._
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions are met:
|
||||
|
||||
1. Redistributions of source code must retain the above copyright
|
||||
notice, this list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright
|
||||
notice, this list of conditions and the following disclaimer in the
|
||||
documentation and/or other materials provided with the distribution.
|
||||
3. Neither the name of the copyright holder nor the
|
||||
names of its contributors may be used to endorse or promote products
|
||||
derived from this software without specific prior written permission.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS “AS IS” AND
|
||||
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
16
README.md
Normal file
16
README.md
Normal file
@ -0,0 +1,16 @@
|
||||
# Maki - Discord bot written in Python
|
||||
### The bot that sits on PEEPBEEPMEMECREEP and does things.
|
||||
|
||||
---
|
||||
|
||||
## Running Maki
|
||||
Maki uses Python 3.4 with discord.py. Install python3.4 and use pip to install asyncio and discord.py.
|
||||
To run Maki, simply run bot.py.
|
||||
|
||||
You will require an account for Maki to use, the logon details for which should be stored in a file called secret.py
|
||||
|
||||
## License
|
||||
Copyright 2016, Zac Herd.
|
||||
All Rights Reserved.
|
||||
Licensed under the BSD 3-clause License.
|
||||
See LICENSE.md for a full copy of the license text.
|
136
bot.py
Normal file
136
bot.py
Normal file
@ -0,0 +1,136 @@
|
||||
# Maki
|
||||
# ----
|
||||
# Discord bot by MrDetonia
|
||||
#
|
||||
# Copyright 2016 Zac Herd
|
||||
# Licensed under BSD 3-clause License, see LICENSE.md for more info
|
||||
|
||||
# IMPORTS
|
||||
import discord
|
||||
import asyncio
|
||||
import time
|
||||
import datetime
|
||||
from collections import namedtuple
|
||||
|
||||
# file in this directory called "secret.py" should contain these variables
|
||||
from secret import email,pwd
|
||||
|
||||
|
||||
# CONFIGURATION
|
||||
|
||||
# reported bot name
|
||||
name = "Maki"
|
||||
|
||||
# bot version
|
||||
version = "v0.4"
|
||||
|
||||
# text shown by .help command
|
||||
helptext = """I am a bot written in Python by MrDetonia
|
||||
|
||||
My commands are:
|
||||
```
|
||||
.help - displays this text
|
||||
.bots - prints basic info
|
||||
.source - show a link to my source
|
||||
.whoami - displays your user info
|
||||
.seen <user> - prints when user was last seen
|
||||
```"""
|
||||
|
||||
# IDs of admin users
|
||||
admins = ['116883900688629761']
|
||||
|
||||
|
||||
# GLOBALS
|
||||
|
||||
# number of times Ben has mentioned his meme boards
|
||||
ben_ck_count = 0
|
||||
ben_fit_count = 0
|
||||
|
||||
# log of users' last messages and timestamps
|
||||
history = {'test': ('test message',time.time())}
|
||||
|
||||
# this instance of a Discord client
|
||||
client = discord.Client()
|
||||
|
||||
|
||||
# FUNCTIONS
|
||||
|
||||
# converts a datetime to a string
|
||||
def strfromdt(dt):
|
||||
return dt.strftime('%Y-%m-%d %H:%M:%S')
|
||||
|
||||
# converts a timestamp to a datetime
|
||||
def dtfromts(ts):
|
||||
return datetime.datetime.fromtimestamp(ts)
|
||||
|
||||
# EVENT HANDLERS
|
||||
|
||||
# called when client ready
|
||||
@client.event
|
||||
@asyncio.coroutine
|
||||
def on_ready():
|
||||
# info on terminal
|
||||
print('Connected')
|
||||
print('User: ' + client.user.name)
|
||||
print('ID: ' + client.user.id)
|
||||
|
||||
# set "Now Playing" to print version
|
||||
game = discord.Game(name = version)
|
||||
yield from client.change_status(game, False)
|
||||
|
||||
# called when message received
|
||||
@client.event
|
||||
@asyncio.coroutine
|
||||
def on_message(message):
|
||||
# print messages to terminal for info
|
||||
print(message.author.name + ': ' + message.content)
|
||||
|
||||
# do not parse own messages
|
||||
if message.author != client.user:
|
||||
|
||||
# log each message against users
|
||||
history[message.author.name] = (message.content, time.time())
|
||||
|
||||
# parse messages for commands
|
||||
if message.content.startswith('.bots'):
|
||||
# print bot info
|
||||
yield from client.send_message(message.channel, 'I am ' + name + ', a Discord bot by MrDetonia | ' + version + ' | Python 3.4 with discord.py')
|
||||
|
||||
elif message.content.startswith('.help'):
|
||||
# print command list
|
||||
yield from client.send_message(message.channel, helptext)
|
||||
|
||||
elif message.content.startswith('.source'):
|
||||
# link to source code
|
||||
yield from client.send_message(message.channel, 'These are my insides: http://27b-a.xyz/mrdetonia/Maki')
|
||||
|
||||
elif message.content.startswith('.die') and message.author.id in admins:
|
||||
# exit discord and kill bot
|
||||
yield from client.send_message(message.channel, 'y tho :(')
|
||||
yield from client.logout()
|
||||
print('exited via die command')
|
||||
|
||||
elif message.content.startswith('.whoami'):
|
||||
# show info about user
|
||||
yield from client.send_message(message.channel, 'User: ' + message.author.name + ' ID: ' + message.author.id + ' Discriminator: ' + message.author.discriminator + '\nAccount Created: ' + strfromdt(message.author.created_at))
|
||||
|
||||
elif message.content.startswith('.seen'):
|
||||
# print when user was last seen
|
||||
target = message.content[6:]
|
||||
if target in history:
|
||||
# user logged, print last message and time
|
||||
yield from client.send_message(message.channel, 'user ' + target + ' was last seen saying "' + history[target][0] + '" at ' + strfromdt(dtfromts(history[target][1])))
|
||||
else:
|
||||
# user not logged
|
||||
yield from client.send_message(message.channel, 'user not seen yet')
|
||||
|
||||
# Ben meme trackers
|
||||
elif '/ck/' in message.content and message.author.name == "Ben.H":
|
||||
ben_ck_count += 1
|
||||
yield from client.send_message(message.channel, 'I have seen Ben reference /ck/ ' + ben_ck_count + ' times now.')
|
||||
elif '/fit/' in message.content and message.author.name == "Ben.H":
|
||||
ben_ck_count += 1
|
||||
yield from client.send_message(message.channel, 'I have seen Ben reference /fit/ ' + ben_fit_count + ' times now.')
|
||||
|
||||
# Run the client
|
||||
client.run(email, pwd)
|
Loading…
Reference in New Issue
Block a user