From a66453c86f65e01e3a529c199ebea06f78234048 Mon Sep 17 00:00:00 2001 From: maurercw Date: Sat, 30 Nov 2024 20:49:41 -0500 Subject: [PATCH] SAK-48501 - Use a legit date/time format instead of a toString representation so that we can ensure it's properly parsed --- .../sakaiproject/site/tool/SiteAction.java | 24 ++++++++++++++----- 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/site-manage/site-manage-tool/tool/src/java/org/sakaiproject/site/tool/SiteAction.java b/site-manage/site-manage-tool/tool/src/java/org/sakaiproject/site/tool/SiteAction.java index bffe7a5f69d9..9c59f009b9d2 100644 --- a/site-manage/site-manage-tool/tool/src/java/org/sakaiproject/site/tool/SiteAction.java +++ b/site-manage/site-manage-tool/tool/src/java/org/sakaiproject/site/tool/SiteAction.java @@ -33,6 +33,8 @@ import java.time.ZoneId; import java.time.LocalDateTime; import java.time.ZoneOffset; +import java.time.ZonedDateTime; +import java.time.format.DateTimeFormatter; import java.time.format.DateTimeParseException; import java.util.ArrayList; import java.util.Arrays; @@ -2656,6 +2658,7 @@ else if (state.getAttribute(STATE_CM_REQUESTED_SECTIONS) != null) { if(daysafter > 0){ context.put("daysafter",daysafter); } + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss"); if (site != null) { // editing existing site context.put("site", site); @@ -2689,9 +2692,14 @@ else if (state.getAttribute(STATE_CM_REQUESTED_SECTIONS) != null) { ZoneId localZoneId = userTimeService.getLocalTimeZone().toZoneId(); termPublishDate = new Date(courseStartTime - (ONE_DAY_IN_MS * daysbefore)); - context.put("termStartDate", termPublishDate.toInstant().atZone(localZoneId).toString()); - context.put("termEndDate", new Date(courseEndTime).toInstant().atZone(localZoneId).toString()); - context.put("termUnpublishDate", new Date(courseEndTime + (ONE_DAY_IN_MS * daysafter)).toInstant().atZone(localZoneId).toString()); + + ZonedDateTime termStartDate = termPublishDate.toInstant().atZone(localZoneId); + ZonedDateTime termEndDate = new Date(courseEndTime).toInstant().atZone(localZoneId); + ZonedDateTime termUnpublishDate = new Date(courseEndTime + (ONE_DAY_IN_MS * daysafter)).toInstant().atZone(localZoneId); + + context.put("termStartDate", termStartDate.format(formatter)); + context.put("termEndDate", termEndDate.format(formatter)); + context.put("termUnpublishDate", termUnpublishDate.format(formatter)); context.put("readableTermStartDate", userTimeService.dateFormat(termPublishDate, rb.getLocale(), DateFormat.LONG)); //create readable versions of all dates context.put("readableTermStartDateTime", userTimeService.dateTimeFormat(termPublishDate, rb.getLocale(), DateFormat.SHORT)); context.put("readableTermEndDate", userTimeService.dateFormat(academicSession.getEndDate(), rb.getLocale(), DateFormat.LONG)); @@ -2818,9 +2826,13 @@ else if (state.getAttribute(STATE_CM_REQUESTED_SECTIONS) != null) { long courseEndTime = academicSession.getEndDate().getTime(); ZoneId localZoneId = userTimeService.getLocalTimeZone().toZoneId(); - context.put("termStartDate", new Date(courseStartTime - (ONE_DAY_IN_MS * daysbefore)).toInstant().atZone(localZoneId).toString()); - context.put("termEndDate", new Date(courseEndTime).toInstant().atZone(localZoneId).toString()); - context.put("termUnpublishDate", new Date(courseEndTime + (ONE_DAY_IN_MS * daysafter)).toInstant().atZone(localZoneId).toString()); + ZonedDateTime termStartDate = new Date(courseStartTime - (ONE_DAY_IN_MS * daysbefore)).toInstant().atZone(localZoneId); + ZonedDateTime termEndDate = new Date(courseEndTime).toInstant().atZone(localZoneId); + ZonedDateTime termUnpublishDate = new Date(courseEndTime + (ONE_DAY_IN_MS * daysafter)).toInstant().atZone(localZoneId); + + context.put("termStartDate", termStartDate.format(formatter)); + context.put("termEndDate", termEndDate.format(formatter)); + context.put("termUnpublishDate", termUnpublishDate.format(formatter)); context.put("readableTermStartDate", userTimeService.dateFormat(new Date(courseStartTime - (ONE_DAY_IN_MS * daysbefore)), rb.getLocale(), DateFormat.LONG)); //create readable versions of all dates context.put("readableTermEndDate", userTimeService.dateFormat(academicSession.getEndDate(), rb.getLocale(), DateFormat.LONG)); context.put("readableTermUnpublishDate", userTimeService.dateFormat(new Date(courseEndTime + (ONE_DAY_IN_MS * daysafter)), rb.getLocale(), DateFormat.LONG));