(c) Michal Novák, [email protected], see LICENSE file
Implementace "Elektronické evidence tržeb" http://www.etrzby.cz
Implementation of "Registration of sales" see http://www.etrzby.cz
Toto je ukázka implementace "Elektronické evidence tržeb" s použitím XML zpracování v Groovy
a s knihovnou groovy-wslite
. Implementace byla otestována oproti testovacímu prostředí EET.
Díky své jednoduchosti může být použitelná například pro prodej v kanceláři, provozovně a jiný sporadický prodej (např. občasná úhrada přes platební bránu či kartou) za pomocí běžného PC.
S použitím zjednodušeného režimu lze vytvořit účtenku i bez přítomnosti Internetu (např. u zákazníka) a tu pak odeslat dodatečně v ostrém režimu.
Používání může vyžadovat určité znalosti příkazové řádky. Doporučuje se vše nejdříve vyzkoušet oproti testovacímu prostředí EET (výchozí nastavení).
Stránky projektu (popis instalace a použití):
https://sites.google.com/view/eetlite
Zdrojové kódy:
https://github.com/novakmi/eetlite
https://gitlab.com/novakmi/eetlite
Aplikace, její použití i zdrojové kódy jsou k dispozici zdarma pod MIT licencí.
Autor nenese jakoukoliv odpovědnost za funkčnost a chování, ani neposkytuje jakoukoliv záruku! Používání může vyžadovat určité znalosti používání příkazové řádky. Doporučuje se vše nejdříve vyzkoušet oproti testovacímu prostředí EET (výchozí nastavení).
Viz soubor LICENSE
-
2020-03-03 version
0.7.0
- libeetlite ver 0.6.0
- otestovano s Oracle JDK 8, OpenJDK 11, OpenJDK 13, OpenJDK 14
- aktualizace README a LICENSE
-
2020-02-17 version
0.6.0
- libeetlite ver 0.5.1, logback 1.2.3
- aktualizace certifkátů testovacího prostředí
- aktualizace README a LICENSE
-
2017-03-09 version
0.5.0
- libeetlite ver 0.5.0
-
2017-03-09 version
0.4.2
- pokud existuje v akt. adresáři soubor s nastaveným pořadovým číslem, tržba se nezpracuje
-
2017-03-06 version
0.4.1
- libeetlite ver 0.4.1
-
2017-03-06 version
0.4.0
- libeetlite ver 0.4.0
- datum tržby je implicitně roven aktuálnímu času (lze změnit)
- certikát poplatníka je nyní předáván jako stream
(je třeba použít
new FileInputStream(path)
a stream uzavřít po zavoláníEetXml.makeMsg
)
-
2017-02-20 version
0.3.0
- ve zjednodušeném režimu se tiskne PKP
-
2017-01-22 version
0.2.0
- tisk účtenky do souboru
- aktualizace dokumentace
- aktualizace verzí závislých knihoven (dependence)
-
2016-11-21 version
0.1.0
- použití knihovny
libeetlite
- použití knihovny
-
2016-10-13 version
0.0.3
- upraveno pro testovací prostředí v3 (URL, namespace)
-
2016-08-31 version
0.0.2
- přidána podpora volitelných parametrů
- přidán popis parametrů pro editaci v souboru
./eetlite_run.groovy
-
2016-08-16 version
0.0.1
- první verze
- vytvoření a podepsání EET zprávy
- odeslání EET zprávy na testovací prostředí
- zpracování odpovědi
- vytisknutí hodnoty 'FIK' z odpovědi
- kontrola správnosti parametrů 'tržby' a konfigurace (částečně implementováno)
- validace XML zprávy oproti XML schématu
- podpora pro hash (zakódování) hesla v konfiguračním souboru
- zpracování chybové odpovědi
- kontrola podpisu odpovědi
- jednoduchá okenní nástavba
- jednoduchá aplikace pokladna pro PC s možností PDF účtenky
K provozu je nutná Java (Java SE JDK http://www.oracle.com/technetwork/java/javase/downloads/index.html)
a instalace jazyka/prostředí Groovy - http://groovy-lang.org/download.html.
Pro MS Window spoužijte Windows installer (stačí zvolit pouze Groovy binaries
a Modify variables
).
V prostředí Linux bývá instalace součástí systémů balíčků (např. apt-get install groovy
).
V jiných případech postupujte dle návodu http://groovy-lang.org/install.html.
Aplikace je k dispozici ve formě zdrojových skriptů. Ty je třeba rozbalit do libovolného adresáře.
Aplikaci lze používat z příkazové řádky nebo spuštěním scriptu (2x kliknout myší).
- Nejprve se přesvědčte, že máte správně neinstalovanou podporu Groovy (příkaz
groovy --version
):
$ groovy --version
Groovy Version: 2.4.0 JVM: 1.8.0_101 Vendor: Oracle Corporation OS: Linux
- Upravte parametry tržby a konfigurace (cestu na soubor s klíčem, heslo a další volby) v souboru
eetlite_run.groovy
. Pro úpravu lze použít jakýkoliv editor, doporučuje se použít editor s podporou syntaxegroovy
a Linux formátu (popř.JEdit
,notepad++
) - Spusťte aplikaci přikazem
groovy eetlite_run.groovy
(Windows, Linux, Mac) popřípadě příkazem./eetlite_run.groovy
(Linux). Aplikaci je třeba spustit z adresáře, ve kterém jsou všechny její soubory. Při úplně prvním spuštění je třeba vyčkat, než Groovy stáhne potřebné 'dependence' (většinou do adresáře.groovy
v domovském adresáři). - Po úspěšném zpracování se zobrazí jednoduchá účtenka dané tržby s hodnotou
FIK
aBKP
a vytiskne do souboru (je-li povoleno):
$ groovy eetlite_run.groovy
eetlite 0.2.0 uctenka
https://sites.google.com/view/eetlite
(https://github.com/novakmi/eetlite)
Soubor: /eetlite_run_ostry_2017_01_21_11_06_42_eetlite.txt
====================================
celk_trzba: 7896.00
dat_trzby: 2017-01-21T18:45:15+01:00
dic_popl: CZ00000019
id_pokl: Q-126-R
id_provoz: 123
porad_cis: 0/6460/ZQ42
rezim: 0
FIK: e91ca135-9f13-4eb1-8a2b-4bc759e33c9f-ff
BKP: FAD6D023-E92678FE-410EE310-51580CA5-5697BDAA
REZIM: bezny (s Internetem)
CAS ZPRACOVANI: 988ms
Od verze 0.1.0
je celá aplikace provozována jako jediný soubor (skript). Ze souboru eetlite_run.groovy
lze vytvářet
kopie a mít tak například vlastní soubor pro každou platbu. Zároveň si lze takto připravit celou sadu nejčastěji
používaných šablon. Pokud budete kopírovat soubor do jiného adresáře, překopírujete i soubor logback.groovy
a
popřípadě adresář cert
(nebo změňte cestu jeho umístění ve skriptu).
POZNÁMKA: V základním tvaru tato aplikace komunikuje s testovacím prostředím EET, pro používání v produkčním
prostředí je potřeba přepnout url:
a cert_popl:
- Java https://www.oracle.com/java/index.html
- Groovy http://groovy-lang.org/
- groovy-wslite https://github.com/jwagenleitner/groovy-wslite
- slf4j http://www.slf4j.org/
- http://logback.qos.ch/
- libeetlite - https://github.com/novakmi/libeetlite
(viz případné jednotlivé licence)
Změnou následujícího řádku v souboru logback.groovy
:
root(WARN, ["STDOUT"]) // change log level here to TRACE, DEBUG, INFO, WARN
lze měnit úroveň logování na konzoli
V případě, že je třeba nutno provádět ladění (úpravu kódu) na úrovni knihovny libeetlite
,
lze doporučit následující postup:
-
odstranit
@Grab
řádek@Grab("com.github.novakmi:libeetlite:0.1.0"),
, který imporutje knihovnu -
provést
clone
knihovnylibeetlite
pomocígit clone https://github.com/novakmi/libeetlite
- spustit s
classpath
ukazující na zdrojové souborylibeetlite
příkazemgroovy -cp <adresář s libeetlite>/libeetlite/src/main/groovy/ eetlite_run.groovy
- (nebo) nakopírovat obsah adresáře
<adresář s libeetlite>/libeetlite/src/main/groovy
do adresáře se souboremeetlite_run.groovy
- spustit s
-
nyní lze provádět změny ve zdrojových souborech
libeetlite
, které se projeví v ihned dalším spuštění (vgroovy
není třeba nic překládat)
Stránky projektu:
https://sites.google.com/view/eetlite
K hlášení chyb, podávání podnětů na zlepšení lze použít:
https://github.com/novakmi/eetlite/issues
https://gitlab.com/novakmi/eetlite/issues
e-mail: [email protected]
https://github.com/l-ra/openeet
https://github.com/todvora/eet-client