Under Construction

Click here to view anyways
  • Previous Page

  • Next Page

  • Table of Contents [Show]


    SMS

    So. That's talking, which is the simple part. The nerdy bit comes with SMS. The number of ways that I could send or receive a text message is verging on silly. The obvious place to start is still the text messaging app on my phone. I went with a VoIP provider that already had one in the Play Store. The voice recognition for Android would be a cool way to interact with that, but it is provided by the Google Keyboard which I no longer use because Google creeps me out. So the app is probably my least favourite way to send text messages since the keyboard is small and is always trying to correct my spelling.

    SMS-to-Email

    This section is now actually sort of dated. As described below, my VoIP service provides an easy SMS to Email tool which I had hacked to allow a variety of ways to interact inbound and outbound. All of them are still possible and I actually do still have the emails coming in to be archived, but I have improved the other methods of interaction. But here is the old techniques if you are curious.

    Inbox

    This functionality is exactly what it sounds like. When I receive a message, a copy is sent to me as an email. It, of course, uses a special mailbox but I run my own mail server, so I have the VoIP service whitelisted to guarantee delivery and reroute the mail wherever I like. Of course, if reply from any of my email client, that reply will be sent out as an SMS.

    Online Archive

    I also have my emails archived using my spam filter, so if my mail server is down I can still reply from there and I can even enforce filtering rules if I feel like it. If I don't want texts from area codes other than my own I can just block them, for example. Of course, that doesn't stop them from making it to my phone, but I don't actually look for messages on my phone very often.

    IRC

    The great thing about email is that it just lands as raw text on the mail server. You can do absolutely anything you want with raw text, so this is where it gets nerdy. My favourite way to answer text messages is IRC. I got addicted to IRC at the office where we use it for everything: generating support tickets based off of caller display, alerts for new email tickets, vacation schedules, meeting and call reminders, and just to chat and ask questions. As a result, I always have an irssi window open and have alerts set up whenever my nick is mentioned.

    This allowed me to simply set up procmail to send messages to a special IRC channel mentioning my nick so that I get a notification in the corner of my screen when messages come in. Procmail actually runs a script that creates, or retrieves a nick for each phone number before sending the message to IRC. The nick is made up of a 3 character shortcut plus the actual phone number. That way I can tell who it was from and reply by referencing the shortcut as shown in the image. I have an IRC bot that then parses for the shortcut, finds the associated phone number and sends the message back to it as a reply via email. This way I can have multiple conversations going in the same window, only visible to me, and can reply to each seperately.

    My IRC channel is open from anywhere, but password protected outside of my LAN, so as long as my firewall is open and I have an IRC client, this is usually how I 'text'. The fallback is then my desktop email client. If that fails there is always webmail. If my mail server is down I can use my Archiver. Finally, if I don't have access to a keyboard, I can be an animal and answer with my cell phone, but what am I, some sort of Millenial.

    API

    As I mentioned, the SMS to Email interface is largely old news. It is an inelegant way of interacting with the service. There are a lot of steps, but I'm work with email so it was a very easy way to hack together a solution. I have since taken the time to do this better by interacting directly with the services API. For those who aren't aware, this is a Application Programmer's Interface. Basically it means that I can send requests directly to the service provider and handle the responses however I like.

    This largely just simplified how I get the data. Most of the user interaction is the same. While the emails still come in, it no longer relies on hitting Procmail. Instead, I can have my API program running anywhere I like, not just on my mail server. This is then able to submit new messages directly and poll for any new inbound messages to alert me to. When new messages still come in, the code that sends that message to IRC behaves basically as it did above and IRC replies are forwarded back through the API as well.

    The main advantage to the API data is that it is all standard JSON which is extremely easy to work with. As email I needed to parse the headers. If messages came in quicker than the program could run I would sometimes get alerted to the first second message twice, and all of this made it slightly slow. The messages in JSON cannot be confused with one another, there is no extra junk to slow it down and the data is guaranteed to be exactly what I was looking for.

  • Previous Page

  • Next Page