Skip to content

Automated email alerts using text files in Dropbox as a datastore and the Gmail API, (currently) built in Node.js.

Notifications You must be signed in to change notification settings

bridge-club/bridge-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

 ______     ______     __     _____     ______     ______        ______     ______     ______ 
/\  == \   /\  == \   /\ \   /\  __-.  /\  ___\   /\  ___\      /\  == \   /\  __ \   /\__  _\
\ \  __<   \ \  __<   \ \ \  \ \ \/\ \ \ \ \__ \  \ \  __\      \ \  __<   \ \ \/\ \  \/_/\ \/
 \ \_____\  \ \_\ \_\  \ \_\  \ \____-  \ \_____\  \ \_____\     \ \_____\  \ \_____\    \ \_\
  \/_____/   \/_/ /_/   \/_/   \/____/   \/_____/   \/_____/      \/_____/   \/_____/     \/_/

Abandoned

This project has been abandoned. Firstly, I rewrote it in Kotlin (with tests) as a job for Shiny shiny, shiny boots of leather. Secondly, I left the club and apparently nobody had an interest in working on it.

About

Automated email alerts using text files in Dropbox as a datastore and the Gmail API, (currently) built in Node.js.

BRIDGE-BOT is an automated messaging system. It consumes a list of club members' names and email addresses (in JSON format) from a file in Dropbox. Every week it prepares an email - either to one member or all members - and then emails it using its own Gmail account and the Gmail API (Google auth secrets are also read from JSON files in Dropbox). Hosted in Heroku, it uses a 'custom' Node buildpack (no web process) and the Heroku scheduler set to run a single process every hour. It then checks whether it needs to do anything, depending on the time of day and whether it has done anything that day, then either writes and sends a message, or shuts down. The bot is built and destroyed once every hour, so it reads and writes to another file in Dropbox to store the state of the application.

Current version is little more than a spike, but it works and is plenty good enough for our purposes.

Get involved

If you can write code, feel free to contribute some. If you want to make suggestions about functionality, those are also very welcome.

TODO:

  • Better testing.
  • Design improvements / refactoring.
  • More modularity - less hardcoded stuff and more config.
  • Java (?) version. Just cuz I wanna.
  • Twilio integration - members can report jobs that need doing via SMS and those on shift are notified.

Prerequisites

Installation

git clone this repo.

npm install

create a Heroku app:

heroku create <your-app-name> --buildpack https://github.com/endofhome/heroku-buildpack-nodejs

git push heroku master

set the BRIDGE_BOT_DROPBOX_ACCESS_TOKEN environment variable in your Heroku app.

an EMAIL environment variable is used to add some hard-coded email addresses to the BCC field in the Gmailer buildMessage() function.

set the Heroku scheduler to run npm start every hour - or as often as suits you.

optionally: set the timezone of your app in the CLI using the TZ format (ie. heroku config:add TZ="Europe/London")

File formats:

members.json:

{
  "members": [{
    "id": 1,
    "name": "Carla",
    "surname": "Azar",
    "email": "carla@azar.com"
  }, {
    "id": 2,
    "name": "Drumbo",
    "surname": "",
    "email": "drumbo@drums.com"
  }, {
    "id": 3,
    "name": "Chris",
    "surname": "Corsano",
    "email": "chris@cor.sano.com"
  }]
}

bridge-bot.txt (the "memory"):

{
    "currentMember": {
        "id": 2,
        "name": "Drumbo",
        "surname": "",
        "email": "drumbo@drums.com"
    },
    "cleaningScheduled": true,
    "dayTracker": 5
}
*****************
*  E N J O Y !  *
*****************

About

Automated email alerts using text files in Dropbox as a datastore and the Gmail API, (currently) built in Node.js.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published