Как создавать опции msync из списка?

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

Что пытался:
1) Через newObject но он вообще не находит объект опции, схему смотрел класс копировал. Пытался через $xpdo-> а так же $modx
$newMsPr = $xpdo->newObject('mSyncProductProperty');
$newMsPr->set('source', 'ТЕСТПРИКОЛ');
$newMsPr->set('type', 1);
$newMsPr->set('target', 'testprikol');
$newMsPr->set('active', 1);
$newMsPr->set('default', 0);
$newMsPr->set('is_multiple', 0);
$newMsPr->set('is_primary', 0);
$newMsPr->save();
2) Пытался с эмулировать запрос. Но получал лишь 401 ошибку. Выполнял в косноли
<?php
    
function transliteCyrilic($value){
    $converter = array(
        'а' => 'a',    'б' => 'b',    'в' => 'v',    'г' => 'g',    'д' => 'd',
        'е' => 'e',    'ё' => 'e',    'ж' => 'zh',   'з' => 'z',    'и' => 'i',
        'й' => 'y',    'к' => 'k',    'л' => 'l',    'м' => 'm',    'н' => 'n',
        'о' => 'o',    'п' => 'p',    'р' => 'r',    'с' => 's',    'т' => 't',
        'у' => 'u',    'ф' => 'f',    'х' => 'h',    'ц' => 'c',    'ч' => 'ch',
        'ш' => 'sh',   'щ' => 'sch',  'ь' => '',     'ы' => 'y',    'ъ' => '',
        'э' => 'e',    'ю' => 'yu',   'я' => 'ya',
    );
 
    $value = mb_strtolower($value);
    $value = strtr($value, $converter);
    $value = mb_ereg_replace('[^-0-9a-z]', '_', $value);
    $value = mb_ereg_replace('[-]+', '_', $value);
    $value = trim($value, '_'); 
 
    return $value;
}


$chars = array("Объем, л", "Номенклатура");

$translated_arr = array();

$createUrl = 'https://example.com/assets/components/msync/connector.php/';
foreach ($chars as $char) {
        
        $params = array(
            'action' => 'mgr/property/create',
            'id' => '',
            'default' => '',
            'source' => $char,
            'type' => 1,
            'target' => transliteCyrilic($char),
            'is_multiple' => 0,
            'is_primary' => 0,
            'active' => 1
        );
   
        $myCurl = curl_init();
        curl_setopt_array($myCurl, array(
            CURLOPT_URL => $createUrl,
            CURLOPT_RETURNTRANSFER => true,
            CURLOPT_POST => true,
            CURLOPT_POSTFIELDS => http_build_query($params)
        ));
        $response = curl_exec($myCurl);
        echo var_dump($response);
        die();
        curl_close($myCurl);    
    
}

die();
3) Сделал это всё на питоне, там авторизовывался в адмнке, но так же 401 ошибка.
import re
from requests import Session

LOGIN_CONTEXT = "mgr"
RETURN_URL = "/manager/"
USERNAME = "ashdjkashldkfjhasldf"
PASSWORD = "sadkfas;lkdjfh;lasd"
LOGIN_URL = "https://example/manager/"


msync_coonector = 'https://example/assets/components/msync/connector.php/'


def main():
	chars = {"Объем, л":"obem__l","Номенклатура":"nomenklatura"}

	with Session() as session:
		req = session.post(LOGIN_URL, data={"login_context": LOGIN_CONTEXT , 'returnUrl': RETURN_URL, 'username': USERNAME, 'password': PASSWORD, 'login': "1"})

		for char_key, char_value in chars.items():
			send_params = {
				'action': 'mgr/property/create',
				'id': '',
				'default': '',
				'source': char_key,
				'type': 1,
				'target': char_value,
				'is_multiple': 0,
				'is_primary': 0,
				'active': 1			
			}
			
			create_property = session.post(msync_coonector, data=send_params, timeout=60)

			print(create_property.text)


if __name__ == '__main__':
	main()
4) Пытался прям на месте через повторить запрос создания опции через chrome tools, но даже там получил ошибку 401, уверен что это из-за mod http auth
Vladimir
17 января 2023, 14:07
modx.pro
647
0

Babel ошибка 404

Всем здравствуйте!

Установил Babel, открываю связанные страницы (даже из админки), и получаю 404 ошибку…
Страницы опубликованы
Делал по инструкции:

Вот мой .htaccess

RewriteEngine On
RewriteBase /

# Rewrite www.domain.com -> domain.com -- used with SEO Strict URLs plugin
RewriteCond %{HTTP_HOST} .
RewriteCond %{HTTP_HOST} ^www.(.*)$ [NC]
RewriteRule ^(.*)$ https://%1/$1 [R=301,L]


RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(ru|en)/favicon.ico$ favicon.ico [L,QSA]

RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(ru|en)/assets(.*)$ assets$2 [L,QSA]

RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(ru|en)?/?(.*)$ index.php?cultureKey=$1&q=$2 [L,QSA]
В чем могут быть грабли?
Спасибо заранее!
Антон
17 января 2023, 01:10
modx.pro
556
0

Добавить в Tikets возможность создавать вопросы неавторизованным пользователям

14
Приветствую.

В Tickets есть возможность комментировать тикеты неавторизованным пользователям. Для этого в настройках TicketComments надо задать значение 1 в параметре allowGuest. После этого появляются два поля (автор и почта) и можно внести в них данные и откомментировать. А вот задавать вопрос, т. е. создавать тикет неавторизованный пользователь не может. Надо эту ситуацию исправить и сделать возможным задавать вопросы неавторизованным пользователям.
weranda
16 января 2023, 09:50
modx.pro
457
0

Залить json в структуру modx

100 000
Добрый. Нужно распарсить json в структуру modx, создать ресурсы. В json архив описаний: год, автор, текст к ретрофоткам и папка непосредственно с фотографиями. Пишите t.me/shorohi
infora
14 января 2023, 22:48
modx.pro
420
0

Как реализовать замену document.write в сниппете

Подскажите пожалуйста, как можно заменить метод document.write в данном примере
<script type="text/javascript">
			cityFields = {
				actionUrl: "'.$cityFields->config['actionUrl'].'",
				cityInDomain: '.($cityFields->cityInDomain?'true,
				mainHost: "'.$hostASCII.'"':'false').'
			};
			typeof jQuery == "function" || document.write("<script type=\"text/javascript\" src=\"' . $cityFields->config['jsUrl'] . 'web/jquery.min.js\"><\/script>");
</script>
Диман
13 января 2023, 21:36
modx.pro
694
0

Какие альтернативы есть модулю Tickets?

Приветствую.
Какие вы знаете альтернативы модулю Tickets?
weranda
13 января 2023, 10:15
modx.pro
589
0

Почему я не могу сохранить данные в 2 новых поля при создании заказа?

При создании заказа, в два поля добавляются данные, но получается так что у меня добавляются и сохраняются дданые лишь в последний стоящий в коде, а не в оба. Все данные работают, если всё пробовать в консоли всё великолепно работает.

$msOrder->set('myfield', $fielddata);
            $msOrder->set('myfield2', $fielddata2);
            $msOrder->save();
Пытался и так
$msOrder->set('myfield', $fielddata);
             $msOrder->save();
            $msOrder->set('myfield2', $fielddata2);
            $msOrder->save();
И разделял даже плагины на отдельные куски, то есть в каждом плагине было по 1 сохранению, но всё так же заполняется только последний, хотя данные для обоих.
Vladimir
13 января 2023, 08:57
modx.pro
449
0

Как вывести в лог списки, json объекты, в место всего получаю либо пустоту либо 1, как исправить?

При попытки вывести в лог получаю просто пустоту, хотя объект есть, ошибок нет.
$modx->log(modX::LOG_LEVEL_ERROR, 'ORG');
$modx->log(modX::LOG_LEVEL_ERROR, $dt['invoiceId']);
$modx->log(modX::LOG_LEVEL_ERROR, $_POST);
$modx->log(modX::LOG_LEVEL_ERROR, print_r($dt));
Пытался через
var_dump
через
print_r
Никак не получается, что я делаю не так?
Vladimir
13 января 2023, 07:41
modx.pro
527
0

Как через pdoField вывести глобальные параметры контекста

Вывожу все ресурсы что лежат в контекстах, используя

[[pdoResources?
            &parents=`0`
            &depth=`3`
            &tpl=`tpl_a2_2`
            &limit=`1000`
        ]]
внутри чанка tpl_a2_2 хочу получить параметр с настроек контекста, к ним доступ идет через [[++Key]]

Пробую вот так — но ничего не выводит.

[[pdoField? &id=`[[*id]]` &field=`cultureKey`]] или так [[pdoField? &id=`[[*id]]` &field=`[[++cultureKey]]`]]
Alex
12 января 2023, 21:59
modx.pro
539
0

Тема интернет-магазина - handyShop v1

Прошли новогодние праздники, а за ними пришел выход темы HandyShop.

HandyShop — готовая тема для интернет магазина или каталога на основе miniShop2. Основана на мини-движке magicThemes и позволяет создать сайт без глубокого погружения в программирование на MODX Revolution.
Тема достаточно универсальная и может подойти практически для любой области, где не нужен сложный функционал. Ниже распишу возможности с перечнем допустимого.
Алексей Смирнов
12 января 2023, 18:48
modx.pro
2 336
+11