Beispiel #1
0
 /**
  * Get the number of rows in the table
  *
  * @param array $options
  *
  * @return int
  */
 public function getCountRowsTable($options = NULL)
 {
     $request = $this->getRequest();
     $params = $request->getParams();
     $table = $params['table'];
     //---------------------------
     if ($table == 'admin.blog_posts') {
         return Default_Model_DbTable_BlogPost::GetPostsCount($this->db, $options);
     }
     if ($table == 'admin.blog_posts_tags') {
         $post_ids = Default_Model_DbTable_BlogPost::GetPostsIds_Array($this->db, $options);
         return Default_Model_DbTable_BlogPostTag::GetPostsTags_Count($this->db, array('post_id' => $post_ids));
     }
     if ($table == 'admin.blog_posts_images') {
         $post_ids = Default_Model_DbTable_BlogPost::GetPostsIds_Array($this->db, $options);
         return Default_Model_DbTable_BlogPostImage::GetPostsImages_Count($this->db, array('post_id' => $post_ids));
     }
     if ($table == 'admin.blog_posts_audio') {
         $post_ids = Default_Model_DbTable_BlogPost::GetPostsIds_Array($this->db, $options);
         return Default_Model_DbTable_BlogPostAudio::GetPostsAudio_Count($this->db, array('post_id' => $post_ids));
     }
     if ($table == 'admin.blog_posts_video') {
         $post_ids = Default_Model_DbTable_BlogPost::GetPostsIds_Array($this->db, $options);
         return Default_Model_DbTable_BlogPostVideo::GetPostsVideo_Count($this->db, array('post_id' => $post_ids));
     }
     if ($table == 'admin.blog_posts_locations') {
         $post_ids = Default_Model_DbTable_BlogPost::GetPostsIds_Array($this->db, $options);
         return Default_Model_DbTable_BlogPostLocation::GetPostsLocations_Count($this->db, array('post_id' => $post_ids));
     }
 }
 /**
  * Action - video
  * upload/download/ordering video
  * 
  * Access to the action is possible in the following paths:
  * - /blogmanager/video
  *
  * @return void
  */
 public function videoAction()
 {
     $json = array();
     $filterSanitize = new Default_Form_Filter_Sanitize();
     //-----------------------
     // Получим обьект записи
     $request = $this->getRequest();
     $params = $request->getParams();
     $post_id = (int) $request->getPost('id');
     if (!$post_id) {
         $post_id = (int) $request->getParam('id');
     }
     $post = new Default_Model_DbTable_BlogPost($this->db);
     // Если конкретной записи нет, то перейдем к странице по умолчанию
     if (!$post->loadForUser($this->_identity->user_id, $post_id)) {
         $this->_redirect('/blogmanager');
     }
     // Определим тип операции над видео: 'upload', 'reorder', 'delete'
     // Загрузка файла с помощью - FileUploader
     if (Default_Plugin_FileUploader::isFileUploader()) {
         // Получим вид загрузчика - Iframe или Xhr
         $fileUploader = Default_Plugin_FileUploader::isFileUploader();
         // list of valid extensions, ex. array("jpeg", "xml", "bmp")
         $allowedExtensions = $params['allowedExtensions'];
         $allowedExtensions = str_replace(' ', '', $allowedExtensions);
         $arrAllowedExtensions = explode(';', $allowedExtensions);
         // max file size in bytes
         $sizeLimit = (int) $request->getParam('sizeLimit');
         // Получим обьект загрузчика файлов
         try {
             $uploader = new Default_Plugin_FileUploader($arrAllowedExtensions, $sizeLimit);
             // Определим путь загрузки файлов
             $path = Default_Model_DbTable_BlogPostVideo::GetUploadPath();
             $path .= '/';
             //Загрузим файлы
             $result = $uploader->handleUpload($path);
         } catch (Exception $e) {
             $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', Default_Plugin_SysBox::getMessageError($e)));
             if ($fileUploader == 'Iframe') {
                 $this->sendJson_Html($json);
             } else {
                 $this->sendJson($json);
             }
             return;
         }
         if (isset($result['success'])) {
             // Создадим обьект изображения
             try {
                 $filename = $path . $uploader->file->getName();
                 $pathinfo = pathinfo($filename);
                 $ext = $pathinfo['extension'];
                 $video = new Default_Model_DbTable_BlogPostVideo($post->getDb());
                 $video->post_id = $post->getId();
                 $video->uploadFile($filename);
                 $video->identifier = basename($filename);
                 $video->type = 'file-' . $ext;
                 if (!$video->save()) {
                     $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                     if ($fileUploader == 'Iframe') {
                         $this->sendJson_Html($json);
                     } else {
                         $this->sendJson($json);
                     }
                     return;
                 }
                 $json['success'] = $result['success'];
                 $json['video_id'] = $video->getId();
                 $json['filename'] = $video->identifier;
                 $json['post_id'] = $video->post_id;
                 $json['form_action'] = $this->getUrl('video', 'blogmanager');
                 // Определим путь к изображению для видео
                 $srcImage = 'images/media/thumbs/' . $video->type . '.png';
                 $json['url_image'] = $this->getUrlRes($srcImage) . '?id=' . $video->getId();
             } catch (Exception $e) {
                 $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', Default_Plugin_SysBox::getMessageError($e)));
                 if ($fileUploader == 'Iframe') {
                     $this->sendJson_Html($json);
                 } else {
                     $this->sendJson($json);
                 }
                 return;
             }
         } else {
             // Error
             $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', $result['error']));
             if ($fileUploader == 'Iframe') {
                 $this->sendJson_Html($json);
             } else {
                 $this->sendJson($json);
             }
             return;
         }
     } else {
         if ($request->getPost('add_video_url')) {
             // Создадим обьект изображения
             try {
                 $strInfoVideo = $request->getPost('info_video');
                 $strInfoVideo = stripslashes($strInfoVideo);
                 $arrInfoVideo = Zend_Json::decode($strInfoVideo);
                 $video = new Default_Model_DbTable_BlogPostVideo($post->getDb());
                 $video->post_id = $post->getId();
                 $video->identifier = $arrInfoVideo['url'];
                 $video->type = $arrInfoVideo['type'];
                 if (!$video->save()) {
                     $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                     $this->sendJson($json);
                     return;
                 }
                 // Определим путь к изображению для видео
                 $srcImage = 'images/media/thumbs/' . $video->type . '.png';
                 $json['video_id'] = $video->getId();
                 $json['filename'] = $video->identifier;
                 $json['post_id'] = $video->post_id;
                 $json['url_image'] = $this->getUrlRes($srcImage) . '?id=' . $video->getId();
                 $json['form_action'] = $this->getUrl('video', 'blogmanager');
                 $json['result'] = $this->Translate('URL на ресурс добавлен');
             } catch (Exception $e) {
                 $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', Default_Plugin_SysBox::getMessageError($e)));
                 $this->sendJson($json);
                 return;
             }
         } else {
             if ($request->getPost('reorder')) {
                 $order = $request->getPost('preview-video');
                 $post->setVideoOrder($order);
             } else {
                 if ($request->getPost('delete')) {
                     $video_id = (int) $request->getPost('image');
                     $video = new Default_Model_DbTable_BlogPostVideo($this->db);
                     if ($video->loadForPost($post->getId(), $video_id)) {
                         $video->delete();
                         // Определим кол. оставшихся изображений
                         $count_videos = count($post->video) - 1;
                         $json = array('deleted' => true, 'image_id' => $video_id, 'count_images' => $count_videos);
                     }
                 } else {
                     if ($request->getPost('comment_update')) {
                         $video_id = (int) $request->getPost('image');
                         $video = new Default_Model_DbTable_BlogPostVideo($this->db);
                         if ($video->loadForPost($post->getId(), $video_id)) {
                             $comment = $request->getPost('comment');
                             // Отфильтруем ненужные теги в комментарии
                             $comment = $filterSanitize->filter($comment);
                             // Выделим название и комментарий
                             $arrComment = explode('#', $comment);
                             // Если тип видео -> 'url-godtv', то важно получить точное название видео
                             // это название должно точно соответствовать пути к загрузочной странице этого видео
                             // пр. http://god-tv.ru/%D0%A0%D0%B5%D1%88%D0%B0%D1%8E%D1%89%D0%B8%D0%B9-%D1%80%D1%8B%D0%B2%D0%BE%D0%BA-%D1%81%D0%BC%D0%BE%D1%82%D1%80%D0%B5%D1%82%D1%8C-%D0%BE%D0%BD%D0%BB%D0%B0%D0%B9%D0%BD
                             // или так %D0%A0%D0%B5%D1%88%D0%B0%D1%8E%D1%89%D0%B8%D0%B9-%D1%80%D1%8B%D0%B2%D0%BE%D0%BA-%D1%81%D0%BC%D0%BE%D1%82%D1%80%D0%B5%D1%82%D1%8C-%D0%BE%D0%BD%D0%BB%D0%B0%D0%B9%D0%BD
                             // или так "Решающий-рывок-смотреть-онлайн"
                             if ($video->type == 'url-godtv') {
                                 $tmpName = urldecode($arrComment[0]);
                                 $tmpNames = explode('/', $tmpName);
                                 $tmpName = $tmpNames[count($tmpNames) - 1];
                                 $arrComment[0] = $tmpName;
                             }
                             if (count($arrComment) > 1) {
                                 $video->name = $arrComment[0];
                                 $video->comment = $arrComment[1];
                             } else {
                                 $video->name = $arrComment[0];
                             }
                             // Сохраним в базе данных
                             if (!$video->save()) {
                                 $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                                 $this->sendJson($json);
                                 return;
                             }
                             $json = array('commented' => true, 'title' => $video->name, 'comment' => $video->comment);
                         }
                     } else {
                         if ($request->getPost('download_images')) {
                             // Загрузим изображения в виде HTML на страницу
                             // Получим файлы видео для статьи
                             $videos = Default_Model_DbTable_BlogPostVideo::GetVideo($this->db, array('post_id' => $post_id));
                             // Создадим обьект шаблона
                             $templater = Default_Plugin_SysBox::createViewSmarty();
                             //Установим параметры шаблона
                             $templater->videos = $videos;
                             $templater->post_id = $post_id;
                             // Получим результат шаблона
                             $html = $templater->render('blogmanager/lib/download-video.tpl');
                             $json = array('downloaded' => true, 'html' => $html);
                         }
                     }
                 }
             }
         }
     }
     if ($this->_isAjaxRequest) {
         $this->sendJson($json);
     } else {
         $this->sendJson_Html($json);
     }
 }
Beispiel #3
0
 /**
  * Get the array of posts satisfying the criteria specified in the parameter $options
  *
  * @param Zend_Db_Adapter_Abstract $db
  * @param array $options
  * @return array
  */
 public static function GetPosts_Array($db, $options = array())
 {
     $arrPosts = FALSE;
     $user_ids = array();
     //----------------------
     // initialize the options
     $defaults = array('offset' => 0, 'limit' => 0, 'order' => 'p.ts_created', 'sort' => true);
     foreach ($defaults as $k => $v) {
         $options[$k] = array_key_exists($k, $options) ? $options[$k] : $v;
     }
     $select = self::_GetBaseQuery($db, $options);
     // set the fields to select
     $select->from(null, 'p.*');
     // set the offset, limit, and ordering of results
     if ($options['limit'] > 0) {
         $select->limit($options['limit'], $options['offset']);
     }
     // Установим параметры сортировки для таблицы
     if ($options['sort']) {
         $select = self::GetSelectForSort($select, $options);
     }
     $strSelect = $select->__toString();
     //------ Применить кеширование -------
     $dbCache = Default_Plugin_SysBox::getCache('db');
     if ($dbCache->getOption('caching')) {
         // Получим TAG для кеширования
         $arrItems = array($select, $options);
         $strSerialize = serialize($arrItems);
         $tagCache = md5($strSerialize);
         // Очистим кеш
         if (Default_Plugin_SysBox::isCleanCache()) {
             $dbCache->clean(Zend_Cache::CLEANING_MODE_ALL);
         }
         // Получим данные из кеша по тегу $tagCache
         $arrPosts = $dbCache->load($tagCache);
     }
     // проверка, есть ли уже данные в кэше:
     if ($arrPosts === FALSE) {
         // fetch user data from database
         $data = $db->fetchAll($select);
         // turn data into array of DatabaseObject_User objects
         $posts = parent::BuildMultiple_Array($db, __CLASS__, $data);
         if (count($posts) == 0) {
             return $posts;
         }
         $post_ids = array_keys($posts);
         // load the profile data for loaded posts
         $profiles = Default_Model_Profile::BuildMultiple_Array($db, 'Default_Model_DbTable_BlogPostProfile', array($post_ids));
         $arrPosts = array();
         foreach ($posts as $post_id => $post) {
             if (array_key_exists($post_id, $profiles)) {
                 $arrPosts[$post_id] = $posts[$post_id] + $profiles[$post_id];
             } else {
                 $arrPosts[$post_id] = $posts[$post_id];
             }
             // Получим ids пользователей для всех сообщениий
             $user_ids[] = $post['user_id'];
         }
         // Уберем повторяющиеся значения из массива
         $user_ids = array_unique($user_ids);
         // Получим всех пользователей
         $options = array('user_id' => $user_ids);
         $users = Default_Model_DbTable_User::GetUsers_Array($db, $options);
         // Добавим пользователя для каждого сообщения
         foreach ($posts as $post_id => $post) {
             $postuser_id = $post['user_id'];
             foreach ($users as $user) {
                 $user_id = $user['id'];
                 if ($user_id == $postuser_id) {
                     $arrPosts[$post_id]['_user_'] = $user;
                     break;
                 }
             }
         }
         // Загрузим изображения для каждого сообщения
         $options = array('post_id' => $post_ids);
         $images = Default_Model_DbTable_BlogPostImage::GetImages_Array($db, $options);
         foreach ($images as $image) {
             $post_id = $image['post_id'];
             $image_id = $image['id'];
             $arrPosts[$post_id]['_images_'][$image_id] = $image;
         }
         // Загрузим координаты для каждого сообщения
         $locations = Default_Model_DbTable_BlogPostLocation::GetLocations_Array($db, $options);
         foreach ($locations as $location) {
             $post_id = $location['post_id'];
             $location_id = $location['id'];
             $arrPosts[$post_id]['_locations_'][$location_id] = $location;
         }
         // Загрузим метки для каждого сообщения
         $tags = Default_Model_DbTable_BlogPostTag::GetTags_Array($db, $options);
         foreach ($tags as $tag) {
             $post_id = $tag['post_id'];
             $tag_id = $tag['id'];
             $arrPosts[$post_id]['_tags_'][$tag_id] = $tag;
         }
         // Загрузим audio для каждого сообщения
         $audios = Default_Model_DbTable_BlogPostAudio::GetAudio_Array($db, $options);
         foreach ($audios as $audio) {
             $post_id = $audio['post_id'];
             $audio_id = $audio['id'];
             $arrPosts[$post_id]['_audio_'][$audio_id] = $audio;
         }
         // Загрузим video для каждого сообщения
         $videos = Default_Model_DbTable_BlogPostVideo::GetVideo_Array($db, $options);
         foreach ($videos as $video) {
             $post_id = $video['post_id'];
             $video_id = $video['id'];
             $arrPosts[$post_id]['_video_'][$video_id] = $video;
         }
         // Загрузим comments для каждого сообщения
         $comments = Default_Model_DbTable_BlogPostComment::GetComments_Array($db, $options);
         foreach ($comments as $comment) {
             $post_id = $comment['post_id'];
             $comment_id = $comment['id'];
             $arrPosts[$post_id]['_comments_'][$comment_id] = $comment;
         }
         // Если разрешено кеширование, то сохраним данные в кеше
         if ($dbCache->getOption('caching')) {
             $dbCache->save($arrPosts, $tagCache);
         }
     } else {
         $result = $arrPosts;
     }
     return $arrPosts;
 }
Beispiel #4
0
 /**
  * Action - videos
  * Actions with the videos. Get a list of videos.
  *
  * Access to the action is possible in the following paths:
  * router pattern - user/:username/post/:post_id/videos/*
  * 
  * - /user/user1/post/27/videos
  *
  * @return void
  */
 public function videosAction()
 {
     $playlist = array();
     //-----------------------
     // Получим файл конфигурации
     $ini = Zend_Registry::get('config');
     $adapter = $ini['http']['adapter'];
     $proxy_host = $ini['proxy']['host'];
     // Получим обьект запроса
     $request = $this->getRequest();
     $params = $request->getParams();
     $type_action = $params['type_action'];
     $username = trim($request->getUserParam('username'));
     $post_id = (int) $request->getUserParam('post_id');
     if ($type_action == 'playlist') {
         // Получим файлы видео для сообщения
         $videos = Default_Model_DbTable_BlogPostVideo::GetVideo($this->db, array('post_id' => $post_id));
         // Получим список видео данных для статьи
         foreach ($videos as $video) {
             // Получим URL ресурса
             $type = $video->type;
             $arrType = explode('-', $type);
             if ($arrType[0] == 'file') {
                 $url = $video->getFullUrl_Res($username);
             } else {
                 $url = $video->identifier;
             }
             $path = $video->GetUploadPath($username) . '/' . $video->getId() . '.json';
             if (is_file($path)) {
                 $strJson = file_get_contents($path);
                 $strJson = stripslashes($strJson);
                 try {
                     // Получим пути к изобржаениям и флеш для пользователя
                     $pathImages = Default_Model_DbTable_BlogPostImage::GetUploadUrl($username);
                     $pathFlash = Default_Model_DbTable_BlogPostVideo::GetUploadUrlForFlash($username);
                     // Преобразуем Json в PHP массив
                     $itemPlaylist = Zend_Json::decode($strJson);
                     // Изменим данные в массиве
                     $itemPlaylist['clip_id'] = $video->getId();
                     $itemPlaylist['clip_type'] = $video->type;
                     $itemPlaylist['url'] = $url;
                     $itemPlaylist['title'] = $video->name;
                     if (isset($itemPlaylist['cuepoints'])) {
                         $cuepoints = $itemPlaylist['cuepoints'];
                         $newCuepoints = array();
                         foreach ($cuepoints as $cuepoint) {
                             if (isset($cuepoint['image'])) {
                                 $cuepoint['image'] = $this->getUrlRes($pathImages . '/' . ltrim($cuepoint['image'], '/'));
                             }
                             if (isset($cuepoint['flash'])) {
                                 $cuepoint['flash'] = $this->getUrlRes($pathFlash . '/' . ltrim($cuepoint['flash'], '/'));
                             }
                             $newCuepoints[] = $cuepoint;
                         }
                         $itemPlaylist['cuepoints'] = $newCuepoints;
                     }
                 } catch (Exception $exc) {
                     $jsons = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка получения видео') . '</em>', Default_Plugin_SysBox::getMessageError($exc)));
                     $this->sendJson($jsons);
                     return;
                 }
             } else {
                 $itemPlaylist = array();
                 $itemPlaylist['clip_id'] = $video->getId();
                 $itemPlaylist['clip_type'] = $video->type;
                 $itemPlaylist['url'] = $url;
                 $itemPlaylist['title'] = $video->name;
                 $itemPlaylist['description'] = $video->comment;
             }
             $playlist[] = $itemPlaylist;
         }
         if ($this->_isAjaxRequest) {
             $this->sendJson($playlist);
         }
     } elseif ($type_action == 'godtv_url') {
         // Получим параметры клипа
         $clip_name = $params['clip_name'];
         $clip_id = $params['clip_id'];
         // Получим файлы видео для сообщения
         $videos = Default_Model_DbTable_BlogPostVideo::GetVideo($this->db, array('post_id' => $post_id));
         // Найдем нужное видео и обновим "identifier"
         foreach ($videos as $video) {
             if ($video->getId() == $clip_id) {
                 // Получим уникальный URL для фильма
                 $arrBox = new Default_Plugin_ArrayBox();
                 $url_video = $arrBox->set($video->identifier, '/')->getLast();
                 // Получим новый URL для этого видео
                 $new_url = $this->_getGodtvURL($clip_name, $url_video);
                 if ($new_url === FALSE) {
                     $jsons = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка URL') . '</em>', $this->Translate('Ошибка получения URL для видео')));
                     $this->sendJson($jsons);
                     return;
                 }
                 $video->identifier = $new_url;
                 if ($video->save()) {
                     $json = array('url' => $new_url);
                 } else {
                     $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                 }
                 $this->sendJson($json);
                 return;
             }
         }
     } elseif ($type_action == 'play') {
         $json = array('result' => 'OK');
         $this->sendJson($json);
         return;
     }
 }