public static function matricularUno($alumno_id, $grupo_id) { $year = Year::where('actual', '=', true)->first(); $consulta = 'SELECT m.id, m.alumno_id, m.grupo_id, m.matriculado, g.year_id FROM matriculas m inner join grupos g on m.alumno_id = :alumno_id and g.year_id = :year_id and m.grupo_id=g.id'; $matriculas = DB::select(DB::raw($consulta), array('alumno_id' => $alumno_id, 'year_id' => $year->id)); $matricula = false; for ($i = 0; $i < count($matriculas); $i++) { $matri = Matricula::onlyTrashed()->where('id', $matriculas[$i]->id)->first(); /* $queries = DB::getQueryLog(); $last_query = end($queries); return $last_query; */ if ($matri) { if ($matri->grupo_id == $grupo_id) { if ($matricula) { // Si ya he encontrado en un elemento anterior una matrícula identica, es por que ya la he activado, no debo activar más. Por el contrario, debo borrarlas ${$matri}->delete(); } else { $matri->matriculado = true; $matri->fecha_retiro = null; $matri->save(); $matri->restore(); $matricula = $matri; } } else { $matri->delete(); } } } try { if (!$matricula) { $matricula = new Matricula(); $matricula->alumno_id = $alumno_id; $matricula->grupo_id = $grupo_id; $matricula->matriculado = true; $matricula->save(); } } catch (Exception $e) { // se supone que esto nunca va a ocurrir, ya que eliminé todas las matrículas // excepto la que concordara con el grupo, poniéndola en matriculado=true $matricula = Matricula::where('alumno_id', '=', $alumno_id)->where('grupo_id', '=', $grupo_id)->first(); $matricula->matriculado = true; $matricula->save(); } return $matricula; }
public function postStore() { $user = User::fromToken(); $alumno = []; try { $this->sanarInputAlumno(); $date = Carbon::createFromFormat('Y-m-d', Request::input('fecha_nac')); $alumno = new Alumno(); $alumno->no_matricula = Request::input('no_matricula'); $alumno->nombres = Request::input('nombres'); $alumno->apellidos = Request::input('apellidos'); $alumno->sexo = Request::input('sexo'); #$alumno->user_id = Request::input('user_id'); $alumno->fecha_nac = $date->format('Y-m-d'); $alumno->ciudad_nac = Request::input('ciudad_nac'); $alumno->tipo_doc = Request::input('tipo_doc'); $alumno->documento = Request::input('documento'); $alumno->ciudad_doc = Request::input('ciudad_doc'); $alumno->tipo_sangre = Request::input('tipo_sangre')['sangre']; $alumno->eps = Request::input('eps'); $alumno->telefono = Request::input('telefono'); $alumno->celular = Request::input('celular'); $alumno->barrio = Request::input('barrio'); $alumno->estrato = Request::input('estrato'); $alumno->ciudad_resid = Request::input('ciudad_resid'); $alumno->religion = Request::input('religion'); $alumno->email = Request::input('email'); $alumno->facebook = Request::input('facebook'); $alumno->pazysalvo = Request::input('pazysalvo'); $alumno->deuda = Request::input('deuda'); $alumno->save(); $this->sanarInputUser(); $this->checkOrChangeUsername($alumno->user_id); $yearactual = Year::actual(); $periodo_actual = Periodo::where('actual', true)->where('year_id', $yearactual->id)->first(); $usuario = new User(); $usuario->username = Request::input('username'); $usuario->password = Hash::make(Request::input('password', '123456')); $usuario->email = Request::input('email2'); $usuario->is_superuser = Request::input('is_superuser', false); $usuario->periodo_id = $periodo_actual->id; $usuario->is_active = Request::input('is_active', true); $usuario->tipo = 'Alumno'; $usuario->save(); $role = Role::where('name', 'Alumno')->get(); $usuario->attachRole($role[0]); $alumno->user_id = $usuario->id; $alumno->save(); $alumno->user = $usuario; if (Request::input('grupo')['id']) { $grupo_id = Request::input('grupo')['id']; $matricula = new Matricula(); $matricula->alumno_id = $alumno->id; $matricula->grupo_id = $grupo_id; $matricula->matriculado = true; $matricula->save(); $grupo = Grupo::find($matricula->grupo_id); $alumno->grupo = $grupo; } return $alumno; } catch (Exception $e) { return abort('400', $alumno); //return $e; } }