Skip to content
This repository has been archived by the owner on Jun 19, 2024. It is now read-only.

Latest commit

 

History

History
30 lines (20 loc) · 2.45 KB

README.md

File metadata and controls

30 lines (20 loc) · 2.45 KB

HN Notifications Build Status

This project is temporarily discontinued. I need to find a suitable transactional email provider to substitute Mandrill (they decided to stub developers in the back) and possibly port the app to Google Cloud infraestructure

Get an email as soon as a Hacker News story matches your custom criteria.

HN Notifications is a simple web service to fetch Hacker News items, and deliver email notification to its subscribers. This small project has mainly been used to play around with Go and MongoDB, and although the current status is fully functional, there are a few things to polish up. So please, feel free to contribute!

How it works

In a nutshell, the notification process runs every 15 minutes, getting the top 100 HN items (via the official Firebase API), and delivers an email to the corresponding users subscribed to the service. This implementation does not make use of the Live Data feature of Firebase, which would in turn be more efficient.

Authentication mechanism is currently minimalist: any configuration in the subscription settings is confirmed through a verification email. Therefore no username or password is required.

Getting started

You'll need Go (1.3+) and MongoDB:

  • Install Go and MongoDB.
  • Some packages are managed with Mercurial or Bazaar. Ensure you have both bzr and hg installed in your path: http://mercurial.selenic.com/, http://wiki.bazaar.canonical.com/Download.
  • Install dependencies, and build the app: go get & go build.
  • Start MongoDB: mongod [options].
  • Copy the sample config file config.json.sample into a new file config.json, under the same directory, and edit this file according to your system configuration (mongodb address and credentials, SMTP setup, etc).
  • Run the app: ./hnnotifications.

The server will now be listening on the port specified in the config file (3000 by default): http://localhost:3000/.

License

This software is distributed under the BSD-style license found in the LICENSE file.