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:
- RESTful backend App::REST (with lots of help from Web::MREST)
- Command-line client App::CLI
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::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:
- 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
- fix a bug
- fix another bug
- implement SQL functions, associated employee model methods and unit tests:
- enforce policy on
interval/self/:tsrangeresources: 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:
- 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
- lots of bugfixes
- support PUT, POST, and DELETE as well as GET
- implement several new commands
Looking for mad skills in:
This project is part of:
Hack Week 11 Hack Week 12 Hack Week 13 Hack Week 15 Hack Week 16
Finish extension for server side history for ja...
Minion, the ...
Scanning books stopped 6 years ago. We need vol...
We have some internal systems for videoconferen...
One of the winning factors of Docker is the [Do...