Syslog Документация
Описание
В данном документе описаны syslog сообщения отправляемые домофонной панелью Сокол Плюс во время работы.
API
Сообщение | Условие появление |
Info | |
[Api]: Запуск приложения | появляется при запуске приложения "API" |
[Api]: Остановка приложения | появляется при остановке приложения "API" |
Вызов метода: %d %s [%s] | появляется при запуске определенного заданного метода |
SendDbusCrmProxiResp собран ответ: %s | появляется после выполнения операции SendDbusCrmProxiResp, где %s — заменяется на фактический текст |
ReadPages: %#X, %u, %p", pageAddr, numPages, bufAddr | появляется при совершении выполнения операции на чтение данных из памяти. |
Тело запроса: %s | появляется при совершении передачи или обработки тела запроса в рамках сетевого взаимодействия или обработки HTTP-запросов |
text = %s | появляется при наличие текстовой информации, которая была найдена или обработана в рамках определенного процесса |
RFID %s written to MC | появляется при успешном сохранении данных полученные с помощью RFID |
RFID %s deleted from MC | появляется при успешном удалении данных из памяти, связанных с RFID-меткой |
All data markup and state sectors key for Mifare key deleted from MC | появляется при успешном удалении всех данных разметки и ключей состояния для ключа Mifare из определенной области памяти |
Send opening external door with addr = %d by API command | появляется при попытки открыть дверь через API-команду |
Warning | |
Обнаружены ошибки, RouteCallback не будет выполнен | появляется при наличии ошибок, которые препятствуют выполнению функции RouteCallback |
[Api]: Получен сигнал \"%d\" | появляется при получении определенного сигнала через API |
Неавторизованный вызов метода: %d %s [%s] | появляется при попытки неавторизованного вызова метода в системе |
Аппаратный сброс | появляется при выполнении аппаратного сброса устройства |
Init input buf FAILED! | появляется при неудачной инициализации буфера ввода данных |
Backup camera... | появляется при активации или использовании резервной камеры |
Read pages... | появляется при попытке чтения страницы из определенного источника |
Error | |
Ошибка при инициализации общего буфера | появляется в контексте системных ошибок, связанных с проблемами при инициализации разделяемого буфера между различными процессами или компонентами системы |
Ошибка при инициализации буфера страниц | появляется в контексте системных ошибок, связанных с проблемами при инициализации буфера страниц в оперативной памяти |
TConfigPage wrong size, %d != %d | появляется в контексте системных ошибок, связанных с проблемами при инициализации или использовании конфигурационных страниц в программном обеспечении |
Не удалось создать evBase: #%d (%s) | появляется в контексте системных ошибок, связанных с проблемами при создании базы событий в программном обеспечении |
Не удалось создать evHttpApi: #%d (%s) | появляется в контексте системных ошибок, связанных с проблемами при создании HTTP API (evHttpApi) в программном обеспечении |
Не удалось привязать HTTP сокет %s:%d | появляется в контексте системных ошибок, связанных с проблемами при попытке привязки HTTP сокета к определенному порту и адресу |
Running HTTP сокет %s:%d | появляется, когда сетевой сервис или приложение успешно запустило HTTP сокет на указанном порту и адресе |
Путь не найден: %s | появляется в контексте системных ошибок, связанных с проблемами при попытке доступа к файлу или директории, путь к которой указан в сообщении |
Не удалось создать evHttpWeb: #%d (%s) | появляется в контексте системных ошибок, связанных с проблемами при попытке создания объекта или компонента, связанного с HTTP протоколом, в программном обеспечении |
Не удалось привязать сокет %s:%d | появляется в контексте системных ошибок, связанных с проблемами при попытке привязки сетевого сокета к определенному порту и адресу |
Ошибка при инициализации буфера: %s | появляется в контексте системных ошибок, связанных с проблемами при попытке инициализации буфера памяти для хранения данных |
Ошибка обновления кэша основной конфигурации | появляется в контексте системных ошибок, связанных с проблемами при попытке обновления кэша основной конфигурации приложения или системы |
Ошибка обновления кэша таблицы квартир конфигурации | появляется в контексте системных ошибок, связанных с проблемами при попытке обновления кэша таблицы квартир конфигурации приложения или системы |
Не удалось актуализировать кэш | появляется в контексте системных ошибок, связанных с проблемами при попытке обновления кэша приложения или системы |
Ошибка освобождения отображённой памяти: %s (%d)\n | появляется |
Pages count for table type %d = 0 ! | появляется |
State flag pnt is NULL for table type %d = 0 ! | появляется |
Unexpected page type: %d | появляется |
Not found table! | появляется |
Not found begin addr! | появляется |
Обращение к некорректному адресу: %#X | появляется |
Ошибка обновления кэша | появляется |
Ошибка установки режима открытых дверей: #%d | появляется |
Ошибка очистки памяти MCU: #%d | появляется |
Ошибка при инициализации входящего буфера | появляется |
Не удалось открыть буферный файл: %s | появляется |
Не удалось отобразить буфер в файл | появляется |
Ошибка чтения %s при изменении пароля | появляется |
Ошибка при конвертации из cp1251 в utf8 | появляется |
Ошибка при конвертации из utf8 в cp1251 | появляется |
Ошибка обновления кэша | появляется |
Not valid number profile number = %d! | появляется |
Ошибка сброса кэша ключей | |
Параметр (\"name\") отсутствует или не является строкой | |
Параметр \"repeat\" отсутствует или не являются числом | |
Параметр (\"name\") отсутствует или не является строкой | |
Не удалось записать общую конфигурацию | |
Не удалось записать ключи | |
Не удалось записать данные о квартирах | |
Не удалось записать данные о матрицах коммутации | |
Не удалось записать данные о разметке ключей | |
Не удалось записать данные о состоянии секторов | |
Не удалось выполнить перезагрузку панели | |
Ошибка при восстановлении из бэкапа | |
setsockopt SO_REUSEADDR error: %s | |
setsockopt SO_REUSEPORT error: %s | |
Socket() error\n | |
Bind port (%u) error\n | |
\"%s\" not found | |
Debug | |
Очистка кэша основной конфигурации | |
Очистка кэша таблицы квартир конфигурации | |
CrmCoreIsHandler: Получены параметры: %s | |
CrmCoreIsHandler Получены параметры: %s | |
Length data from core-is %d | |
Read Page %u on MCU: %s | |
Read Page on cache: %s | |
Read Page on cache %x | |
Read Page on MCU %x | |
Write page: %s | |
Read page: %s | |
Content type in req = %s | |
Can't set gate settings! | |
Notification Forced Play: path-%s, repeat-%d | |
Notification Forced Delete: name-%s | |
Квартира %d уже существует |
Camofon
Сообщение | Условие появление |
Info | |
DTMF event: %s | |
Open main door by DTMF | |
Open second door by DTMF | |
SOS_CALL_ESTABLISHED | |
CONCIERGE_CALL_ESTABLISHED | |
Incoming assist call | |
Hangup assistant | |
Incoming call to %u | |
Can't dial with flat %u. Hangup | |
Load accounts from SIP header: %s | |
SIP call done for apartment %u, handset is down | |
All calls are done for apartment %u | |
All calls are done for %s | |
SIP call done, handset is down | |
All calls are done | |
[Camofon]: Запуск приложения | |
[Baresip]: Успешная авторизация с %d попытки | |
[Camofon]: Остановка приложения" | |
All calls are done for apartment %u | |
All calls are done for %s | |
All calls are done | |
Open from handset! | |
terminated by signal %d | |
Calling to %u flat... | |
Calling to %u house %u flat... | |
Calling %s through account | |
Baresip AOR: %s | |
Warning | |
[Camofon]: Получен сигнал \"%d\" | |
Can't write gate settings to config | |
Detect dbus loop hanging by %d secs | |
Detect dbus loop hanging by %d secs. Exit! | |
main: configure failed: %m | |
main: baresip init failed (%m) | |
Can't call to %s account of %u flat | |
Trying make call to null SIP address!\nState = %d, flat = %u | |
Attempt to set %s call header with value %s | |
account: no account for this ua | |
account: failed to register ua | |
Error | |
Failed main door by DTMF | |
Failed second door by DTMF | |
Ошибка открытия сокета ассистента | |
[Baresip]: Ошибка инициализации | |
[Baresip]: Неудачная попытка авторизации более %d раз | |
[Baresip]: Ошибка применения параметров | |
Поле 'proxy.enable' не является логическим типом | |
Строка '%s' должна быть не более %u символов | |
Поле '%s' не является строкой | |
Неправильно указан %s: %d | |
Поле '%s' не является целым числом | |
Неверный формат JSON со списком SIP аккаунтов | |
Ошибка сохранения SIP аккаунтов | |
Номер квартиры должен быть строковым представлением числа: %s | |
Список аккаунтов для квартиры %s не является массивом | |
Максимум аккаунтов доступных для сохранения на одну квартиру: %d. Для квартиры %s задано %d | |
Список аккаунтов для квартиры %s должен состоять из строк | |
Длина поля sip аккаунта не должна быть больше %d (Квартира %s) | |
Список аккаунтов для квартиры %s содержит дубликаты | |
Can not check SIP block status: buf length is less than 3 (%d) | |
Can not check handset block status: buf length is less than 3 (%d) | |
Ошибка создания ответа со статусом sip регистрации | |
Ошибка отправки ответа со статусом sip регистрации | |
SIP registration failed, can't make call | |
Ошибка, sip сервер не задан | |
State is %d on BYE event! Unprocessed condition | |
Ошибка парсинга правил набора | |
Ошибка при вызове, правило набора для номера дома не задано: %s | |
Ошибка открытия директории с фразами ассистента: %s | |
Ошибка проигрывание сообщения (сокет закрыт) | |
Ошибка отправки аудиофайла в сокет | |
Ошибка проигрывание сообщения (сокет закрыт) | |
Ошибка отправки аудиофайла в сокет | |
Ошибка чтения поля subchunk1Size | |
Длина заголовка не соответствует PCM формату | |
Ошибка чтения поля audioFormat | |
Аудио формат заголовка не соответствует PCM | |
Ошибка чтения поля numChannels | |
Неподдерживаемое количество каналов: %d | |
Ошибка чтения поля sampleRate | |
Неподдерживаемая частота дискретизации: %d | |
Ошибка чтения поля byteRate | |
Ошибка чтения поля blockAlign | |
Ошибка чтения поля bitsPerSample | |
Ошибка чтения поля chunkId или поле задано неверно: %s | |
Ошибка чтения поля chunkSize | |
Ошибка чтения поля chunkId или поле задано неверно: %s | |
Ошибка чтения поля subchunk1Id" | |
Ошибка проверки заголовка аудиофайла | |
Ошибка чтения id чанка | |
Ошибка чтения размера чанка: %s | |
Error setting custom call header %s: %d | |
Debug | |
Baresip terminate with exit (%d) | |
Baresip event: %s State: %s | |
Loaded %u flat SIP accounts list from config: %s | |
Call to %s | |
Baresip endpoint: %s:%d | |
Сброс всех вызовов | |
Loaded accounts list: \n%s | |
Set sos value: '%s' | |
Set concierge value: '%s' | |
GetSosJson | |
SetSosJson | |
GetConciergeJson | |
SetConciergeJson | |
GetDtmfJson | |
SetDtmfJson | |
DeleteDtmf | |
GetServerJson | |
SetServerJson | |
GetAssistantJson | |
SetAssistantJson | |
DeleteAssistant | |
SetVideoSettingsJson | |
GetRegisterStatusJson | |
%s | |
ua_hangup %p:%p! | |
HangupAnotherCalls! | |
UART_EV_ANSWER | |
HangupAnotherCalls! | |
ctx.state == NOTIFICATION_DIALING | |
UART_EV_BYE | |
HangupAnotherCalls! | |
UART_EV_OPEN_HANDSET | |
BYE BYE BYE | |
ua exited -- stopping main runloop | |
Terminate | |
Calling to the %s account linked to the %u flat | |
HangupAnotherCalls: %p | |
ua_hangup: %p:%p! | |
SipUnregister |
Ddns
Сообщение | Условие появление |
Info | |
[Ddns]: Запуск приложения | появляется при запуске приложения Ddns |
[Ddns]: Остановка приложения | появляется при остановке приложения Ddns |
[%d]: %s | представляет собой шаблон сообщения для форматирования сообщения, где “%d” и “%s” являются заполнителями для числовых и строковых значений соответственно |
Загружена конфигурация: | появляется при успешной загрузки конфигурационных файлов |
Enabled (%d) | появляется в контексте активации или деактивации функций, модулей, сервисов или параметров в системе, указывая на текущее состояние активации |
Interval (%d) |
появляется в контексте настройки временных интервалов для выполнения задач, периодических операций или мониторинга в системе, указывая на установленный интервал времени |
[Server]: port (%d) | появляется контексте настройки сетевых соединений и портов, указывая на используемый порт для конкретного сервера или сервиса |
[Server]: address (%s) | появляется в контексте настройки сетевых подключений и адресов, указывая на адрес сервера, с которым устанавливается соединение |
[Server]: username (%s) | появляется, когда пользователь хочет ввести "Имя пользователя", чтобы получить доступ к серверу или сервису |
[Data]: hostname (%s) | появляется в контексте идентификации и логирования событий, связанных с конкретным устройством или системой, указывая на имя хоста (hostname) устройства, генерирующего событие |
Warning | |
[Ddns]: Получен сигнал \"%d\" | появляется при получении сигнала от клиента или сервера Ddns |
Error | |
[%d]: %s | представляет собой шаблон сообщения для форматирования сообщения, где “%d” и “%s” являются заполнителями для числовых и строковых значений соответственно |
Debug | |
iface: %s | появляется при активации или использования определенного сетевого интерфейса в системе |
[Server]: password (%s) | появляется, когда пользователь на этапе аутентификации пытается ввести пароль |
IRCut
Сообщение | Условие появление |
Info | |
[Daemon]: daemon loop started | |
[Request]: IRCut On (on) | |
[Request]: IRCut On (off) | |
[Request]: IRCut Off (on) | |
[Request]: IRCut Off (off) | |
[Dbus]: dbus loop started | |
Warning | |
Device model is Goke v200 | |
Device model is Goke v300 | |
Device model is Hisilicon Ev200 | |
Method = %s | |
Error | |
[DBus]: not initiated | |
Unknown device model: %u | |
[DBus]: failed connect to bus | |
[DBus]: failed authorization | |
[DBus]: name %s already exists | |
[DBus]: failed create message | |
[DBus]: failed add data to message | |
[DBus]: failed get data from message: iter init failed | |
[DBus]: failed get data from message: message type is NOT string | |
[DBus]: failed get data from message | |
[DBus]: failed to create Dbus string message | |
[DBus]: failed create signal: %s | |
[DBus]: failed add data to message | |
[DBus]: failed to send signal: %s | |
[DBus]: limits exceeded | |
[DBus]: failed get reply message | |
[DBus]: failed create method reply message | |
[DBus]: failed add data to method reply message | |
[DBus]: failed send method reply message | |
Debug | |
Libiscom
Сообщение | Условие появление |
Info | |
%s: %s\n | |
Warning | |
Unknown dbus method: %s | |
DBUS_LIMITS_EXCEEDED: stopping %s | |
RTSP instance is already created | |
Can't get Session attribute from response | |
Error | |
[DBus]: failed connect to bus | |
[DBus]: failed authorization | |
[DBus]: name %s already exists | |
[DBus]: failed get data from message: iter init failed | |
[DBus]: failed get data from message: message type is NOT string | |
[DBus]: failed get data from message | |
[DBus]: failed to create Dbus string message | |
Ошибка создания контейнера dbus сообщения | |
Ошибка добавления параметров к dbus сообщению | |
Ошибка закрытия контейнера dbus сообщения | |
Ошибка создания D-Bus сообщения | |
Ошибка добавления JSON данных в D-Bus сообщение | |
Ошибка создания D-Bus сообщения | |
Ошибка добавления массива данных в D-Bus сообщение | |
[DBus]: failed create signal: %s | |
[DBus]: failed add data to message | |
[DBus]: failed to send signal: %s | |
Ошибка создания сигнала %s | |
Недостаточно памяти для отправки сигнала %s | |
[DBus]: failed create method reply message | |
[DBus]: failed add data to method reply message | |
[DBus]: failed send method reply message | |
[DBus]: failed create method reply message | |
[DBus]: failed add data to method reply message | |
[DBus]: failed send method reply message | |
Ошибка отправки D-Bus сообщения %s адресату %s: %s - %s | |
Ошибка отправки dbus сообщения %s адресату %s: %s, %s | |
[DBus]: failed get data from message: iter init failed | |
[DBus]: failed get data from message: message type is NOT string | |
DBUS_LIMITS_EXCEEDED: failed exec command (%s) | |
DBUS_LIMITS_EXCEEDED: unknown target (%s) | |
Parse url failed! | |
Create event base failed! | |
Create dns base failed! | |
Parse host failed! | |
Create evhttp connection failed! | |
Error create file (%s) | |
Can't write data in file (%s) | |
Failed to init curl | |
RTSP: OPTIONS %s - Authorization is required | |
failed to allocate memory size: %u | |
Failed to curl_easy_perform. Error: %s (CURLcode: %d) | |
Ошибка чтения параметра %s/%s из хранилища | |
Ошибка записи параметра в хранилище (%s/%s) | |
Не удалось получить из json данные о состоянии обновления | |
Не удалось распарсить поле %s | |
Ошибка освобождения отображённой памяти: %s (%d)\n | |
Ошибка открытия /dev/mem | |
Ошибка отображения файла в память: %s (%d) | |
Can't get camera chip id | |
Can't get mcu chip id | |
Calculate md5sum for camera chip id error! | |
Calculate md5sum for stm chip id error! | |
MakeSnapshotJson: can't get hostname | |
Debug | |
%s D-Bus %s.%s %s:", toDbus ? "To" : "From | |
%s D-Bus:", toDbus ? "To" : "From | |
Ошибка при получении ответа на dbus сообщение: %s | |
Get 0 bytes from D-Bus | |
(Inited) RTSP: OPTIONS %s | |
(Completed) RTSP: OPTIONS %s -> %d | |
(Inited) RTSP: DESCRIBE %s | |
(Completed) RTSP: DESCRIBE %s -> %d | |
(Inited) RTSP: PLAY %s | |
(Completed) RTSP: PLAY %s -> %d | |
(Inited) RTSP: TEARDOWN %s | |
(Completed) RTSP: TEARDOWN %s -> %d | |
Not compile pattern %s |
Proguard
Сообщение | Условие появление |
Info | |
[Config]: json parsed (%s) | |
Daemon started | |
Proguard started | |
Proguard stopped | |
[Request]: applications list | |
[Request]: status (%s) | |
[Request]: stop (%s) | |
[Request]: start (%s) | |
[Request]: restart (%s) | |
[Request]: enable (%s) | |
[Request]: disable (%s) | |
DBus loop started | |
[Process]: stop (%s) | |
[Process]: stopped (%s) | |
[Process]: start (%s) | |
[Process]: started (%s) | |
[Process]: enabled (%s) | |
[Process]: disabled (%s) | |
Warning | |
Daemon stopped | |
DBus loop stopped | |
Received signal (%d) | |
Error | |
[Config]: failed update config (%s) | |
Error scandir | |
[Config]: failed parse json (%s) | |
[2]: not initiated | |
[Process]: service not found (%s) | |
[Process]: failed exec command (%s) | |
[1]: not initiated | |
[Method]: \"%s\" not found | |
Debug | |
Uart
Сообщение | Условие появление |
Info | |
RFID Registers: %s | |
[Uart]: Запуск приложения | |
Start watchdog | |
Open UART AU socket | |
Create UART queue | |
[Uart]: Остановка приложения | |
Работа сети восстановлена. Восстанавливается режим открытых дверей | |
Start listener thread | |
UART is already running | |
UART port %s successfully opened! | |
Opening door by RFID %s, apartment %d | |
RFID %s, apartment %d, failed authorization by %d sector | |
SOS button press | |
Concierge button press | |
CMS handset call started for apartment %u | |
SOS button press, but the button is not assigned | |
Concierge button press, but the button is not assigned | |
CMS handset is not connected for apartment %u, aborting CMS call | |
Сall to a non-existent apartment %u | |
CMS handset talk started for apartment %u | |
CMS handset call done for apartment %u, handset is down | |
Door is opened by common code %u | |
Opening door by code %u, apartment %u | |
Common code %u is disabled | |
Got invalid code %u from MC | |
Opening door by RFID %s with \"Any key open\" feature | |
Intercom voltage is lower than 10 volts. Voltage = %f | |
External relay %u is opened by button press | |
Tamper alarm detected (%.2f) | |
The password for service codes has been entered. Selected: %s | |
Personal volume settings for the apartment %u have been overwritten | |
RFID %s, apartment %d, authorization with %d profile failed | |
RFID %s, apartment %d, no suitable profile was found | |
RFID %s, apartment %d, authorization with %d profile successed | |
RFID %s, apartment %d, open the door failed (flag openByError = 0) | |
RFID %s, apartment %d, %s (sector: %d, block: %d) | |
RFID %s, apartment %d, %s failed: the key was removed early | |
RFID %s, apartment %d, %s failed: %s (sector: %d) | |
RFID %s, apartment %d, mifare markup was uploaded | |
RFID %s, apartment %d, increment success:\"%d\" => \"%d\" (sector: %d, block: %d) | |
RFID %s, apartment %d, not free space for save state of sectors | |
openDoorLogStr[0] | |
openDoorLogStr[1] | |
%s opened by %s, UUID %s, flat %d | |
External relay %d is opened by %s, UUID %s, flat %d | |
Unknown door was open | |
UUID %s, flat %d, has no access to %s | |
UUID %s, flat %d has no access | |
RFID %s is not present in database | |
Превышено время ожидания. Выполняется перезагрузка. | |
Warning | |
[Ddns]: Получен сигнал \"%d\" | |
poll warning! | |
UART blocked | |
Get bad length in header: %u | |
Error | |
Ошибка отправки ответа в dbus | |
Ошибка формирования ответа в dbus | |
Ошибка создания ответа в dbus | |
UART.Timeout exceeded while awaiting dequeue. | |
Превышено время ожидания ответа на запрос %s | |
Ошибка создания сообщения об ошибке | |
Ошибка отправки сообщения об ошибке в dbus | |
Failed to check network state | |
Ошибка создания ответа со статусом sip усиления | |
Ошибка в работе стримера. Выполняется перезагрузка устройства | |
Ошибка в работе сети. Включается режим открытых дверей | |
Error: write to UART failed %s (%i) | |
Error %i from tcgetattr: %s | |
Unable to open %s. Error %i: %s | |
Couldn't set attributes to uart | |
Couldn't spawn uart thread | |
PREFIX: bad first: %02X | |
PREFIX: bad second: %02X | |
HEADER: bad receive: %02X | |
HEADER: bad receive | |
BUFFER: bad receive | |
CRC: bad receive | |
Debug | |
MethodCall error: dbus msg buf len=%d, request command buf len = %d | |
TTY >> UART: Send command %s (Hex:0x%x|Dec:%i) | |
UART >> TTY: Receive command %s (Hex:0x%x|Dec:%i). %s | |
CRC: cb: [%04X] ce: [%04X] (lr: %d lb: %d) hsize: %d header: [%02X %02X] - bad | |
Send new UART message to callback: hsize %d, id %d, num %d, cm_id %d. m.bufLen %d | |
Start upgrade watchdog | |
Stop upgrade watchdog | |
Upgrade WDT: %s seconds passed |
Upgrade
Сообщение | Условие появление |
Info | |
Warning | |
Отправка команды на перезагрузку | |
Error | |
Обновление остановлено | |
Ошибка обновления MCU | |
Не удалось записать файл | |
Ошибка открытия файла %s | |
Error calculate crc for type addr | |
Crc data = %x, crc calculate = %x | |
High addr = %x, low addr = %x | |
Устройство с версией платы %d.%d не поддерживает обновление загрузчика | |
Прошивка не была загружена в память MCU. Продолжение обновления невозможно | |
Проверка подлинности не пройдена | |
Не удалось получить текущую разметку камеры | |
Не удалось установить актуальную разметку для камеры | |
Не указан раздел MCU | |
Ошибка при загрузке прошивки в память MCU | |
%s | |
Debug | |
File save as = %s | |
EEPROM_ADDR_FIRMWARE = %x | |
EEPROM_ADDR_FIRMWARE --------------- %x | |
num : %d | |
Ошибка записи страницы - #%d | |
HW major версия = %u | |
Удаление %s | |
Find keys: %s | |
Ошибка при верификации по ключу %s | |
Пройдена верификация по ключу %s | |
Path on server = %s | |
Path on device = %s | |
CreateFilePath: path = %s | |
Значение разметки не задано, будет использовано стандартное для конкретной модели камеры | |
Path for update file: %s | |
Приложение %s не запущено | |
Приложение %s уже запущено |