Система управления сайтом Handy.CMS 3.1. build 2002

Список изменений в билде

1. Модуль "Формы" - добавлен валидатор полей форм
В модуль "Формы" встроен валидатор проверок полей формы. Администратор может создать собственные валидаторы. Валидаторы базируются на соответствие введенного пользователем значения формы регекс выражению.



2. Модуль "Формы" - добавлены обязательные для заполнения поля
В модуль "Формы" добавлена возможность указания обязательных для заполнения пользователем полей.


3. Модуль "Формы" - изменен принцип валидации значений
Валидация поля используется в двух ситуациях:
- "Контроль обязательных к заполнению данных". Производится при статусе поля "обязательно для заполнения". Проверки: заполненность данных; валидация, в случае наличия валидатора.
- "Проверка на ошибочность заполнения поля пользователем": Производится при отсутствии статуса "обязательно для заполнения". Проверки: валидация данных, в случае заполнения поля пользователем и наличии валидатора.

4. Добавлена возможность логизирования запросов к БД
Для возможности оптимизации работы модулей разработчиками и выявления медленных запросов к БД введена возможность логизирования запросов. Для активиации лога к базе данных, необходимо в модуле определить функцию debugAvalible()

PHP код:
public function debugAvalible () {
return
true;
}

Для активации лога БД в системе, в config.ini установить параметр sql_debug_log=on

5. Улучшена работа с БД на хостингах с ограниченными ресурсами
Для площадок с ограниченными ресурсами введена возможность использования непостоянных соединений с БД (по-умолчанию включены постоянные соединения). Для активации опции необходимо установить параметр db_pconnect=N в config.ini

6. Исправлено отображение пути установки
В 3-ем шаге инсталляции исправлено некорректное отображение путей к папкам, расположенным в публичной директории.

7. Парсинг переменной {theme}
Добавлен парсинг переменной {theme} в шаблонах видов модулей, хранящей в себе путь к теме текущего шалобна.

8. Откорректировано добавление шаблонов в систему
Ранее, при добавлении шаблона, идентичного по содержанию (дубликат), существующему в системе, но отличному по названию, система удаляла дубликат. По просьбе пользователей данная функция была отключена. Теперь при попытке загрузки в систему шаблона аналогичного по содержанию, но с отличным названием, выводится предупреждение с просьбой изменить содержимое шаблона.


9. Расширены возможности ввода параметров вида модуля
Добавлена возможность указания условий WHERE для вида модуля, при его привязке к странице.
Синтаксис:

PHP код:
forms.form_id:forms.reserved<>"true"|forms.form_id<>1@form_id=form_name=Выберите форму:

Условия для WHERE: forms.reserved<>"true"|forms.form_id<>1 (часть между двоеточием и @).
При наличии нескольких услвовий, необходимо использовать разделитель условий - вертикальный слеш |
Примеры:
1) Выбрать все формы:

 

PHP код:
forms.form_id@form_id=form_name=Выберите форму:

2) Выбрать все формы, кроме форм с типом reserved

 

PHP код:
forms.form_id:forms.reserved<>"true"@form_id=form_name=Выберите форму:

3) Выбрать все формы, кроме форм с типом reserved и id которых не равен 1

PHP код:
forms.form_id:forms.reserved<>"true"|forms.form_id<>1@form_id=form_name=Выберите форму:
10. Модуль "Формы" - возможность использования другими модулям

Модуль "Формы" претерпел революционные изменения, теперь его могут использовать другие модули в собственных целях. Это сделано для удобства создания различных форм и анкет внешними разработчиками и автоматизации профессов проверки, заполнения и отправки данных из форм.


Для использования формы из модуля, необходимо:
1) Установить системное имя формы и статус зарезервированности в таблице forms: значения полей reserved="true" и form_type="системное_имя_на_латинице"

Теперь форма может быть вызвана любым модулем.
Она также стала недоступна для удаления, а также прикрепления ее к странице.

Для вызова формы и получение ее содержимого используется функция:


PHP код:
self::getFormContents($form_type=false, $show_title=false)
, где Для автоматической проверки значений формы и отправки письма:

PHP код:
self::checkFormContents($form_type=false, $show_title=false, $text)
Значения первых двух переменных аналогичны self::getFormContents В случае, если у формы установлено одно или несколько полей с системным именемemail, оно заполнено пользователем, на данные адреса также будут отправлены письма с данными из формы. Это удобно, в случае, если необходимо уведомлять об успешной отправке формы не только администратора, но и пользователя, дублируя ему информацию.


11. Модуль "Формы" - добавлена возможность валидации полей формы модулем

В случае, если возможностей встроенных правил валидации полей не хватает, в поле field_validation таблицы form_fields можно указать название модуля, который будет вызван для проверки корректности заполненности поля.

Для осуществления проверки у данного модуля должна быть определена функция проверки:
PHP код:
public function fieldValidation($field_type, $field_value){
return array (
validate => true [,message => ""]);



}
Функция должна вернуть массив, содержащий обязательный ключ validate с значением true - если поле прошло валидацию,false - если не прошло.

Ключ message - опционален и содержит текст сообщения об ошибке, который выводится пользователю, в случае если поле не прошло валидацию.



Пример использования:

PHP код:
private $city_title;
public function
fieldValidation($field_type, $field_value){
// Если не передано название поля или у поля пустое значение
if($field_type==NULL || $field_value==NULL) $callback['validate'] = false;
// Устанавливаем первичный флаг валидации
$callback['validate'] = true;
if(
$field_type=="city_title") {
$contents = $this->database->sqlParse("SELECT city_title FROM cities WHERE city_title=?", $field_value);
if(
$contents[0]==NULL) $callback['validate'] = true;
else
$callback['validate'] = false;
}
$callback['message'] = "Город <b>".htmlspecialchars($field_value)."</b> уже есть в базе.";
return
$callback;
}
public function
onExecute($param_str) {
// Подгружаем управляющий модуль "Формы"
$forms = handyCore::loadExtension ( 'ext.forms' );
if(
$_POST) {
// Текст, добавляемый перед данными из формы
$text = "Добавленный город:\n";
// $form_data хранит значения всех заполненных пользователем полей,
// при этом к полям, имеющим системное имя можно обращаться как к ключу
// $form_data[form_type]
$form_data = $forms->checkFormContents("cities", true, $text);
// Присваиваем значение системного поля city_title переменной
$this->city_title = $form_data['city_title']
if(
$form_data['form_data']['form_fields']!=NULL) {
// Действия модуля с формой
// Например внесение данных в БД
$this->database ->sqlParse('INSERT INTO cities SET city_title=?', $this->city_title);
}
} else {
if(
$form_data = $forms->getFormContents("cities", true))){
} else
$error = "cities_form_not_found";
}
return array (
'form' => $form_data['contents'],
'template' => 'users_registration.tpl',
'error' => $error
);
}
12. Возможность работы системы на 64-bit машинах
Добавлена возможность работы системы на серверах 64-bit

13. Получение значение и внесение изменений в значения настроек модулей
Добавлены функции self::setExtSettings($ext, $array) и self::getExtSettings($ext) для более удобного получения настроек из модуля и внесение настроек в модуль.

PHP код:
self::setExtSettings($ext, $array)
, где
PHP код:
self::getExtSettings($ext)
, где Таблица extensions_settings содержит следующие поля:
Пример использования:

Код модуля:
PHP код:
// Устанавливаем значение сеттингов
$this->setExtSettings("subscribe", $_POST['extensions_settings_id']);
// Получаем значение сеттингов
$settings = $this->getExtSettings("subscribe");
$this -> smarty -> assign ('subscribe_settings', $settings);
Код шаблона:
PHP код:
<table border="0" cellpadding="0" cellspacing="0" width="100%">
{
section loop=$subscribe_settings name=i} <tr>
<
td nowrap>{$subscribe_settings[i].setting_title|escape}</td>
<
td><img src="$theme/p.gif" width=10 height=1></td>
<
td width="100%"><input type="text" name="extensions_settings_id[{$subscribe_settings[i].extensions_settings_id}]" value="{$subscribe_settings[i].setting_value|escape}" class="input100persent" /></td>
</
tr>
{/
section}
</
table>
14. Права доступупа на robots.txt
В систему прав доступа добавлено событие - "Редактирование robots.txt", для возможности запрета изменения robots.txt младшими администраторами и "случайного" запрета сайта к индексации.
 
15. Макросы
Обработчики макросов перенесы в отдельные файлы, для удобства их создания и редактирования. Теперь, для того чтобы создать макрос, необходимо:
1) написать название его тега и пространства имен, если есть в XML-файле списке макросов (см. документацию), например:
PHP код:
<rule>
<
namespace>active</namespace>
<
tag>form</tag>
</
rule>
2) создать файл с обработчиком в папке /handy_framework/lib/replaceprocessor/macros_тип_макроса. При этом название файла должно формироваться следующим образом: название_тега.php или название_пространства_имен_название_тега.php, например:
htmleditor.php | тег: htmleditor, пространство имен не задано
active_form.php тег: form, пространство имен: active
active.php | тег: не задан, прострнанство имен: active
Типы макросов:
admin - шаблоны административного интерфейса (папка: macros_admin, XML-обработчик: rules.xml)
public - шаблоны публичной части проекта (папка: macros_public, XML-обработчик: macros.xml)
ext - шаблоны публичной части модулей (папка: macros_ext, XML-обработчик: ext_macros.xml)
 
16. Улучшена работа антиспам фильтра для форм.
Улучшена работа базового антиспам фильтра для форм, не требующего наличия captcha в форме.
 
17. Модуль "Формы", информация о пользователе
В модуль "Формы" добавлена передача администратору информации о пользователе, который отправил форму.

На почту вместе с запросом направляется следующая информация по пользователю:
- Реферер (адрес страницы-источника посетителя)
- IP адрес пользователя
- Броузер пользователя
 
18. Управление свойствами страницы из модулей
Получить доступ к свойствам страницы, например, meta-данным теперь можно через функцию:
PHP код:
handyCore::loadExtension ( 'ext.sitemanager' )->getPageSettings([$key]);
, где $key - название свойства.
При этом, если не обозначить название конкретного свойства, Вы получите весь массив свойств.
Для того, чтобы установить значение свойства, используется функция:


PHP код:
handyCore::loadExtension ( 'ext.sitemanager' )->setPageSettings($key, $value);
, где Примечательно, что массив свойств не ограничен, соответственно можно добавлять свои свойства.

На данный момент базовые модули системы используются свойства: meta_title, meta_keywords, meta_description, которые отвечают за вывод META-тегов конкретной страницы. В случае, если страница динамически формируется модулем, из модуля можно установить свойства META для данной страницы.
 
19. Возможность установки времени показа формы
Добавлена возможность установки интервала, в который должна отображаться форма.
 
20. Русские даты в Smarty
Система автоматически переводит названия месяцев в датах в русский эквивалент, в соответствии с установленным в системе форматом дат.
Однако иногда для форматирования удобно выводить части даты отдельно и для этого нужно воспользоваться модификатором форматирования даты шаблонизатора smarty - date_format. Проблема заключается в том, что исходная версия smarty не предусматривает русских дат.
Мы модифицировали код smarty и теперь шаблонизатор поддерживает русские даты месяцев. Для указания русского формата дат, необходимо указать модификатор даты:
21. Шаблоны для модулей
Добавлена возможность задавать шаблоны для элементов модулей, а также запрашивать список существующих шаблонов модуля.
Для получения данных о шаблонах модуля используется функция: getTemplates()

Данные о шаблонах хранятся в базе данных в таблице extensions_templates, где:
Для использования в публичной части модуля предусмотрена функция: getTemplate($id), где $id - ID шаблона. Функция возвращает итоговое название файла шаблона.
Название файла шаблона формируется по принципу: <extension_sysname>_<extensions_template_filename>
(Системное название модуля, знак подчеркивания, название файла шаблона. В случае, если название файла шаблона не задано, итоговое название будет совпадать с системным названием модуля).

Пример:
INSERT INTO `extensions_templates` VALUES (1, 'Общий шаблон форм', '', 'forms');
INSERT INTO `extensions_templates` VALUES (2, 'Мы вам перезвоним', 'recall', 'forms');
В первом случае итоговое название файла шаблона будет: forms.tpl, во втором случае: form_recall.tpl

PHP код:
// получить данные по всем шаблонам модуля
$this->getTemplates();
// получить название файла шаблона
$this->getTemplate($id);

22. Шаблоны и стили для модуля "Формы"
Добавлена возможность задавать различные шаблоны вывода для форм.

Кроме того, для каждого поля формы возможно указать собственный CSS-класс, который будет определять его отображение на странице.

23. Установка и получение шаблонов по-умолчанию
Добавлена функция для установки шаблонов по-умолчанию: setDefaultTemplate($id), где $id - ID шаблона (значение поля extensions_template_id таблицы extensions_templates).
При вызове функции из модуля и передаче ей ID шаблона, данный шаблон устанавливается в качестве шаблона по-умолчанию для модуля (флаг extensions_template_default в значение Y), в случае наличия у другого шаблона данного модуля флага extensions_template_default в значении Y, он сбрасывается на N.

Пример использования:

PHP код:
$this -> setDefaultTemplate($param_str['extensions_template_id']);
Для получения шаблона, используемого по-умолчанию, добавлена функция: getDefaultTemplate(), которая возвращает массив данных шаблона.
Пример использования:
PHP код:
$default_template = $this -> getDefaultTemplate();
Содержимое $default_template:
Array
(
[extensions_template_id] => 1
[extensions_template_title] => Общий шаблон форм
[extensions_template_filename] =>
[extension_sysname] => forms
[owner_id] => 10
[extensions_template_default] => Y
)
24. Получание текущей языковой версии
Получить ID текущей языковой версии можно с помощью функции getLangVersion()


PHP код:
// Создаем экземпляр класса системы разграничения прав доступа
$this -> right_access_manager = handyCore::loadExtension ( 'kernel.right_access_manager' );
$this->right_access_manager->getLangVersion();