Dochazka is a long-term project to replace the obsolete Attendance & Time Tracking system used by the Prague office since 2007. Dochazka is a complex system consisting of three major components:

In addition to the modules listed above, the Dochazka project also spawned the App::CELL and Dateadd-emojiCZ CPAN modules.

The Dochazka REST server is implemented as a state machine powered by Web::Machine. The front-end is implemented using jQuery and RequireJS.

Hackweek 15 developments:

  • implement "Look up a schedule by code or ID" front-end feature
  • implement "Browse all schedules" front-end feature
  • implement "Create a new schedule" front-end feature (WIP)

Hackweek 13 developments:

  • implement, document, and test a Dockerized testing environment for App:add-emoji:REST
  • fix several bugs found by running the test suite in the Docker environment
  • divide tests into "regression tests" and "unit tests"
  • reduce regression test initialization boilerplate down to one line

Hackweek 12 developments:

App:add-emoji:CLI

  • come up with a (hopefully) intuitive syntax for specifying attendance intervals and tsranges in general
  • implement normalize_date routine that can handle special keywords TODAY, TOMORROW, YESTERDAY, as well as offsets (e.g., +10, -3) relative to the prompt date
  • implement normalize_time routine
  • add commands for entering new attendance intervals
  • add commands for viewing attendance intervals
  • expand testing infrastructure by adding a new "parse_test" routine that, given a raw command string, returns full name of handler routine
  • improve password change workflow
  • add lots more commands for fetching/displaying attendance intervals

App:add-emoji:REST

  • fix a bug
  • fix another bug
  • implement SQL functions, associated employee model methods and unit tests:
    • privhistory_at_timestamp
    • schedhistory_at_timestamp
    • priv_change_during_tsrange
    • schedule_change_during_tsrange
  • enforce policy on interval/eid/:eid/:tsrange, interval/nick/:nick/:tsrange, and interval/self/:tsrange resources: they only work if the tsrange specified contains no history records (i.e. the employee's privilege level and schedule must be constant over the tsrange, where "constant" is defined as "no history records during the range")
  • impose a limit on number of attendance intervals returned by SELECT; the limit is configurable and can be set to "no limit"

Hackweek 11 developments:

App:add-emoji:REST

  • refactor employee PUT and POST targets
  • add support for DELETE requests
  • write employee CRUD tests and missing top-level tests
  • codify test-driven workflow for implementing resources
  • make resources "self-documenting" by implementing new 'docu' top-level resource
  • make sure all existing resources are documented
  • use new workflow to document, test, and implement 'privhistory' resources

App:add-emoji:CLI

  • lots of bugfixes
  • support PUT, POST, and DELETE as well as GET
  • implement several new commands

Looking for mad skills in:

javascript perl

This project is part of:

Hack Week 11 Hack Week 12 Hack Week 13 Hack Week 15 Hack Week 16

Activity

  • about 1 year ago: TBro liked Dochazka
  • about 1 year ago: bruclik liked Dochazka
  • almost 2 years ago: jfajerski joined Dochazka
  • almost 3 years ago: mkubecek liked Dochazka
  • almost 3 years ago: oholecek liked Dochazka
  • Show History

    Comments

    Be the first to comment!

    Similar Projects

    Jabber server side history by -miska-

    Finish extension for server side history for ja...


    Admin UI for the Minion job queue by kraih

    Minion, the ...


    Library.suse.de update/replacement by jnweiger

    Scanning books stopped 6 years ago. We need vol...


    Google Hangouts killer: WebRTC-based video conferencing system by ancorgs

    We have some internal systems for videoconferen...


    UI for the Docker registry by flavio_castelli

    One of the winning factors of Docker is the [Do...