Новости Joomla

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

Перевод и публикация интервью с Joomla евангелистом на греческом портале Joomla

Перевод и публикация интервью на греческом портале Joomla 🇬🇷

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

Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции. Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉

До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊

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

Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент.

🌐 Оригинальное интервью (на английском)
🇬🇷 Интервью на греческом портале (joomla.gr)

Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

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

act1ve

  • Осваиваюсь на форуме
  • 43
  • 4 / 0
Доброго времени суток.
Пытаюсь настроить редактирование материалов с фронтенда.

В настройках "Submissions" добавил возможность редактирования материалов для группы registered. Добавил в шаблон full отображение ссылки на редактирование материала.
Также настроил меню "My submissions".
Сейчас, если разные пользователи заходят в это меню, каждый видит только свои материалы - это как раз то, что мне надо.
А вот ссылка "редактировать материал" на странице full доступна всем registered пользователям, вне зависимостри от того, кто явлется автором.

Можно ли как то настроить права редактирования материала? Таким образом, чтобы статью мог редактировать только ее автор и администраторы?
*

act1ve

  • Осваиваюсь на форуме
  • 43
  • 4 / 0
Получил ответ на другом форуме. Решение представляет собой небольшой хак. Но все очень просто:

Цитата: Станислав
За 5 минут придумал небольшой хак элемента itemedit

В файле: media/zoo/elements/itemedit/itemedit.php надо слегка модифицировать функцию рендеринга элемента:

от строки 40:
public function render($params = array()) {
до включительно
Код: [Выделить]
if ($layout = $this->getLayout()) {

замените на
Код
public function render($params = array()) { 
        // ID автора материала ZOO
        $author_id = $this->getItem()->created_by;
        // ID текущего пользователя Joomla
        $user = &JFactory::getUser();
        $user_id = $user->id;
        // Группы текущего пользователя Joomla
        $groups = $user->groups;
// render layout
if ($layout = $this->getLayout() AND ($author_id == $user_id OR array_search(8, $groups))) {

В общем идея простая: получаем ID материала ZOO и текущего пользователя и сравниваем, если они совпадают или id группы пользователя = 8 (Super Administrators), то выводим линк. Если надо давать доступ нескольким группам, то надо модифицировать условие в последней строке. Специально сделал код понятным с несколькими дополнительными переменными и комментами, так как все можно вместить в пару строку  Код проверил, рабочий.
*

Иннокентий Петров

  • Новичок
  • 9
  • 0 / 0
Ничего не получается, так как этот файл php находится в группе элементов и его даже если временно переименовать, то все равно с панели как был доступ к своим ранее размещенным, так и остался для СуперАдмина. Т.е. суперАдмин не видит чужих ранее размещенных материалов. Кеш обновлял, все как нужно делал.

Вывод: менять очевидно нужно не в этом файле, но в каком же?
Есть общие на весь ZOO по пути \components\com_zoo\controllers\submission.php

Здесь формируется весь вывод.
Хорошо бы дополнить отображение даты размещения/модификации и еще некоторую служебную информацию, например, имя публикатора, город.

Автору давать исключительные права? - это не его уровень доступа, на это есть более высокие уровни.
Тут Адмиину я никак не могу дать исключительные права, не то, что автору...  >:(

Может что я напутал? Подскажите пожалуйста!
« Последнее редактирование: 16.08.2012, 13:13:15 от Иннокентий Петров »
*

kostas8008

  • Осваиваюсь на форуме
  • 15
  • 3 / 0
У меня работает! спасибо!
*

aniangeless

  • Захожу иногда
  • 168
  • 0 / 0
И у меня работает! Спасибо!! То что надо!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывод материала категории

Автор face2005

Ответов: 0
Просмотров: 3582
Последний ответ 28.09.2018, 18:26:52
от face2005
Многостраничные формы и динамические поля подачи материала с фронта?

Автор leonidivanov1980

Ответов: 1
Просмотров: 1674
Последний ответ 07.12.2014, 20:30:03
от leonidivanov1980
При сохранении материала выкидывает с сайта

Автор jinn81

Ответов: 0
Просмотров: 1791
Последний ответ 19.07.2014, 06:46:18
от jinn81
Вставка из материала ZOO

Автор yellowbarmaley

Ответов: 2
Просмотров: 1571
Последний ответ 28.06.2014, 02:10:58
от yellowbarmaley
Прямой доступ к элементу материала в Zoo

Автор metheoryt

Ответов: 2
Просмотров: 1663
Последний ответ 27.01.2014, 00:01:37
от metheoryt