Exemple #1
0
 public function run($controller_name)
 {
     if (!$controller_name) {
         cmsCore::error404();
     }
     $controller_info = $this->model->getControllerInfo($controller_name);
     if (!$controller_info || !$controller_info['is_external']) {
         cmsCore::error404();
     }
     if ($controller_info['is_backend']) {
         $backend_context = $this->request->isAjax() ? cmsRequest::CTX_AJAX : cmsRequest::CTX_INTERNAL;
         $backend_request = new cmsRequest($this->request->getData(), $backend_context);
         $backend_controller = $this->loadControllerBackend($controller_info['name'], $backend_request);
         // смотрим специальный экшен
         if ($backend_controller->isActionExists('delete_component')) {
             $backend_controller->redirectToAction('delete_component');
         }
     }
     // нет бэкэенда или экшена, удаляем через метод модели контроллера
     // если в модели контроллера нет метода deleteController
     // будет использоваться из основной модели
     // который просто удалит запись в cms_controllers
     if (cmsCore::isModelExists($controller_info['name'])) {
         cmsCore::getModel($controller_info['name'])->deleteController($controller_info['id']);
     } else {
         $model = new cmsModel();
         $model->deleteController($controller_info['id']);
     }
     cmsUser::addSessionMessage(sprintf(LANG_CP_COMPONENT_IS_DELETED, $controller_info['title']), 'success');
     $this->redirectToAction('controllers');
 }
Exemple #2
0
 private function getLocationTypeValue($id, $location_type)
 {
     $model = new cmsModel();
     $item_name = $model->getField('geo_' . $location_type, $id, 'name');
     if ($item_name) {
         return $item_name;
     }
     return null;
 }
Exemple #3
0
function add_perms($data, $type, $options = null)
{
    $model = new cmsModel();
    foreach ($data as $controller => $names) {
        foreach ($names as $name) {
            if (!$model->db->getRowsCount('perms_rules', "controller = '{$controller}' AND name = '{$name}'", 1)) {
                $model->insert('perms_rules', array('controller' => $controller, 'name' => $name, 'type' => $type, 'options' => $options));
            }
        }
    }
}
Exemple #4
0
 public function run($id)
 {
     if (!$id) {
         cmsCore::error404();
     }
     $content_model = cmsCore::getModel('content');
     $ctype = $content_model->getContentType($id);
     $ctype = cmsEventsManager::hook("ctype_before_delete", $ctype);
     $content_model->deleteContentType($id);
     cmsEventsManager::hook("ctype_after_delete", $ctype);
     cmsCore::getModel('widgets')->deletePagesByName('content', "{$ctype['name']}.*");
     $binded_widgets = $content_model->get('widgets_bind', function ($item, $model) {
         $item['options'] = cmsModel::yamlToArray($item['options']);
         return $item;
     });
     if ($binded_widgets) {
         foreach ($binded_widgets as $widget) {
             if (isset($widget['options']['ctype_id']) && $ctype['id'] == $widget['options']['ctype_id']) {
                 $content_model->delete('widgets_bind', $widget['id']);
             }
         }
     }
     cmsCore::getController('activity')->deleteType('content', "add.{$ctype['name']}");
     $this->redirectToAction('ctypes');
 }
Exemple #5
0
 public function getPresetByName($name)
 {
     return $this->getItemByField('images_presets', 'name', $name, function ($item, $model) {
         $item['wm_image'] = cmsModel::yamlToArray($item['wm_image']);
         return $item;
     });
 }
Exemple #6
0
 public function store($value, $is_submitted, $old_value = null)
 {
     $config = cmsConfig::getInstance();
     $files_model = cmsCore::getModel('files');
     if ($value) {
         $file = cmsModel::yamlToArray($old_value);
         $path = $config->upload_path . $file['path'];
         @unlink($path);
         $files_model->deleteFile($file['id']);
         $old_value = null;
     }
     $uploader = new cmsUploader();
     if (!$uploader->isUploaded($this->name)) {
         return $old_value;
     }
     $allowed_extensions = $this->getOption('extensions');
     $max_size_mb = $this->getOption('max_size_mb');
     if (!trim($allowed_extensions)) {
         $allowed_extensions = false;
     }
     if (!$max_size_mb) {
         $max_size_mb = 0;
     }
     $result = $uploader->upload($this->name, $allowed_extensions, $max_size_mb * 1048576);
     if (!$result['success']) {
         if (!empty($result['path'])) {
             $uploader->remove($result['path']);
         }
         cmsUser::addSessionMessage($result['error'], 'error');
         return null;
     }
     $file = $files_model->registerFile($result['url'], $result['name']);
     return array('id' => $file['id'], 'url_key' => $file['url_key'], 'name' => $result['name'], 'size' => $result['size'], 'path' => $result['url']);
 }
Exemple #7
0
 public function getControllerInfo($controller_name)
 {
     return $this->getItemByField('controllers', 'name', $controller_name, function ($item) {
         $item['options'] = cmsModel::yamlToArray($item['options']);
         return $item;
     });
 }
Exemple #8
0
 public function routeAction($action_name)
 {
     if (!is_numeric($action_name)) {
         return $action_name;
     }
     $this->lock_explicit_call = false;
     $group_id = $action_name;
     $group = $this->model->getGroup($group_id);
     if (!$group) {
         cmsCore::error404();
     }
     // кешируем запись для получения ее в виджетах
     cmsModel::cacheResult('current_group', $group);
     cmsModel::cacheResult('group_model', $this->model);
     $this->current_params = $this->cms_core->uri_params;
     $this->current_params[0] = $group;
     $membership = $this->model->getMembership($group['id'], $this->cms_user->id);
     $is_member = $membership !== false;
     if ($group['is_closed'] && !$is_member && !$this->cms_user->is_admin && (empty($this->cms_core->uri_params[0]) || $this->cms_core->uri_params[0] != 'join')) {
         return 'group_closed';
     }
     if (!$this->cms_core->uri_params) {
         return 'group';
     }
     $action_name = $this->cms_core->uri_params[0];
     $action_name = 'group_' . $action_name;
     return $action_name;
 }
Exemple #9
0
 public function getControllerInfo($controller_name)
 {
     return $this->getItemByField('controllers', 'name', $controller_name, function ($item) {
         $item['options'] = cmsModel::yamlToArray($item['options']);
         $item['title'] = string_lang($item['name'] . '_CONTROLLER', $item['title']);
         return $item;
     });
 }
Exemple #10
0
 public function getFeedByCtypeName($ctype_name)
 {
     return $this->filterEqual('ctype_name', $ctype_name)->getItem('rss_feeds', function ($item, $model) {
         $item['mapping'] = cmsModel::yamlToArray($item['mapping']);
         $item['image'] = cmsModel::yamlToArray($item['image']);
         return $item;
     });
 }
Exemple #11
0
 private function feed()
 {
     return $this->getItem('rss_feeds', function ($item, $model) {
         $item['mapping'] = cmsModel::yamlToArray($item['mapping']);
         $item['image'] = cmsModel::yamlToArray($item['image']);
         return $item;
     });
 }
Exemple #12
0
 public function getPhoto($id)
 {
     $this->select('u.nickname', 'user_nickname');
     $this->select('u.avatar', 'user_avatar');
     $this->join('{users}', 'u', 'u.id = i.user_id');
     return $this->getItemById('photos', $id, function ($item, $model) {
         $item['user'] = array('id' => $item['user_id'], 'nickname' => $item['user_nickname'], 'avatar' => $item['user_avatar']);
         $item['image'] = cmsModel::yamlToArray($item['image']);
         return $item;
     });
 }
Exemple #13
0
 public function getInput($value)
 {
     $users_model = cmsCore::getModel('users');
     $items = $this->getProperty('show_all') ? array(0 => LANG_ALL) : array();
     $is_show_guests = (bool) $this->getProperty('show_guests');
     $groups = $users_model->getGroups($is_show_guests);
     foreach ($groups as $group) {
         $items[$group['id']] = $group['title'];
     }
     $this->data['groups'] = $items;
     if (!is_array($value)) {
         $value = cmsModel::yamlToArray($value);
     }
     return parent::getInput($value ? $value : array(0));
 }
Exemple #14
0
 public function deleteGroup($group)
 {
     $this->deleteGroupMemberships($group['id']);
     $this->deleteGroupInvites($group['id']);
     cmsCache::getInstance()->clean('groups.list');
     if ($group['logo']) {
         if (!is_array($group['logo'])) {
             $group['logo'] = cmsModel::yamlToArray($group['logo']);
         }
         $config = cmsConfig::getInstance();
         foreach ($group['logo'] as $image_url) {
             $image_path = $config->upload_path . $image_url;
             @unlink($image_path);
         }
     }
     return $this->delete('groups', $group['id']);
 }
Exemple #15
0
 public function routeAction($action_name)
 {
     if (!is_numeric($action_name)) {
         return $action_name;
     }
     // разблокируем вызов экшенов, которым запрещено вызываться напрямую
     $this->lock_explicit_call = false;
     $user_id = $action_name;
     $is_logged = $this->cms_user->is_logged;
     $profile = $this->model->getUser($user_id);
     if (!$profile) {
         cmsCore::error404();
     }
     if (!$is_logged && $this->options['is_auth_only']) {
         cmsUser::goLogin();
     }
     if ($this->options['is_themes_on']) {
         $this->cms_template->applyProfileStyle($profile);
     }
     $this->current_params = $this->cms_core->uri_params;
     // Статус
     if ($this->options['is_status']) {
         $profile['status'] = $this->model->getUserStatus($profile['status_id']);
     }
     // Репутация
     $profile['is_can_vote_karma'] = $is_logged && cmsUser::isAllowed('users', 'vote_karma') && $this->cms_user->id != $profile['id'] && $this->model->isUserCanVoteKarma($this->cms_user->id, $profile['id'], $this->options['karma_time']);
     // кешируем запись для получения ее в виджетах
     cmsModel::cacheResult('current_profile', $profile);
     // Нет параметров после названия экшена (/users/id) - значит
     // это главная страница профиля, первым параметром добавляем
     // сам профиль
     if (!$this->cms_core->uri_params) {
         array_unshift($this->current_params, $profile);
         return 'profile';
     }
     // Ищем экшен внутри профиля
     if ($this->isActionExists('profile_' . $this->cms_core->uri_params[0])) {
         $this->current_params[0] = $profile;
         return 'profile_' . $this->cms_core->uri_params[0];
     }
     // Если дошли сюда, значит это неизвестный экшен, возможно вкладка
     // от другого контроллера, тогда первым параметром добавляем
     // сам профиль
     array_unshift($this->current_params, $profile);
     return 'profile_tab';
 }
Exemple #16
0
 public function run()
 {
     $sources['photos'] = LANG_PHOTOS;
     // по каким полям поиск
     $match_fields['photos'] = array('title', 'content');
     // какие поля получать
     $select_fields['photos'] = array('id', 'content', 'image', 'slug', 'date_pub', 'title', 'rating', 'comments', 'user_id', 'sizes', 'hits_count');
     // из каких таблиц выборка
     $table_names['photos'] = 'photos';
     // получаем тут высоту строк, чтобы в шаблоне потом забрать
     $this->getRowHeight();
     return array('name' => $this->name, 'sources' => $sources, 'table_names' => $table_names, 'match_fields' => $match_fields, 'select_fields' => $select_fields, 'filters' => array('photos' => array()), 'item_callback' => function ($item, $model, $sources_name, $match_fields, $select_fields) {
         $item['image'] = cmsModel::yamlToArray($item['image']);
         $item['sizes'] = cmsModel::yamlToArray($item['sizes']);
         $item['title'] = strip_tags($item['title']);
         return $item;
     });
 }
Exemple #17
0
 public function run()
 {
     $ctype = cmsModel::getCachedResult('current_ctype');
     $ctype_name = $this->getOption('ctype_name');
     $active_cat = false;
     if (!$ctype_name) {
         if (!$ctype) {
             return false;
         }
         $ctype_name = $ctype['name'];
     }
     if ($ctype && $ctype['name'] == $ctype_name) {
         if (strpos(cmsCore::getInstance()->uri, '.html') === false) {
             $current_ctype_category = cmsModel::getCachedResult('current_ctype_category');
             if (!empty($current_ctype_category['id'])) {
                 $active_cat = $current_ctype_category;
             }
         } else {
             $item = cmsModel::getCachedResult('current_ctype_item');
             if (!$item) {
                 return false;
             }
             if (!empty($item['category'])) {
                 $active_cat = $item['category'];
             }
         }
     }
     $model = cmsCore::getModel('content');
     $cats = $model->getCategoriesTree($ctype_name, $this->getOption('is_root'));
     if (!$cats) {
         return false;
     }
     if ($active_cat) {
         $path = array_filter($cats, function ($cat) use($active_cat) {
             return $cat['ns_left'] <= $active_cat['ns_left'] && $cat['ns_level'] <= $active_cat['ns_level'] && $cat['ns_right'] >= $active_cat['ns_right'] && $cat['ns_level'] > 0;
         });
     }
     return array('ctype_name' => $ctype_name, 'cats' => $cats, 'active_cat' => $active_cat, 'path' => !empty($path) ? $path : array());
 }
Exemple #18
0
 public function run($id)
 {
     $menu_model = cmsCore::getModel('menu');
     $form = $this->getForm('menu', array('edit'));
     $menu = $menu_model->getMenu($id);
     if ($menu['is_fixed']) {
         $form->removeField('basic', 'name');
     }
     if ($this->request->has('submit')) {
         $new_menu = $form->parse($this->request, true);
         $errors = $form->validate($this, $new_menu);
         if (!$errors) {
             $menu_model->updateMenu($id, $new_menu);
             cmsUser::setCookiePublic('menu_tree_path', "{$id}.0");
             // обновление виджетов меню, в которых используется это меню
             if ($menu['name'] !== $new_menu['name']) {
                 $widgets_model = cmsCore::getModel('widgets');
                 $w_binds = $widgets_model->join('widgets', 'w', 'w.id = i.widget_id')->filterEqual('w.name', 'menu')->get('widgets_bind', function ($item, $model) {
                     $item['options'] = cmsModel::yamlToArray($item['options']);
                     return $item;
                 });
                 foreach ($w_binds as $w_bind) {
                     if (isset($w_bind['options']['menu']) && $w_bind['options']['menu'] === $menu['name']) {
                         $new = array('options' => $w_bind['options']);
                         $new['options']['menu'] = $new_menu['name'];
                         $widgets_model->updateWidgetBinding($w_bind['id'], $new);
                     }
                 }
             }
             $this->redirectToAction('menu');
         }
         if ($errors) {
             cmsUser::addSessionMessage(LANG_FORM_ERRORS, 'error');
         }
         $menu = $new_menu;
     }
     return $this->cms_template->render('menu_form', array('do' => 'edit', 'item' => $menu, 'form' => $form, 'errors' => isset($errors) ? $errors : false));
 }
Exemple #19
0
 /**
  * Сохраняет опции контроллера
  * @param string $controller_name
  * @param array $options
  * @return boolean
  */
 static function saveOptions($controller_name, $options)
 {
     $model = new cmsModel();
     $model->filterEqual('name', $controller_name);
     return $model->updateFiltered('controllers', array('options' => $options));
 }
Exemple #20
0
 /**
  * Подготавливает значение $value поля $field для вставки в запрос
  * @param string $field
  * @param string $value
  * @return string
  */
 public function prepareValue($field, $value)
 {
     // если значение поля - массив,
     // то преобразуем его в YAML
     if (is_array($value)) {
         $value = "'" . $this->escape(cmsModel::arrayToYaml($value)) . "'";
     } else {
         // если это поле даты публикации и оно не установлено,
         // то используем текущее время
         if (strpos($field, 'date_') === 0 && $value === false) {
             $value = "NULL";
         } else {
             if (strpos($field, 'date_') === 0 && ($value == '' || is_null($value))) {
                 $value = "CURRENT_TIMESTAMP";
             } else {
                 // если это поле булево,
                 // то преобразуем его в число
                 if (is_bool($value)) {
                     $value = (int) $value;
                 } else {
                     // если значение поля не задано,
                     // то запишем в базу NULL
                     if ($value === '' || is_null($value)) {
                         $value = 'NULL';
                     } else {
                         $value = $this->escape(trim($value));
                         $value = "'{$value}'";
                     }
                 }
             }
         }
     }
     return $value;
 }
Exemple #21
0
 public function getInput($value)
 {
     $this->data['images'] = false;
     if ($value) {
         $this->data['images'] = is_array($value) ? $value : cmsModel::yamlToArray($value);
     }
     $this->data['sizes'] = $this->getOption('sizes');
     $this->data['images_controller'] = cmsCore::getController('images');
     return parent::getInput($value);
 }
Exemple #22
0
/**
 * Возвращает путь к файлу изображения
 * @param array|yaml $image Все размеры заданного изображения
 * @param string $size_preset Название пресета
 * @param bool $is_add_host Возвращать путь отностительно директории хранения или полный путь
 * @param bool $is_relative Возвращать относительный путь или всегда с полным url
 * @return boolean|string
 */
function html_image_src($image, $size_preset = 'small', $is_add_host = false, $is_relative = true)
{
    $config = cmsConfig::getInstance();
    if (!is_array($image)) {
        $image = cmsModel::yamlToArray($image);
    }
    if (!$image) {
        return false;
    }
    $keys = array_keys($image);
    if ($keys[0] === 0) {
        $image = $image[0];
    }
    if (isset($image[$size_preset])) {
        $src = $image[$size_preset];
    } else {
        return false;
    }
    if ($is_add_host && !strstr($src, $config->upload_host)) {
        if ($is_relative) {
            $src = $config->upload_host . '/' . $src;
        } else {
            $src = $config->upload_host_abs . '/' . $src;
        }
    }
    return $src;
}
Exemple #23
0
function install_package()
{
    $core = cmsCore::getInstance();
    $content_model = cmsCore::getModel('content');
    $remove_table_indexes = array('{users}_friends' => array('is_mutual', 'friend_id', 'user_id'), 'tags_bind' => array('tag_id'));
    $add_table_indexes = array('{users}_friends' => array('user_id' => array('user_id', 'is_mutual'), 'friend_id' => array('friend_id', 'is_mutual')), 'tags_bind' => array('tag_id' => array('tag_id')));
    // все таблицы
    // удаляем ненужные индексы
    foreach ($remove_table_indexes as $table => $ri) {
        foreach ($ri as $index_name) {
            $core->db->dropIndex($table, $index_name);
        }
    }
    // добавляем нужные
    foreach ($add_table_indexes as $table => $indexes) {
        foreach ($indexes as $index_name => $fields) {
            $core->db->addIndex($table, $fields, $index_name);
        }
    }
    //************************************************************************//
    // типы контента
    $ctypes = $content_model->getContentTypes();
    $varchar_fields = array('seo_keys', 'seo_desc', 'seo_title');
    $remove_ctype_indexes = array('_cats' => array('ns_left', 'ns_right', 'ns_differ', 'ns_ignore', 'parent_id'), '_props_bind' => array('cat_id', 'ordering'), '' => array('date_pub', 'user_id', 'parent_id', 'parent_type', 'is_comments_on', 'is_approved', 'date_approved', 'comments', 'rating', 'is_private', 'is_parent_hidden', 'photos_count', 'date_pub_end', 'date_last_modified', 'title'));
    $add_ctype_indexes = array('_cats' => array('ns_left' => array('ns_level', 'ns_right', 'ns_left'), 'parent_id' => array('parent_id', 'ns_left')), '_props_bind' => array('ordering' => array('cat_id', 'ordering')), '' => array('date_pub' => array('is_pub', 'is_parent_hidden', 'is_approved', 'date_pub'), 'parent_id' => array('parent_id', 'parent_type', 'date_pub'), 'user_id' => array('user_id', 'date_pub'), 'date_pub_end' => array('date_pub_end')));
    $add_ctype_fulltext_indexes = array('' => array('title' => array('title')));
    foreach ($ctypes as $ctype) {
        // меняем типы сео полям
        foreach ($varchar_fields as $varchar_field) {
            $core->db->query("ALTER TABLE  `{#}{$content_model->table_prefix}{$ctype['name']}` CHANGE  `{$varchar_field}`  `{$varchar_field}` VARCHAR( 256 ) NULL DEFAULT NULL;");
            $core->db->query("ALTER TABLE  `{#}{$content_model->table_prefix}{$ctype['name']}_cats` CHANGE  `{$varchar_field}`  `{$varchar_field}` VARCHAR( 256 ) NULL DEFAULT NULL;");
        }
        // комментарии по умолчанию включены
        $core->db->query("ALTER TABLE  `{#}{$content_model->table_prefix}{$ctype['name']}` CHANGE  `is_comments_on`  `is_comments_on` TINYINT( 1 ) UNSIGNED NULL DEFAULT  '1'");
        // для текущих записей включаем их
        $core->db->query("UPDATE `{#}{$content_model->table_prefix}{$ctype['name']}` SET `is_comments_on` =  '1'");
        // удаляем ненужные индексы
        foreach ($remove_ctype_indexes as $table_postfix => $rcci) {
            foreach ($rcci as $index_name) {
                $core->db->dropIndex($content_model->table_prefix . $ctype['name'] . $table_postfix, $index_name);
            }
        }
        // добавляем нужные обычные индексы
        foreach ($add_ctype_indexes as $table_postfix => $indexes) {
            foreach ($indexes as $index_name => $fields) {
                $core->db->addIndex($content_model->table_prefix . $ctype['name'] . $table_postfix, $fields, $index_name);
            }
        }
        // добавляем FULLTEXT индексы только для поля title. остальные поля включаются в индекс в настройках
        foreach ($add_ctype_fulltext_indexes as $table_postfix => $fulltext_indexes) {
            foreach ($fulltext_indexes as $index_name => $fields) {
                $core->db->addIndex($content_model->table_prefix . $ctype['name'] . $table_postfix, $fields, $index_name, 'FULLTEXT');
            }
        }
    }
    if (!$core->db->isFieldExists('content_datasets', 'index')) {
        $core->db->query("ALTER TABLE `{#}content_datasets` ADD `index` VARCHAR(40) NULL DEFAULT NULL COMMENT 'Название используемого индекса' AFTER `sorting`, ADD INDEX (`index`);");
    }
    if (!$core->db->isFieldExists('controllers', 'is_external')) {
        $core->db->query("ALTER TABLE `{#}controllers` ADD `is_external` TINYINT(1) UNSIGNED NULL DEFAULT NULL COMMENT 'Сторонний компонент' AFTER `is_backend`");
    }
    if (!$core->db->isFieldExists('rss_feeds', 'template')) {
        $core->db->query("ALTER TABLE  `{#}rss_feeds` ADD  `template` VARCHAR(30) NOT NULL DEFAULT  'feed' COMMENT  'Шаблон ленты';");
    }
    if (!$core->db->isFieldExists('images_presets', 'quality')) {
        $core->db->query("ALTER TABLE  `{#}images_presets` ADD  `quality` TINYINT(1) NOT NULL DEFAULT  '90';");
    }
    if (!$core->db->getRowsCount('perms_rules', "controller = 'content' AND name = 'disable_comments'", 1)) {
        $core->db->query("INSERT INTO `{#}perms_rules` (`controller`,`name`,`type`,`options`) VALUES ('content','disable_comments','flag', NULL)");
    }
    $core->db->query("UPDATE `{#}perms_rules` SET `options` = 'own,all,full_delete' WHERE controller = 'comments' AND name = 'delete'");
    // для всех датасетов создаем индексы, если нужно
    $datasets = $content_model->select('ct.name', 'ctype_name')->joinInner('content_types', 'ct', 'ct.id = i.ctype_id')->get('content_datasets', function ($item, $model) {
        $item['filters'] = cmsModel::yamlToArray($item['filters']);
        $item['sorting'] = cmsModel::yamlToArray($item['sorting']);
        return $item;
    });
    if ($datasets) {
        foreach ($datasets as $dataset) {
            $index = $content_model->addContentDatasetIndex($dataset, $dataset['ctype_name']);
            $content_model->update('content_datasets', $dataset['id'], array('index' => $index), true);
        }
    }
    $config = cmsConfig::getInstance();
    $values = $config->getAll();
    $values['db_engine'] = 'InnoDB';
    if (!$config->save($values)) {
        cmsUser::addSessionMessage('Не могу записать файл конфигурации сайта. Добавьте в него строку <b>"db_engine" => "InnoDB",</b>', 'info');
    }
    // если вдруг для каких то компонентов нет конфига в таблице cms_controllers
    // пропускаем компонент карты сайта, т.к. там конфиг динамический
    // будем надеяться, что опции в нем хоть раз сохранялись =)
    $controllers = $content_model->filterNotEqual('name', 'sitemap')->get('controllers', function ($item, $model) {
        $item['options'] = cmsModel::yamlToArray($item['options']);
        return $item;
    }, 'name');
    foreach ($controllers as $controller) {
        $controller_root_path = cmsConfig::get('root_path') . 'system/controllers/' . $controller['name'] . '/';
        $form_file = $controller_root_path . 'backend/forms/form_options.php';
        $form_name = $controller['name'] . 'options';
        cmsCore::loadControllerLanguage($controller['name']);
        $form = cmsForm::getForm($form_file, $form_name, false);
        if ($form) {
            $options = $form->parse(new cmsRequest(cmsController::loadOptions($controller['name'])));
        } else {
            $options = null;
        }
        $content_model->filterEqual('name', $controller['name'])->updateFiltered('controllers', array('options' => $options));
    }
}
Exemple #24
0
 public function getCommentsModerators()
 {
     // сначала ищем юзеров, которым разрешено модерировать
     $moderators = cmsPermissions::getRulesGroupMembers('comments', 'is_moderator');
     if (!$moderators) {
         // не нашли модераторов, получаем администраторов
         $moderators = $this->filterEqual('is_admin', 1)->selectList(array('i.id' => 'id', 'i.notify_options' => 'notify_options', 'i.email' => 'email', 'i.nickname' => 'nickname', 'i.avatar' => 'avatar'), true)->get('{users}', function ($item, $model) {
             $item['notify_options'] = cmsModel::yamlToArray($item['notify_options']);
             $item['is_online'] = cmsUser::userIsOnline($item['id']);
             return $item;
         });
     }
     return $moderators;
 }
Exemple #25
0
 /**
  * Сохраняет опции контроллера
  * @param string $controller_name
  * @param array $options
  * @return boolean
  */
 static function saveOptions($controller_name, $options)
 {
     $model = new cmsModel();
     $model->filterEqual('name', $controller_name);
     $model->updateFiltered('controllers', array('options' => $options));
     cmsCache::getInstance()->clean('controllers');
     return true;
 }
Exemple #26
0
 private function widgetUpdate($manifest)
 {
     $model = new cmsModel();
     $model->filterEqual('name', $manifest['package']['name'])->filterEqual('controller', $manifest['package']['controller'])->updateFiltered('widgets', array('title' => $manifest['info']['title'], 'author' => isset($manifest['author']['name']) ? $manifest['author']['name'] : LANG_CP_PACKAGE_NONAME, 'url' => isset($manifest['author']['url']) ? $manifest['author']['url'] : null, 'version' => $manifest['version']['major'] . '.' . $manifest['version']['minor'] . '.' . $manifest['version']['build']));
     return 'widgets';
 }
Exemple #27
0
 public function deleteCategory($ctype_name, $id, $is_delete_content = false)
 {
     $category = $this->getCategory($ctype_name, $id);
     $this->filterCategory($ctype_name, $category, true);
     if (!$is_delete_content) {
         $table_name = $this->table_prefix . $ctype_name;
         $this->updateFiltered($table_name, array('category_id' => 1));
     }
     if ($is_delete_content) {
         $items = $this->getContentItems($ctype_name);
         if ($items) {
             foreach ($items as $item) {
                 $this->deleteContentItem($ctype_name, $item['id']);
             }
         }
     }
     $this->unbindContentProps($ctype_name, $id);
     parent::deleteCategory($ctype_name, $id);
 }
Exemple #28
0
 /**
  * Возвращает пользователей групп, для которых переданное правило включено
  * или установлено в значение $value
  *
  * @param string $controller Название компонента
  * @param string $name Название правила
  * @param mixed $value Значение правила. Если не передано, значение не учитывается
  * @param string $subject Субъект правила. Если не передан, то одинаков с компонентом
  *
  * @return array Массив пользователей с данными: id, email, nickname, avatar, notify_options, is_online
  */
 static function getRulesGroupMembers($controller, $name, $value = false, $subject = false)
 {
     if (!$subject) {
         $subject = $controller;
     }
     $model = new cmsModel();
     $rule = $model->filterEqual('controller', $controller)->filterEqual('name', $name)->getItem('perms_rules');
     if (!$rule) {
         return array();
     }
     $model->filterEqual('subject', $subject)->filterEqual('rule_id', $rule['id']);
     if ($value) {
         $model->filterEqual('value', $value);
     }
     $groups_ids = $model->selectOnly('group_id')->get('perms_users', function ($item, $model) {
         return $item['group_id'];
     }, 'group_id');
     if (!$groups_ids) {
         return array();
     }
     return $model->filterIn('group_id', $groups_ids)->selectOnly('user_id', 'id')->joinUser('user_id', array('u.notify_options' => 'notify_options', 'u.email' => 'email', 'u.nickname' => 'nickname', 'u.avatar' => 'avatar'))->get('{users}_groups_members', function ($item, $model) {
         $item['notify_options'] = cmsModel::yamlToArray($item['notify_options']);
         $item['is_online'] = cmsUser::userIsOnline($item['id']);
         return $item;
     });
 }
Exemple #29
0
 /**
  * Уменьшает счетчик загруженных пользователем файлов
  * @return bool
  */
 public function decreaseFilesCount()
 {
     $this->files_count--;
     $model = new cmsModel();
     $model->filterEqual('id', $this->id);
     return $model->decrement('{users}', 'files_count');
 }
Exemple #30
0
 public function renderItemsList($ctype, $page_url, $hide_filter = false, $category_id = 0, $filters = array(), $dataset = false, $ext_hidden_params = array())
 {
     $props = $props_fields = false;
     // Получаем поля для данного типа контента
     $fields = cmsCore::getModel('content')->getContentFields($ctype['name']);
     $page = $this->request->get('page', 1);
     $perpage = empty($ctype['options']['limit']) ? self::perpage : $ctype['options']['limit'];
     if ($hide_filter) {
         $ctype['options']['list_show_filter'] = false;
     }
     if ($category_id && $category_id > 1) {
         // Получаем поля-свойства
         $props = cmsCore::getModel('content')->getContentProps($ctype['name'], $category_id);
         $props_fields = $this->getPropsFields($props);
     }
     // проверяем запросы фильтрации по полям
     foreach ($fields as $name => $field) {
         if (!$field['is_in_filter']) {
             continue;
         }
         if (!$this->request->has($name)) {
             continue;
         }
         $value = $this->request->get($name, false, $field['handler']->getDefaultVarType(true));
         if (!$value) {
             continue;
         }
         if ($field['handler']->applyFilter($this->model, $value) !== false) {
             $filters[$name] = $value;
         }
     }
     // проверяем запросы фильтрации по свойствам
     if (isset($props) && is_array($props)) {
         foreach ($props as $prop) {
             $name = "p{$prop['id']}";
             if (!$prop['is_in_filter']) {
                 continue;
             }
             if (!$this->request->has($name)) {
                 continue;
             }
             $prop['handler'] = $props_fields[$prop['id']];
             $value = $this->request->get($name, false, $prop['handler']->getDefaultVarType(true));
             if (!$value) {
                 continue;
             }
             if ($this->model->filterPropValue($ctype['name'], $prop, $value) !== false) {
                 $filters[$name] = $value;
             }
         }
     }
     // Приватность
     // флаг показа только названий
     $hide_except_title = !empty($ctype['options']['privacy_type']) && $ctype['options']['privacy_type'] == 'show_title';
     // Сначала проверяем настройки типа контента
     if (!empty($ctype['options']['privacy_type']) && in_array($ctype['options']['privacy_type'], array('show_title', 'show_all'), true)) {
         $this->model->disablePrivacyFilter();
         if ($ctype['options']['privacy_type'] != 'show_title') {
             $hide_except_title = false;
         }
     }
     // А потом, если разрешено правами доступа, отключаем фильтр приватности
     if (cmsUser::isAllowed($ctype['name'], 'view_all')) {
         $this->model->disablePrivacyFilter();
         $hide_except_title = false;
     }
     // Постраничный вывод
     $this->model->limitPage($page, $perpage);
     list($ctype, $this->model) = cmsEventsManager::hook('content_list_filter', array($ctype, $this->model));
     list($ctype, $this->model) = cmsEventsManager::hook("content_{$ctype['name']}_list_filter", array($ctype, $this->model));
     // Получаем количество и список записей
     $total = $this->model->getContentItemsCount($ctype['name']);
     $items = $this->model->getContentItems($ctype['name']);
     // если запрос через URL
     if ($this->request->isStandard()) {
         if (!$items && $page > 1) {
             cmsCore::error404();
         }
     }
     // Рейтинг
     if ($ctype['is_rating'] && $items && $this->isControllerEnabled('rating')) {
         $rating_controller = cmsCore::getController('rating', new cmsRequest(array('target_controller' => $this->name, 'target_subject' => $ctype['name']), cmsRequest::CTX_INTERNAL));
         $is_rating_allowed = cmsUser::isAllowed($ctype['name'], 'rate');
         foreach ($items as $id => $item) {
             $is_rating_enabled = $is_rating_allowed && $item['user_id'] != $this->cms_user->id;
             $items[$id]['rating_widget'] = $rating_controller->getWidget($item['id'], $item['rating'], $is_rating_enabled);
         }
     }
     list($ctype, $items) = cmsEventsManager::hook('content_before_list', array($ctype, $items));
     list($ctype, $items) = cmsEventsManager::hook("content_{$ctype['name']}_before_list", array($ctype, $items));
     cmsModel::cacheResult('current_ctype_fields', $fields);
     cmsModel::cacheResult('current_ctype_props', $props);
     cmsModel::cacheResult('current_ctype_props_fields', $props_fields);
     $this->cms_template->setContext($this);
     $html = $this->cms_template->renderContentList($ctype, array('category_id' => $category_id, 'page_url' => $page_url, 'ctype' => $ctype, 'fields' => $fields, 'props' => $props, 'props_fields' => $props_fields, 'filters' => $filters, 'ext_hidden_params' => $ext_hidden_params, 'page' => $page, 'perpage' => $perpage, 'total' => $total, 'items' => $items, 'user' => $this->cms_user, 'dataset' => $dataset, 'hide_except_title' => $hide_except_title), new cmsRequest(array(), cmsRequest::CTX_INTERNAL));
     $this->cms_template->restoreContext();
     return $html;
 }