xsuchy09 / uctenkovka
Library for connection to Uctenkovka API (send EET receipts into Uctenkovka).
Requires
- php: >=7.1
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- ext-openssl: *
Requires (Dev)
- phpunit/phpunit: ^7.5
This package is auto-updated.
Last update: 2024-12-15 02:44:39 UTC
README
PHP library for communication with Uctenkovka (EET Czech Republic competition with receipts). See Uctenkovka.cz. PHP 7.1+ is required.
Authors:
Overview
Uctenkovka library can send receipts directly into Uctenkovka competition.
Installation (via composer)
Get composer and add this in your requires section of the composer.json:
{
"require": {
"xsuchy09/uctenkovka": "*"
}
}
and then
composer install
or just
composer require xsuchy09/uctenkovka
Usage
You have to have own certificates to communicate with Uctenkovka. See etrzby for more info. In czech language there are two important documents:
This library covers specification but you have to fill all of the conditions.
Basic Example
You can see tests which are included in this repository. To run that tests you need own certs for communication with test server (see Conditions in Czech language). Save your test_crt.pem
and test_key.pem
into the /src/certs/
folder and then you can run the tests which will generate PhpUnit cover report too (100% btw).
How to send receipt/request into Uctenkovka
use xsuchy09\Uctenkovka\Request; use xsuchy09\Uctenkovka\Uctenkovka; $request = new Request(); $request->setEmail('test@example.com') ->setPhone('777777777') ->setBasicConsent(true) ->setFik('B3A09B52-7C87-4014') ->setBkp('01234567-89abcdef') ->setDate('2018-03-17') ->setTime('16:41') ->setAmount(4570) // in hellers ->setSimpleMode(false); $uctenkovka = new Uctenkovka(); $uctenkovka->setMode(Uctenkovka::MODE_TESTING); $uctenkovka->setSslCert(__DIR__ . '/../src/certs/test_crt.pem'); $uctenkovka->setSslKey(__DIR__ . '/../src/certs/test_key.pem'); $uctenkovka->send($request);
You can set date and time of receipt (request) at once with \DateTime
object:
$request->setDateTime(DateTime::createFromFormat('Y-m-d H:i:s', $date)); // seconds are optional
You can set all of receipt/request values as array - not required param of Request
constructor:
use xsuchy09\Uctenkovka\Request; $request = new Request([ 'email' => 'test@example.com', 'phone' => '777777777', 'basicConsent' => true, 'fik' => 'B3A09B52-7C87-4014', 'bkp' => '01234567-89abcdef', 'date' => '2018-03-17', 'time' => '16:41', 'amount' => 4570, 'simpleMode' => false ]);
More examples can be found in the /tests/
directory.
Usage is clear and easy. You can contact me if you need.