示例#1
0
文件: barra.php 项目: 4bs4/marifa
 /**
  * Suceso producido cuando se publica un post.
  * @param array $suceso Datos del suceso.
  * @return array
  */
 protected static function suceso_post_publicar($suceso)
 {
     // Verifico si fui yo.
     if ($suceso['objeto_id1'] == Usuario::$usuario_id) {
         return NULL;
     }
     // Cargo datos del post.
     $model_post = new Model_Post((int) $suceso['objeto_id']);
     // Cargo datos de quien publica el post.
     $model_usuario = new Model_Usuario((int) $suceso['objeto_id1']);
     return array('post' => $model_post->as_array(), 'usuario' => $model_post->usuario()->as_array(), 'publica' => $model_usuario->as_array());
 }
示例#2
0
文件: post.php 项目: 4bs4/marifa
 /**
  * Información de un post.
  * @param int $post ID del post a visualizar.
  */
 public function action_index($post)
 {
     // Convertimos el post a ID.
     $post = (int) $post;
     // Cargamos el post.
     $model_post = new Model_Post($post);
     // Verificamos exista.
     if (!is_array($model_post->as_array())) {
         $_SESSION['flash_error'] = 'El post al que intentas acceder no está disponible.';
         Request::redirect('/');
     }
     // Verifico el estado de post y permisos necesarios para acceder.
     switch ($model_post->estado) {
         case Model_Post::ESTADO_BORRADO:
             $_SESSION['flash_error'] = 'El post al que intentas acceder no existe.';
             Request::redirect('/');
             break;
         case Model_Post::ESTADO_PAPELERA:
             if ($model_post->usuario_id !== Usuario::$usuario_id && !Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_VER_PAPELERA)) {
                 $_SESSION['flash_error'] = 'El post al que intentas acceder no se encuentra disponible.';
                 Request::redirect('/');
             }
             break;
         case Model_Post::ESTADO_BORRADOR:
             if ($model_post->usuario_id !== Usuario::$usuario_id && !Usuario::permiso(Model_Usuario_Rango::PERMISO_SITIO_ADMINISTRAR_CONTENIDO)) {
                 $_SESSION['flash_error'] = 'El post al que intentas acceder no se encuentra disponible.';
                 Request::redirect('/');
             }
             break;
         case Model_Post::ESTADO_PENDIENTE:
         case Model_Post::ESTADO_OCULTO:
         case Model_Post::ESTADO_RECHAZADO:
             if ($model_post->usuario_id !== Usuario::$usuario_id && !Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_VER_DESAPROBADO)) {
                 $_SESSION['flash_error'] = 'El post al que intentas acceder no se encuentra disponible.';
                 Request::redirect('/');
             }
             break;
     }
     if ($model_post->as_object()->privado && !Usuario::is_login()) {
         // Asignamos el título.
         $this->template->assign('title', 'Post privado');
         $view = View::factory('post/privado');
         $view->assign('post', $model_post->as_array());
     } else {
         // Asignamos el título.
         $this->template->assign('title', $model_post->as_object()->titulo);
         // Cargamos la vista.
         $view = View::factory('post/index');
         // Verifico si debo contabilizar la visita.
         if (Usuario::$usuario_id != $model_post->as_object()->usuario_id) {
             $model_post->agregar_vista();
         }
         // Mi id.
         $view->assign('me', Usuario::$usuario_id);
         // Verifico si sigo al usuario.
         if ($model_post->usuario_id !== Usuario::$usuario_id) {
             $view->assign('sigue_usuario', $model_post->usuario()->es_seguidor(Usuario::$usuario_id));
         } else {
             $view->assign('sigue_usuario', TRUE);
         }
         // Información del usuario dueño del post.
         $u_data = $model_post->usuario()->as_array();
         $u_data['seguidores'] = $model_post->usuario()->cantidad_seguidores();
         $u_data['posts'] = $model_post->usuario()->cantidad_posts();
         $u_data['comentarios'] = $model_post->usuario()->cantidad_comentarios();
         $u_data['puntos'] = $model_post->usuario()->cantidad_puntos();
         $view->assign('usuario', $u_data);
         unset($u_data);
         // Información del post.
         $pst = $model_post->as_array();
         $pst['contenido_raw'] = $pst['contenido'];
         $pst['contenido'] = Decoda::procesar($pst['contenido']);
         $pst['seguidores'] = $model_post->cantidad_seguidores();
         $pst['puntos'] = $model_post->puntos();
         $pst['favoritos'] = $model_post->cantidad_favoritos();
         $view->assign('post', $pst);
         unset($pst);
         // Verifico las acciones extendidas.
         $view->assign('modificar_ocultar', Usuario::$usuario_id === $model_post->usuario_id || Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_OCULTAR));
         $view->assign('modificar_especiales', Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_FIJAR_PROMOVER));
         $view->assign('modificar_aprobar', Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_VER_DESAPROBADO) || Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_VER_DENUNCIAS));
         //TODO: ver si en todo momento es correcto permitir modificaciones.
         $view->assign('modificar_editar', Usuario::$usuario_id === $model_post->usuario_id || Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_EDITAR));
         $view->assign('modificar_borrar', Usuario::$usuario_id === $model_post->usuario_id || Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_ELIMINAR));
         // Verifico si el usuario puede comentar.
         $view->assign('podemos_comentar', Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_COMENTAR_CERRADO) || $model_post->comentar && Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_COMENTAR));
         // Verifico si el usuario puede votar comentarios.
         $view->assign('podemos_votar_comentarios', Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_VOTAR));
         // Verifico acciones generales.
         if ($model_post->as_object()->usuario_id == Usuario::$usuario_id) {
             $view->assign('es_favorito', TRUE);
             $view->assign('sigo_post', TRUE);
             $view->assign('puntuacion', FALSE);
         } else {
             $view->assign('es_favorito', $model_post->es_favorito(Usuario::$usuario_id));
             $view->assign('sigo_post', $model_post->es_seguidor(Usuario::$usuario_id));
             if (!Usuario::permiso(Model_Usuario_Rango::PERMISO_POST_PUNTUAR) || $model_post->dio_puntos(Usuario::$usuario_id)) {
                 $view->assign('puntuacion', FALSE);
             } else {
                 // Obtenemos puntos disponibles.
                 $m_user = Usuario::usuario();
                 $p_d = $m_user->puntos_disponibles;
                 $p_arr = array();
                 for ($i = 1; $i <= $p_d; $i++) {
                     $p_arr[] = $i;
                 }
                 $view->assign('puntuacion', $p_arr);
                 unset($m_user, $p_d, $p_arr);
             }
         }
         // Categoria del post.
         $view->assign('categoria', $model_post->categoria()->as_array());
         // Etiquetas.
         $view->assign('etiquetas', $model_post->etiquetas());
         // Acciones posibles sobre comentarios.
         $view->assign('comentario_eliminar', Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_ELIMINAR));
         $view->assign('comentario_ocultar', Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_OCULTAR));
         $view->assign('comentario_editar', Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_EDITAR));
         // Comentarios del post.
         $cmts = $model_post->comentarios(NULL);
         $l_cmt = array();
         foreach ($cmts as $cmt) {
             // Verifico omito los no visibles si el usuario no puede verlos.
             if ($cmt->estado !== Model_Comentario::ESTADO_VISIBLE && !Usuario::permiso(Model_Usuario_Rango::PERMISO_COMENTARIO_VER_DESAPROBADO)) {
                 continue;
             }
             $cl_cmt = $cmt->as_array();
             $cl_cmt['contenido_raw'] = $cl_cmt['contenido'];
             $cl_cmt['contenido'] = Decoda::procesar($cl_cmt['contenido']);
             if ($cl_cmt['usuario_id'] == Usuario::$usuario_id) {
                 $cl_cmt['vote'] = TRUE;
             } else {
                 $cl_cmt['vote'] = $cmt->ya_voto(Usuario::$usuario_id);
             }
             $cl_cmt['votos'] = $cmt->cantidad_votos();
             $cl_cmt['usuario'] = $cmt->usuario()->as_array();
             $l_cmt[] = $cl_cmt;
         }
         $view->assign('comentarios', $l_cmt);
         unset($l_cmt, $cmts);
         $view->assign('comentario_content', isset($_POST['comentario']) ? $_POST['comentario'] : NULL);
         $view->assign('comentario_error', get_flash('post_comentario_error'));
         $view->assign('comentario_success', get_flash('post_comentario_success'));
     }
     // Menu.
     $this->template->assign('master_bar', parent::base_menu('posts'));
     $this->template->assign('top_bar', Controller_Home::submenu('index'));
     // Asignamos la vista.
     $this->template->assign('contenido', $view->parse());
 }