package org.ntlab.citrusserver.resources; import jakarta.ws.rs.core.Response; import org.ntlab.citrusserver.entities.Schedule; import org.ntlab.citrusserver.repositories.AccountManager; import org.ntlab.citrusserver.repositories.ScheduleManager; import jakarta.ws.rs.*; import jakarta.ws.rs.core.MediaType; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.HashMap; @Path("/accounts") @Component public class ScheduleRest { private final ScheduleManager scheduleManager; private final AccountManager accountManager; @Autowired public ScheduleRest(ScheduleManager sm, AccountManager ac){ scheduleManager = sm; accountManager = ac; } // @Path("/{account_id}/schedule") // @GET//登録されたスケジュールのidを返す // @Produces(MediaType.APPLICATION_JSON) // public ArrayList<Integer> getScheduleAll(@PathParam("account_id") String accountId, @QueryParam("token") String token){ // if(accountManager.checkToken(accountId,token)) { // return scheduleManager.getScheduleAll(accountId); // } // return null; // } // @Path("/{account_id}/schedule/{year}") // @GET//登録されたスケジュールのidを年単位で返す // @Produces(MediaType.APPLICATION_JSON) // public ArrayList<Integer> getScheduleYear(@PathParam("account_id") String accountId, @PathParam("year") Integer year,@QueryParam("token") String token){ // if(accountManager.checkToken(accountId,token)) { // return scheduleManager.getScheduleYear(accountId,year); // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}") // @GET//登録されたスケジュールのidを月単位で返す // @Produces(MediaType.APPLICATION_JSON) // public ArrayList<Integer> getScheduleMonth(@PathParam("account_id") String accountId, @PathParam("year") Integer year,@PathParam("month") Integer month, // @QueryParam("token") String token){ // if(accountManager.checkToken(accountId,token)) { // return scheduleManager.getScheduleMonth(accountId,year,month); // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}/{day}") // @GET//登録されたスケジュールのidを日ごとで返す // @Produces(MediaType.APPLICATION_JSON) // public ArrayList<Integer> getScheduleDay(@PathParam("account_id") String accountId, @PathParam("year") Integer year,@PathParam("month") Integer month, // @PathParam("day") Integer day,@QueryParam("token") String token){ // if(accountManager.checkToken(accountId,token)) { // return scheduleManager.getScheduleYear(accountId,year,month,day); // } // return null; // } @Path("/{account_id}/schedule/{year}/{month}/{day}") @POST//スケジュールの新規作成 @Consumes(MediaType.APPLICATION_FORM_URLENCODED) @Produces(MediaType.APPLICATION_JSON) public Schedule addSchedule(@PathParam("account_id") String accountId, @PathParam("year") Integer year, @PathParam("month") Integer month, @PathParam("day") Integer day,@FormParam("title") String title, @FormParam("start_time") String startTime,@FormParam("end_time") String endTime,@FormParam("book_id") Integer bookId, @FormParam("token") String token) { if(accountManager.checkToken(accountId,token)) { return scheduleManager.addSchedule(accountId, year, month, day,title,startTime,endTime,bookId); }else { var response = Response.status(Response.Status.FORBIDDEN).entity("認証失敗"); throw new WebApplicationException(response.build()); } } @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}") @GET//スケジュールの情報を返す @Produces(MediaType.APPLICATION_JSON) public Schedule getScheduleInfo(@PathParam("account_id") String accountId, @PathParam("year") Integer year, @PathParam("month") Integer month, @PathParam("day") Integer day, @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { if(accountManager.checkToken(accountId,token)) { Schedule schedule = scheduleManager.getScheduleId(accountId, year, month, day, scheduleId); return schedule; } var response = Response.status(Response.Status.FORBIDDEN).entity("認証失敗"); throw new WebApplicationException(response.build()); } // @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}") // @DELETE//特定のスケジュールを削除する // @Produces(MediaType.TEXT_PLAIN) // @Consumes(MediaType.APPLICATION_FORM_URLENCODED) // public Schedule deleteSchedule(@PathParam("account_id") String accountId, @PathParam("year") Integer year, // @PathParam("month") Integer month, @PathParam("day") Integer day, // @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { // if(accountManager.checkToken(accountId,token)) { // scheduleManager.deleteSchedule(accountId, year, month, day, scheduleId); // return "success"; // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}/start_time") // @PUT//スケジュールの開始時刻の新規作成・変更 // @Produces(MediaType.TEXT_PLAIN) // @Consumes(MediaType.APPLICATION_FORM_URLENCODED) // public Schedule setScheduleStartTime(@PathParam("account_id") String accountId, @PathParam("year") Integer year, // @PathParam("month") Integer month, @PathParam("day") Integer day, // @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { // if(accountManager.checkToken(accountId,token)) { // scheduleManager.setScheduleStartTime(accountId, year, month, day, scheduleId); // return "success"; // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}/end_time") // @PUT//スケジュールの終了時刻の新規作成・変更 // @Produces(MediaType.TEXT_PLAIN) // @Consumes(MediaType.APPLICATION_FORM_URLENCODED) // public Schedule setScheduleEndTime(@PathParam("account_id") String accountId, @PathParam("year") Integer year, // @PathParam("month") Integer month, @PathParam("day") Integer day, // @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { // if(accountManager.checkToken(accountId,token)) { // scheduleManager.setScheduleEndTime(accountId, year, month, day, scheduleId); // return "success"; // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}/title") // @PUT//スケジュールのタイトルの変更 // @Produces(MediaType.TEXT_PLAIN) // @Consumes(MediaType.APPLICATION_FORM_URLENCODED) // public Schedule setScheduleTitle(@PathParam("account_id") String accountId, @PathParam("year") Integer year, // @PathParam("month") Integer month, @PathParam("day") Integer day, // @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { // if(accountManager.checkToken(accountId,token)) { // scheduleManager.setScheduleTitle(accountId, year, month, day, scheduleId); // return schedule; // } // return null; // } // @Path("/{account_id}/schedule/{year}/{month}/{day}/{schedule_id}/book_id") // @PUT//スケジュールの所属している本の新規設定・変更 // @Produces(MediaType.TEXT_PLAIN) // @Consumes(MediaType.APPLICATION_FORM_URLENCODED) // public Schedule setSchedulesBook(@PathParam("account_id") String accountId, @PathParam("year") Integer year, // @PathParam("month") Integer month, @PathParam("day") Integer day, // @PathParam("schedule_id") Integer scheduleId, @QueryParam("token") String token) { // if(accountManager.checkToken(accountId,token)) { // scheduleManager.setSchedulesBook(accountId, year, month, day, scheduleId);//token後でつける // return "success"; // } // return null; // } }