0 Пользователей и 1 Гость просматривают эту тему.
  • 15 Ответов
  • 519 Просмотров
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
Задумал новый сайт, контент уже лежит в базе разложенный так - главные категории / подкатегории / материалы.

Создал тестово три категории, внимательно просмотрел таблицы
_categories
_assets

Написал скрипт, заполнил их. Так же сделал и с материалами.
В итоге все же где-то напутал. Если главные категории выводятся все, то уже подкатегории и материалы то есть то нет.
Хотя если искать через базу по полю parent_id то все верно и структура соблюдена. Не пойму где косяк?

Подозреваю что что-то не учел в таблице _assets и она портит все дело.

Вопрос - есть где-то мануал или список запросов как заполнять сайт программно а не вручную?
Уже два череа сижу, голова пухнет.

Может у кого-то остались скрипты, может поделитесь?
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
Спасибо! Я попытался сначала погуглить вероятно не так запросы вводил!
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
А не т же такого же мануала касательно категорий?
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
Вроде то что нужно спс!
*

sivers

  • Давно я тут
  • 835
  • 97 / 0
еще может пригодится:
_https://sivers.su/113-programmnoe-sozdanie-kategorii.html
На связи в телеге @sivers
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
К сожалению ни один из представленных кодов запустить не удалось. Продолжаю поиск.
Пока у меня получилось корректно создавать материалы в уже существующие категории с помощью этого кода http://inet-reklama.com/blog/joomla/programvnoe-sozdanie-materiala-v-joomla-2-5.html

Но вот сами категории пока не могу создать через скрипт. Точнее через пень колоду получается - но былокодом через запросы, минуя Ядро Joomla и вероятно где-то косячу с зависимостями в assets
« Последнее редактирование: 08.06.2019, 11:41:57 от Dram »
*

voland

  • Легенда
  • 10649
  • 566 / 111
  • Эта строка съедает место на вашем мониторе
А как делаете?
Посмотрел как в движке делается - вроде ничего сложного
Код
// Save New Category
if ($catid == 0 && $this->canCreateCategory())
{
$table = array();
$table['title'] = $data['catid'];
$table['parent_id'] = 1;
$table['extension'] = 'com_content';
$table['language'] = $data['language'];
$table['published'] = 1;

// Create new category and get catid back
$data['catid'] = CategoriesHelper::createCategory($table);
}
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
voland, ну а как это в отдельный скрипт перенести? Что в начале  это добавить?

define('JPATH_BASE', dirname(__FILE__). '/../..' );
define('DS', DIRECTORY_SEPARATOR);

require_once '/var/www/site/includes/defines.php';
require_once '/var/www/site/includes/framework.php';

$app = JFactory::getApplication('site')->initialise();
$db = JFactory::getDBO();
$query = $db->getQuery(true);

Вероятно что-то еще?
*

voland

  • Легенда
  • 10649
  • 566 / 111
  • Эта строка съедает место на вашем мониторе
voland, ну а как это в отдельный скрипт перенести? Что в начале  это добавить?

define('JPATH_BASE', dirname(__FILE__). '/../..' );
define('DS', DIRECTORY_SEPARATOR);

require_once '/var/www/site/includes/defines.php';
require_once '/var/www/site/includes/framework.php';

$app = JFactory::getApplication('site')->initialise();
$db = JFactory::getDBO();
$query = $db->getQuery(true);

Вероятно что-то еще?
В cli надо что ли?
Посмотрите - недавно выкладывал cli под shopping, лишнее уберете - https://gist.github.com/volandku/87d897d02bf9c7ef0962336d6f047ec1
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
Скажите тоже :))) Я PHP месяц назад учить начал :))) Не смогу я понять что там убрать :((
*

voland

  • Легенда
  • 10649
  • 566 / 111
  • Эта строка съедает место на вашем мониторе
Скажите тоже :))) Я PHP месяц назад учить начал :))) Не смогу я понять что там убрать :((
Ну, написать за вас - уже платно.

Или пробовать самому  8)
*

AlekVolsk

  • Гуру
  • 6889
  • 403 / 4
Цитировать
$this->canCreateCategory()
@voland а это откуда?
*

voland

  • Легенда
  • 10649
  • 566 / 111
  • Эта строка съедает место на вашем мониторе
*

Dram

  • Захожу иногда
  • 179
  • 0 / 0
Господа, снова проблемы. Был у меня код, который добавлял материалы программно, еще 2 дня назад он работал.
Сейчас я наконец-то правильно создал категории и подошел к добавлению материалов. Но тот код отказывается работать, просто белая страница и все.
Прошу, посмотрите, где может быть проблема?
Цитировать
<?php
set_time_limit(0);

ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);

define('JPATH_BASE', dirname(__FILE__). '/../..' );
define('DS', DIRECTORY_SEPARATOR);
require_once '/var/www/firm/includes/defines.php';
require_once '/var/www/firm/includes/framework.php';
$app = JFactory::getApplication('site')->initialise();
$db = JFactory::getDBO();
$query = $db->getQuery(true);

$db->setQuery("SELECT `id`, `parent_id`, `title`, `name`, `brand`, `alias` FROM #__firm");
$result = $db->loadObjectList();
var_dump($result);

foreach ($result as $res) {
  if ($res->parent_id < 335){
    $catid = $res->parent_id + 34;
  }else{
    $catid = $res->parent_id + 33;
  }
  $res->name = str_ireplace("&amp; ", "& ", $res->name);
  $res->name = str_ireplace("'", "\'", $res->name);

//Создаем объект таблички #__content
  $contentTable = new JTableContent( $db );
//Данные материала
  $dataContent = array(
    'title' => $res->title,
    'alias' => $res->alias,
    'catid' => $catid,
    'state' => 1,
    'introtext' => $res->name. $res->brand,
    'fulltext' => '',
    'created' => date( 'Y-m-d H:i:s' ),
    'publish_up' => date( 'Y-m-d H:i:s' ),
    'created_by' => 430,
    'metakey' => '',
    'metadesc' => '',
    'featured' => 0
  );
//Вносим данные в таблицу
  $contentTable->bind( $dataContent );
//Проверяем или данные корректны
  if ( $contentTable->check() ) {
    //Создаем новую запись
    $contentTable->store();
  }
}
echo "end";
К сожалению PHP учу только месяц, поэтому пробую запускать этот код поместив его в индекс PHP шаблона (2 дня назад так все работало)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как изменить ширину сайта?

Автор erlan_mk

Ответов: 17
Просмотров: 413
Последний ответ 02.11.2019, 12:30:54
от erlan_mk
С сайта каждый день приходят письма про обновление

Автор SimonovSergey

Ответов: 27
Просмотров: 4341
Последний ответ 26.10.2019, 23:33:47
от Candidate
Копирование, перенос сайта с помощью Akeeba Backup. Может пригодиться кому

Автор stendapuss

Ответов: 73
Просмотров: 32196
Последний ответ 21.10.2019, 18:56:41
от stendapuss
Как вывести список меток (тегов) в карту сайта (OSmap)?

Автор Apollon

Ответов: 16
Просмотров: 1179
Последний ответ 19.08.2019, 16:17:42
от Septdir
Скрытые пользователи сайта

Автор Koot

Ответов: 1
Просмотров: 259
Последний ответ 05.07.2019, 13:57:55
от dm-krv