Spousteni Dispatch
-----------------------------

- instaluje se do C:/atx300
- spousti se pomoci dispatch.exe --db ./data.db
- neni-li pri startu nalezen databazovy soubor:
    - dispatch jej automaticky vytvori a nainicializuje prazdnymi tabulkami.
    - je-li nalezen adresar se starymi daty ("/atx300/minidisp/data/cs/"), pak jsou tato data
      automaticky naimportovana a adresar je prejmenovan na prefix "_imported"
- dalsi parametry lze ziskat spusenim dispatch.exe -h

Import starych dat
-----------------------------

- neni-li pri startu nalezen databazovy soubor a je li zaroven nalezen adresar se starymi daty
  ("/atx300/minidisp/data/cs/"), pak jsou tato data automaticky naimportovana a adresar je prejmenovan na prefix "_imported"
- data z DBF souboru (atxd300] jsou importovana pomoci parametru --import-dbf
  Kazdy z DBF souboru je importovan pouze jednou, pote je prejmenovan na <jmeno>_imported.pripona
  Importuji se pouze Vozidla, Stavby a Odberatele
  Poznamka: Obvykly DBF adresar je /asterix/atxd300/data

Bridge provoz
-----------------------------

Pri bridge provozu jsou z ORD souboru  extrahovany informace, zakladany zaznamy v DB a
soubory jsou pote kopirovany do vystupniho adresare

Parametry pro KDX:
  --from-kdx <path>              Path to where KDX writes files to
  --to-kdx <path>                Path to where KDX reads files from
  --kdx-material-ini <path>      Path to material.ini file being generated by KDX


Databáze
-----------------------------
Databaze je pri ukonceni zalohovana do souboru history/dispatch/<timstamp>.sqlite3
(pokud podadresare neexistuji, jsou automaticky vytvoreny)

Integritu dat lze ověřit spuštěním dispatch.py --integrity-check : vypíše do logu všechny logické problémy s existujícími daty.
Může změnit data v databázi.

Ostatni
-----------------------------

Pro zjistovani teploty se pouziva Asterix aplikace Thermometer. Ta musi byt spustena (dispatch toto nezajistuje)
a jeji vystupni soubor byt nakonfigurovan v souboru /atx300/conf/thermometer.ini
Debug tip: pri kazde objednavce Dispatch zapisuje do logu stav cteni teploty vcetne zjistenych chyb

Konfigurace featur vetsiho dispecinku
---------------------------------------

Dispatch pouziva konfiguracni soubor /atx300/conf/dispatch.hjson
Je urcen k zapinani rozsirujicich modulu v zavislosti na konkretni instalaci.
Neni-li nalezen, Dispatch se chova, jako by vsechny rozsirujici moduly byly vypnuty.

Obsahuje hodnoty typu module_<modulename>: true|false , zapinajici jednotlive moduly, a dalsi nastaveni
Default je vzdy false
    module_cars                     databaze aut
    module_contracts                databaze zakazek. Je-li zadano, je pristupna rovnez databaze staveb a odberatelu.
    module_login                    prihlasovani pomoci databaze uzivatelu. Viz Management uzivatelu nize.
    module_delivery_sheets          Tiskove sestavy dodaciho a zamesoveho listu
    module_statistics               Vsemozne statistiky
    module_stock                    Naskladnovani materialu
    module_pumps                    Cerpadla
    module_prices                   Veci tykajici se cen:
                                        - zobrazeni a uprava cen v expedicnim dialogu
                                        - editace specialnich cen pro jednotlive zakazniky
    module_samples                  featura automaticke hlaseni / odber vzorku.
                                    Frekvenci vzorku (v receptech) lze zadavat, i kdyz je featura vypnuta
    ares_disabled                   Je-li nastaveno, nezobrazuje UI tlacitko "ARES"
    rpo_disabled                    Je-li nastaveno, nezobrazuje UI tlacitko "RPO" (Register právnických osôb)
    continuous_mode_enabled         Je-li nastaveno, umožnuje expedovat v kontinuálním režimu
    transport_zones                 Je-li nastaveno, betonarka pouziva cenik dopravy definovany zonove.
                                    V takovem pripade nelze zadat u vozidel cenu za kilometr.
                                    (plati jen pro prepravu betonu, cerpadla toto nastaveni neovlivni)
    rounding_precision              Pocet desetinnych mist, na nez se zaokrouhluji ceny (v tiskovych sestavach i vypisech). Default 2


Tiskove sestavy
------------------

Automaticky tisk dodacich listu se zapina/vypina v dialogu nastaveni.

Logo do dodacího listu:

Program automaticky doplní do hlavičky dodacího listu logo, které se pokusí najít pod jménem "static/delivery_sheet/logo/<logo_fn>", kde <logo_fn> je specifikovano v konfiguracnim souboru.

Management uzivatelu
------------------------------------
Spust program s parametrem --users.
Master heslo je "PeroxidBetonu"

Uživatele poté může ve standardním UI editovat kdokoliv s příslušnými právy.
Zamykání tabulek: uživateli lze zamknout pro zápis některé tabulky (číselníky); změna se na úrovni databáze
projeví okamžitě, nicméně pokud je uživatel přihlášen, musí udělat refresh (F5), aby §viděl§ zamčené tabulky
ve svém UI (tzn. zobrazení ikonek zámečku v menu, skrytí tlačitek na editaci a podobně)

Externi url (pro nastaveni vyjimek ve firewallu)
------------------------------------

Minidisp se pripojuje na:

https://ares.gov.cz/ekonomicke-subjekty-v-be/rest/ekonomicke-subjekty/<XXXXXXX>

Aplikace thermometer se pripojuje na:

http://wttr.in/<XXXXXXX>?format=j1
A nějakou adresu zadánu v congigu thermometru, via funkci read_temperature_from_thermometer_protocol_1
(informace ohledne thermometer nejsou zaruceny, doporuceno prekontrolovat v jejim manualu)

Testování produkce pomocí curl příkazu
----------------------------------------

Produkce je vázána na autentizaci. Pokud dispečink běží v "mini" režimu, tj. bez zapnutého
modulu module_login, lze produkovat i bez přihlášení (bezpečnostní díra by design, btw).

Se zapnutým module_login je třeba nejprve se přihlásit, to je ovšem vnitřně manageováno přes session
(dispečing nepodporuje HTTP SIMPLE AUTH), a správu session curl (afaik) neumí.

TLDR: curlem lze posílat objednávky pouze je-li vypnut module_login, vše další vyžaduje přestavbu (po konzultaci, neboť bezpečnost).

Recept je identifikován pomocí recipe_id, které odpovídá našemu vnitřnímu ID v databázi.
Nejde tedy o "number" zobrazené v uživatelském rozhraní.
Pro jednoduché testy lze používat nízká ID receptů, která pravděpodobně existují,
při neexistujícím ID dispečink zahlásí srozumitelnou chybu.

Dispečink samozřejmě musí běžet, buď v zkompilované verzi, nebo jej spustit spustit v jednom okně termínálu
a z druhého posílat curl příkazy.

Jednoduchá produkce:

curl http://localhost:7781/produce --request POST --header "Content-Type: application/json" --data '{"recipe_id": 1, "volume": 1, "vehicle_id": "AAB 1111"}'

Složitější produkce:

curl http://localhost:7781/produce --request POST --header "Content-Type: application/json" --data '{"recipe_id": 1, "volume": 10, "vehicle_id": "AAB 1111", "without_water": true, "comment": "Přidáno pomocí curl", "temperature_air": 22.1, "customer": "Bořek stavitel", "construction_site": "Opera v Sydney"}'
