Time registration that doesn't suck
Clone or download
jurre Merge pull request #462 from herminiotorres/ht/application-javascript…

add application javascript improvements
Latest commit 0762ad5 Jan 14, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
app Add improvements in javascript application Jan 14, 2019
bin Add documentation for getting set up to use Docker Oct 18, 2016
config Fix TypeError no implicit conversion of Integer into String Jan 14, 2019
db assortment of fixes and refactors Mar 24, 2015
lib Use task of brakeman gem instead of custom task Feb 4, 2016
public initial commit Feb 24, 2014
spec Use create_list Oct 17, 2017
vendor/assets clean up entry select styling, remove unused selectize dependencies Feb 26, 2015
.gitignore initial commit Feb 24, 2014
.hound.yml split entries to represent either hours or mileage Mar 23, 2015
.rspec Use `--require spec_helper` option on rspec Sep 13, 2015
.ruby-gemset Add ability to switch to single tenant mode Jan 9, 2015
.ruby-version update ruby and rails Dec 12, 2017
.sample.env add the TLD_LENGTH env var Jan 4, 2019
.travis.yml update ruby and rails Dec 12, 2017
Dockerfile update ruby and rails Dec 12, 2017
Gemfile [Security] Bump rails from 4.2.10 to 4.2.11 Nov 27, 2018
Gemfile.lock [Security] Bump rails from 4.2.10 to 4.2.11 Nov 27, 2018
LICENSE add MIT license Aug 8, 2014
Procfile initial commit Feb 24, 2014
README.md Merge pull request #460 from herminiotorres/ht/feature/add_prax_as_an… Jan 7, 2019
Rakefile Use task of brakeman gem instead of custom task Feb 4, 2016
app.json Remove pgbackups as it's depricated Oct 7, 2015
config.ru initial commit Feb 24, 2014
docker-compose.yml Add documentation for getting set up to use Docker Oct 18, 2016



Build Status Code Climate Reviewed by Hound


Hours is a dead simple project based time tracking application that we use for internal time-tracking. It allows users to register how many hours they've worked on a project with a certain category (think design, software development, testing for software teams) and add any tag they like to it. This gives us a lot of insight on how we spend our time on different projects.

It looks like this:

Projects overview

Single project


Audit Log



As we're using Hours we're constantly thinking of ways to improve it and we'd love to hear your thoughts!

System Dependencies

  • Ruby 2.4.2 (install with rbenv)
  • Rubygems
  • Bundler (gem install bundler)
  • PostgreSQL
  • qmake (brew install qt) or read extensive instructions here
  • memcached (brew install memcached, an older version ships with OSX)(optional)

Getting Started

This repository comes equipped with a self-setup script:

% ./bin/setup

After setting up, you can run the application using foreman:

% foreman start

Since we're using subdomains to point to accounts, you can't run the app on localhost. If you have pow set up or if you use linux an alternative is prax, it will be automatically configured by the setup script, otherwise you need to point apache/nginx to the port foreman is running the app on (7000 by default). With pow/prax the app will run on http://hours.dev

In order to activate caching in development you can add CACHE_DEVELOPMENT="anything" to your .env. Make sure to run $ memcached when you do need this.

Getting Started with Docker

This repository comes equipped to be run within Docker, but this requires a few more local dependencies. For instructions on installing and getting started with Docker go here. You'll also need docker-compose, but it will be installed for you through Docker for Mac or Windows.

This repository comes equipped with a self-setup script for using Docker:

% ./bin/docker_setup

On first boot you'll also need to create your database, for that use:

% docker-compose run --rm app rake db:create db:migrate

After setting up, you can run the application and dependencies using [docker-compose]:

% docker-compose up -d

If your Docker host is running on localhost then you should be able to use pow/prax, otherwise you'll need to connect to it via:


Feature Flags


Single Tenant Mode: Initialize application in single tenant mode. Disabled by default.


To use the single tenant mode, you can add SINGLE_TENANT_MODE to your enviroment variables with the value true. On development you can set this in your .env with SINGLE_TENANT_MODE=true and restart foreman. On heroku it's under the Config Variables. The first user in single tenant mode can be created by a rake task rake create_user. We'll ask you for your credentials.


  • Pull requests are welcome! If you aren't able to contribute code please open an issue on Github.
  • Write specs!
  • Develop features on dedicated feature branches, feel free to open a PR while it's still WIP
  • Please adhere to the Thoughtbot ruby styleguide
  • All code and commit messages should be in English
  • Commit messages are written in the imperative with a short, descriptive title. Good => Return a 204 when updating a question, bad => Changed http response or I updated the http response on the update action in the QuestionController because we're not showing any data there. The first line should always be 50 characters or less and that it should be followed by a blank line.
  • Please localize all strings and add i18n keys to the locale files sorted by key in ascending order


Hours is distributed under the MIT license.