private CurriculumRequirement GetModule(TimeTableDbContext db, TimeTable.Data.Curriculum curriculum, CieCourse scheduleCourse) { var pck = curriculum.Packages.FirstOrDefault(); if (curriculum.ShortName.Equals("WI") && pck != null) { pck = curriculum.Packages.SingleOrDefault(x => x.Name.Equals("Wahlpflicht")); } if (pck == null) { pck = new CurriculumPackage(); pck.Name = "Studium"; curriculum.Packages.Add(pck); db.CurriculumPackages.Add(pck); } var option = pck.Options.FirstOrDefault(); if (option == null) { option = new PackageOption(); option.Name = "Gesamt"; option.Package = pck; db.PackageOptions.Add(option); } var module = option.Requirements.FirstOrDefault(x => x.Name.ToLower().Equals(scheduleCourse.name.ToLower())); if (module == null) { module = new CurriculumRequirement(); module.Name = scheduleCourse.name; module.ECTS = scheduleCourse.ects; module.USCredits = scheduleCourse.usCredits; module.SWS = scheduleCourse.semesterWeekHours; option.Requirements.Add(module); } db.SaveChanges(); return(module); }
/// <summary> /// /// </summary> /// <param name="db"></param> /// <param name="gruppenId">Gruppenalias nach dem in der Datenbank gesucht wird</param> /// <returns></returns> private List <SemesterGroup> InitSemesterGroups(TimeTableDbContext db, string gruppenId) { var semester = db.Semesters.SingleOrDefault(s => s.Id == _semId); var org = db.Organisers.SingleOrDefault(x => x.Id == _orgId); // Annahme, die Semestergruppen existieren! var semGroupList = new List <SemesterGroup>(); // suche alle aktuellen Zuordnungen zu dieser gruppenID var zuordnungen = _import.GruppenZuordnungen.Where(x => x.Alias.Equals(gruppenId)); foreach (var zuordnung in zuordnungen) { // Studiengang finden var curr = db.Curricula.SingleOrDefault(x => x.ShortName.Equals(zuordnung.Studiengang) && x.Organiser.Id == org.Id); if (curr == null) { curr = new TimeTable.Data.Curriculum { Organiser = org, ShortName = zuordnung.Studiengang, Name = zuordnung.Studiengang }; db.Curricula.Add(curr); } var sg = curr.CurriculumGroups.SingleOrDefault(x => x.Name.Equals(zuordnung.Studiengruppe)); if (sg == null) { sg = new CurriculumGroup { Name = zuordnung.Studiengruppe, IsSubscribable = true, Curriculum = curr }; db.CurriculumGroups.Add(sg); curr.CurriculumGroups.Add(sg); } var cg = string.IsNullOrEmpty(zuordnung.Kapazitätsgruppe) ? sg.CapacityGroups.SingleOrDefault(x => string.IsNullOrEmpty(x.Name)) : sg.CapacityGroups.SingleOrDefault(x => x.Name.Equals(zuordnung.Kapazitätsgruppe)); if (cg == null) { cg = new CapacityGroup { InSS = true, InWS = true, Name = zuordnung.Kapazitätsgruppe, CurriculumGroup = sg }; db.CapacityGroups.Add(cg); sg.CapacityGroups.Add(cg); } // bis hierher habe ich ohne Semesterbezug gearbeitet // jetzt noch die Semestergruppe var semGroup = cg.SemesterGroups.SingleOrDefault(x => x.Semester.Id == semester.Id); if (semGroup == null) { // semestergruppe gibt es nicht => auf jeden Fall anlegen semGroup = new SemesterGroup { CapacityGroup = cg, Semester = semester, }; _Logger.InfoFormat("Semestergruppe {0} angelegt {1}", semGroup.FullName, gruppenId); cg.SemesterGroups.Add(semGroup); db.SemesterGroups.Add(semGroup); } semGroupList.Add(semGroup); } db.SaveChanges(); return(semGroupList); }
private TimeTable.Data.Curriculum GetCurriculum(TimeTableDbContext db, Semester semester, string orgName, string currName) { var org = db.Organisers.SingleOrDefault(x => x.ShortName.Equals(orgName)); var curr = org.Curricula.SingleOrDefault(x => x.ShortName.Equals(currName)); if (curr == null) { curr = new TimeTable.Data.Curriculum { ShortName = currName, Name = currName, Organiser = org }; db.Curricula.Add(curr); db.SaveChanges(); } // Gleich alles notwendige anlegen var wpmCurrciculumGroup = curr.CurriculumGroups.SingleOrDefault(x => x.Name.Equals("WPM")); if (wpmCurrciculumGroup == null) { wpmCurrciculumGroup = new CurriculumGroup { Curriculum = curr, Name = "WPM", IsSubscribable = true, }; db.CurriculumGroups.Add(wpmCurrciculumGroup); db.SaveChanges(); } var wpmCapacityGroup = wpmCurrciculumGroup.CapacityGroups.FirstOrDefault(); if (wpmCapacityGroup == null) { wpmCapacityGroup = new CapacityGroup { CurriculumGroup = wpmCurrciculumGroup, Name = string.Empty, InSS = true, InWS = true }; db.CapacityGroups.Add(wpmCapacityGroup); db.SaveChanges(); } var wpmSemesterGroup = db.SemesterGroups.FirstOrDefault(x => x.CapacityGroup.Id == wpmCapacityGroup.Id && x.Semester.Id == semester.Id); if (wpmSemesterGroup == null) { wpmSemesterGroup = new SemesterGroup { Semester = semester, CapacityGroup = wpmCapacityGroup, IsAvailable = false // zu Beginn nicht freigegeben }; db.SemesterGroups.Add(wpmSemesterGroup); db.SaveChanges(); } return(curr); }
public StudyProgram GetProgram(Guid id, int no) { _curr = _db.Curricula.SingleOrDefault(x => x.Id == id); _prog = new StudyProgram { id = no, name = _curr.Name, shortcut = _curr.ShortName, modules = new List <StudyProgramModule>(), rules = new List <StudyProgramRuleSet>() }; // alle Module bauen // Grundidee => Ein kriterium entspricht dem Modul // Erstmal ohne Studienrichtung, d.h. immer das erste Paket foreach (var pck in _curr.Packages) { foreach (var req in pck.Options.First().Requirements) { // nicht nach Kriterien aufspalten // immer das erste nehmen AddCriteria(req.Criterias.First()); } } // spezielle Abfragen // ects => summe ects module _prog.ects = _prog.modules.Sum(x => x.ects); // Studiendauer = höchste semesternummer _prog.standardStudyPeriod = _prog.modules.Max(x => x.regularSemester); // praktisches Semester => Name einer Anforderung "Praktikum" var critPract = _prog.modules.SingleOrDefault(x => x.title.Equals("Praktikum")); if (critPract != null) { _prog.practicalSemester = critPract.regularSemester; } // Jetzt die Regeln // Fakes var ruleSet = new StudyProgramRuleSet { studyProgramId = _prog.id, startRules = new List <StudyProgramStartRule>(), riseRules = new List <StudyProgramRiseRule>(), Prequisites = new List <StudyProgramPrequisite>(), retryDeadlines = new StudyProgramRetryDeadlines { first = 1, second = 2, maxSecondFailCount = 5 } }; _prog.rules.Add(ruleSet); InitRules(); return(_prog); }
/// <summary> /// /// </summary> /// <param name="db"></param> /// <param name="gruppenId">Gruppenalias nach dem in der Datenbank gesucht wird</param> /// <returns></returns> private List <SemesterGroup> InitSemesterGroups(TimeTableDbContext db, string gruppenId) { var semester = db.Semesters.SingleOrDefault(s => s.Id == _semId); var org = db.Organisers.SingleOrDefault(x => x.Id == _orgId); // Annahme, die Semestergruppen existieren! var semGroupList = new List <SemesterGroup>(); // Annahme, die Semestergruppen existieren nicht alle und müssen ggf. angelegt werden // damit man nach den Alias namen in Abhängigkeit der Studiengänge / Fakultät suchen kann // so müssen die Namen derzeit auf globale Ebene eindeutig sein var aliasList = db.GroupAliases.Where(g => g.Name.ToUpper().Equals(gruppenId.ToUpper()) && g.CapacityGroup.CurriculumGroup.Curriculum.Organiser.Id == _orgId).ToList(); // falls leer, jetzt in Zuordnungen nachsehen if (!aliasList.Any()) { var zuordnungen = _import.GruppenZuordnungen.Where(x => x.Alias.Equals(gruppenId)); foreach (var zuordnung in zuordnungen) { // Studiengang finden var curr = db.Curricula.SingleOrDefault(x => x.ShortName.Equals(zuordnung.Studiengang) && x.Organiser.Id == org.Id); if (curr == null) { curr = new TimeTable.Data.Curriculum { Organiser = org, ShortName = zuordnung.Studiengang, Name = zuordnung.Studiengang }; db.Curricula.Add(curr); } var sg = curr.CurriculumGroups.SingleOrDefault(x => x.Name.Equals(zuordnung.Studiengruppe)); if (sg == null) { sg = new CurriculumGroup { Name = zuordnung.Studiengruppe, IsSubscribable = true, Curriculum = curr }; db.CurriculumGroups.Add(sg); curr.CurriculumGroups.Add(sg); } var cg = string.IsNullOrEmpty(zuordnung.Kapazitätsgruppe) ? sg.CapacityGroups.SingleOrDefault(x => string.IsNullOrEmpty(x.Name)) : sg.CapacityGroups.SingleOrDefault(x => x.Name.Equals(zuordnung.Kapazitätsgruppe)); if (cg == null) { cg = new CapacityGroup { InSS = true, InWS = true, Name = zuordnung.Kapazitätsgruppe, CurriculumGroup = sg }; db.CapacityGroups.Add(cg); sg.CapacityGroups.Add(cg); } var al = cg.Aliases.SingleOrDefault(x => x.Name.Equals(zuordnung.Alias)); if (al == null) { al = new GroupAlias { Name = zuordnung.Alias, CapacityGroup = cg }; db.GroupAliases.Add(al); cg.Aliases.Add(al); } aliasList.Add(al); } db.SaveChanges(); } foreach (var groupAlias in aliasList) { // zugehörige Kapazitätsgruppe var capGroup = groupAlias.CapacityGroup; // im semester suchen var semGroup = semester.Groups.SingleOrDefault(g => g.CapacityGroup.Id == capGroup.Id); if (semGroup == null) { // semestergruppe gibt es nicht => auf jeden Fall anlegen semGroup = new SemesterGroup { CapacityGroup = capGroup, Semester = semester, }; _Logger.InfoFormat("Semestergruppe {0} angelegt {1}", semGroup.FullName, gruppenId); capGroup.SemesterGroups.Add(semGroup); db.SemesterGroups.Add(semGroup); db.SaveChanges(); } semGroupList.Add(semGroup); } return(semGroupList); }
public string ImportCourse(ScheduleCourse scheduleCourse) { string msg; _Logger.DebugFormat("Importiere Fach: {0}", scheduleCourse.Name); _report.AppendFormat("<h1>Erzeuge LV \"{0} ({1})\" - [{2}]</h1>", scheduleCourse.Name, scheduleCourse.ShortName, scheduleCourse.CourseId); _report.AppendLine(); var db = new TimeTableDbContext(); var organiser = db.Organisers.SingleOrDefault(s => s.Id == _orgId); var sem = db.Semesters.SingleOrDefault(s => s.Id == _semId); long msStart = sw.ElapsedMilliseconds; var course = new Course { ExternalSource = "JSON", ExternalId = scheduleCourse.CourseId, Organiser = organiser, ShortName = scheduleCourse.ShortName, Name = scheduleCourse.Name, Description = scheduleCourse.Description, Occurrence = CreateDefaultOccurrence(scheduleCourse.SeatRestriction ?? 0), IsInternal = true, }; // Kurs sofort speichern, damit die ID gesichert ist db.Activities.Add(course); db.SaveChanges(); long msEnd = sw.ElapsedMilliseconds; _Logger.DebugFormat("Dauer: {0}ms", msEnd - msStart); msStart = msEnd; _report.AppendLine("<h2>Bezeichnungen</h2>"); _report.AppendLine("<table>"); _report.AppendFormat("<tr><td>Name</td><td>{0}</td></tr>", course.Name); _report.AppendFormat("<tr><td>Kurzname</td><td>{0}</td></tr>", course.ShortName); _report.AppendFormat("<tr><td>Beschreibung</td><td>{0}</td></tr>", course.Description); _report.AppendLine("</table>"); // jetzt die Gruppen foreach (var scheduleGroup in scheduleCourse.Groups) { // Fakultät ermitteln var org = db.Organisers.SingleOrDefault(x => x.ShortName.Equals(scheduleGroup.FacultyName)); // Studiengang innerhalb der Fakultät ermitteln var curr = org.Curricula.SingleOrDefault(x => x.ShortName.Equals(scheduleGroup.CurriculumShortName)); if (curr == null) { curr = new TimeTable.Data.Curriculum { ShortName = scheduleGroup.CurriculumShortName, Name = scheduleGroup.CurriculumName, Organiser = org }; db.Curricula.Add(curr); db.SaveChanges(); } // Studiengruppe innerhalb des Studiengangs ermitteln var groupName = scheduleGroup.GroupName; // Sonderlocke FK 11 // aus der LV-Nummer das Semester raussuchen /* OHI 20180720: wieder ausgebaut, weil Schnittstelle jetzt sauber befüllt ist * if (org.ShortName.Equals("FK 11")) * { * if (!string.IsNullOrEmpty(course.ShortName)) * { * groupName = course.ShortName[1].ToString(); * * } * else * { * groupName = "#N.V."; * } * } */ var currGroup = curr.CurriculumGroups.SingleOrDefault(x => x.Name.Equals(groupName)); if (currGroup == null) { currGroup = new CurriculumGroup { Curriculum = curr, Name = groupName, IsSubscribable = true, }; db.CurriculumGroups.Add(currGroup); db.SaveChanges(); } // Kapazitätsgruppe innerhalb der Studiengruppe ermitteln CapacityGroup capGroup = null; if (string.IsNullOrEmpty(scheduleGroup.SubGroupName)) { capGroup = currGroup.CapacityGroups.SingleOrDefault(x => string.IsNullOrEmpty(x.Name)); if (capGroup == null) { capGroup = new CapacityGroup { CurriculumGroup = currGroup, Name = string.Empty, InSS = scheduleGroup.SemesterName.StartsWith("SS"), InWS = scheduleGroup.SemesterName.StartsWith("WS") }; db.CapacityGroups.Add(capGroup); db.SaveChanges(); } } else { capGroup = currGroup.CapacityGroups.SingleOrDefault(x => !string.IsNullOrEmpty(x.Name) && x.Name.Equals(scheduleGroup.SubGroupName)); if (capGroup == null) { capGroup = new CapacityGroup { CurriculumGroup = currGroup, Name = scheduleGroup.SubGroupName, InSS = scheduleGroup.SemesterName.StartsWith("SS"), InWS = scheduleGroup.SemesterName.StartsWith("WS") }; db.CapacityGroups.Add(capGroup); db.SaveChanges(); } } // Semester ermitteln var semester = db.Semesters.SingleOrDefault(x => x.Name.Equals(scheduleGroup.SemesterName)); if (semester.Id == sem.Id) { // jetzt können wir die Semestergruppe ermitteln var semGroup = db.SemesterGroups.SingleOrDefault(x => x.Semester.Id == semester.Id && x.CapacityGroup.Id == capGroup.Id); if (semGroup == null) { semGroup = new SemesterGroup { Semester = semester, CapacityGroup = capGroup, IsAvailable = false // zu Beginn nicht freigegeben }; db.SemesterGroups.Add(semGroup); db.SaveChanges(); } course.SemesterGroups.Add(semGroup); semGroup.Activities.Add(course); // zu jeder Semestergruppe gibt es dann noch eine // Gruppe für Platzverlosung var occGroup = course.Occurrence.Groups.SingleOrDefault( gg => gg.SemesterGroups.Any(s => s.Id == semGroup.Id)); if (occGroup == null) { occGroup = new OccurrenceGroup { Capacity = 0, FitToCurriculumOnly = true, Occurrence = course.Occurrence }; occGroup.SemesterGroups.Add(semGroup); semGroup.OccurrenceGroups.Add(occGroup); course.Occurrence.Groups.Add(occGroup); db.OccurrenceGroups.Add(occGroup); } // NEU: Chapter und Topics if (!string.IsNullOrEmpty(scheduleGroup.ChapterName) && !string.IsNullOrEmpty(scheduleGroup.TopicName)) { var chapter = curr.Chapters.FirstOrDefault(x => x.Name.Equals(scheduleGroup.ChapterName)); if (chapter == null) { chapter = new CurriculumChapter { Curriculum = curr, Name = scheduleGroup.ChapterName }; db.CurriculumChapters.Add(chapter); } var topic = chapter.Topics.FirstOrDefault(x => x.Name.Equals(scheduleGroup.TopicName)); if (topic == null) { topic = new CurriculumTopic { Chapter = chapter, Name = scheduleGroup.TopicName }; db.CurriculumTopics.Add(topic); } var semTopic = db.SemesterTopics.FirstOrDefault(x => x.Semester.Id == sem.Id && x.Topic.Id == topic.Id); if (semTopic == null) { semTopic = new SemesterTopic { Semester = sem, Topic = topic, }; db.SemesterTopics.Add(semTopic); } semTopic.Activities.Add(course); } } // else => Semestergruppe wird nicht angelegt } db.SaveChanges(); if (!course.SemesterGroups.Any()) { _Logger.ErrorFormat("Kurs {0} ohne Gruppe", scheduleCourse.CourseId); } // zum Schluss die Termine _report.AppendLine("<h2>Neue Termine</h2>"); _report.AppendLine("<table>"); foreach (var scheduleDate in scheduleCourse.Dates) { // Der Tag var occDate = scheduleDate.Begin.Date; bool isVorlesung = true; foreach (var sd in _semester.Dates) { // Wenn der Termin in eine vorlesungsfreie Zeit fällt, dann nicht importieren if (sd.From.Date <= occDate.Date && occDate.Date <= sd.To.Date && sd.HasCourses == false) { isVorlesung = false; } } if (isVorlesung) { var occ = new ActivityDate { Begin = scheduleDate.Begin, End = scheduleDate.End, Activity = course, Occurrence = CreateDefaultOccurrence(), }; _report.AppendLine("<tr>"); _report.AppendFormat("<td>{0}</td><td>{1}</td><td>{2}</td>", occ.Begin.ToShortDateString(), occ.Begin.ToShortTimeString(), occ.End.ToShortTimeString()); _report.AppendFormat("<td>"); foreach (var scheduleDateRoom in scheduleDate.Rooms) { _report.AppendFormat("<p>{0}", scheduleDateRoom.RoomNumber); if (!string.IsNullOrEmpty(scheduleDateRoom.RoomNumber)) { var room = db.Rooms.SingleOrDefault(r => r.Number.Equals(scheduleDateRoom.RoomNumber)); if (room == null) { room = new Room { Number = scheduleDateRoom.RoomNumber, Capacity = 0, Description = string.Empty, Owner = string.Empty, }; db.Rooms.Add(room); db.SaveChanges(); _numRooms++; _report.AppendFormat(" !!!NEUER RAUM!!!"); } var assignment = db.RoomAssignments.SingleOrDefault(x => x.Room.Id == room.Id && x.Organiser.Id == organiser.Id); if (assignment == null) { assignment = new RoomAssignment { Organiser = organiser, InternalNeedConfirmation = false, // offen für interne ExternalNeedConfirmation = true // geschlossen für externe }; room.Assignments.Add(assignment); db.RoomAssignments.Add(assignment); db.SaveChanges(); } occ.Rooms.Add(room); _report.AppendFormat("</p>"); } } _report.AppendFormat("</td>"); _report.AppendFormat("<td>"); foreach (var scheduleDateLecturer in scheduleDate.Lecturers) { _report.AppendFormat("<p>{0} ({1})", scheduleDateLecturer.Name, scheduleDateLecturer.ShortName); var lecturer = organiser.Members.SingleOrDefault(l => l.ShortName.Equals(scheduleDateLecturer.ShortName)); if (lecturer == null) { lecturer = new OrganiserMember { ShortName = scheduleDateLecturer.ShortName, Name = scheduleDateLecturer.Name, Role = String.Empty, Description = String.Empty }; organiser.Members.Add(lecturer); db.Members.Add(lecturer); db.SaveChanges(); _numLecturers++; _report.AppendFormat(" !!!NEUER DOZENT!!!"); } occ.Hosts.Add(lecturer); _report.AppendFormat("</p>"); } _report.AppendFormat("</td>"); db.ActivityDates.Add(occ); _report.AppendLine(); _report.AppendLine("</tr>"); } } _report.AppendLine("</table>"); db.SaveChanges(); msEnd = sw.ElapsedMilliseconds; _Logger.DebugFormat("Dauer {0}ms", msEnd - msStart); msg = $"Kurs {course.ShortName} mit Terminen importiert"; return(msg); }