Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/philippks/kms

Web application for time tracking and invoicing.
https://github.com/philippks/kms

invoicing time-tracking working-time

Last synced: 3 months ago
JSON representation

Web application for time tracking and invoicing.

Awesome Lists containing this project

README

        

![KMS logo](app/assets/images/logo-blue.png)

![GitHub release](https://img.shields.io/github/release/philippks/kms.svg) [![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
[![Build Status](https://travis-ci.org/philippks/kms.svg?branch=master)](https://travis-ci.org/philippks/kms)

A web application for time tracking and invoicing.

Initially created for the [Koster Consulting AG](http://kosterconsulting.ch/) and in productive use since multiple years.

## Features

- Time & absences tracking
- Time & invoice reports
- Generate invoices based on tracked time
- Send invoice by e-mail
- Manage invoice payments
- and many more...

## Getting Started

Use docker for development, testing and production.

### Start Locally

Install dependencies with mise:

```
mise install
```

Start postgres database:

```
docker compose -f docker-compose.dev.yml up postgres
```

Edit configuration file `.env.development` if necessary.

Start rails server:

```
bundle exec rails s
```

Access web application: http://localhost:3000

### Run Tests Locally

To run the tests locally, ensure that postgres is running.

```
docker compose -f docker-compose.dev.yml up postgres
bundle exec rspec
```

### Run Tests in CI

Run tests inside docker container with:

```
docker compose -f docker-compose.test.yml run --rm tests
```

### Run Production

Change values in `.env.production` accordingly.

Start server with:

```
docker compose -f docker-compose.prod.yml up kms
```

Access web application: http://localhost:3000

### Configuration

See `.env.example` for example configuration.

## Hints

### Invoice Configuration

The invoice parameters are configured with env variables:

- INVOICE_IBAN
- INVOICE_VAT_NUMBER
- INVOICE_SWIFT
- INVOICE_MAIL_FOOTER (use \n for newlines)

To use a company template for the invoices, set the path to the corresponding PDF as `INVOICE_COMPANY_TEMPLATE_PATH`, e.g.

```yml
INVOICE_COMPANY_TEMPLATE_PATH='/home/kms/invoice_template.pdf'
```

### Mails in development

In development no emails will be sent. One can access all emails here: http://localhost:3000/letter_opener
For more details, see https://github.com/fgrehm/letter_opener_web

## Questions?

For any questions drop me a mail:

## License

[GPL-3.0](https://github.com/philippks/kms/blob/master/LICENSE)