Raspberry Pi Slack Scroll Bot!

by matthewh415 in Circuits > Raspberry Pi

3004 Views, 1 Favorites, 0 Comments

Raspberry Pi Slack Scroll Bot!

Hi.png
Hi.JPG
IMG_5666.jpg

This project combines a Raspberry Pi with a Pimoroni Scroll Bot kit (modified with buttons), Slack, and IFTT for visual and audible notifications when youtube videos are posted to a subscription!

The button modifications to the kit are optional, as well as the speaker to announce the arrival of a new video.

You can also use this to send any message to the bot through slack by prepending "bot" the front of the message, such as "bot hello world". "bot clear" will clear the screen.

Scroll Bot Assembly

Complete the instructions for assembling the Pimoroni Scroll Bot:

https://learn.pimoroni.com/tutorial/sandyj/assembl...

Install Packages and Codebase

Install Audio Packages:

sudo apt-get update & sudo apt-get upgrade -y
sudo apt-get install mpg123    

Install python packages:

pip install flask
pip install psutil
pip install slackclient

Follow the tutorial at Pimoroni's for Getting Started with Scroll Hat:

https://learn.pimoroni.com/tutorial/sandyj/getting...

which includes downloading the sample source code and resources:

curl  https://get.pimoroni.com/scrollphathd  | bash

Since the screen is mounted upside down in the robot kit, you need to uncomment code to rotate the screen 180:

$ sed -i 's/#scrollphathd.rotate(degrees=180)/scrollphathd.rotate(degrees=180)/g' /home/pi/Pimoroni/scrollphathd/examples/web-api.py

Configuring Slack Instance

Screen Shot 2019-02-10 at 8.34.28 AM.png
Screen Shot 2019-02-10 at 8.36.38 AM.png

For the script to communicate with Slack, you'll need a bot API Key.

Start by logging into your Slack team webpage (https://my.slack.com/services/new/bot) and chose a username for your bot, then copy the API token provided.

Create a Slack Channel, and Invite Your Robot to the Channel.

Screen Shot 2019-02-10 at 8.40.30 AM.png

You can use the general slack channel, or if you prefer you can create a separate slack channel.

In my case I used #robot-claire-control

You must invite your robot into the channel, or it won't see the messages that are sent.

Download SlackPiBot Source Code & Configure

Download the slackPiBot sourcecode from git:

<p>git clone https://github.com/mhajda/slackPiBot.git</p>

Update line 29 with your API Key:

<p>slack_client = SlackClient("xoxb-YOUR-API-KEY-HERE")</p>

Update line 34 with your robot name:

<p>if user.get('name') == "robot-claire":</p>

Configure Crontabs to Start Automatically on Boot:

Setting up crontabs to start automatically on boot:

<p>crontab -e</p>

Add the following to the bottom of your crontab:

<p>@reboot python /home/pi/Pimoroni/scrollphathd/examples/web-api.py<br>@reboot python /home/pi/slackPiBot/check_button.py
@reboot python /home/pi/slackPiBot/forever.py /home/pi/slackPiBot/slackPiBot.py >> /home/pi/slackPiBot/outputLog.txt 2>&1</p>

Optional: Add a USB Speaker Output

For this project, I am using a USB speakerphone from US Robotics - available on amazon or ebay.

If using something similar, you will need to change the default system sound device by editing the alsa config (/usr/share/alsa/alsa.conf). Change the following lines:

<p>defaults.ctl.card 1<br>defaults.pcm.card 1</p>

1 being the index of your device. To find the device ID of your USB device, run aplay -l and look for the card ID.

Optional: Add Wired Buttons to Robot to Clear Messages

IMG_7062.jpg
IMG_5666.jpg

This step is optional but highly recommended to clear messages on the screen.

I have added two push buttons to my robot, but in this project I'm only using GPIO17.

The script check_button.py that runs on boot polls the GPIO17 every few milliseconds and if depressed sends an HTTP POST to the sample screen script to clear the screen.

Pulling It All Together and Sending Output to the Pi

There are 4 scripts that work together for this project:

<p>/home/pi/Pimoroni/scrollphathd/examples/web-api.py<br>/home/pi/slackPiBot/check_button.py<br>/home/pi/slackPiBot/forever.py /home/pi/slackPiBot/slackPiBot.py</p>

The web-api script is provided by Pimoroni and is a simple web application to control the screen with POST commands.

The check_button python script polls the GPIO pins and when the button is depressed sends an HTTP POST to the web-api.py script.

The forever.py script kicks off the slackPiBot.py script to ensure that if there are any uncaught errors or disconnects from slack, the script is restarted to avoid missing any messages.

The slackPiBot.py script connects to slack and monitors the channel for messages starting with "bot" or posts from IFTT. If there's a match, it will send an HTTP POST to the web-api.py script and display on the screen.

Optional: IFTT Integration

Screen Shot 2019-02-10 at 11.03.17 AM.png
Screen Shot 2019-02-10 at 11.03.28 AM.png
Screen Shot 2019-02-10 at 11.05.28 AM.png

This project was designed to alert my kids of videos posted by people they follow on youtube, since they are too young to have their own iPhone or iPads. I accomplished this by creating IFTT recipes that send a notification to the slack control channel once a video has been posted.

The instructables wiki makes this complicated to see in one step, but the screenshots above show the end result.