CatalogFill - Загрузка XML из 1С

Всем добрый день. Купил модуль CatalogFill. разобрался с загрузкой из Excel. Все супер, автору программы огромное спасибо.
Но вот возникла потребность загрузки из XML:

Вот часть конфига связанного с настройкой XML импорта:

<?php

//Название класса таблицы товаров в БД
$cf_config['className'] = 'ShopContent';
//Название пакета таблицы товаров в БД
$cf_config['packageName'] = 'shop';
//Название поля ID родителя
$cf_config['parent_field'] = 'resource_id';

//разбивка по столбцам при импорте и экспорте (content|tv|category)
/*$cf_config['content_row'] = array(
    array('Код',array('articul','content')),
    array('Категория',array(2,'category')),//3 - ID шаблона категории
    array('Подкатегория',array(3,'category')),//3 - ID шаблона подкатегории
    array('Наименование',array('pagetitle','content')),
    array('Описание',array('content','content')),
    array('Цена',array('price','content')),
    array('Ед. имз',array('unit','content')),
    array('Количество',array('quantity','content')),
    array('Уценка',array('ucenka','content'))
    
  );
*/
//значения по умолчанию при импорте или проверка при экспорте
$cf_config['imp_content_default'] = array(
    'content' => array(
        'deleted' => 0,
        'published' => 1,
        'template' => 3  //Шаблон для карточки товара
        //'createdon' => strtotime("now")
        //'publishedon' => strtotime("now")
        //'pub_date' => strtotime("now")
        //'editedby' => 1
        //'editedon' => strtotime("now")
    ),
    'tv' => array(
        //7 => 0
    )
);

//первая строка - названия полей
$cf_config['include_captions'] = true;

//число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
$cf_config['batch_import'] = 300;

//разбивать по категориям
$cf_config['include_categories'] = false;

//удалять дочерние категории при очистке и обновлении каталога
$cf_config['delete_subcategories'] = true;

//по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
$cf_config['imp_chk_field'] = 'articul';

//проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
$cf_config['imp_chk_tvid_val'] = false;

//Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
$cf_config['imp_if_not_exist'] = true;

//удалять HTML-теги при экспорте
$cf_config['exp_strip_tags'] = false;

//автоматически генерировать псевдоним (alias) при импорте
//false - выключено; true - генерировать с переводом в транслит; 'notranslit' - генерировать без перевода в транслит.
$cf_config['imp_autoalias'] = true;

//Изменить значения поля для всех вложенных товаров до начала импорта.
//Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
//первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
$cf_config['imp_before_change'] = false;//'[{"tv.inventory":0},{}]';//'[{"published":0},{"tv.pricename":"Поставщик1"}]';//false - для отмены

//удалить файл после экспорта (скачивания)
$cf_config['exp_delete_file'] = false;

//кодировка CSV-файла при экспорте
$cf_config['exp_csv_charset'] = 'UTF-8'; //'windows-1251'

//Импортировать (обновлять) пустые значения
$cf_config['imp_empty'] = true;

//Имя файла процессора, который использовать для импорта. Если пусто, используется стандартный процессор "import".
$cf_config['imp_custom_processor'] = '';

//путь (xpath) в XML структуре до товаров
$cf_config['imp_xml_itemsparent_path'] = '/Каталог/Товары';

//Структура XML файла для импорта
$cf_config['imp_xml_structure'] = <<<EOF
<Товар>
				
				<Артикул>articul</Артикул>
				<Наименование>pagetitle</Наименование>
			   <Описание>content</Описание>
				
</Товар>
EOF;

//тестирование конфигурации (без записи в БД). Отчёты -> Журнал ошибок.
$cf_config['imp_testmode'] = TRUE;

//функция для фильтрации значений при ИМПОРТЕ
function filter_import($value_arr){
    $output_arr = $value_arr;
   // $output_arr['content']['image'] = NULL;
  /*  if(isset($output_arr['content']['pagetitle']))
        $output_arr['content']['image'] = $output_arr['content']['sortindex'];
    */
    
    return $output_arr;
}


//функция для фильтрации значений при ЭКСПОРТЕ
function filter_export($value_arr,$doc_id=0){
    $output_arr = $value_arr;
    //var_dump($value_arr,$output_arr);
    //exit;
    /*
    if(isset($output_arr['price']))
        $output_arr[1] = floatval($output_arr[1]) - 200;
    */
    return $output_arr;
}


?>

Вот сама XML:

<?xml version="1.0" encoding="UTF-8"?>
<КоммерческаяИнформация xmlns="urn:1C.ru:commerceml_2" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ВерсияСхемы="2.07" ДатаФормирования="2016-06-07T17:12:18">
	<Каталог>
		<Товары>
			<Товар>
				<Артикул>48477</Артикул>
				<Наименование>Заготовка - брусок  4х 4х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
				<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
								
			</Товар>
			<Товар>
			
				<Артикул>48499</Артикул>
				<Наименование>Заготовка - брусок  5х 5х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
				<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
			
			</Товар>
			<Товар>
			
				<Артикул>48333</Артикул>
				<Наименование>Заготовка - брусок  5х</Наименование>
				<Описание>Применяется для изготовления резцов.</Описание>
			
			</Товар>
		</Товары>
	</Каталог>
</КоммерческаяИнформация>

При загрузке вываливаю вот такие ошибки:

[2016-06-09 14:12:16] (ERROR @ /var/www/seovolga/data/www/b.seovolga.ru/core/components/catalogfill/model/catalogfill.class.php : 1503) PHP warning: Invalid argument supplied for foreach()

Подскажите пожалуйста что я делаю не так?

Первое что мне бросилось в глаза

<Артикул>articul</Артикул>

в modx нет поля articul
Если нужно чтобы артикул попал в доп поле (В документации про это написано)

<Options>
        <Stock>tv5</Stock>
        <Image>tv2</Image>
    </Options>

Сам я из xml не выгружал, но еще вложенность может неверно указал

$cf_config['imp_xml_itemsparent_path'] = '/Каталог/Товары';

Добавь КоммерческаяИнформация/Каталог/Товары

У меня таблица MIGX, поле артикул я создал, причем загрузка из XLS прекрасно работает.
Пробывал добавить -> КоммерческаяИнформация:

$cf_config['imp_xml_itemsparent_path'] = '/КоммерческаяИнформация/Каталог/Товары';

тоже не работает, та же самая ошибка

Я думаю причина в том, что xpath не работает с русским текстом. Вряд ли разработчики библиотеки SimpleXML на такое рассчитывали.

Но если вы в конфиге сделаете так:

$cf_config['imp_xml_itemsparent_path'] = '';

А в XML так:

<Товары>
	<Товар>
		<Артикул>48477</Артикул>
		<Наименование>Заготовка - брусок  4х 4х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
		<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>			
	</Товар>
	<Товар>
		<Артикул>48499</Артикул>
		<Наименование>Заготовка - брусок  5х 5х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
		<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
	</Товар>
	<Товар>
		<Артикул>48333</Артикул>
		<Наименование>Заготовка - брусок  5х</Наименование>
		<Описание>Применяется для изготовления резцов.</Описание>
	</Товар>
</Товары>

скорее всего сработает.

Похоже, подключение к Форум | MODX Shopkeeper было разорвано, подождите, пока мы пытаемся восстановить соединение.