<?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-5 можно удалить и все оказывается чуть проще:
— добавляем свой документ в типы общей команды «ПрисоединенныеФайлыБП», определяемых типов «ВладелецПрисоединенныхФайлов» и «Присоединенный файл»;
— копируем любой справочник «хххПрисоединенныеФайлы», изменяем имя и синоним, затем меняем тип реквизита «ВладелецФайла» на наш документ;
— смотрим кинчик/наливаем чай пока происходит реструктуризация;
— с удовлетворением созерцаем кнопку на панели команд нужного документа, закрываем 1С и идем домой с чувством выполненного долга =)
а мне вот интересно, если после обновления
вот эта вод часть затрется, данные будут утеряны? или после того, как типы нетипового документа будут добавлены все вернется на место?
(6)
если верить итс еще надо добавлять в ПрисоединенныйФайлОбъект и в подписку УстановитьПометкуУдаленияПрисоединенныхФайлов (если объект пометят на удаление, то и файлы все пометятся)
(8) Да, все верно, поторопился)
Так правильно:
— добавляем свой документ в типы общей команды «ПрисоединенныеФайлыБП» и определяемого типа «ВладелецПрисоединенныхФайлов»;
— копируем любой справочник «хххПрисоединенныеФайлы», изменяем имя и синоним, добавляем его в определяемые типы «ПрисоединенныйФайл» и «ПрисоединенныйФайлОбъект» и «ВладелецПрисоединенныхФайловОбъект» и меняем тип реквизита «ВладелецФайла» на наш документ;