Example #1
0
        public GradeDTOOut AddSubjectToGrade(int id, GradeSubjectDTOIn gradeSubject)
        {
            Grade             grade    = GetGradeId(id);
            HashSet <Subject> subjects = new HashSet <Subject>();

            foreach (var ID in gradeSubject.SubjectID)
            {
                var subject = subjectsService.GetSubjectByID(ID);
                subjects.Add(subject);
            }

            grade.Subjects = subjects;
            db.GradesRepository.Update(grade);

            IEnumerable <SubjectDTO> subjectDTO = subjects.Select(x => Utilities.ConverterDTO.SimpleDTOConverter <SubjectDTO>(x));

            GradeDTOOut gradeDTO = new GradeDTOOut()
            {
                Id        = grade.Id,
                GradeYear = grade.GradeYear,
                Subjects  = subjectDTO
            };

            return(gradeDTO);
        }
Example #2
0
        public MarkDTOOut CreateMarkTeacher(string userId, MarkDTOIn newMark)
        {
            logger.Info($"Getting student {newMark.StudentID} over student service, from Create mark teacher, mark service");
            Student student = studentsService.GetStudent(newMark.StudentID);

            logger.Info($"Getting subject {newMark.SubjectID} over subject service, from create mark teacher, mark service");
            Subject subject = subjectsService.GetSubjectByID(newMark.SubjectID);

            logger.Info($"Getting teach for student {student.UserName}, subject {subject.SubjectName} and teacher with Id {userId}");
            Teach teach = subject.Teaches.Where(x => x.StudentDepartments.Id == student.StudentDepartments.Id && x.Teachers.Id == userId && x.Subject.Id == subject.Id).FirstOrDefault();

            if (teach == null)
            {
                logger.Info($"Teacher with id {userId} tried to enter the mark to wrong student or subject");
                throw new TeacherDontTeachThisSubjectException("Wrong student or subject");
            }
            if (newMark.MarkValue < 1 || newMark.MarkValue > 5)
            {
                logger.Info($"Teacher with id {userId} tried to enter the mark out of boundaries");
                throw new BadRequestException("Mark van be only 1,2,3,4,5");
            }

            logger.Info("Preparing mark for storing in db");
            Mark mark = new Mark()
            {
                MarkValue = newMark.MarkValue,
                Teaches   = teach
            };

            logger.Info($"Storing mark {mark.Id} in mark repo");
            db.MarksRepository.Insert(mark);

            logger.Info($"Saving marl with id {mark.Id} in db");
            db.Save();

            logger.Info($"Preparing student's {student.UserName} parent's for mail sending");
            IEnumerable <ParentDTOOut> parents = mark.Teaches.StudentDepartments.Students.Parents.Select(x => new ParentDTOOut()
            {
                Id        = x.Id,
                FirstName = x.FirstName,
                LastName  = x.LastName,
                Email     = x.Email,
                UserName  = x.UserName
            });

            logger.Info($"Converting mark with id {mark.Id} to DTO");
            MarkDTOOut markDTO = new MarkDTOOut()
            {
                Mark = new MarkDTODate()
                {
                    Id         = mark.Id,
                    MarkValue  = mark.MarkValue,
                    InsertDate = mark.InsertDate
                },
                Student = Utilities.ConverterDTO.SimpleDTOConverter <StudentDTO>(mark.Teaches.StudentDepartments.Students),
                Subject = Utilities.ConverterDTO.SimpleDTOConverter <SubjectDTO>(mark.Teaches.Subject),
                Teacher = Utilities.ConverterDTO.SimpleDTOConverter <TeacherDTO>(mark.Teaches.Teachers)
            };

            foreach (var parent in parents)
            {
                try
                {
                    logger.Info($"Sending parent {parent.UserName} to mail service");
                    emailService.SendEmail(parent, markDTO);
                }
                catch (Exception)
                {
                    logger.Info($"Something went wrong with email sending to {parent.Email}");
                    continue;
                }
            }

            return(markDTO);
        }
Example #3
0
        public TeachDTOOut CreateTeach(TeachDTOIn newTeach)
        {
            logger.Info("Get student department over student department service, create teach teaches service");
            StudentDepartment studentDepartment = studentDepartmentsService.GetStudentDepartmentByID(newTeach.StudentDepartmentID);

            logger.Info("Get teacher over teacher service, create teach teaches service");
            Teacher teacher = teachersService.GetById(newTeach.TeacherID);

            logger.Info("Get subject over subject service, create teach teaches service");
            Subject subject = subjectsService.GetSubjectByID(newTeach.SubjectID);

            logger.Info("Get teaches over teach service, create teach teaches service");
            IEnumerable <Teach> teach = GetAllTeach();

            //Check if subject is for students grade
            logger.Info("Checking if subject is for the selected grade, create teaches, teaches service");
            var isGradeOk = subject.Grades.Any(x => x.Id == studentDepartment.Departments.Grades.Id);

            if (!isGradeOk)
            {
                throw new SubjectIsNotForThisGrade("Wrong subject");
            }

            //check if teacher is teaching this subject
            logger.Info("Checking if teacher is teaching subject");
            var result = teacher.Subjects.Contains(subject);

            if (!result)
            {
                logger.Info("Throwing exception, wrong teacher subject pair");
                throw new TeacherDontTeachThisSubjectException("Teacher - subject pair does not match");
            }

            //check if subject is alreaady added to student
            logger.Info("Checking if subject is already added to student");
            var subjectExists = teach.Any(x => x.Subject.Equals(subject) && x.StudentDepartments.Equals(studentDepartment));

            if (subjectExists)
            {
                logger.Info("Throwing exception subject already added to student");
                throw new SubjectExistsException($"Subject {subject.SubjectName} already added to student {studentDepartment.Students.UserName}");
            }

            //check if teacher teach to this department, and finds who teach
            logger.Info("Checking if theacher is teach in department");
            var isDepartmentOK = teach.Any(x => x.Subject.Equals(subject) && x.Teachers.Equals(teacher) &&
                                           x.StudentDepartments.Departments.Id.Equals(studentDepartment.Departments.Id));
            var isSubjectInDepartment = teach.Any(x => x.Subject.Equals(subject) && x.StudentDepartments.Departments.Id.Equals(studentDepartment.Departments.Id));
            var whoTeach = teach.Where(x => x.Subject.Equals(subject) && x.StudentDepartments.Equals(studentDepartment)).Select(x => x.Teachers.UserName);

            if (!isDepartmentOK)
            {
                if (isSubjectInDepartment)
                {
                    logger.Info("Throwing exception teacher doesn't teach in department");
                    throw new TeacherDontTeachThisDepartment($"Teacher {teacher.UserName} doesn't teach to department {studentDepartment.Departments.DepartmentName}, {whoTeach} does.");
                }
            }

            logger.Info("Preparing teach for save in db");
            Teach teachIn = new Teach()
            {
                StudentDepartments = studentDepartment,
                Teachers           = teacher,
                Subject            = subject
            };

            logger.Info("Access to teaches repository for insert new teach");
            db.TeachesRepository.Insert(teachIn);
            logger.Info("db save new teach");
            db.Save();

            logger.Info("Converting to dto for output");
            TeachDTOOut teachDTOOut = new TeachDTOOut()
            {
                Id             = teachIn.Id,
                Student        = Utilities.ConverterDTO.SimpleDTOConverter <StudentDTO>(teachIn.StudentDepartments.Students),
                Department     = Utilities.ConverterDTO.SimpleDTOConverter <DepartmentDTOStudent>(teachIn.StudentDepartments.Departments),
                TeacherSubject = studentDepartment.Teaches.Select(x => new TeacherSubjectDTO()
                {
                    Teacher = Utilities.ConverterDTO.SimpleDTOConverter <TeacherDTO>(x.Teachers),
                    Subject = Utilities.ConverterDTO.SimpleDTOConverter <SubjectDTO>(x.Subject)
                })
            };

            return(teachDTOOut);
        }