Библиотека для интеграции вашего сайта с облачным сервисом распределенной печати чеков КОМТЕТ Касса
- PHP >= 5.4
- 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';
Первым делом необходимо создать менеджер очередей:
<?php
use Komtet\KassaSdk\Client;
use Komtet\KassaSdk\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
use Komtet\KassaSdk\Agent;
use Komtet\KassaSdk\Buyer;
use Komtet\KassaSdk\Check;
use Komtet\KassaSdk\Cashier;
use Komtet\KassaSdk\Payment;
use Komtet\KassaSdk\Position;
use Komtet\KassaSdk\TaxSystem;
use Komtet\KassaSdk\Vat;
use Komtet\KassaSdk\Exception\SdkException;
// уникальный ID, предоставляемый магазином
$checkID = 'id';
// E-Mail клиента, на который будет отправлен E-Mail с чеком.
$clientEmail = 'user@host';
$check = Check::createSell($checkID, $clientEmail, TaxSystem::COMMON); // или Check::createSellReturn для оформления возврата
// Говорим, что чек нужно распечатать
$check->setShouldPrint(true);
$vat = new Vat(Vat::RATE_20);
// Позиция в чеке: имя, цена, кол-во, общая стоимость, налог
$position = new Position('name', 100, 1, 100, $vat);
// Опционально можно установить:
// Идентификатор позиции
// $position->setId('123');
// Единицу измерения
// $position->setMeasureName('Кг.');
// Cпособ рассчета
// $position->setCalculationMethod(CalculationMethod::FULL_PAYMENT);
// Признак рассчета
// $position->setCalculationSubject(CalculationSubject::PRODUCT);
// Агента по предмету расчета
// $agent = new Agent(Agent::COMMISSIONAIRE, "+77777777777", "ООО 'Лютик'", "12345678901");
// $position->setAgent($agent);
$check->addPosition($position);
// Итоговая сумма расчёта
$payment = new Payment(Payment::TYPE_CARD, 100);
$check->addPayment($payment);
// Добавление данных покупателя (опционально)
$buyer = new Buyer('Пупкин П.П.', '123412341234');
$check->addBuyer($buyer);
// Добавление кассира (опционально)
$cashier = new Cashier('Иваров И.П.', '1234567890123');
$check->addCashier($cashier);
// Добавляем чек в очередь.
try {
$manager->putCheck($check, 'queue-name-1');
} catch (SdkException $e) {
echo $e->getMessage();
}
Отправка чека коррекции:
<?php
use Komtet\KassaSdk\Correction;
use Komtet\KassaSdk\CorrectionCheck;
use Komtet\KassaSdk\AuthorisedPerson;
// Данные коррекции
// createSelf для самостоятельной коррекции
// createForced для коррекции по предписанию
$correction = Correction::createSelf(
'2012-12-21', // Дата документа коррекции в формате yyyy-mm-dd
'4815162342', // Номер документа коррекции
'description' // Описание коррекции
);
// createSell для коррекции прихода
// createSellReturn для коррекции расхода
$check = CorrectionCheck::createSell(
'4815162342', // Номер операции в вашей системе
'4815162342', // Серийный номер принтера
TaxSystem::COMMON, // Система налогообложения
$correction // Данные коррекции
);
$check->setPayment(
new Payment(Payment::TYPE_CARD, 4815), // Общая сумма по чеку
new Vat('120') // Ставка налога
);
$authorised_person = new AuthorisedPerson(
'Иваров И.И.', // ФИО
'123456789012' // ИНН
);
$check->setAuthorisedPerson($authorised_person);
// Добавляем чек в очередь.
try {
$manager->putCheck($check, 'queue-name-1');
} catch (SdkException $e) {
echo $e->getMessage();
}
Чтобы не указывать каждый раз имя очереди, установите очередь по умолчанию:
<?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 = new Order('123', 'new', 0);
$order->setClient('г.Пенза, ул.Суворова д.10 кв.25',
'+87654443322',
'client@email.com',
'Сергеев Виктор Сергеевич');
$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->createOrder($order);
} catch (SdkException $e) {
echo $e->getMessage();
}
Обновление заказа на доставку:
<?php
$orderManager = new OrderManager(client);
$order_id = 1;
$order = new Order('123', 'new', 0);
$order->setClient('г.Пенза, ул.Суворова д.10 кв.25',
'+87654443322',
'client@email.com',
'Сергеев Виктор Сергеевич');
$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);
$order_id = 1;
try {
$orderList = $orderManager->getOrders();
} catch (SdkException $e) {
echo $e->getMessage();
}
Получить список курьеров:
<?php
$courierManager = new CourierManager(client);
try {
$courierList = $courierManager->getCouriers();
} catch (SdkException $e) {
echo $e->getMessage();
}
- В классе
Position
убрана поддержкаdiscount
- В класс
Check
добавлен методaddAdditionalCheckProps
для поддержки дополнительного реквизита чека
- Для заказов добавлена поддержка
exices
,country_code
,declaration_number
- Заменены параметры
gtin
иserial
классаNomenclature
наcode
- В метод
Order.add_position
добавлен необязательный параметрagent
.
- Параметр
inn
в классеCashier
иAuthorisedPerson
необязателен для ввода
- Точности округления перед использованием функции
json_encode
выставлена для всех версий php
- Изменена настройка точности округления перед использованием функции
json_encode
- Добавлен метод
setName
в классBuyer
- В
ClientException
добавлен кодEXTERNAL_ID_EXISTS
— чек с таким внешним идентификатором уже был напечатан
- Исправлены ошибки при серилиазации полей класса
Position
- Добавлены празнаки рассчета
PROPERTY_RIGHT
,NON_OPERATING
,INSURANCE
,SALES_TAX
,RESORT_FEE
у классаCalculationSubject
- Добавлен класс
Nomenclature
для создания маркировок - Добавлены новые методы
Position::setNomenclature
,Position::setExcise
,Position::setCountryCode
иPosition::setDeclarationNumber
- Исправлена обработка НДС 0%
- Параметры конструктора
Buyer
сделаны необязательны для ввода - Добавлен метод
setINN
в классBuyer
- Добавлена настройка точности округления перед использованием функции
json_encode
- Добавлена функция
applyDiscount
для заказа доставки для применения общей скидки
- Добавлены классы
Order
,OrderManager
,OrderPosition
для работы с заказами. - Добавлен класс
CourierManager
для работы с курьерами. - Добавлено конвертирование типов НДС
Vat::RATE_18
иVat::RATE_118
вVat::RATE_20
иVat::RATE_120
- Добавлен класс покупателя
Buyer
- Добавлена функция
Check::addBuyer
для передачи данных покупателя в чек на фискализацию
- Исправлена структура передачи данных поставщика в позиции заказа
- Расширенны возможности статических функций
Check::createSell
,Check::createSellReturn
,Check::createBuy
иCheck::createBuyReturn
приемом адреса места расчета$paymentAddress
- Перед использованием констант добавлена проверка на существование класса
Psr\Log\LogLevel
- Убраны типы НДС
Vat::RATE_18
иVat::RATE_118
- Добавлены новые методы
Agent::setSupplierInfo
,Agent::setPayingAgentInfo
,Agent::setReceivePaymentsOperatorInfo
иAgent::setMoneyTransferOperatorInfo
. - Класс
Check
принимает необязательный параметр места расчета$paymentAddress
- Добалвены новые виды НДС
Vat::RATE_20
иVat::RATE_120
- Добавлен метод применения скидки к чеку Check::applyDiscount;
- Убрыны методы Payment::createCard и Payment::createCash из-за расширения списка возможных видов оплаты. Теперь объект платежа необходимо создавать явно
new Payment(Payment::TYPE_CARD, 100)
;
- Вернул методы createCard и createCash для подержания совместимости версии 0.X.X
- Добавлены константы направлений платежа
INTENT_BUY
иINTENT_BUY_RETURN
в классCheck
- Добавлен класс
AuthorisedPerson
- Добавлены классы
Agent
,CalculationMethod
,CalculationSubject
иCashier
. - Добавлены методы
Check::addCashier
,Position::setCalculationMethod
,Position::setCalculationSubject
,Position::setAgent
. - Добавлены константы
Payment::TYPE_PREPAYMENT
,Payment::TYPE_CREDIT
иPayment::TYPE_COUNTER_PROVISIONING
. - Удалены методы
Payment::createCard
иPayment::createCash
- Добавлен метод
Client::setPartner
.
- Маскирование значений заголовков Authorization и X-HMAC-Signature в логах.
- Логирование с помощью PSR-совместимого логера.
- Добавлен класс
TaskManager
. - Добавлен метод
Position::setId
.
- Добавлен метод
Payment::getSum
. Check::TS_*
константы перенесены в классTaxSystem
.- Добавлен метод
Position::setMeasureName
. - Добавлен чек коррекции.
- Удалён метод
Vat::calculate
. - Конструктор класса
Vat
теперь принимает только ставку налога. - Метод
Vat::as_array()
заменён наVat::getRate
, который возвращает строку, содержащую ставку налога.
QueueManager::putCheck()
теперь возвращает ответ от сервера.
- Добавлена возможность указать систему налогообложения.
- Удалены все упоминания о Motmom.
- Первый релиз.