__construct($padron, $ej, $ent, $intento, $cuat); } /** * Constructor (PHP5). */ function __construct($padron = null, $ej = null, $ent = null, $intento = null, $cuat = null) { $this->padron = $padron; $this->ejercicio = $ej; $this->entrega = $ent; $this->intento = $intento; $this->cuatrimestre = $cuat; $this->base_dir = 'intentos'; } /** * Representación de string */ function __toString() { return <<padron} Ejercicio: {$this->ejercicio} Entrega: {$this->entrega} Cuatrimestre: {$this->cuatrimestre} Intento: {$this->intento} EOT; } /** * Muestra el intento como una línea. */ function to_line() { return "{$this->padron} {$this->ejercicio}.{$this->entrega}.{$this->intento} {$this->cuatrimestre}"; } /** * Toma de los atributos publicos padron, entrega y ejercicio * En el atributo publico intento deja el numero de intento que corresponderia * a esta entrega del alumno y en cuatrimestre el cuatrimestre en que cursa * @param code Código verificador * @param clave Clave a utilizar para validar el código * @return string con la descripcion del error, si esta vacio fue ok */ function validar_entrega($code, $claves) { $query = "SELECT C.id, C.anio, C.cuatrimestre, C.curso FROM alumno A JOIN cuatrimestre C ON (A.id_cuatrimestre = C.id) WHERE A.padron = {$this->padron} AND C.activo = 1"; $inscripto = DB_DataObject::factory('inscripto'); if (!$inscripto->getFrom($this->padron)) return 'El alumno no está inscripto'; $inscripto->getLinks(); $cuat = $inscripto->_curso_id->toLine(); $this->cuatrimestre = $cuat; if (!T_chequear_codigo($code, $this->padron, $claves)) return 'La clave de la entrega no es válida'; $this->llegada = time(); $date = date('Y-m-d H:i:s', $this->llegada); $entrega = DB_DataObject::factory('entrega'); $entrega->getFrom($inscripto->curso_id, $this->ejercicio, $this->entrega); var_dump($this); var_dump($inscripto->id); var_dump($inscripto->curso_id); var_dump($entrega->id); # 2005-01-06, 2005-02-26 20:00:00, 2005-02-03 19:48:15 var_dump($entrega->desde, $entrega->hasta, $date); var_dump($entrega->desde <= $date); var_dump($entrega->hasta >= $date); if (!($entrega->desde <= $date and $entrega->hasta >= $date)) return 'El ejercicio está siendo entregado fuera de fecha'; $intento = DB_DataObject::factory('intento'); $intento->id_entrega = $entrega->id; $intento->id_inscripto = $inscripto->id; $cant = $intento->find(); $this->intento = 1 + $cant; $this->id_entrega = $entrega->id; $this->id_inscripto = $inscripto->id; return ''; } /** * Toma de los atributos publicos cuatrimestre, padron, entrega, ejercicio, mail e intento * Debería llamarse antes a validar_entrega siempre * En el atributo publico intento deja el numero de intento del alumno * @param mail Mail con el que se recibió la entrega * @return resultado del query */ function hacer_entrega($mail) { $intento = DB_DataObject::factory('intento'); $intento->inscripto_id = $this->id_inscripto; $intento->entrega_id = $this->id_entrega; $intento->numero = $this->intento; $intento->llegada = date('Y-m-d H:i:s', $this->llegada); $intento->mail_respuesta = $mail; return $intento->insert(); } /** * Pone en los atributos publicos cuatrimestre, padron, entrega, ejercicio e intento * retorna true si encuentra alguno y false sino. */ function proximo_a_probar() { $result = $this->db->getRow("SELECT cuatrimestre, padron, ejercicio, entrega, intento, mail FROM intento WHERE inicio_pruebas is null ORDER BY llegada LIMIT 1"); if (DB::isError($result) or is_null($result)) return false; $date = date('YmdHis'); $this->cuatrimestre = $result[0]; $this->padron = $result[1]; $this->ejercicio = $result[2]; $this->entrega = $result[3]; $this->intento = $result[4]; $this->db->query("UPDATE intento SET inicio_pruebas = '$date' WHERE cuatrimestre = {$this->cuatrimestre} AND padron = {$this->padron} AND ejercicio = {$this->ejercicio} AND entrega = {$this->entrega} AND intento = {$this->intento}"); return $result[5]; } /** * Toma de los atributos publicos cuatrimestre, padron, entrega, ejercicio e intento * el parametro indica si compilo ok es true, sino es false */ function informar_compilacion($compilo_ok) { if ($compilo_ok) $compilo_ok = 1; else $compilo_ok = 0; $date = date('YmdHis'); return $this->db->query(" UPDATE intento SET fin_pruebas = '$date' AND compila_ok = $compilo_ok WHERE cuatrimestre = {$this->cuatrimestre} AND padron = {$this->padron} AND ejercicio = {$this->ejercicio} AND entrega = {$this->entrega} AND intento = {$this->intento}"); } /** * Toma de los atributos publicos cuatrimestre, padron, entrega, ejercicio e intento * carga el atributo publico caso_de_prueba con el proximo caso de prueba a usar * devuelve true si encuentra alguno, sino devuelve false */ function pedir_caso_de_prueba() { $prueba = $this->db->getRow(" SELECT C.caso_de_prueba, C.privado, C.descripcion, C.parametros, C.salidas FROM caso_de_prueba as C WHERE C.cuatrimestre = $this->cuatrimestre AND C.ejercicio = $this->ejercicio AND C.entrega = $this->entrega AND C.caso_de_prueba NOT IN ( SELECT P.caso_de_prueba from prueba as P WHERE P.cuatrimestre = $this->cuatrimestre AND P.entrega = $this->entrega AND P.ejercicio = $this->ejercicio AND P.padron = $this->padron AND P.intento = $this->intento )"); if (!is_null($prueba) && !DB::isError($prueba)) { list($id, $priv, $desc, $params, $salidas) = $prueba; return new T_Prueba($id, $priv, $desc, $params, $salidas); } return $prueba; } /** * Toma de los atributos publicos cuatrimestre, padron, entrega, ejerciico e intento * Carga los resultados de una prueba en un nuevo registro en prueba */ function resultado_de_prueba($prueba, $salida, $descripcion = "") { if($memoria)$memoria = 1; else $memoria = 0; if($salida)$salida = 1; else $salida = 0; $date = date("YmdHis"); $this->db->query("INSERT INTO prueba (cuatrimestre, padron, ejercicio, entrega, intento, caso_de_prueba, memoria_ok, salida_ok, descripcion) VALUES ($this->cuatrimestre, $this->padron, $this->ejercicio, $this->entrega, $this->intento, $prueba->id, $prueba->memoria, $salida, '$descripcion')"); $this->db->query("UPDATE intento SET fin_pruebas = '$date' WHERE cuatrimestre = {$this->cuatrimestre} AND padron = {$this->padron} AND ejercicio = {$this->ejercicio} AND entrega = {$this->entrega} AND intento = {$this->intento}"); } /** * Busca una de los intentos no notificados cual tiene todas las pruebas terminadas y la * hora de llegada + $hora es menor que ahora. el registro despues se marca como notificado. * Deja en los atributos publicos cuatrimestre, padron, ejercicio, entrega, intento y mail * en mail deja la suma del mail del intento y del mail del alumno * devuelve el/los mails a donde mandar la notificación si encuentra alguno y false sino */ function notificacion_pendiente($horas = 1) { $date = date("YmdHis"); $date -= 10000*$horas; $row = $this->db->getRow("SELECT I.cuatrimestre as cuatrimestre, I.padron, I.ejercicio as ejercicio, I.entrega as entrega, I.intento, I.mail FROM intento I JOIN prueba P ON (I.ejercicio = P.ejercicio AND I.cuatrimestre = P.cuatrimestre AND I.entrega = P.entrega AND I.padron = P.padron AND I.intento = P.intento) WHERE notificado is null AND '$date' >= I.llegada GROUP BY I.cuatrimestre, I.padron, I.ejercicio, I.entrega, I.intento, I.mail HAVING count(P.memoria_ok) = ( SELECT count(1) FROM caso_de_prueba C WHERE ejercicio = C.ejercicio AND entrega = C.entrega AND cuatrimestre = C.cuatrimestre)"); if(is_null($row) || is_a($row, "db_error")) return false; $this->cuatrimestre = $row[0]; $this->padron = $row[1]; $this->ejercicio = $row[2]; $this->entrega = $row[3]; $this->intento = $row[4]; $mail = $row[5]; $this->db->query("UPDATE intento SET notificado = 1 WHERE cuatrimestre = $this->cuatrimestre and padron = $this->padron and ejercicio = $this->ejercicio and entrega = $this->entrega and intento = $this->intento"); $mail2 = $this->db->getOne("select mail_alumno FROM alumno WHERE cuatrimestre = $this->cuatrimestre AND padron = $this->padron"); if(strtolower($mail) != strtolower($mail2)) $mail .= ";$mail2"; return $mail; } /** * Obtiene el directorio en el cual se almacena el intento. */ function path() { return $this->base_path() . "/{$this->padron}/{$this->intento}"; } /** * Obtiene el directorio base de la entrega. * El directorio base no contempla los datos propios del intento, como * padrón e intento. * @param base_dir Directorio base, si no se especifica se usa el directorio * base del intento. */ function base_path($base_dir = null) { if (is_null($base_dir)) $base_dir = $this->base_dir; return "$base_dir/{$this->cuatrimestre}/{$this->ejercicio}-{$this->entrega}"; } } ?>