Max/Backend/CoursesEndpoints #129
| @ -0,0 +1,80 @@ | |||||||
|  | package ovh.herisson.Clyde.EndPoints; | ||||||
|  |  | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import ovh.herisson.Clyde.Responses.UnauthorizedResponse; | ||||||
|  | import ovh.herisson.Clyde.Services.AuthenticatorService; | ||||||
|  | import ovh.herisson.Clyde.Services.CourseService; | ||||||
|  | import ovh.herisson.Clyde.Services.TeacherCourseService; | ||||||
|  | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.Role; | ||||||
|  | import ovh.herisson.Clyde.Tables.TeacherCourse; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @CrossOrigin(originPatterns = "*", allowCredentials = "true") | ||||||
|  | public class CourseController { | ||||||
|  |  | ||||||
|  |     private final CourseService courseServ; | ||||||
|  |  | ||||||
|  |     private final TeacherCourseService teacherCourseServ; | ||||||
|  |  | ||||||
|  |     private final AuthenticatorService authServ; | ||||||
|  |  | ||||||
|  |     public CourseController(CourseService courseServ, TeacherCourseService teacherCourseServ, AuthenticatorService authServ) { | ||||||
|  |         this.courseServ = courseServ; | ||||||
|  |         this.teacherCourseServ = teacherCourseServ; | ||||||
|  |         this.authServ = authServ; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/course/{id}") | ||||||
|  |     public ResponseEntity<Course> getCourse(@RequestHeader("Authorization") String token, @PathVariable long id){ | ||||||
|  |         if (authServ.getUserFromToken(token) == null) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(courseServ.findById(id), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @PostMapping("/course") | ||||||
|  |     public ResponseEntity<Course> postCourse(@RequestHeader("Authorization") String token, @RequestBody Course course){ | ||||||
|  |         if (authServ.isNotSecretaryOrAdmin(token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(courseServ.save(course), HttpStatus.CREATED); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @PatchMapping("/course/{id}") | ||||||
|  |     public ResponseEntity<Course> patchCourse(@RequestHeader("Authorization") String token, | ||||||
|  |                                               @RequestBody Map<String,Object> updates, | ||||||
|  |                                               @PathVariable long id) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |         if (authServ.IsNotIn(new Role[]{Role.Admin,Role.Teacher,Role.Secretary}, token)){ | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return new ResponseEntity<>(courseServ.modifyData(id, updates, authServ.getUserFromToken(token).getRole()), HttpStatus.OK); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PostMapping("/course/{id}") | ||||||
|  |     public ResponseEntity<String> postTeachers(@RequestHeader("Authorization") String token, | ||||||
|  |                                                @RequestBody Iterable<Long> teacherIds, | ||||||
|  |                                                @PathVariable Long id) | ||||||
|  |     { | ||||||
|  |         if (authServ.IsNotIn(new Role[]{Role.Admin,Role.Secretary}, token)) | ||||||
|  |             return new UnauthorizedResponse<>(null); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         teacherCourseServ.saveAll(teacherIds,courseServ.findById(id)); | ||||||
|  |         return new ResponseEntity<>(HttpStatus.OK); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package ovh.herisson.Clyde.Repositories; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import org.springframework.data.repository.CrudRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.TeacherCourse; | ||||||
|  |  | ||||||
|  | public interface TeacherCourseRepository extends CrudRepository<TeacherCourse, Long> { | ||||||
|  | } | ||||||
| @ -50,5 +50,18 @@ public class AuthenticatorService { | |||||||
|         return poster.getRole() != Role.Secretary || poster.getRole() != Role.Admin; |         return poster.getRole() != Role.Secretary || poster.getRole() != Role.Admin; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public boolean IsNotIn(Role[] roles, String token){ | ||||||
|  |         if (token == null) | ||||||
|  |             return true; | ||||||
|  |  | ||||||
|  |         User poster = getUserFromToken(token); | ||||||
|  |         if (poster == null) return true; | ||||||
|  |  | ||||||
|  |         for (Role r:roles){ | ||||||
|  |             if (poster.getRole() == r) | ||||||
|  |                 return false; | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -3,6 +3,10 @@ package ovh.herisson.Clyde.Services; | |||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import ovh.herisson.Clyde.Repositories.CourseRepository; | import ovh.herisson.Clyde.Repositories.CourseRepository; | ||||||
| import ovh.herisson.Clyde.Tables.Course; | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.Role; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
| @Service | @Service | ||||||
| public class CourseService { | public class CourseService { | ||||||
| @ -13,11 +17,39 @@ public class CourseService { | |||||||
|         this.courseRepo = courseRepo; |         this.courseRepo = courseRepo; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void save(Course course){ |     public Course save(Course course){ | ||||||
|         courseRepo.save(course); |         return courseRepo.save(course); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public Course findById(long id){ |     public Course findById(long id){ | ||||||
|         return courseRepo.findById(id); |         return courseRepo.findById(id); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public Course modifyData(long id, Map<String, Object> updates, Role role) { | ||||||
|  |         Course target = courseRepo.findById(id); | ||||||
|  |  | ||||||
|  |         if (role == Role.Teacher){ | ||||||
|  |             for (Map.Entry<String, Object> entry : updates.entrySet()){ | ||||||
|  |                 if (entry.getKey().equals("title")){ | ||||||
|  |                     target.setTitle((String) entry.getValue()); | ||||||
|  |                     return courseRepo.save(target); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for (Map.Entry<String ,Object> entry: updates.entrySet()){ | ||||||
|  |             switch (entry.getKey()){ | ||||||
|  |                 case "title": | ||||||
|  |                     target.setTitle((String) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "credits": | ||||||
|  |                     target.setCredits((Integer) entry.getValue()); | ||||||
|  |                     break; | ||||||
|  |                 case "owner": | ||||||
|  |                     target.setOwner((User) entry.getValue()); //todo check if is a teacher ! | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return courseRepo.save(target); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,39 @@ | |||||||
|  | package ovh.herisson.Clyde.Services; | ||||||
|  |  | ||||||
|  | import org.springframework.stereotype.Controller; | ||||||
|  | import ovh.herisson.Clyde.Repositories.TeacherCourseRepository; | ||||||
|  | import ovh.herisson.Clyde.Repositories.UserRepository; | ||||||
|  | import ovh.herisson.Clyde.Tables.Course; | ||||||
|  | import ovh.herisson.Clyde.Tables.TeacherCourse; | ||||||
|  | import ovh.herisson.Clyde.Tables.User; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  |  | ||||||
|  | @Controller | ||||||
|  | public class TeacherCourseService { | ||||||
|  |     private final TeacherCourseRepository teacherCourseRepo; | ||||||
|  |  | ||||||
|  |     private final UserRepository userRepo; | ||||||
|  |  | ||||||
|  |     public TeacherCourseService(TeacherCourseRepository teacherCourseRepo, UserRepository userRepo) { | ||||||
|  |         this.teacherCourseRepo = teacherCourseRepo; | ||||||
|  |         this.userRepo = userRepo; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean saveAll(Iterable<Long> teacherIds, Course course){ | ||||||
|  |  | ||||||
|  |         ArrayList<Long> addedIds = new ArrayList<>(); | ||||||
|  |         for (Long teacherId : teacherIds){ | ||||||
|  |             User teacher = userRepo.findById((long) teacherId); | ||||||
|  |             if ( teacher== null){ | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |             if (!addedIds.contains(teacherId)) | ||||||
|  |             { | ||||||
|  |                 teacherCourseRepo.save(new TeacherCourse(teacher,course)); | ||||||
|  |                 addedIds.add(teacherId); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user