Running Google Coder on BeagleBone (Black)

http://www.adafruit.com/blog/2013/09/17/run-google-coder-on-your-beaglebone-black/

Google Coder is a new Node.JS-based application to help kids create web pages that include HTML, JavaScript and CSS. With a bit of Googling, I was able to run it on a BeagleBone Black over the USB cable in no time.

You’ll need your BeagleBone Black to have Internet access for these initial configuration steps to work. For me, I configured some hacks to get my board access to the Internet to follow some of these steps, but I suggest you do the initial installation via an Ethernet connection that has access to the Internet, then go back to using the USB connection or whatever other network connection you had going for development after that. Perhaps in a later post I’ll share all my tricks for getting a BeagleBone Black out to the web even when only plugged in over USB.

First, we need to update some of the included Python modules and other odds and ends on the default Angstrom Distribution image:

opkg update
opkg install python-compiler python-distutils python-multiprocessing python-misc openssl-misc sudo

There’s also a need to install ‘redis’, which I didn’t find in the Angstorm package repository:

cd
wget http://download.redis.io/releases/redis-2.6.16.tar.gz
tar xzf redis-2.6.16.tar.gz
cd redis-2.6.16
make
make install
cp redis.conf /etc/redis.conf
cat >/lib/systemd/system/redis.service <

Next, we need to work-around a bug in the installed node-gyp’s semver:

perl -i -pe “s/(&& semver.lt(version, ‘3.0.0’)) {)/) {/” /usr/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js

Now, we can get down to installing Google Coder:

useradd -m pi
cd
git clone git://github.com/googlecreativelab/coder
cd coder/coder-base
npm install

Before I ran it, I modified coder/coder-base/config.js to avoid trying to use the same port name as the default BoneScript server:

.
.
.
exports.httpVisiblePort = ‘9000’; //forwarded http port the user sees
exports.httpsVisiblePort = ‘9001’; //forwarded https port the user sees
.
.
.

Alternatively, you could have simply disabled the BoneScript server, but I didn’t do this because I like to keep it running:

systemctl stop bonescript
systemctl disable bonescript.service bonescript.socket

You can now start it instantly:

cd ~/coder/coder-base
npm start

Or, you can create a service to start it up at every reboot:

cat >/lib/systemd/system/coder.service <<EOF
[Unit]
Description=Google Coder
After=network.target

[Service]
Type=simple
WorkingDirectory=/home/root/coder/coder-base
ExecStart=/usr/bin/npm start
Restart=always

[Install]
WantedBy=multi-user.target
EOF
systemctl enable coder
systemctl start coder

After that, you are in Google Coder land. Open your browser to your BeagleBone Black port 8081 using https, assuming you made the recommended change to the config.js file mentioned above. If you are using the default config connected up over USB, browse to https://192.168.7.2:8081.

One really cool aspect of running Google Coder on BeagleBone Black is that it can be ultimately cheaper because you don’t need to buy an SD card or power supply if you are running your BeagleBone Black off of another computer’s USB port. Of course, the coolest aspect is all of the hardware I/O capability on the BeagleBone Black and the extra processing power to do things like computer vision.

Because this is using an HTTPS connection, the BoneScript library doesn’t work out-of-the-box. However, the ability to edit the node.js of the application should make it trivial for me to add BoneScript as a service, so stay tuned for that post.

Thanks Jason, this looks very useful. Will give it a thorough looksee when time permits.