Metadata-Version: 2.0
Name: dankbot
Version: 0.0.4
Summary: Slack bot for posting dank memes from Reddit
Home-page: https://github.com/DankCity/dankbot
Author: Levi Noecker
Author-email: levi.noecker [at] gmail [dot] com
License: MIT
Keywords: reddit,slack,imgur,dank,memes,bot,slack bot,dankbot
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Communications :: Chat
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Requires-Dist: appdirs (==1.4.0)
Requires-Dist: configparser (==3.5.0)
Requires-Dist: imgurpython (==1.1.7)
Requires-Dist: mysqlclient (==1.3.9)
Requires-Dist: praw (==3.6.0)
Requires-Dist: retryz (==0.1.8)
Requires-Dist: slacker (==0.9.30)

Dankbot
=======

|PyPIVersion| |CircleCI| |CoverageStatus| |CodeHealth| |StoriesInReady|

.. |PyPIVersion| image:: https://badge.fury.io/py/dankbot.svg
    :target: https://badge.fury.io/py/dankbot
.. |CircleCI| image:: https://circleci.com/gh/DankCity/dankbot/tree/master.svg?style=svg
    :target: https://circleci.com/gh/DankCity/dankbot/tree/master
.. |CoverageStatus| image:: https://coveralls.io/repos/github/DankCity/dankbot/badge.svg?branch=master
    :target: https://coveralls.io/github/DankCity/dankbot?branch=master
.. |CodeHealth| image:: https://landscape.io/github/DankCity/dankbot/master/landscape.svg?style=flat
   :target: https://landscape.io/github/DankCity/dankbot/master
   :alt: Code Health
.. |StoriesInReady| image:: https://badge.waffle.io/DankCity/dankbot.svg?label=ready&title=Ready
   :target: http://waffle.io/DankCity/dankbot

A Slack Bot that scrapes memes from subreddits and posts them to slack

Steps to run
============

Clone into directory
--------------------
::

    cd /opt
    sudo mkdir dankbot && sudo chown <user>:<user> dankbot
    git clone git@github.com:DankCity/dankbot.git

Setup INI file
--------------
::

    cd /opt/dankbot
    cp dankbot/dankbot.ini.sample dankbot/dankbot.ini

Edit the INI file to fill in the missing token, username, and password fields:
::

    (.venv35)➜  dankbot git:(master) ✗ cat dankbot/dankbot.ini.sample
    [slack]
    token: <put here>
    channel: #random

    [reddit]
    subreddits: dankmemes, fishpost, me_irl, 4chan

    [imgur]
    client_id: <client_id>
    client_secret: <client Secret>

    [mysql]
    database: <db>
    username: <username>
    password: <password>

    [misc]
    include_nsfw: <boolean>
    max_memes: 3

Create and activate a virtual environment
-----------------------------------------
::

    cd /opt/dankbot
    virtualenv --python=`which python3` env
    source env/bin/activate

Install the python package
--------------------------
::

    cd /opt/dankbot
    source env/bin/activate
    pip install -e .

Create logging folder
---------------------
::

    sudo mkdir /var/log/dankbot
    sudo chown <user> /var/log/dankbot

Add an entry to your crontab
-----------------------------
Edit the crontab with your favorite editor
::

    sudo vi /etc/crontab

And add an entry like so:
::

    # /etc/crontab: system-wide crontab
    # Unlike any other crontab you don't have to run the 'crontab'
    # command to install the new version when you edit this file
    # and files in /etc/cron.d. These files also have username fields,
    # that none of the other crontabs do.

    SHELL=/bin/sh
    PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

    # m h dom mon dow usernamecommand
    */5 09-17 * * 1-5 root cd /opt/dankbot && source env/bin/activate && dankbot .

This will run dankbot once every 5 minutes, Monday to Friday, between 9 AM and
5 PM CST


