James Mead by James Mead

Show and Tell 48

One night in September, an intrepid group (Ben G, James A, Tom S and me) gathered in our office in deepest darkest Whitechapel.

Twilio - James M

Company voicemail

We managed to do without a company phone number for many years, mainly by using email, Skype, and occasionally giving out individual personal mobile phone numbers. However, the latter was definitely far from ideal and I decided to see whether we could use Twilio to set up a company phone number.

Obtaining a phone number from Twilio is very straightforward and it costs just $1 per month, excluding the cost of making or receiving calls. Having obtained a number, we had to decide how to handle incoming calls. Initially we contemplated putting the call through to one of our mobiles at random à la Harmonia, but in the end we decided to handle calls with a simple voicemail service.

To achieve this I constructed a voicemail Twimlet URL and added a web hook handler to our phone number to point at the URL. This way incoming calls are sent straight to voicemail and any messages recorded are emailed to us as an MP3 attachment. The email address we use is one that we all monitor and so if an urgent message is received, there’s a good chance that one of us will respond.

Company conference call

This was a bit more of an experiment. Over the years we’ve tried quite a few ways to have mulit-way audio/video conferences when some of us were working remotely, but they’ve never worked very well. So I thought I’d have a go at setting up an audio conference call number using Twilio to see whether that worked any better.

I obtained a second phone number from Twilio and initially I hosted the necessary TwiML handler in a Twilio “bin”, but as I added functionality I ended up moving the code over to our company website, which is currently a Rails app.

Most of the relevant code is in the ConferencesController and its associated view templates. Any incoming call to the conference call line is routed via a web hook and POSTs to the ConferencesController#create action. Since the initial request does not have the Digits parameter set, the request is redirected to the #auth action and its associated TwiML template which when rendered prompts the caller to enter a PIN.

Once the caller has entered a PIN, the request is redirected back to the #create action with the PIN stored in the Digits parameter. The PIN is checked against a value stored in an environment variable and if it’s not correct the request is redirected to the #auth_fail action and its associated TwiML template which when rendered informs the caller that the PIN was incorrect and allows them to try again.

If the PIN was correct, then the TwiML template for the #create action is rendered which sets up a conference call with some appropriate hold music.

Sailing boat catalogue - James M

I was recently looking for a comprehensive list of sailing boat specifications so I could find all the designs with certain characteristics. The most comprehensive dataset I found was on SailboatData.com, but the website is pretty clunky and doesn’t provide a very sophisticated searching capability.

So I set about scraping the pages, parsing them from the crazily nested HTML tables, and finally inserting them into a SQLite database. I then used Simon Willinson’s excellent datasette to expose the data as a local website with a powerful search capability.

This gave me exactly what I needed, so I’ve stopped at that point. However, it is tempting to publish the datasette website so other people can use it. But I’m not sure about the legalities of that nor whether I want to take on the responsibility of keeping the data up-to-date.

Patchbay - James A

James showed us Patchbay which is one of a number of clients for Secure Scuttlebutt, which in turn is a “database protocol for unforgeable append-only message feeds”. I first came across Scuttlebut over a year ago when I read about how its creator, Dominic Tarr, lives on a yacht in New Zealand and uses it to communicate with friends even though he’s only sporadically online. I’m afraid I can’t remember very much about the things James showed us and I didn’t take very good notes (sorry!), but if you’re interested in learning more, the Scuttlebut website seems like a good place to start.

Negative numbers - Tom S

Tom took us through an idea he’s had for demonstrating how picking the right representation can make solving a problem much easier. In many ways it reminded me of the LRUG talk he did on automatic differentiation. This time, however, the problem was how to do arithmetic with negative numbers when you have no native way to represent negative numbers.

I won’t say any more, because Tom’s thinking about turning this work into a conference talk or workshop and I don’t want to spoil it for people. Suffice it to say the exercise was thoroughly worthwhile and enjoyable - Tom is really good at explaining things!

Show & Tell 49

We’ll be hosting our 49th Show & Tell on Wednesday, 17th October. Please get in touch if you’d like to join us.

– James

If you have any feedback on this article, please get in touch!

Historical comments can be found here.