Библиотека для интеграции вашего сайта с облачным сервисом распределенной печати чеков КОМТЕТ Касса
- PHP >= 7.2
- CURL
С помощью Composer:
composer require komtet/kassa-sdk
Вручную:
git clone https://github.com/Komtet/komtet-kassa-php-sdk
<?php
require __DIR__.'/komtet-kassa-php-sdk/autoload.php';
Для отправки примеров из examples из php-cli:
make build
make cli_php_7 или make cli_php_8
php -f examples/v1/send_check_example.php
Первым делом необходимо создать менеджер очередей:
<?php
use Komtet\KassaSdk\v1\Client;
use Komtet\KassaSdk\v1\QueueManager;
$key = 'идентификатор магазина';
$secret = 'секретный ключ';
// PSR-совместимый логгер (опциональный параметр)
$logger = null;
$client = new Client($key, $secret, $logger);
$manager = new QueueManager($client);
После чего зарегистрировать очереди:
$manager->registerQueue('queue-name-1', 'queue-id-1');
$manager->registerQueue('queue-name-2', 'queue-id-2');
// 'queue-name-1' и 'queue-name-2' - произвольные псевдомимы для обращения к очередям.
// 'queue-id-1' и 'queue-id-2' - идентификаторы очередей, созданных в личном кабинете.
Отправка чека на печать - Пример
Отправка чека коррекции на печать - Пример
Чтобы не указывать каждый раз имя очереди, установите очередь по умолчанию:
<?php
$manager->setDefaultQueue('queue-name-1');
$manager->putCheck($check);
Получить состояние очереди:
<?php
$manager->isQueueActive('queue-name-1');
Получить информацию о поставленной на фискализацию задаче:
<?php
$taskManager = new TaskManager($client);
try {
$taskManager->getTaskInfo('task-id');
} catch (SdkException $e) {
echo $e->getMessage();
}
Создание заказа на доставку - Пример
Обновление заказа на доставку:
<?php
$orderManager = new OrderManager($client);
$order_id = 1;
$order = new Order('123', TaxSystem::COMMON, 'new', 0);
$order->setClient('г.Пенза, ул.Суворова д.10 кв.25',
'+87654443322',
'[email protected]',
'Сергеев Виктор Сергеевич');
$order->setDeliveryTime('2018-02-28 14:00',
'2018-02-28 15:20');
$orderPosition = new OrderPosition(['oid' => '1',
'name' => 'position name1',
'price' => 555.0,
'type' => 'product'
]);
$order->addPosition($orderPosition);
try {
$orderManager->updateOrder($order_id, $order);
} catch (SdkException $e) {
echo $e->getMessage();
}
Информация о заказе:
<?php
$orderManager = new OrderManager($client);
$order_id = 1;
try {
$info = $orderManager->getOrderInfo($order_id);
} catch (SdkException $e) {
echo $e->getMessage();
}
Применить общую скидку на заказ:
<?php
$discount = 250;
$order->applyDiscount($discount);
Удалить заказ:
<?php
$orderManager = new OrderManager($client);
$order_id = 1;
try {
$orderManager->deleteOrder($order_id);
} catch (SdkException $e) {
echo $e->getMessage();
}
Получить список заказов:
<?php
$orderManager = new OrderManager($client);
try {
$orderList = $orderManager->getOrders();
} catch (SdkException $e) {
echo $e->getMessage();
}
Получить список сотрудников:
<?php
use Komtet\KassaSdk\EmployeeManager;
use Komtet\KassaSdk\EmployeeType;
$employeeManager = new EmployeeManager(client);
try {
$employeeList = $employeeManager->getEmployees(EmployeeType::COURIER);
} catch (SdkException $e) {
echo $e->getMessage();
}
Получить информацию по сотруднику:
<?php
$employeeManager = new EmployeeManager(client);
$employeeID = 1;
try {
$employee = $employeeManager->getEmployee($employeeID);
} catch (SdkException $e) {
echo $e->getMessage();
}
Создание сотрудника:
<?php
$employeeManager = new EmployeeManager(client);
$employee = new Employee(EmployeeType::CASHIER, 'Full Name',
'login_employee', 'password', 'POS_KEY');
$employee->setPaymentAddress('payment address');
$employee->setAccessSettings(true, false, none);
try {
$employeeManager->createEmployee($employee);
} catch (SdkException $e) {
echo $e->getMessage();
}
Обновление сотрудника:
<?php
$employeeManager = new EmployeeManager(client);
$employee = new Employee(EmployeeType::CASHIER, 'Full Name',
'login_employee', 'new_password', 'POS_KEY');
$employee->setPaymentAddress('new payment address');
$employee->setAccessSettings(true, true, true);
$employeeID = 1;
try {
$employeeManager->updateEmployee($employeeID, $employee);
} catch (SdkException $e) {
echo $e->getMessage();
}
Удаление сотрудника:
<?php
$employeeManager = new EmployeeManager(client);
$employeeID = 1;
try {
$employeeManager->deleteEmployee($employeeID);
} catch (SdkException $e) {
echo $e->getMessage();
}
Первым делом необходимо создать менеджер очередей:
<?php
use Komtet\KassaSdk\v2\Client;
use Komtet\KassaSdk\v2\QueueManager;
$key = 'идентификатор магазина';
$secret = 'секретный ключ';
// PSR-совместимый логгер (опциональный параметр)
$logger = null;
$client = new Client($key, $secret, $logger);
$manager = new QueueManager($client);
После чего зарегистрировать очереди:
$manager->registerQueue('queue-name-1', 'queue-id-1');
$manager->registerQueue('queue-name-2', 'queue-id-2');
// 'queue-name-1' и 'queue-name-2' - произвольные псевдомимы для обращения к очередям.
// 'queue-id-1' и 'queue-id-2' - идентификаторы очередей, созданных в личном кабинете.
Отправка чека на печать - Пример
Отправка чека коррекции на печать - Пример
Чтобы не указывать каждый раз имя очереди, установите очередь по умолчанию:
<?php
$manager->setDefaultQueue('queue-name-1');
$manager->putCheck($check);
Получить состояние очереди:
<?php
$manager->isQueueActive('queue-name-1');
Получить информацию о поставленной на фискализацию задаче:
<?php
$taskManager = new TaskManager($client);
try {
$taskManager->getTaskInfo('task-id');
} catch (SdkException $e) {
echo $e->getMessage();
}
Создание заказа на доставку - Пример
<?php
$orderManager = new OrderManager($client);
$order_id = 1;
$order = new Order('12345', 'new', true);
$orderCompany = new OrderCompany(TaxSystem::COMMON, 'Улица Московская д.4');
$order->setCompany($orderCompany);
$orderBuyer = new OrderBuyer('+87654443322',
'г.Пенза, ул.Суворова д.10 кв.25')
$order->setOrderBuyer($orderBuyer);
$order->setDeliveryTime('20.02.2022 14:00',
'20.02.2022 15:20');
$orderPosition = new OrderPosition(['name' => 'position name1',
'price' => 555.0,
'quantity' => 1,
'total' => 555.0,
'vat' => '20',
]);
$order->addPosition($orderPosition);
try {
$orderManager->updateOrder($order_id, $order);
} catch (ApiValidationException $e) {
echo $e->getMessage();
echo $e->getVLDCode();
echo $e->getDescription();
} catch (SdkException $e) {
echo $e->getMessage();
}
Следующие операции в API v2 идентичны по вызову с API v1(примеры представлены выше в описании API v1):
- Информация о заказе
- Применить общую скидку на заказ
- Удалить заказ
- Получить список заказов
- Получить список сотрудников
- Получить информацию по сотруднику
- Создание сотрудника
- Обновление сотрудника
- Удаление сотрудника