Подсистема "Дополнительные регламентные задания" для "Управления торговлей 10.3"




Принцип обмена данными из 1С с сайтом (на MySQL) и выдачи (публикации) этих данных по запросу.
PHP-Скрипт автоматической загрузки данных из файла данных в формате CSV в базу данных сайта работающего на WordPress.

В продолжение моей темы: 1С:Альфа-Авто Автосалон Автосервис: обмен с сайтом.
С помощью данного скрипта можно загружать в автоматическом режиме, по расписанию, данные сервисных книжек (ремонтов авто) из 1С:Альфа-Авто Автосалон Автосервис.
Также можно загружать данные в ручном режиме: для этого делается скрытая страница, где размещается специальная кнопка.
Комментарии размещенные внутри скрипта разъяснят логику и порядок действия.
Комментарии с "/////    echo" использовались для отладки.
Дополнительно создана таблица для журналирования результатов загрузки данных.
Скрипт включает в себя защиту от SQL инъекций (думаю безопасность соблюдена в полной мере).
В кратце:
1. Пишется скрипт, который запускает этот.
2. Создается регламентное задание в WordPress, по которому запускается скрипт из п.1. 
3. Этот скрипт осуществляет проверку на существование файла обмена в папке.
4. Если данные не новые, загрузка не производится.
5. Если данные новые, очищается таблица сервисных книжек.
6. Загружаются новые данные.

Собственно сам скрипт:

<?php // Полная загрузка сервисных книжек, создан 2024-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='\

29 Comments

  1. Поручик

    Разработана ещё в прошлом году по просьбе уже бывшего руководителя для снятия просроченных резервов.

    Тема просроченных резервов недавно обсуждалась на другом форуме, решил вывалить своё решение.

    Reply
  2. iov

    а авансы учитываются? а авансы возникшие в результате возвратов?

    а как будет если у клиента положительный баланс +100 р. и два заказа по 500 000 ведь +100 это положительный баланс и соответственно один из заказов должен «выжить». как поступает в таком случае?

    итак комментарии есть (0) (2) ждем развития..

    Reply
  3. iov

    P.S. Вещь вообще то нужная но мало «галочек и кнопочек» 🙂

    Reply
  4. Поручик

    >>>но мало «галочек и кнопочек» но мало «галочек и кнопочек»

    Не то что мало, их вообще нет. Есть куда двигаться.

    Задача была простая: есть заказ, есть резерв, предоплаты в течение определённого в договоре срока нет, заказ закрывается, резерв снимается. Все довольны, ничего ручками делать не надо.

    Reply
  5. Restore6

    здрасте.установил я вашу прогу.сформировал заказ,образовался резерв,в договоре конртагента указан 1 день без оплаты.прошло 2 суток.я так понимаю должен был создаться документ закрытия заказов и снять с резерва товар.Но ничего не произошло!может я что то не учел, в чем причина? ❓

    Reply
  6. Поручик

    (8)

    1. База клиент-серверная? Если да, переходим к следующему пункту, если нет, прервать.

    2. Фоновое задание отработало? Если да, посмотреть журнал регистрации, как отработало.

    3. Посмотреть расписание регламентного задания.

    4. Посмотреть, что у вас по регистру РасчетыСКонтрагентами по данному заказу.

    Reply
  7. Поручик

    Кстати говоря, приму советы по хранению настроек. В двух других аналогичных работах я использовал регистр СохраненныеНастройки, но мне кажется это не совсем удачное решение, хоть те проекты благополучно работают. Добавлять новый регистр или справочник? Стоит ли огород городить, плодить сущности?

    ps И ещё не слышу комментов типа: нах проведение по партиям, это же было в ранних релизах УТ, а потом убрали 👿 😀

    Reply
  8. iov

    (7) а как еще то ? надо «брать » пока тепленький…. А то потом энтузиазм угаснет или кто-то в каментах насрет..

    P.S. http://infostart.ru/community/groups/14/blog/1050/?commentId=883#883 Вот место и время для обсуждения 1С.

    Reply
  9. volga1

    Получилось закрытие заказов и в файловом варианте. ❗

    Поручик спасибо за идею и открытый код. +

    Reply
  10. volga1

    PS Получилось заказ покупателя.

    Reply
  11. Поручик

    Ах, да, процесс для регламентных заданий, пользователь для выполнения и вообще эмуляция работы фоновых заданий в файловом варианте.

    Грустно всё это а посему никогда не пользуюсь.

    Reply
  12. Поручик

    Так, сделаю типа закладки:

    — дополнительные настройки

    — календарь.

    зы Код у моих работ всегда открыт. Критика и предложения по коду воспринимаются адекватно при наличии адекватно-конструктивной критики.

    Reply
  13. volga1

    14. в модуле приложения при начале работы ссылка на модуль с процедурами, тормозов нету, все закрывает как надо, тока без регламентных и чють код изменил.

    Reply
  14. kvp

    Спасибо. Включила в свою конфигурацию Закрытие заказов. Все отлично работает. Но проведение по партиям включать в фоновом режиме не стала, у нас распределенка, файл для периферии может получится немыслимых размеров + можем потерять изменения в периферии (если у них были исправления в старых документах).

    Reply
  15. Поручик

    Я уж думал, она никому не нужна.

    Reply
  16. kvp

    (18) Плюс я уже раньше ставила, второй не берет

    Reply
  17. esoldatov

    Интересная разработка, сейчас попробую реализовать ее работу в нашей базе, и поскольку база типовая, думаю особых проблем не должно быть… по результату отпишусь и конечно плюсану 🙂

    Reply
  18. mvgfirst

    Проведение по партиям, есть такая обработка в УТ 10.3, у нее есть режим «Останавливаться при ошибках…»

    Так вот, я саму разработку не качал, но хотел узнать — учитывает ли ваша разработка этот параметр, и если учитывает то как происходит устранение ошибок?!

    Сам задумался над созданием подобного (резервы и так уже закрывают регламентным заданием) на очереди партии…

    Я мыслил себет так: два регламетных задания, одно «дневное» запускается каждые 5-10 минут, пытается провести малую порцию документов (не более 100); второе задание «ночное» запускается один раз вечером (после того как сотрудники заканчивают работу) и работает всю ночь и уже перепроводит все документы сколько успеет. Утром «ночное» задание должно быть прекращено.

    Таким образом восстановление партий идет без остановочно и практически всегда должно быть в актуальном состоянии — кроме тех случаев когда кто-то закинет последовательность на год или два года назад.

    Единсвенно что, пока не придумал как выдавать пользователям сообщение о том что в процессе востановления возникла ошибка требущая устранения пользоватлем (как правило нехватка товара на складе по партям)

    Reply
  19. Поручик

    (21) Эта обработка не моя, а та самая штатная. Когда-то, в ранних релизах управление торговлей 10.3 было такое регламентное задание, а потом его выбросили из конфы по каким-то причинам. Я всего лишь вернул его обратно.

    Reply
  20. mvgfirst

    (22)

    Когда-то, в ранних релизах управление торговлей 10.3 было такое регламентное задание, а потом его выбросили из конфы по каким-то причинам. Я всего лишь вернул его обратно.

    Т.е. никаких изменений? Ну а все-таки «та самая» обработка как это делала — я к сожалению к УТ10.3 добрался уже после того как было выкинуто задание и посмотреть как она работает — возможности нет. В двух словах можно описать принцип действия восстановления партий? Останавливается ли на ошибках по недостаче товара? Блокирует ли работу пользователей (выпадает как правило сообщение о блокировках)

    Reply
  21. Поручик

    (23) Какой возможности нет? Вы о чём?

    Откройте уже самостоятельно Проведение по партиям и гляньте. Документы -> Дополнительно.

    Reply
  22. mvgfirst

    (24) вы писали

    в ранних релизах управление торговлей 10.3 было такое регламентное задание, а потом его выбросили из конфы

    так вот в моей конфе нет регламентного задания по восстановлению партий, поэтому и хотел узнать какие принципы у него были ранее. А если точнее останавливался ли он по ошибкам отсутствия товара и создавал ли препятствия в работе пользователей создавая блокировки.

    Reply
  23. volga1

    (25) mvgfirst,

    Можно как хочешь, останавливаться при ошибках, писать в лог Файл(я так делал, работает вечером после рабочего дня в регламентном задании в файловом варианте и лог можно почитать затем исправить ошибки — руками)

    Reply
  24. mvgfirst

    (26) volga1,

    Можно как хочешь, останавливаться при ошибках, писать в лог Файл(я так делал, работает вечером после рабочего дня в регламентном задании в файловом варианте и лог можно почитать затем исправить ошибки — руками)

    Если очень захотеть — можно в космосо полететь! Это я понимаю, меня интересует делает ли это обработка, или потребуется допрограммирование своих желаний?

    Reply
  25. Поручик

    (27) Вывались из темы. Второй день не можешь открыть матчасть, посмотреть и прогнать по базе. Тестовой.

    Reply
  26. demidd

    Отличная вещь, именно то что я искал! Вам +. Но вот только не обратил внимание на то, что для платформы 8.1. Планируете сделать для 8.2?

    Reply
  27. Поручик

    (29) 600 рублей на счёт в сбербанке и сделаю вам для 8.2.

    Reply
  28. demidd

    А в файловом варианте будет на 8.2 работать?

    Reply
  29. Поручик

    (31) Тему сверху вниз прочитайте.

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *