]> git.llucax.com Git - z.facultad/75.43/tp1.git/blobdiff - src/lib/faq.functions.php
Cambio mi listador.
[z.facultad/75.43/tp1.git] / src / lib / faq.functions.php
index 95bf4ffefc9db0397ba6a526149538fd49f2451d..abf95d0e6b248027ec841049c00e603de2841e51 100644 (file)
-<?php\r
-// vim: set binary noeol et sw=4 sts=4 :\r
-// Grupo 10\r
-//\r
-// Lucarella, Schein, Arena\r
-//\r
-// Creado: Jonathan Schein ( 01/05/2005 )\r
-//\r
-// $Id: faq.functions.php\r
-\r
-require_once 'Pregunta.php';\r
-require_once 'Respuesta.php';  \r
-\r
-function Faq_ObtenerPreguntas()\r
-{\r
- // Verifica que el file que guarda las preguntas exista\r
- // Si no existe, devuelve un array vacio\r
- if ( file_exists ( "data/preguntas.txt" ) )\r
- {\r
-       $RespuestasPorPregunta = array();\r
-       \r
-       if ( file_exists ( "data/respuestas.txt" ) )\r
-       {\r
-        // Levanta todas las respuestas existentes de un archivo,\r
-        // Para luego vincularlas con las preguntas\r
-        $respuestasPlano = file("data/respuestas.txt");\r
-       \r
-        foreach($respuestasPlano as $row)\r
-        {\r
-          $objRespuesta = new Respuesta;\r
-                \r
-                $rowDiv = explode("|",$row);\r
-                $objRespuesta->idPregunta      = $rowDiv[0];\r
-                $objRespuesta->autor                   = $rowDiv[1];\r
-                $objRespuesta->fecha                           = date('d/m/y H:i:s', $rowDiv[2]);\r
-                $objRespuesta->texto                   = $rowDiv[3];\r
-                // La respuesta no fue rankeada\r
-                // ToDo: Manejar los rankings de preguntas\r
-                $objRespuesta->ranking         = -1;\r
-                \r
-                if ( array_key_exists($objRespuesta->idPregunta, $RespuestasPorPregunta ) )\r
-                {\r
-                        $ListaRespuestas = $RespuestasPorPregunta[$objRespuesta->idPregunta];\r
-                }\r
-                else\r
-                {\r
-                                $ListaRespuestas = array();\r
-                }\r
-               \r
-                // Agrega la respuesta a la lista de respuestas correspondiente a una pregunta\r
-                $ListaRespuestas[] = $objRespuesta;\r
-               \r
-                // Guarda la lista de respuestas de la pregunta                \r
-                $RespuestasPorPregunta[$objRespuesta->idPregunta] = $ListaRespuestas;   \r
-         }\r
-       }\r
-       \r
-       $preguntasDesactivadas = array();\r
-       \r
-       if ( file_exists("data/desactivadas.txt" ) )\r
-       {\r
-               $desactivadasPlano = file("data/desactivadas.txt");\r
-               foreach ($desactivadasPlano as $row)\r
-               {\r
-                $rowDiv = explode("|",$row);\r
-                $preguntasDesactivadas[$rowDiv[0]] = "0";\r
-               }\r
-       } \r
-       \r
-       $preguntasPlano = file("data/preguntas.txt");\r
-       \r
-       foreach($preguntasPlano as $row) \r
-       {\r
-         $objPregunta = new Pregunta;\r
-\r
-               $rowDiv = explode("|",$row);\r
-               $objPregunta->id                                        = $rowDiv[0];\r
-               $objPregunta->autor                     = $rowDiv[1];\r
-               $objPregunta->fecha                             = date('d/m/y H:i:s', $rowDiv[2]);\r
-               $objPregunta->texto                     = $rowDiv[3];\r
-               \r
-               // Verifica si una pregunta esta activa o fue dada de baja\r
-               if ( array_key_exists($objPregunta->id, $preguntasDesactivadas) )\r
-               {\r
-                $objPregunta->activa                   = 0;\r
-               }\r
-               else\r
-               {\r
-                $objPregunta->activa                   = 1;\r
-               }\r
-               \r
-               // Busca las respuestas a la pregunta\r
-               if ( array_key_exists($objPregunta->id, $RespuestasPorPregunta ) )\r
-               {\r
-                         $objPregunta->respuestas = $RespuestasPorPregunta[$objPregunta->id];\r
-               }\r
-               \r
-               $Preguntas[] = $objPregunta;\r
-       }\r
-       return $Preguntas;\r
- }\r
- return;\r
-}\r
-\r
-function Faq_IngresarPregunta($UsrId, $Pregunta)\r
-{\r
- $Fecha        = time();\r
-\r
- $Preguntas = Faq_ObtenerPreguntas();\r
- $CantidadPreguntas = count($Preguntas);\r
-\r
- $NuevoId= 0;\r
- if ( $CantidadPreguntas != 0 )\r
- {\r
-   $PreguntaObj = $Preguntas[$CantidadPreguntas -1];\r
-        $NuevoId = $PreguntaObj->id;\r
-        $NuevoId = $NuevoId + 1;\r
- }\r
-\r
- //Formato:\r
- // PreguntaId | UserId | Fecha | Pregunta\r
- $Linea = $NuevoId."|".$UsrId."|".$Fecha."|".$Pregunta."\r\n";\r
- $fp = fopen("data/preguntas.txt","a");\r
- if(!$fp) \r
- {\r
-   return "Error en el archivo";\r
- }\r
- fwrite($fp, $Linea);\r
- fclose($fp);\r
- return "La pregunta fue dada de alta correctamente";\r
-}\r
-\r
-function Faq_IngresarRespuesta($PreguntaId, $UsrId, $Respuesta)\r
-{\r
- $Fecha        = time();\r
-\r
- //Formato:\r
- // PreguntaRespondidaId| UserId | Fecha | Respuesta\r
- $Linea = $PreguntaId."|".$UsrId."|".$Fecha."|".$Respuesta."\r\n";\r
- $fp = fopen("data/respuestas.txt","a");\r
- if(!$fp) \r
- {\r
-   return "Error en el archivo";\r
- }\r
- fwrite($fp, $Linea);\r
- fclose($fp);\r
- return "La respuesta fue dada de alta correctamente";\r
-}\r
-\r
-function Faq_ListarPreguntas($Usuario)\r
-{\r
- echo $Usuario->getId();\r
- $Preguntas = Faq_ObtenerPreguntas();\r
\r
- $CantidadPreguntas = count($Preguntas);\r
-\r
- if ( $CantidadPreguntas != 0 )\r
- {\r
- ?>\r
- <form name="faq_listado_preguntas" action="faq.responderPregunta.php" method="post">\r
- <?php \r
-   foreach($Preguntas as $ObjPregunta)\r
-        {\r
-               if ( $ObjPregunta->activa )\r
-               {\r
-                       $ObjPregunta->Mostrar();\r
-                               ?>\r
-                               <input type="radio" name="PreguntaId" value="<?php echo $ObjPregunta->id ?>"> Seleccionar Pregunta <br/> \r
-                               <?php\r
-               }\r
-        }\r
-        ?>\r
-        <input type=submit value="Responder Pregunta">\r
-   </form>\r
-<?php\r
- }\r
- else\r
- {\r
-       echo "NO HAY PREGUNTAS PARA MOSTRAR";\r
- }\r
- if ( $Usuario->esAdmin() )\r
- {\r
-               //echo "<a href='faq.desactivarPregunta.php'>Pasar preguntas a un log historico</a><br/>";\r
-               include 'faq.desactivarPregunta.php';\r
- }\r
-}\r
-\r
-function Faq_DesactivarPregunta( $PreguntaId )\r
-{\r
- $fp = fopen("data/desactivadas.txt","a");\r
- if(!$fp) \r
- {\r
-   return "Error en el archivo";\r
- }\r
- fwrite($fp, $PreguntaId."|".time()."\r\n");\r
- fclose($fp);\r
- return "La pregunta fue dada de baja, no sera listada mas, pero conservada en un historico";   \r
-}\r
-?>\r
+<?php
+// vim: set binary noeol et sw=4 sts=4 :
+// Grupo 10
+//
+// Lucarella, Schein, Arena
+//
+// Creado: Jonathan Schein ( 01/05/2005 )
+//
+// $Id$
+
+require_once 'Pregunta.php';
+require_once 'Respuesta.php';
+require_once 'file.creditos.php'; 
+require_once 'file.php';
+require_once 'pagina.php';
+require_once 'file.log.php';
+
+// Levanta las respuestas del archivo, y devuelve
+// todas las respuestas para una pregunta determinada
+function Faq_ObtenerRespuestas($PreguntaId)
+{
+ // Levanta las puntuaciones de respuestas desde el archivo
+       // Si existe el archivo
+       $calificaciones = array();
+       if ( file_exists ( "data/calificacion.csv" ) )
+       {
+        $fp = @fopen("data/calificacion.csv", 'r');
+        while ($data = fgetcsv ($fp, 4096)) 
+        {      
+                       $calificaciones[$data[0]] = $data[1];   
+   }
+        fclose ($fp);
+       }
+       
+       $respuestasPorPregunta = array();
+       
+       if ( file_exists ( "data/respuestas.csv" ) )
+       {
+        // Levanta todas las respuestas existentes de un archivo,
+        // Para luego vincularlas con las preguntas
+        $respuestasPlano = @fopen("data/respuestas.csv", 'r');
+       
+        $respuestaId = 1;
+        while($rowDiv = fgetcsv($respuestasPlano,4069))
+        {
+          $objRespuesta = new Respuesta;
+                
+                $objRespuesta->idPregunta      = $rowDiv[0];
+                $objRespuesta->id                                      = $respuestaId;
+                $objRespuesta->autorPregunta = $rowDiv[1];
+                $objRespuesta->autor                   = $rowDiv[2];
+                $objRespuesta->fecha                           = date('d/m/y H:i:s', $rowDiv[3]);
+                $objRespuesta->texto                   = $rowDiv[4];
+                // Agrega la calificacion de la respuesta, si es que esta calificada
+                if ( array_key_exists($respuestaId, $calificaciones ) )
+                {
+                                $objRespuesta->ranking         = $calificaciones[$respuestaId];
+                }
+                else
+                {
+                                $objRespuesta->ranking         = -1;
+                }
+                
+                $respuestaId++;
+                
+                if ( array_key_exists($objRespuesta->idPregunta, $respuestasPorPregunta ) )
+                {
+                        $listaRespuestas = $respuestasPorPregunta[$objRespuesta->idPregunta];
+                }
+                else
+                {
+                                $listaRespuestas = array();
+                }
+               
+                // Agrega la respuesta a la lista de respuestas correspondiente a una pregunta
+                $listaRespuestas[] = $objRespuesta;
+               
+                // Guarda la lista de respuestas de la pregunta                
+                $respuestasPorPregunta[$objRespuesta->idPregunta] = $listaRespuestas;   
+         }
+               fclose($respuestasPlano);
+       }
+       if ( array_key_exists ( $PreguntaId, $respuestasPorPregunta  ) )
+       {
+        return Faq_SortRespuestasByRanking($respuestasPorPregunta[$PreguntaId]);
+       }
+       else
+       {
+        return;
+       }
+}
+// Levanta las preguntas 
+// Devuelve un array con cada una de las preguntas creadas
+function Faq_ObtenerPreguntas()
+{
+ // Verifica que el file que guarda las preguntas exista
+ // Si no existe, devuelve un array vacio
+ if ( file_exists ( "data/preguntas.csv" ) )
+ {
+       $preguntasDesactivadas = array();
+       
+       if ( file_exists("data/desactivadas.csv" ) )
+       {
+               $desactivadasPlano = @fopen("data/desactivadas.csv", 'r');
+               while ($rowDiv = fgetcsv($desactivadasPlano,4096) )
+               {
+                $preguntasDesactivadas[$rowDiv[0]] = "0";
+               }
+               fclose($desactivadasPlano);
+       } 
+       
+       $preguntasPlano = fopen("data/preguntas.csv", 'r');
+       
+       while($rowDiv = fgetcsv($preguntasPlano, 4096 ) ) 
+       {
+         $objPregunta = new Pregunta;
+
+               $objPregunta->id                                        = $rowDiv[0];
+               $objPregunta->autor                     = $rowDiv[1];
+               $objPregunta->fecha                             = date('d/m/y H:i:s', $rowDiv[2]);
+               $objPregunta->texto                     = $rowDiv[3];
+               
+               // Verifica si una pregunta esta activa o fue dada de baja
+               if ( array_key_exists($objPregunta->id, $preguntasDesactivadas) )
+               {
+                $objPregunta->activa                   = 0;
+               }
+               else
+               {
+                $objPregunta->activa                   = 1;
+               }
+               
+/*             // Busca las respuestas a la pregunta
+               if ( array_key_exists($objPregunta->id, $respuestasPorPregunta ) )
+               {
+                         // Ordena las respuestas por ranking
+                               $objPregunta->respuestas = 
+                                                                                                                                Faq_SortRespuestasByRanking($respuestasPorPregunta[$objPregunta->id]);
+                                                               
+               }
+*/             
+               // Si la pregunta esta activa, la incluye en la lista de preguntas
+               if ( $objPregunta->activa )
+               {
+                $preguntas[] = $objPregunta;
+               }
+       }
+       fclose($preguntasPlano);
+       return $preguntas;
+ }
+ else
+ {
+       return;
+ }
+}
+
+// Obtiene la cantidad de preguntas existentes
+// de manera rapida ( sin armar elobjeto pregunta )
+function Faq_ObtenerCantidadPreguntas()
+{
+ if ( file_exists ( "data/preguntas.csv" ) )
+ {
+       $preguntas = @file("data/preguntas.csv");
+       return count($preguntas);
+ }
+ else
+ {
+       return 0;
+ }
+
+}
+// Ingresa una pregunta en el sistema. 
+// Tiene que haber estado validado que el usuario pueda hacerlo
+function Faq_IngresarPregunta($Usuario, $Pregunta)
+{
+ // Valida nuevamente que el usuario tenga los creditos suficientes para
+ // dar de alta la pregunta
+ if ( $Usuario->GetCreditos() > 0 )
+ {
+  $fecha       = time();
+       // Obtiene la lista de preguntas ya existentes
+       $cantidadPreguntas = Faq_ObtenerCantidadPreguntas();
+       
+  $NuevoId= $cantidadPreguntas + 1;
+  
+  //Formato:
+  // PreguntaId | UserId | Fecha | Pregunta
+  if( !fappendcsv("data/preguntas.csv", array($NuevoId,$Usuario->getId(),$fecha,$Pregunta) ) ) 
+       {
+               return error("Error en el archivo");
+       }
+                
+       // Disminuye el credito del usuario, si es que no es asesor y tiene credito infinito
+       if ( !$Usuario->esAsesor() )
+       {
+        file_creditos_preguntar( $Usuario->getId() );
+       }
+       // Loguea la accion
+       file_log_add($Usuario->getId(), "Da de alta de una pregunta");
+       return ok("La pregunta fue dada de alta correctamente");
+ }
+ else
+ {
+       return error("La pregunta no fue dada de alta. No dispone de credito suficiente");
+ }
+}
+
+// Ingresa una respuesta para una pregunta seleccionada
+// Tienen que estar chequeadas las precondiciones
+function Faq_IngresarRespuesta($PreguntaId, $AutorPreguntaId, $UsrId, $Respuesta)
+{
+ $Fecha        = time();
+
+ //Formato:
+ // PreguntaRespondidaId| AutorDePreguntaId | UserId | Fecha | Respuesta
+ if( !fappendcsv("data/respuestas.csv", array($PreguntaId,$AutorPreguntaId,$UsrId,$Fecha,$Respuesta) ) ) 
+ {
+               return error("Error en el archivo");
+ }
+ // Loguea la accion
+ file_log_add($UsrId, "Da de alta de una respuesta");
+ return ok("La respuesta fue dada de alta correctamente");
+}
+
+function Faq_ListarPreguntas($Usuario)
+{
+       Faq_Listador ( Faq_ObtenerPreguntas() );
+       if ( $Usuario->esAdmin() )
+       {
+               echo "<a href='faq.desactivarPregunta.php'>Pasar preguntas a un log historico</a><br/>";
+  }
+}
+
+function Faq_ListarRespuestas( $PreguntaId, $Pagina )
+{
+       Faq_Listador ( Faq_ObtenerRespuestas($PreguntaId) , $Pagina);
+}
+// La funcion agrega el id de la pregunta a la lista de preguntas desactivadas
+function Faq_DesactivarPregunta( $PreguntaId , $UsrId)
+{
+ // Formato PreguntaID,fechaYHora
+ if( !fappendcsv("data/desactivadas.csv", array($PreguntaId, time()) ) ) 
+ {
+   return error("Error en el archivo");
+ }
+ // Loguea la accion
+ file_log_add($UsrId, "Desactiva una pregunta");
+
+ return ok("La pregunta fue dada de baja, no sera listada mas, pero conservada en un historico");       
+}
+
+// La funcion agrega la calificacion de la respuesta en un log
+function Faq_CalificarRespuesta( $RespuestaId, $Calificacion , $UsrId)
+{
+ if ( file_exists ( "data/respuestas.csv" ) )
+ {
+        $respuestasPlano = @fopen("data/respuestas.csv", 'r');
+        $row = fgetcsv($respuestasPlano,4096);
+        $countRespuesta = 1;
+        while ( ( $countRespuesta != $RespuestaId ) && ( $row = fgetcsv($respuestasPlano,4096) ) )
+        {
+               $countRespuesta ++;
+        }
+        $autorId = $row[2];
+        fclose($respuestasPlano);
+ }
+ else
+ {
+       return warn("No existen respuestas");
+ }
+ if( !fappendcsv("data/calificacion.csv", array($RespuestaId, $Calificacion) ) ) 
+ {
+   return error("Error en el archivo");
+ }
+ $autorPregunta = new Usuario($autorId);
+ // da de alta los creditos, solo si no es asesor
+ if ( !$autorPregunta->esAsesor() )
+ {
+       if ( !file_creditos_add($autorId, $Calificacion ) )
+       {
+               return error("Error al computar los creditos al usuario");
+       }
+ }
+ // Loguea la accion
+ file_log_add($UsrId, "Califica una respuesta con $Calificacion puntos");
+ return ok("La calificacion a la respuesta fue dada de alta");  
+}
+
+function Faq_SortRespuestasByRanking($respuestas)
+{
+ $n = count($respuestas);
+ for ($i=0; $i<$n-1; $i++) 
+ {
+  for ($j=0; $j<$n-1-$i; $j++)
+    if ($respuestas[$j+1]->ranking < $respuestas[$j]->ranking) 
+               {  
+      $tmp = $respuestas[$j];         
+      $respuestas[$j] = $respuestas[$j+1];
+      $respuestas[$j+1] = $tmp;
+       }
+       }
+       return $respuestas;
+}
+function printfl()
+{
+    $args = func_get_args();
+    $args[0] .= "\n";
+    call_user_func_array('printf', $args);
+}
+
+function Faq_Listador($ObjetosAListar,$link = '', $cant = 2)
+{
+                // Calculo posiciones
+    $total = count($ObjetosAListar);
+    if (!$total)
+    {
+        echo error('No se encontraron Items');
+        return;
+    }
+    $from = intval(@$_GET["lista_from"]);
+    $c = min($total - $from, $cant);
+               
+               while ( $c-- )
+    {
+        if ( array_key_exists($from, $ObjetosAListar) )
+                               {
+                               $obj = $ObjetosAListar[$from++];
+                               $obj->toHTML();
+                               }
+    }
+               
+               $pags = ceil($total / $cant);
+    if ($pags == 1) return; 
+    printfl('<table summary="Paginador" border="0"><tr>');
+               // Arrastro query string, si corresponde
+    if ( isset($_SERVER['QUERY_STRING'] ) )
+               {
+                $query = str_replace('&', '&amp;', $_SERVER['QUERY_STRING']);
+               }
+               else
+               {
+                $query = '';
+               }
+    if (($pos = strpos($query, '&amp;lista_from=')) !== false)
+    {
+        if ($pos) $query = substr($query, 0, $pos);
+        else      $query = '';
+    }
+               if (($pos = strpos($query, 'lista_from=')) !== false)
+    {
+        if ($pos) $query = substr($query, 0, $pos );
+        else      $query = '';
+    }
+    for ($i = 0; $i < $pags; ++$i)
+    {
+               $from = $i * $cant;
+                               $q = $query ? "$query&amp;lista_from=$from" : "lista_from=$from";
+                               printfl('<td><a href="%s?%s">%s</a></td>', $link, $q, $i + 1);
+    }
+               printfl('</tr></table>');
+}
+?>
\ No newline at end of file