Automate monthly reports via tracking service.
 
 
 
Go to file
Lio Novelli df662c3eb9 Short code fixes and Readme update. 2021-10-03 16:45:40 +02:00
app Short code fixes and Readme update. 2021-10-03 16:45:40 +02:00
.gitignore Add code style checks. 2021-04-08 19:23:42 +02:00
README.org Short code fixes and Readme update. 2021-10-03 16:45:40 +02:00

README.org

Report cli

Automate generating invoices from youtrack reports and other time-tracking related functionality.

Usage

./rprt.php rprt -y -p -s

This command would send an invoice for last month created from the template file and last month report from youtrack as an email attachment.

Install/Getting started

Get .phar file, run configuration wizzard (planned for version 1.0).

Before version 1.0 is released you have to navigate into /app directory and call command through .rprt.php file.

Requirements

  1. You have to create a youtrack API token.
  2. You have to configure rprt-cli app.

    • Default folder that app checks for config file is in ~/.config/rprt-cli/.
  3. You have to allow less secure applications in your gmail if you are using that email provider.

Specs

A simple Console Command that prints out monthly report from youtrack.

Simple configuration:

  • authentication token value
  • project categories
  • hourly wage
  • folder for reports

Components

Motivation

  • practice php
  • automatization of repetitive task

    • is it worth it? according to xkcd table - you should spend 1 day for automating a monthly task that takes 30 minutes. That would be if only I'd be using this app. If it get's picked up, by 5 others - it is worth 5 days of development.
  • remove errors from reports

Plan

current

  1. For Version 1.0

    • Track Command (track time from your cli)
    • Report Command (read reports)
    • Improve code and code style
    • .phar file for simple app shipping
  2. Version 2.0

    • Implement templateing service
    • Further code improvements
    • Configuration Wizzard
  3. Version 3.0

    • Emacs package to track directly from orgmode
    • Add tests

old

  1. Basic structure of the cli-app

    1. App preparation

      • nice specifications
      • composer project
      • autoloading & dependency injection
    2. Report service

      • read a local csv file
    3. Parse report

      • read configuration (project categories, hourly wage)
      • simple table output
  2. First round of enhancements

    1. Tests
    2. youtrack request
    3. create composer package, create executable
  3. Second round of enhancements

    1. Invoice output
    2. configuration wizard

Learning

API calls

Get csv file

curl 'https://drunomics.myjetbrains.com/youtrack/api/reports/83-554/export/csv?&$top=-1' -H 'Accept: application/json, text/plain, */*' -H 'Accept-Language: en-US,en;q=0.5' --compressed -H "Authorization: Bearer $TKN" > ~/Documents/Drunomics/workhours/2021/21-09.csv