/** * 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 - audio * upload/download/ordering audio * * Access to the action is possible in the following paths: * - /blogmanager/audio * * @return void */ public function audioAction() { $json = array(); $filterSanitize = new Default_Form_Filter_Sanitize(); //----------------------- // Получим обьект записи $request = $this->getRequest(); $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 = explode(';', $request->getParam('allowedExtensions')); // max file size in bytes $sizeLimit = (int) $request->getParam('sizeLimit'); // Получим обьект загрузчика файлов try { $uploader = new Default_Plugin_FileUploader($allowedExtensions, $sizeLimit); // Определим путь загрузки файлов $path = Default_Model_DbTable_BlogPostAudio::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'])) { // OK // Создадим обьект изображения try { $audio = new Default_Model_DbTable_BlogPostAudio($post->getDb()); $audio->post_id = $post->getId(); $filename = $path . $uploader->file->getName(); $audio->uploadFile($filename); $audio->filename = basename($filename); if (!$audio->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['audio_id'] = $audio->getId(); $json['filename'] = $audio->filename; $json['post_id'] = $audio->post_id; $json['url_image'] = $this->getUrlRes('images/media/thumbs/file-mp3.png') . '?id=' . $audio->getId(); $json['form_action'] = $this->getUrl('audio', 'blogmanager'); } 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('reorder')) { $order = $request->getPost('preview-audio'); $post->setAudioOrder($order); } else { if ($request->getPost('delete')) { $audio_id = (int) $request->getPost('image'); $audio = new Default_Model_DbTable_BlogPostAudio($this->db); if ($audio->loadForPost($post->getId(), $audio_id)) { $audio->delete(); // Определим кол. оставшихся изображений $count_audios = count($post->audio) - 1; $json = array('deleted' => true, 'image_id' => $audio_id, 'count_images' => $count_audios); } } else { if ($request->getPost('comment_update')) { $audio_id = (int) $request->getPost('image'); $audio = new Default_Model_DbTable_BlogPostAudio($this->db); if ($audio->loadForPost($post->getId(), $audio_id)) { $comment = $request->getPost('comment'); $comment = $filterSanitize->filter($comment); $arrComment = explode('#', $comment); if (count($arrComment) > 1) { $audio->name = $arrComment[0]; $audio->comment = $arrComment[1]; } else { $audio->name = $arrComment[0]; } if (!$audio->save()) { $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>')); $this->sendJson($json); return; } $json = array('commented' => true, 'title' => $audio->name, 'comment' => $audio->comment); } } else { if ($request->getPost('download_images')) { // Загрузим изображения в виде HTML на страницу // Получим файлы музыки для статьи $audios = Default_Model_DbTable_BlogPostAudio::GetAudio($this->db, array('post_id' => $post_id)); // Создадим обьект шаблона $templater = Default_Plugin_SysBox::createViewSmarty(); //Установим параметры шаблона $templater->audios = $audios; $templater->post_id = $post_id; // Получим результат шаблона $html = $templater->render('blogmanager/lib/download-audio.tpl'); $json = array('downloaded' => true, 'html' => $html); } } } } } if ($this->_isAjaxRequest) { $this->sendJson($json); } else { $this->sendJson_Html($json); } }
/** * 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; }
/** * Action - audios * Actions with the audios. Get a list of mp3 files and their descriptions * * Access to the action is possible in the following paths: * router pattern - user/:username/post/:post_id/audios/* * * - /user/user1/post/27/audios * * @return void */ public function audiosAction() { $json = array(); $caption = ''; $file = ''; $comment = ''; //----------------------- // Получим обьект запроса $request = $this->getRequest(); $username = trim($request->getUserParam('username')); $post_id = (int) $request->getUserParam('post_id'); // Получим файлы музыки для статьи $audios = Default_Model_DbTable_BlogPostAudio::GetAudio($this->db, array('post_id' => $post_id)); // Получим путь где находяться файлы музыка автора статьи foreach ($audios as $audio) { $arrFilename = explode('.', $audio->filename); $caption = $arrFilename[0]; $comment = $audio->comment; $file = $audio->getFullUrl_Res($username); //Default_Plugin_SysBox::getFullURL_Res($audio->getFullUrl($username)); $json[] = array('caption' => $caption, 'file' => $file, 'comment' => $comment); } if ($this->_isAjaxRequest) { $this->sendJson($json); } }