<?php // Полная загрузка сервисных книжек, создан 2025-01-05 12:44:55
global $wpdb2;
global $failure;
global $file_hist;
///// echo '<H2><b>Старт загрузки</b></H2><br>';
$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
///// echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}
$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
///// echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}
/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
///// echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
///// echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist); ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7]; ////получаем размер файла
$m_mtime_file=$masiv_data_file[9]; ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file
///// echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
///// echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
///// echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);
if ($results)
{ foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));
////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
///// echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
///// echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}
////загружаем данные
$table='vin_history'; // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация // (путь от корня web-сервера)
$delim=';'; // Разделитель полей в CSV файле
$enclosed='"'; // Кавычки для содержимого полей
$escaped='\
Расцеловал бы но монитор давно не мыл 🙂
(1) 😀 😀 😀
radmin бы к нему прикрутить
(3) Это еще как?
(4)Щелкнул на пользователе и его комп открылся в радмине
Приделал бы сохранение последнего пути (путей) в ini-файле — вообще бы классно было
P.S. И иконку какую-нибудь приличную прикомпили, а то досовский значок — не комильфо.
Пришлось ресхакером править;)
(6) Как раз над этим работаю
Нормалек! Красиво смотрится! 😉
(8) Спасибо! 🙂
+ однозначно.
Неплохо! Хорошо бы добавить несколько фишек типа,… отключить пользователя, послать сообщение и т.п.
Зачем сообщения?
Гаджетом оформить! ))
Обновление данных не происходит(последний пользователь висит).
(13) Какая конфигурация, платформа? Путь указывался после запуска или выбирался из списка? Подробнее можно?
(14) у меня в Комплексной , редакция 1.0 (1.0.7.1) — последний пользователь остается «висеть». Платформа 8.1.15.14
(15) Ты выбираешь при этом другую базу или просто все пользователи реально выходят из базы, а в мониторе один остается висеть?
(16) Все пользователи реально выходят из базы, а один остается в «Мониторе 8х»
(17) Ок. Посмотрю, поправлю
(17) Готово!
загоняться
(20) ОК 😀
полезняшка! (+)
Вот блин, обидно, и монитор у меня тоже (как и taskmanager) ошибку выдает. Может, криво встал NF 3.5. Попробую на другой машине 😥
Есть один баг такого плана: если пользователь работал в 1С и потом его «выкинуло» из проги, а затем он заходин вновь, то в Мониторе отображатся уже 2 раза. И так по прогресии «выкидонов» записей может быть несколько. Может сделать кнопку обновить или возможность удалять старые записи «бывших активистов». А их можно отследить по времени входа. Последний есть активный.
(24) Надо продумать этот момент
Запущенный Monitor 8.x server на локальных машинах не отображается в Monitor8x.
Из сети сервер не запускается, пишет ошибка приложения.
А вопрос (24) получил уже решение?
Спасибо
(27) Пока нет
Замечательная весчь! Более 1,5 лет доставляет удовольствие. Запускается с локалки, показывает всех пользователей в сети в 8.1 и 8.2.Рекомендую.
больше понраилась обработка [Tray1C] Сворачивание 1С в системный трей. Мне показалось она проще
(30) А причем тут Tray1C? 🙂
Добрый день! А для версии 8.3 планируется доработка?
(32) Здравствуйте! Постараюсь реализовать
Красиво! А для версии 8.3 планируется доработка?
(34) К сожалению, нет на это времени.