Exemplo n.º 1
0
 public function getcomentarioAction()
 {
     self::requireIsPost();
     General::permissaoAuth(false);
     $arComentario = current(Model_Comentario::getInstance()->get(array('nu_post' => $this->getRequest()->getParam('nu_post'), 'limit' => $this->getRequest()->getParam('limit'))));
     if (count($arComentario)) {
         foreach ($arComentario as $item) {
             $item['size'] = 32;
             echo General::compressHtml($this->view->partial('helpers/li_post.phtml', $item));
         }
     }
 }
Exemplo n.º 2
0
 public function get($param)
 {
     $bind = array();
     $bind['dt_fuso'] = $_SESSION['tw_auth']['dt_fuso'];
     $sql = "SELECT\n\t\t\tp.co_post,\n\t\t\tp.nu_post,\n            u.co_usuario,\n\t\t\tu.nu_usuario,\n\t\t\tu.no_email,\n\t\t\tu.no_usuario,\n\t\t\tp.tx_post,\n\t\t\tCONVERT_TZ(p.dt_cadastro,'+00:00',:dt_fuso) dt_cadastro,\n\t\t\tp.dt_cadastro dt_cadastro_utc,\n\t\t\ttp.qt_comentario,\n\t\t\ti.nu_imagem\n\t\tFROM\n\t\ttb_post p\n\t\tJOIN\n\t\t( \n            SELECT\n\t\t\t    p.co_post,\n\t\t\t    if(c.co_comentario is null,0,count(*)) qt_comentario\n\t\t    FROM\n\t\t    tb_post p\n\t\t    JOIN tb_usuario u\n\t\t\t    ON u.co_usuario = p.co_usuario ";
     if ($param['tipo'] == "amigo") {
         $sql .= " JOIN tb_seguidor s\n\t            ON s.co_usuario_seguido = u.co_usuario ";
     }
     $sql .= " LEFT JOIN tb_comentario c\n\t                ON c.co_post = p.co_post AND c.st_ativo = 1\n                WHERE p.st_ativo = 1\n\t            AND u.st_ativo = 1 ";
     if ($param['tipo'] == "rede") {
         $sql .= " AND u.co_pais = :co_pais ";
         $bind['co_pais'] = $_SESSION['tw_auth']['co_pais'];
     }
     if ($param['tipo'] == "amigo") {
         $sql .= " AND s.co_usuario_seguidor = :co_usuario_seguidor";
         $bind['co_usuario_seguidor'] = $_SESSION['tw_auth']['co_usuario'];
     }
     if ($param['tipo'] == "usuario") {
         if ($param['nu_usuario']) {
             $sql .= " AND u.nu_usuario = :nu_usuario";
             $bind['nu_usuario'] = $param['nu_usuario'];
         } else {
             $sql .= " AND u.co_usuario = :co_usuario";
             $bind['co_usuario'] = $param['co_usuario'];
         }
     }
     if ($param['tipo'] == "id") {
         $sql .= " AND p.nu_post = :nu_post";
         $bind['nu_post'] = $param['nu_post'];
     }
     if ($param['uptime']) {
         $sql .= " AND p.dt_cadastro < :dt_cadastro";
         $bind['dt_cadastro'] = $param['uptime'];
     }
     $sql .= " GROUP BY p.co_post\n                    ORDER BY p.dt_cadastro desc\n                    LIMIT 10 ) tp ON tp.co_post = p.co_post\n        JOIN tb_usuario u ON u.co_usuario = p.co_usuario\n        LEFT JOIN tb_imagem i ON i.co_imagem = u.co_imagem";
     $cache_id = "pst_" . md5(serialize($param) . serialize($bind));
     $cache = General::cache(10);
     General::setCacheID('pst', $cache_id);
     $rs = $cache->load($cache_id);
     if (!$rs) {
         $rs = $this->getAdapter()->fetchAll($sql, $bind);
         $cache->save($rs, $cache_id);
     }
     unset($cache);
     $arIDPost = array();
     $arReturn = array();
     if (count($rs)) {
         foreach ($rs as $item) {
             if ($item['qt_comentario'] > 0) {
                 $arIDPost[] = $item['co_post'];
             }
         }
         $arComentario = array();
         if (count($arIDPost)) {
             $arComentario = Model_Comentario::getInstance()->get(array("co_post" => $arIDPost, "limit" => $param['tipo'] == "id" ? 100 : 3));
         }
         foreach ($rs as $item) {
             $arReturn[$item['co_post']] = $item;
             $arReturn[$item['co_post']]['comentario'] = $arComentario[$item['co_post']];
         }
         unset($arComentario);
         unset($rs);
         unset($arIDPost);
         return $arReturn;
     } else {
         return array();
     }
 }