В данном sdk реализованы только функции онлайн режима (оффлайн не реализован)
https://api.checkbox.in.ua/api/redoc
https://api.checkbox.in.ua/api/docs
https://docs.google.com/document/d/1Zhkc4OljKjea_235YafVvZunkWSp6TCAKeckhgl8t2w/edit
composer require igorbunov/checkbox-in-ua-php-sdk
require_once 'vendor/autoload.php';
адрес продакшен сервера http://api.checkbox.in.ua
адрес тестового сервера http://dev-api.checkbox.in.ua
текущая версия API - v1
$config = new \igorbunov\Checkbox\Config([
\igorbunov\Checkbox\Config::API_URL => 'https://dev-api.checkbox.in.ua/api/v1',
\igorbunov\Checkbox\Config::LOGIN => 'логин кассира',
\igorbunov\Checkbox\Config::PASSWORD => 'пароль кассира', //or
\igorbunov\Checkbox\Config::PINCODE => 02301230440,
\igorbunov\Checkbox\Config::LICENSE_KEY => 'ключ лицензии кассы'
]);
$api = new \igorbunov\Checkbox\CheckboxJsonApi($config);
$api->signInCashier();
$api->signOutCashier();
\igorbunov\Checkbox\Errors\InvalidCredentials - не верные данные логина или пароля
\igorbunov\Checkbox\Errors\EmptyResponse - пустой ответ
\igorbunov\Checkbox\Errors\Validation - ошибка валидации (есть детальные. данные $err->getDetail())
\igorbunov\Checkbox\Errors\NoActiveShift - нет активной смены
\igorbunov\Checkbox\Errors\AlreadyOpenedShift - смена уже открыта
\Exception - стандартная ошибка
$api->getCashierProfile() : \igorbunov\Checkbox\Models\Cashier\Cashier // возвращает профиль кассира
$api->getCashierShift() : \igorbunov\Checkbox\Models\Shifts\Shift // возвращает текущую смену кассира
$api->getShift('ид смены') : \igorbunov\Checkbox\Models\Shifts\Shift // возвращает смену по ид
$api->getShifts() : \igorbunov\Checkbox\Models\Shifts\Shifts // возвращает смены
или
$api->getShifts(
new \igorbunov\Checkbox\Models\Shifts\ShiftsQueryParams(
[
\igorbunov\Checkbox\Models\Shifts\ShiftsQueryParams::STATUS_CLOSED,
\igorbunov\Checkbox\Models\Shifts\ShiftsQueryParams::STATUS_OPENED
], // статусы смен
false, // desc - сортировка (false or true)
2, // limit
0 // offset
)
): \igorbunov\Checkbox\Models\Shifts\Shifts // возвращает смены с учетом фильтра
$api->createShift() : \igorbunov\Checkbox\Models\Shifts\CreateShift // создает смену
$api->closeShift() : \igorbunov\Checkbox\Models\Shifts\CloseShift // закрывает смену
$api->getCashRegisters() : \igorbunov\Checkbox\Models\CashRegisters\CashRegisters // возвращает кассовые регистраторы
или
$api->getCashRegisters(
new \igorbunov\Checkbox\Models\CashRegisters\CashRegistersQueryParams(
true, // inUse - используется или нет (true or false)
3, // limit
0 // offset
)
) : \igorbunov\Checkbox\Models\CashRegisters\CashRegisters // возвращает кассовые регистраторы по фильтру
$api->getCashRegister('ид кассы') : \igorbunov\Checkbox\Models\CashRegisters\CashRegister // возвращает кассу по айди
$api->getCashRegisterInfo() : \igorbunov\Checkbox\Models\CashRegisters\CashRegisterInfo // возвращает информацию текущей кассы
$api->getAllTaxes() : \igorbunov\Checkbox\Models\Receipts\Taxes\GoodTaxes // возвращает все налоги
$api->getTransactions(
new \igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams(
[
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::STATUS_CREATED,
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::STATUS_DONE,
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::STATUS_SIGNED
], // статусы транзакции
[
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::TYPE_RECEIPT,
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::TYPE_SHIFT_OPEN,
\igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams::TYPE_Z_REPORT
], // типы транзакций
2, // limit
0 // offset
)
) : \igorbunov\Checkbox\Models\Transactions\Transactions // возвращает транзакции по фильтру
$api->getTransaction('ид транзакции') : \igorbunov\Checkbox\Models\Transactions\Transaction // возвращает транзакцию по айди
$api->updateTransaction(
'ид транзакции',
base64_encode('request_signature')
) : \igorbunov\Checkbox\Models\Transactions\Transaction // меняет request_signature у транзакции, работает только если у транзакции статус PENDING
$api->createXReport() : \igorbunov\Checkbox\Models\Shifts\ZReport // создает х отчет
$api->getReport('ид отчета') : \igorbunov\Checkbox\Models\Shifts\ZReport // возвращает данные отчета по айди
$api->getReportText('ид отчета') : string // возвращает данные отчета по айди в виде текста
или
$api->getReportText('ид отчета', 60) : string // возвращает данные отчета по айди в виде текста, с указанием ширины текста
$api->getPeriodicalReport(
new \igorbunov\Checkbox\Models\Reports\PeriodicalReportQueryParams(
'2020-10-27 00:00:00', // дата с
'2020-11-04 13:15:00', // дата по
60 // ширина текста
)
) : string // возвращает данные отчета за период по фильру
$api->getReports(
new \igorbunov\Checkbox\Models\Reports\ReportsQueryParams(
'2020-10-27 00:00:00', // дата с
'2020-11-04 13:15:00', // дата по
[], // массив ид смен
false, // is_z_report (true or false)
true, // desc - сортировка (false or true)
3, // limit
0 // offset
)
) : \igorbunov\Checkbox\Models\Reports\Reports // возвращает отчеты по фильтру
$api->getReceipts() : \igorbunov\Checkbox\Models\Receipts\Receipts // возвращает чеки
$api->getReceipts(
new \igorbunov\Checkbox\Models\Receipts\ReceiptsQueryParams(
'', // fiscal code
'', // serial
false, // desc - сортировка (false or true)
2, // limit
0 // offset
)
) : \igorbunov\Checkbox\Models\Receipts\Receipts // возвращает чеки по фильтру
$api->getReceipt('ид чека') : \igorbunov\Checkbox\Models\Receipts\Receipt // возвращает чек по айди
$api->getReceiptPdf('ид чека') : pdf // возвращает чек по айди в виде пдф
$api->getReceiptHtml('ид чека') : string // возвращает чек по айди в виде html
$api->getReceiptText('ид чека') : string // возвращает чек по айди в виде текста
$api->getReceiptQrCodeImage('ид чека') : string // возвращает чек по айди в виде qr-кода
или
// пример с отображением qr-кода
$rawImageContent = $api->getReceiptQrCodeImage('ид чека');
echo '<img src="data:image/png;base64,' . base64_encode($rawImageContent) . '"/>';
$receipt = new \igorbunov\Checkbox\Models\Receipts\SellReceipt(
'Вася Пупкин', // кассир
'Отдел продаж', // отдел
new \igorbunov\Checkbox\Models\Receipts\Goods\Goods(
[
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel( // товар 1
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodModel(
'vm-123', // good_id
50 * 100, // 50 грн
'Биовак' // название товара
),
1 * 1000 // кол-во товара 1 шт
),
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel( // товар 2
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodModel(
'vm-124', // good_id
20 * 100, // 20 грн
'Биовак 2' // название товара
),
2 * 1000 // кол-во товара 2 шт
)
]
),
'admin@gmail.com', // кому отправлять чек по почте
new \igorbunov\Checkbox\Models\Receipts\Payments\Payments([
new \igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload( // безналичная оплата
40 * 100 // 40 грн
),
new \igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload( // наличная оплата
50 * 100 // 50 грн
)
])
);
$api->createSellReceipt($receipt): \igorbunov\Checkbox\Models\Receipts\Receipt; // выполняем оплату
более сложная оплата:
$allTaxes = $api->getAllTaxes(); // получили все налоги
$tax = $allTaxes->getTaxByLabel('Акцизний збір'); // получили один налог по лейбл
$goodTaxes = $allTaxes->getTaxesByLabel('ПДВ'); // получили массив налогов по лейбл
$taxCodes = [];
// подготавливаем массив кодов налогов
foreach ($goodTaxes->results as $goodTax) {
$taxCodes[] = $goodTax->code;
}
$receipt = new \igorbunov\Checkbox\Models\Receipts\SellReceipt(
'Вася Пупкин', // имя кассира
'Отдел продаж', // отдел
new \igorbunov\Checkbox\Models\Receipts\Goods\Goods( // товары
[
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel(
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodModel(
'vm-123', // good_id айди товара
5000, // 50 грн цена 100 = 1 грн
'Биовак', // название
'5р47ле78675е3', // баркод
'хидер', // хидер
'футер', // футер
'', // ktzed
$goodTaxes // налоги товара
),
1000, // кол-во 1000 = 1 шт
new \igorbunov\Checkbox\Models\Receipts\Discounts\Discounts( // скидки или надбавки
[
new \igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel(
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::TYPE_DISCOUNT, // скидка или надбавка
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::MODE_VALUE, // по значению или по проценту
100, // 1 грн сумма скидки/надбавки 100 = 1 грн
0, // сумма (не используется в данном sdk)
$tax->code, // код налога (подготовили выше)
$taxCodes, // массив кодов налога (подготовили выше)
'one good discount' // название
)
]
),
$allTaxes->getTaxesByLabel('Акцизний збір'), // налоги товара
false, // возврат товара (false or true)
0, // сумма (не используется в данном sdk)
'' // айди товара (только если вы загружали список товарв (не используется в данном sdk))
)
]
),
'admin@gmail.com', // кому отправлять чек по почте
new \igorbunov\Checkbox\Models\Receipts\Payments\Payments([ // оплаты
new \igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload( // безналичная оплата
400, // сумма оплаты 400 = 4 грн
'beznalichka', // текст оплаты
0, // code - не знаю для чего (видимо пин код карты)
'0000 0000 0000 0000' // номер карты
),
new \igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload( // наличная оплата
4300, // сумма оплаты 4300 = 43 грн
'nalichka' // текст оплаты
)
]),
new \igorbunov\Checkbox\Models\Receipts\Discounts\Discounts( // скидки/надбавки на весь чек
[
new \igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel(
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::TYPE_DISCOUNT, // скидка или надбавка
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::MODE_VALUE, // по значению или по проценту
200, // 2 грн сумма скидки/надбавки 200 = 2 грн
0, // сумма (не используется в данном sdk)
$tax->code, // код налога (подготовили выше)
$taxCodes, // массив кодов налога (подготовили выше)
'total discount' // название
)
]
),
'check header', // чек хидер
'check footer', // чек футер
'45435h543twrege' // баркод
);
$saleReceiptResult = $api->createSellReceipt($receipt): \igorbunov\Checkbox\Models\Receipts\Receipt; // выполняем оплату
еще пример
$allTaxes = $api->getAllTaxes();
$tax = $allTaxes->getTaxByLabel('Акцизний збір');
$goodTaxes = $allTaxes->getTaxesByLabel('ПДВ');
$taxCodes = [];
foreach ($goodTaxes->results as $goodTax) {
$taxCodes[] = $goodTax->code;
}
$receipt = new \igorbunov\Checkbox\Models\Receipts\SellReceipt(
'Вася Пупкин',
'Отдел продаж',
new \igorbunov\Checkbox\Models\Receipts\Goods\Goods(
[
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel(
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodModel(
'vm-123', // good_id
5000, // 50 грн
'Биовак',
'',
'',
'',
'',
$goodTaxes
),
1000,
new \igorbunov\Checkbox\Models\Receipts\Discounts\Discounts(
[
new \igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel(
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::TYPE_DISCOUNT,
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::MODE_VALUE,
100, // 1 грн
0,
$tax->code,
$taxCodes,
'моя скидка'
)
]
),
$allTaxes->getTaxesByLabel('Акцизний збір'),
false,
0,
''
),
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel(
new \igorbunov\Checkbox\Models\Receipts\Goods\GoodModel(
'vm-124', // good_id
2000, // 20 грн
'Биовак 2',
'',
'',
'',
'',
$goodTaxes
),
2000, // 2 шт
new \igorbunov\Checkbox\Models\Receipts\Discounts\Discounts(
[
new \igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel(
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::TYPE_EXTRA_CHARGE,
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::MODE_VALUE,
200, // 2 грн
0,
$tax->code,
$taxCodes,
'моя надбавка'
)
]
),
$allTaxes->getTaxesByLabel('Акцизний збір'),
false,
0,
''
)
]
),
'admin@gmail.com',
new \igorbunov\Checkbox\Models\Receipts\Payments\Payments([
new \igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload(
4700
),
new \igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload(
4700
)
]),
new \igorbunov\Checkbox\Models\Receipts\Discounts\Discounts(
[
new \igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel(
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::TYPE_EXTRA_CHARGE,
\igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel::MODE_VALUE,
200, // 2 грн
0,
$tax->code,
$taxCodes,
'общая надбавка'
)
]
)
);
$api->createSellReceipt($receipt): \igorbunov\Checkbox\Models\Receipts\Receipt;
$api->createServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\ServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload(5100)
)
): \igorbunov\Checkbox\Models\Receipts\Receipt // создаем чек сервисного внесения денег (наличкой)
$api->createServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\ServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload(1000)
)
): \igorbunov\Checkbox\Models\Receipts\Receipt // создаем чек сервисного внесения денег (картой)
$api->createServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\ServiceReceipt(
new new \igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload(-5100)
)
): \igorbunov\Checkbox\Models\Receipts\Receipt // создаем чек сервисного вынесения денег (наличкой) (знак минус)
$api->createServiceReceipt(
new \igorbunov\Checkbox\Models\Receipts\ServiceReceipt(
new new \igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload(-1000)
)
): \igorbunov\Checkbox\Models\Receipts\Receipt // создаем чек сервисного вынесения денег (картой) (знак минус)
все операции оборачивать в try cache
try {
// тут все делаем
} catch (\igorbunov\Checkbox\Errors\InvalidCredentials $err) {
var_dump('creds err', $err->getMessage());
} catch (\igorbunov\Checkbox\Errors\EmptyResponse $err) {
var_dump('empty response', $err->getMessage(), $err->getTraceAsString());
} catch (\igorbunov\Checkbox\Errors\Validation $err) {
var_dump('valid err', $err->getMessage());
var_dump('error detail', $err->getDetail());
} catch (\igorbunov\Checkbox\Errors\NoActiveShift $err) {
var_dump('no shift', $err->getMessage());
} catch (\igorbunov\Checkbox\Errors\AlreadyOpenedShift $err) {
var_dump('opened shift', $err->getMessage());
} catch (\Exception $err) {
var_dump('default err', $err->getMessage());
}
use igorbunov\Checkbox\CheckboxJsonApi;
use igorbunov\Checkbox\Config;
use igorbunov\Checkbox\Errors\InvalidCredentials;
use igorbunov\Checkbox\Errors\Validation;
use igorbunov\Checkbox\Errors\NoActiveShift;
use igorbunov\Checkbox\Errors\AlreadyOpenedShift;
use igorbunov\Checkbox\Errors\EmptyResponse;
use igorbunov\Checkbox\Models\CashRegisters\CashRegistersQueryParams;
use igorbunov\Checkbox\Models\Shifts\ShiftsQueryParams;
use igorbunov\Checkbox\Models\Receipts\ReceiptsQueryParams;
use igorbunov\Checkbox\Models\Receipts\Discounts\Discounts;
use igorbunov\Checkbox\Models\Receipts\Discounts\DiscountModel;
use igorbunov\Checkbox\Models\Receipts\SellReceipt;
use igorbunov\Checkbox\Models\Receipts\Payments\Payments;
use igorbunov\Checkbox\Models\Receipts\Payments\CardPaymentPayload;
use igorbunov\Checkbox\Models\Receipts\Payments\CashPaymentPayload;
use igorbunov\Checkbox\Models\Receipts\ServiceReceipt;
use igorbunov\Checkbox\Models\Reports\PeriodicalReportQueryParams;
use igorbunov\Checkbox\Models\Reports\ReportsQueryParams;
use igorbunov\Checkbox\Models\Transactions\TransactionsQueryParams;
use igorbunov\Checkbox\Models\Receipts\Goods\Goods;
use igorbunov\Checkbox\Models\Receipts\Goods\GoodItemModel;
use igorbunov\Checkbox\Models\Receipts\Goods\GoodModel;
For run all tests
make all
or connect to terminal
make exec
or use built in php server http://localhost:8080
# start server on 8080 port
make serve
# custom port 8081
make serve PORT=8081
Dafault php version is 8.0. Use PHP_VERSION= for using custom version.
make all PHP_VERSION=8.0
all commands
# security check
make security
# composer install
make install
# composer install with --no-dev
make install-no-dev
# check code style
make style
# run static analyze tools
make static-analyze
# run unit tests
make unit
# check coverage
make coverage
Without Docker
#validate composer json
composer check-composer
#static analyzes and codestyle
composer static
#run unit tests
composer unit-tests
#run all tests
composer all-tests