<?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='\
Разработана ещё в прошлом году по просьбе уже бывшего руководителя для снятия просроченных резервов.
Тема просроченных резервов недавно обсуждалась на другом форуме, решил вывалить своё решение.
а авансы учитываются? а авансы возникшие в результате возвратов?
а как будет если у клиента положительный баланс +100 р. и два заказа по 500 000 ведь +100 это положительный баланс и соответственно один из заказов должен «выжить». как поступает в таком случае?
итак комментарии есть (0) (2) ждем развития..
P.S. Вещь вообще то нужная но мало «галочек и кнопочек» 🙂
>>>но мало «галочек и кнопочек» но мало «галочек и кнопочек»
Не то что мало, их вообще нет. Есть куда двигаться.
Задача была простая: есть заказ, есть резерв, предоплаты в течение определённого в договоре срока нет, заказ закрывается, резерв снимается. Все довольны, ничего ручками делать не надо.
здрасте.установил я вашу прогу.сформировал заказ,образовался резерв,в договоре конртагента указан 1 день без оплаты.прошло 2 суток.я так понимаю должен был создаться документ закрытия заказов и снять с резерва товар.Но ничего не произошло!может я что то не учел, в чем причина? ❓
(8)
1. База клиент-серверная? Если да, переходим к следующему пункту, если нет, прервать.
2. Фоновое задание отработало? Если да, посмотреть журнал регистрации, как отработало.
3. Посмотреть расписание регламентного задания.
4. Посмотреть, что у вас по регистру РасчетыСКонтрагентами по данному заказу.
Кстати говоря, приму советы по хранению настроек. В двух других аналогичных работах я использовал регистр СохраненныеНастройки, но мне кажется это не совсем удачное решение, хоть те проекты благополучно работают. Добавлять новый регистр или справочник? Стоит ли огород городить, плодить сущности?
ps И ещё не слышу комментов типа: нах проведение по партиям, это же было в ранних релизах УТ, а потом убрали 👿 😀
(7) а как еще то ? надо «брать » пока тепленький…. А то потом энтузиазм угаснет или кто-то в каментах насрет..
http://infostart.ru/community/groups/14/blog/1050/?commentId=883#883 Вот место и время для обсуждения 1С.
P.S.
Получилось закрытие заказов и в файловом варианте. ❗
Поручик спасибо за идею и открытый код. +
PS Получилось заказ покупателя.
Ах, да, процесс для регламентных заданий, пользователь для выполнения и вообще эмуляция работы фоновых заданий в файловом варианте.
Грустно всё это а посему никогда не пользуюсь.
Так, сделаю типа закладки:
— дополнительные настройки
— календарь.
зы Код у моих работ всегда открыт. Критика и предложения по коду воспринимаются адекватно при наличии адекватно-конструктивной критики.
14. в модуле приложения при начале работы ссылка на модуль с процедурами, тормозов нету, все закрывает как надо, тока без регламентных и чють код изменил.
Спасибо. Включила в свою конфигурацию Закрытие заказов. Все отлично работает. Но проведение по партиям включать в фоновом режиме не стала, у нас распределенка, файл для периферии может получится немыслимых размеров + можем потерять изменения в периферии (если у них были исправления в старых документах).
Я уж думал, она никому не нужна.
(18) Плюс я уже раньше ставила, второй не берет
Интересная разработка, сейчас попробую реализовать ее работу в нашей базе, и поскольку база типовая, думаю особых проблем не должно быть… по результату отпишусь и конечно плюсану 🙂
Проведение по партиям, есть такая обработка в УТ 10.3, у нее есть режим «Останавливаться при ошибках…»
Так вот, я саму разработку не качал, но хотел узнать — учитывает ли ваша разработка этот параметр, и если учитывает то как происходит устранение ошибок?!
Сам задумался над созданием подобного (резервы и так уже закрывают регламентным заданием) на очереди партии…
Я мыслил себет так: два регламетных задания, одно «дневное» запускается каждые 5-10 минут, пытается провести малую порцию документов (не более 100); второе задание «ночное» запускается один раз вечером (после того как сотрудники заканчивают работу) и работает всю ночь и уже перепроводит все документы сколько успеет. Утром «ночное» задание должно быть прекращено.
Таким образом восстановление партий идет без остановочно и практически всегда должно быть в актуальном состоянии — кроме тех случаев когда кто-то закинет последовательность на год или два года назад.
Единсвенно что, пока не придумал как выдавать пользователям сообщение о том что в процессе востановления возникла ошибка требущая устранения пользоватлем (как правило нехватка товара на складе по партям)
(21) Эта обработка не моя, а та самая штатная. Когда-то, в ранних релизах управление торговлей 10.3 было такое регламентное задание, а потом его выбросили из конфы по каким-то причинам. Я всего лишь вернул его обратно.
(22)
Т.е. никаких изменений? Ну а все-таки «та самая» обработка как это делала — я к сожалению к УТ10.3 добрался уже после того как было выкинуто задание и посмотреть как она работает — возможности нет. В двух словах можно описать принцип действия восстановления партий? Останавливается ли на ошибках по недостаче товара? Блокирует ли работу пользователей (выпадает как правило сообщение о блокировках)
(23) Какой возможности нет? Вы о чём?
Откройте уже самостоятельно Проведение по партиям и гляньте. Документы -> Дополнительно.
(24) вы писали
так вот в моей конфе нет регламентного задания по восстановлению партий, поэтому и хотел узнать какие принципы у него были ранее. А если точнее останавливался ли он по ошибкам отсутствия товара и создавал ли препятствия в работе пользователей создавая блокировки.
(25) mvgfirst,
Можно как хочешь, останавливаться при ошибках, писать в лог Файл(я так делал, работает вечером после рабочего дня в регламентном задании в файловом варианте и лог можно почитать затем исправить ошибки — руками)
(26) volga1,
Если очень захотеть — можно в космосо полететь! Это я понимаю, меня интересует делает ли это обработка, или потребуется допрограммирование своих желаний?
(27) Вывались из темы. Второй день не можешь открыть матчасть, посмотреть и прогнать по базе. Тестовой.
Отличная вещь, именно то что я искал! Вам +. Но вот только не обратил внимание на то, что для платформы 8.1. Планируете сделать для 8.2?
(29) 600 рублей на счёт в сбербанке и сделаю вам для 8.2.
А в файловом варианте будет на 8.2 работать?
(31) Тему сверху вниз прочитайте.