Файл: system/controllers/content/actions/item_edit.php
Строк: 183
<?php
class actionContentItemEdit extends cmsAction {
public function run(){
$user = cmsUser::getInstance();
// Получаем название типа контента и сам тип
$ctype_name = $this->request->get('ctype_name');
$ctype = $this->model->getContentTypeByName($ctype_name);
if (!$ctype) { cmsCore::error404(); }
$id = $this->request->get('id');
if (!$id) { cmsCore::error404(); }
// Получаем нужную запись
$item = $this->model->getContentItem($ctype['name'], $id);
if (!$item) { cmsCore::error404(); }
// проверяем наличие доступа
if (!cmsUser::isAllowed($ctype['name'], 'edit')) { cmsCore::error404(); }
if (!cmsUser::isAllowed($ctype['name'], 'edit', 'all')) {
if (cmsUser::isAllowed($ctype['name'], 'edit', 'own') && $item['user_id'] != $user->id) {
cmsCore::error404();
}
}
$is_premoderation = $ctype['is_premod_edit'];
$is_moderator = $user->is_admin || $this->model->userIsContentTypeModerator($ctype_name, $user->id);
if (!$item['is_approved'] && !$is_moderator) { cmsCore::error404(); }
// Получаем родительский тип, если он задан
if ($this->request->has('parent_type')){
$parent['ctype'] = $this->model->getContentTypeByName($this->request->get('parent_type'));
$parent['item'] = $this->model->getContentItemBySLUG($parent['ctype']['name'], $this->request->get('parent_slug'));
}
// Определяем наличие полей-свойств
$props = $this->model->getContentProps($ctype['name']);
$ctype['props'] = $props;
// Если включены личные папки - получаем их список
$folders_list = array();
if ($ctype['is_folders']){
$folders_list = $this->model->getContentFolders($ctype['id'], $item['user_id']);
$folders_list = array_collection_to_list($folders_list, 'id', 'title');
}
// Получаем поля для данного типа контента
$this->model->orderBy('ordering');
$fields = $this->model->getContentFields($ctype['name'], $id);
// Строим форму
$form = $this->getItemForm($ctype, $fields, 'edit', array(
'folders_list' => $folders_list
), $id, $item);
// Получаем теги
if ($ctype['is_tags']){
$tags_model = cmsCore::getModel('tags');
$item['tags'] = $tags_model->getTagsStringForTarget($this->name, $ctype['name'], $id);
}
cmsEventsManager::hook("content_edit", array($ctype, $item));
list($form, $item) = cmsEventsManager::hook("content_{$ctype['name']}_form", array($form, $item));
// Форма отправлена?
$is_submitted = $this->request->has('submit');
$item['ctype_name'] = $ctype['name'];
$item['ctype_id'] = $ctype['id'];
if ($ctype['props']){
$item_props = $this->model->getContentProps($ctype['name'], $item['category_id']);
$item_props_fields = $this->getPropsFields($item_props);
$item['props'] = $this->model->getPropsValues($ctype['name'], $id);
foreach($item_props_fields as $field){
$form->addField('props', $field);
}
}
$is_pub_control = cmsUser::isAllowed($ctype['name'], 'pub_on');
$is_date_pub_allowed = $ctype['is_date_range'] && cmsUser::isAllowed($ctype['name'], 'pub_late');
$is_date_pub_end_allowed = $ctype['is_date_range'] && cmsUser::isAllowed($ctype['name'], 'pub_long', 'any');
$is_date_pub_days_allowed = $ctype['is_date_range'] && cmsUser::isAllowed($ctype['name'], 'pub_long', 'days');
$is_date_pub_ext_allowed = $is_date_pub_days_allowed && cmsUser::isAllowed($ctype['name'], 'pub_max_ext');
if ($is_date_pub_ext_allowed){
$item['pub_days'] = 0;
}
$add_cats = $this->model->getContentItemCategories($ctype['name'], $id);
if ($add_cats){
foreach($add_cats as $index => $cat_id){
if ($cat_id == $item['category_id']) { unset($add_cats[$index]); break; }
}
}
if ($is_submitted){
// Парсим форму и получаем поля записи
$item = array_merge($item, $form->parse($this->request, $is_submitted, $item));
// Проверям правильность заполнения
$errors = $form->validate($this, $item);
if (!$errors){
list($item, $errors) = cmsEventsManager::hook('content_validate', array($item, $errors));
}
if (!$errors){
unset($item['ctype_name']);
unset($item['ctype_id']);
$item['is_approved'] = $item['is_approved'] && (!$ctype['is_premod_edit'] || $is_moderator);
$item['approved_by'] = null;
if ($ctype['is_auto_keys']){ $item['seo_keys'] = string_get_meta_keywords($item['content']); }
if ($ctype['is_auto_desc']){ $item['seo_desc'] = string_get_meta_description($item['content']); }
if ($ctype['is_tags']){
$tags_model->updateTags($item['tags'], $this->name, $ctype['name'], $id);
$item['tags'] = $tags_model->getTagsStringForTarget($this->name, $ctype['name'], $id);
}
$date_pub_time = strtotime($item['date_pub']);
$date_pub_end_time = strtotime($item['date_pub_end']);
$now_time = strtotime(date('Y-m-d', time()));
$is_pub = true;
if ($is_date_pub_allowed){
$days_to_pub = ceil(($date_pub_time - $now_time)/60/60/24);
$is_pub = $is_pub && ($days_to_pub < 1);
}
if ($is_date_pub_end_allowed && !empty($item['date_pub_end'])){
$days_from_pub = floor(($now_time - $date_pub_end_time)/60/60/24);
$is_pub = $is_pub && ($days_from_pub < 1);
} else if ($is_date_pub_ext_allowed && !$user->is_admin) {
$days = $item['pub_days'];
$date_pub_end_time = $date_pub_end_time + 60*60*24*$days;
$days_from_pub = floor(($now_time - $date_pub_end_time)/60/60/24);
$is_pub = $is_pub && ($days_from_pub < 1);
$item['date_pub_end'] = date('Y-m-d', $date_pub_end_time);
} else {
$item['date_pub_end'] = false;
}
unset($item['pub_days']);
if (!$is_pub_control) { unset($item['is_pub']); }
if (!isset($item['is_pub']) || !empty($item['is_pub'])){
$item['is_pub'] = $is_pub;
if (!$is_pub){
cmsUser::addSessionMessage(LANG_CONTENT_IS_PUB_OFF);
}
}
if (!empty($ctype['options']['is_cats_multi'])){
$add_cats = $this->request->get('add_cats');
if (is_array($add_cats)){
foreach($add_cats as $index=>$cat_id){
if (!is_numeric($cat_id) || !$cat_id){
unset($add_cats[$index]);
}
}
if ($add_cats){
$item['add_cats'] = $add_cats;
}
}
}
//
// Сохраняем запись и редиректим на ее просмотр
//
$item = cmsEventsManager::hook("content_before_update", $item);
$item = cmsEventsManager::hook("content_{$ctype['name']}_before_update", $item);
$item = $this->model->updateContentItem($ctype, $id, $item, $fields);
cmsEventsManager::hook("content_after_update", $item);
cmsEventsManager::hook("content_{$ctype['name']}_after_update", $item);
if ($item['is_approved'] || $is_moderator){
cmsEventsManager::hook("content_after_update_approve", array('ctype_name'=>$ctype_name, 'item'=>$item));
cmsEventsManager::hook("content_{$ctype['name']}_after_update_approve", $item);
} else {
$this->requestModeration($ctype_name, $item, false);
}
// обновляем приватность комментариев
if (isset($item['is_private'])){
cmsCore::getModel('comments')->
filterEqual('target_controller', $this->name)->
filterEqual('target_subject', $ctype_name)->
filterEqual('target_id', $item['id'])->
updateCommentsPrivacy($item['is_private'] || $item['is_parent_hidden']);
}
$back_url = $this->request->get('back');
if ($back_url){
$this->redirect($back_url);
} else {
$this->redirectTo($ctype_name, $item['slug'] . '.html');
}
}
if ($errors){
cmsUser::addSessionMessage(LANG_FORM_ERRORS, 'error');
}
}
return cmsTemplate::getInstance()->render('item_form', array(
'do' => 'edit',
'ctype' => $ctype,
'parent' => isset($parent) ? $parent : false,
'item' => $item,
'form' => $form,
'props' => $props,
'is_moderator' => $is_moderator,
'is_premoderation' => $is_premoderation,
'is_load_props' => false,
'add_cats' => $add_cats,
'errors' => isset($errors) ? $errors : false
));
}
}