== Диспенсер карт (черновик) == == Описание == Управляющий контроллер позволяет управлять выдачей карт с управляющего компьютера (хоста) через интерфейс USB. Хост отслеживает состояние диспенсера (команда STATUS) на предмет наличия фатальных ошибок (JAMMED) и состояния стекера карт. Диспенсер может находится в одном из четырех статусов * 0x00 — инициализация. Производится при старте устройства. * 0x01 — готов к работе. Штатное состояние устройства при ожидании команды на выдачу карт. * 0x02 — идет транзит карты. * 0x03 — карта в положении escrow. * 0xF0 - фатальная ошибка JAMMED. В данное состояние диспенсер переходит в случае если зафиксирован сбой работы. Выход из состояния JAMMED может быть осуществлен двумя способами: * Перезагрузкой устройства * Длительным (2-3 сек) нажатием кнопки на устройстве. == Демонстрационная утилита == Демонстрационная утилита позволяет управлять диспенсером с командной строки. Варианты запуска: Проверка доступности устройства: {{{ protodemo.exe ping }}} Проверка статуса: {{{ protodemo.exe status }}} Выдача карты {{{ priotodemo.exe dispense }}} Информация по последней выданной карте {{{ priotodemo.exe dispense_result }}} == API == Управление БУ с хоста осуществляется через порт USB, который эмулирует работу последовательного порта (COM-порта). Для корректной работы необходимо установить драйвер (USB CDC): Параметры последовательного порта: * Baudrate: 115200 * Parity: none * 8 bits * 1 STOP БУ и хост обмениваются командами и данными, инкапсулированными в пакеты следующего формата: * (1 байт) sync - байт синхронизации, 0x55 * (1 байт) size - размер пакета (включая sync и crc) * (2 байта) адрес устройства, иные параметры - не используются, передавать 0x00 0x00 * (1 байт) cmd/response - код команды или устройства * (N байт) data - блок данных команды (может быть пустым) * (2 байта) crc - контрольная сумма CRC16-CCIT == PING (0x01): проверка связи с устройством == Без данных. Успешный ответна команду (response = 0x01) поступает без данных. == TRANSIT (0x02): команда транзита карты == В запросе: * 1 байт: назначение транзита: 0x01 - в положение escrow, 0x02 - выдать карту, 0x03 - захват карты Успешный ответ на команду (response = 0x02) поступает без данных, ошибка (response = 0x00) поступает с кодом ошибки размером 1 байт в блоке данных. == CARD_INFO (0x03): команда запроса информации по карте == Команда выполняется только в случае наличия карты в положении escrow. При успешном ответе (response = 0x03) в блоке данных последовательно возвращаются: * 1 байт: результат операции (0x00 — карта выдана, 0x01 - операция выполняется, 0x02 - отказ в выдаче, карта отбракована, 0x03 - фатальная ошибка JAMMED) * последовательность TLV-блоков с описанием карты (только если карта выдана) TLV 0x01 : UID карты * 1байт: тип блока - 0x01 * 2байт: размер содержимого блока (length) - переменный (для Mifare Classic 1K/4K - 4 байта, для Mifare UL - 7 байт) * length байт: UID карты при ошибке (response = 0x00) поступает с кодом ошибки размером 1 байт в блоке данных. == STATUS (0x03): текущее состояние устройства == Без данных, запрашивает текущее состояние устройства. В ответе (response = 0x01) в блоке данных последовательно возвращаются: * 1 байт: статус устройства (0x00 — инициализация, 0x01 — готов к работе, 0x02 — в процессе выдачи, 0x03 - фатальная ошибка JAMMED) * 1 байт: состояние датчика нижнего уровня стека карт (0x00 - магнитов достаточно, 0x01 - уровень низкий) == Порядок операции выдачи карты == * Выдать команду TRANSIT в положение escrow * Дождаться состояния 0x03 (карта в положении escrow) в ответе команды STATUS * Выполнить операцию CARD_INFO, получить информацию по карте * Выдать команду TRANSIT на выдачу или захват карты * Дождаться состояния 0x01 (готов к работе) в ответе команды STATUS == Обработка ошибок == При возникновении операционных ошибок транзита карт диспенсер переходит в состояние JAMMED (определяется командой STATUS) и требует обслуживания для восстановления работоспособности,