1
0
Fork 0
mirror of https://github.com/M66B/FairEmail.git synced 2025-01-04 06:20:26 +00:00

Event times are always UTC

This commit is contained in:
M66B 2023-10-28 15:08:36 +02:00
parent a04a9f4c8c
commit fbb9bfbe33

View file

@ -54,6 +54,7 @@ import biweekly.io.text.ICalReader;
import biweekly.parameter.ParticipationStatus; import biweekly.parameter.ParticipationStatus;
import biweekly.property.Action; import biweekly.property.Action;
import biweekly.property.Attendee; import biweekly.property.Attendee;
import biweekly.property.ICalProperty;
import biweekly.property.RecurrenceRule; import biweekly.property.RecurrenceRule;
import biweekly.property.Trigger; import biweekly.property.Trigger;
import biweekly.util.Duration; import biweekly.util.Duration;
@ -95,6 +96,16 @@ public class CalendarHelper {
} }
} }
static String getTimeZoneID(ICalendar icalendar, ICalProperty property) {
TimezoneInfo tzinfo = icalendar.getTimezoneInfo();
TimezoneAssignment tza = (tzinfo == null ? null : tzinfo.getTimezone(property));
TimeZone tz = (tza == null ? null : tza.getTimeZone());
String tzid = (tz == null ? null : tz.getID());
if (tzid == null)
tzid = TimeZone.getDefault().getID();
return tzid;
}
static Long exists(Context context, String selectedAccount, String selectedName, String uid) { static Long exists(Context context, String selectedAccount, String selectedName, String uid) {
ContentResolver resolver = context.getContentResolver(); ContentResolver resolver = context.getContentResolver();
try (Cursor cursor = resolver.query(CalendarContract.Events.CONTENT_URI, try (Cursor cursor = resolver.query(CalendarContract.Events.CONTENT_URI,
@ -154,19 +165,14 @@ public class CalendarHelper {
ICalDate start = (event.getDateStart() == null ? null : event.getDateStart().getValue()); ICalDate start = (event.getDateStart() == null ? null : event.getDateStart().getValue());
ICalDate end = (event.getDateEnd() == null ? null : event.getDateEnd().getValue()); ICalDate end = (event.getDateEnd() == null ? null : event.getDateEnd().getValue());
// Assume one time zone String tzstart = getTimeZoneID(icalendar, event.getDateStart());
TimezoneInfo tzinfo = icalendar.getTimezoneInfo(); String tzend = getTimeZoneID(icalendar, event.getDateEnd());
TimezoneAssignment tza = (tzinfo == null ? null : tzinfo.getTimezone(event.getDateStart()));
TimeZone tz = (tza == null ? null : tza.getTimeZone());
String tzid = (tz == null ? null : tz.getID());
if (tzid == null)
tzid = TimeZone.getDefault().getID();
String rrule = null; String rrule = null;
RecurrenceRule recurrence = event.getRecurrenceRule(); RecurrenceRule recurrence = event.getRecurrenceRule();
if (recurrence != null) { if (recurrence != null) {
RecurrenceRuleScribe scribe = new RecurrenceRuleScribe(); RecurrenceRuleScribe scribe = new RecurrenceRuleScribe();
WriteContext wcontext = new WriteContext(ICalVersion.V2_0, tzinfo, null); WriteContext wcontext = new WriteContext(ICalVersion.V2_0, icalendar.getTimezoneInfo(), null);
rrule = scribe.writeText(recurrence, wcontext); rrule = scribe.writeText(recurrence, wcontext);
} }
@ -206,9 +212,10 @@ public class CalendarHelper {
if (!TextUtils.isEmpty(organizer)) if (!TextUtils.isEmpty(organizer))
values.put(CalendarContract.Events.ORGANIZER, organizer); values.put(CalendarContract.Events.ORGANIZER, organizer);
values.put(CalendarContract.Events.EVENT_TIMEZONE, tzid);
values.put(CalendarContract.Events.DTSTART, start.getTime()); values.put(CalendarContract.Events.DTSTART, start.getTime());
values.put(CalendarContract.Events.DTEND, end.getTime()); values.put(CalendarContract.Events.DTEND, end.getTime());
values.put(CalendarContract.Events.EVENT_TIMEZONE, "UTC");
values.put(CalendarContract.Events.EVENT_END_TIMEZONE, "UTC");
if (rrule != null) if (rrule != null)
values.put(CalendarContract.Events.RRULE, rrule); values.put(CalendarContract.Events.RRULE, rrule);
@ -229,9 +236,8 @@ public class CalendarHelper {
" id=" + calId + ":" + eventId + " id=" + calId + ":" + eventId +
" uid=" + uid + " uid=" + uid +
" organizer=" + organizer + " organizer=" + organizer +
" tz=" + tzid + " start=" + new Date(start.getTime()) + "/" + tzstart +
" start=" + new Date(start.getTime()) + " end=" + new Date(end.getTime()) + "/" + tzend +
" end=" + new Date(end.getTime()) +
" rrule=" + rrule + " rrule=" + rrule +
" summary=" + summary + " summary=" + summary +
" location=" + location + " location=" + location +
@ -243,9 +249,8 @@ public class CalendarHelper {
" id=" + calId + ":" + existId + " id=" + calId + ":" + existId +
" uid=" + uid + " uid=" + uid +
" organizer=" + organizer + " organizer=" + organizer +
" tz=" + tzid + " start=" + new Date(start.getTime()) + "/" + tzstart +
" start=" + new Date(start.getTime()) + " end=" + new Date(end.getTime()) + "/" + tzend +
" end=" + new Date(end.getTime()) +
" rrule=" + rrule + " rrule=" + rrule +
" summary=" + summary + " summary=" + summary +
" location=" + location + " location=" + location +