X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fical_dezonify.c;h=de444a9d5522a791e5a56083c0195b9de0323dcf;hb=HEAD;hp=2b9d6caf72265d916b59f211287a9e3cc550fcdf;hpb=af88c55d471866b7e5d720ce5d757fe1c2eb4a5b;p=citadel.git diff --git a/webcit/ical_dezonify.c b/webcit/ical_dezonify.c index 2b9d6caf7..b0342beee 100644 --- a/webcit/ical_dezonify.c +++ b/webcit/ical_dezonify.c @@ -1,91 +1,91 @@ -/* - * $Id$ - * - * Function to go through an ical component set and convert all non-UTC - * date/time properties to UTC. It also strips out any VTIMEZONE - * subcomponents afterwards, because they're irrelevant. - * - * Everything here will work on both a fully encapsulated VCALENDAR component - * or any type of subcomponent. - * - */ - -#include "webcit.h" -#include "webserver.h" +// Go through an ical component set and convert all non-UTC date/time properties to UTC. +// It also strips out any VTIMEZONE subcomponents afterwards, because they are now unreferenced. +// +// Everything here will work on both components and subcomponents. If subcomponents are discovered it will recurse through them. +// +// Copyright (c) 2002-2024 by the citadel.org team (Art Cancro et al) +// This program is open source software. Use, duplication, or disclosure is subject to the GNU General Public License v3. +// NOTE: this file is symlinked between different generations of WebCit. When we retire WebCit-classic, copy the file over. -#ifdef WEBCIT_WITH_CALENDAR_SERVICE +#include "webcit.h" -/* - * Figure out which time zone needs to be used for timestamps that are - * not UTC and do not have a time zone specified. - * - */ +// Figure out which time zone needs to be used for timestamps that are not UTC and do not have a time zone specified. icaltimezone *get_default_icaltimezone(void) { icaltimezone *zone = NULL; - char *default_zone_name = serv_info.serv_default_cal_zone; if (!zone) { zone = icaltimezone_get_builtin_timezone(default_zone_name); } if (!zone) { - lprintf(1, "Unable to load '%s' time zone. Defaulting to UTC.\n", default_zone_name); + syslog(LOG_WARNING, "ical_dezonify: unable to load '%s' time zone, defaulting to UTC", default_zone_name); zone = icaltimezone_get_utc_timezone(); } if (!zone) { - lprintf(1, "Unable to load UTC time zone!\n"); + syslog(LOG_ERR, "ical_dezonify: unable to load UTC time zone!"); } return zone; } -/* - * Back end function for ical_dezonify() - * - * We supply this with the master component, the relevant component, - * and the property (which will be a DTSTART, DTEND, etc.) - * which we want to convert to UTC. - */ -void ical_dezonify_backend(icalcomponent *cal, - icalcomponent *rcal, - icalproperty *prop) { +// Back end function for ical_dezonify() +// +// We supply this with the master component, the relevant component, and the property +// (which will be a DTSTART, DTEND, etc.) which we want to convert to UTC. +void ical_dezonify_backend(icalcomponent *cal, icalcomponent *rcal, icalproperty *prop) { icaltimezone *t = NULL; icalparameter *param; const char *tzid = NULL; struct icaltimetype TheTime; - int utc_declared_as_tzid = 0; /* Component declared 'TZID=GMT' instead of using Z syntax */ + int utc_declared_as_tzid = 0; // Component declared 'TZID=GMT' instead of using Z syntax - /* Give me nothing and I will give you nothing in return. */ + // Give me nothing and I will give you nothing in return. if (cal == NULL) return; - /* Hunt for a TZID parameter in this property. */ + // Hunt for a TZID parameter in this property. param = icalproperty_get_first_parameter(prop, ICAL_TZID_PARAMETER); - /* Get the stringish name of this TZID. */ + // Get the stringish name of this TZID. if (param != NULL) { tzid = icalparameter_get_tzid(param); - /* Convert it to an icaltimezone type. */ + // Convert it to an icaltimezone type. if (tzid != NULL) { - lprintf(9, " * Stringy supplied timezone is: '%s'\n", tzid); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: Stringy supplied timezone is: '%s'\n", tzid); +#endif if ( (!strcasecmp(tzid, "UTC")) || (!strcasecmp(tzid, "GMT")) ) { utc_declared_as_tzid = 1; - lprintf(9, " * ...and we handle that internally.\n"); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: ...and we handle that internally.\n"); +#endif } else { + // try attached first t = icalcomponent_get_timezone(cal, tzid); - lprintf(9, " * ...and I %s have tzdata for that zone.\n", +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: ...and I %s have tzdata for that zone.\n", (t ? "DO" : "DO NOT") ); +#endif + // then try built-in timezones + if (!t) { + t = icaltimezone_get_builtin_timezone(tzid); +#ifdef DBG_ICAL + if (t) { + syslog(LOG_DEBUG, "ical_dezonify: Using system tzdata!\n"); + } +#endif + } } } } - /* Now we know the timezone. Convert to UTC. */ + // Now we know the timezone. Convert to UTC. if (icalproperty_isa(prop) == ICAL_DTSTART_PROPERTY) { TheTime = icalproperty_get_dtstart(prop); @@ -103,37 +103,49 @@ void ical_dezonify_backend(icalcomponent *cal, return; } - lprintf(9, " * Was: %s\n", icaltime_as_ical_string(TheTime)); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: was: %s\n", icaltime_as_ical_string(TheTime)); +#endif - if (TheTime.is_utc) { - lprintf(9, " * This property is ALREADY UTC.\n"); + if (icaltime_is_utc(TheTime)) { +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: this property is ALREADY UTC"); +#endif } else if (utc_declared_as_tzid) { - lprintf(9, " * Replacing '%s' TZID with 'Z' suffix.\n", tzid); - TheTime.is_utc = 1; +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: replacing '%s' TZID with 'Z' suffix", tzid); +#endif + TheTime.zone = icaltimezone_get_utc_timezone(); } else { - /* Do the conversion. */ + // Do the conversion. if (t != NULL) { - lprintf(9, " * Timezone prop found. Converting to UTC.\n"); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: timezone prop found, converting to UTC"); +#endif } else { - lprintf(9, " * Converting default timezone to UTC.\n"); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: converting default timezone to UTC"); +#endif } if (t == NULL) { t = get_default_icaltimezone(); } icaltimezone_convert_time(&TheTime, t, icaltimezone_get_utc_timezone()); - TheTime.is_utc = 1; + TheTime.zone = icaltimezone_get_utc_timezone(); } icalproperty_remove_parameter_by_kind(prop, ICAL_TZID_PARAMETER); - lprintf(9, " * Now: %s\n", icaltime_as_ical_string(TheTime)); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify: now: %s", icaltime_as_ical_string(TheTime)); +#endif - /* Now add the converted property back in. */ + // Now add the converted property back in. if (icalproperty_isa(prop) == ICAL_DTSTART_PROPERTY) { icalproperty_set_dtstart(prop, TheTime); } @@ -149,31 +161,23 @@ void ical_dezonify_backend(icalcomponent *cal, } -/* - * Recursive portion of ical_dezonify() - */ +// Recursive portion of ical_dezonify() void ical_dezonify_recurse(icalcomponent *cal, icalcomponent *rcal) { icalcomponent *c; icalproperty *p; - /* - * Recurse through all subcomponents *except* VTIMEZONE ones. - */ - for (c=icalcomponent_get_first_component( - rcal, ICAL_ANY_COMPONENT); + // Recurse through all subcomponents *except* VTIMEZONE ones. + for ( c=icalcomponent_get_first_component(rcal, ICAL_ANY_COMPONENT); c != NULL; - c = icalcomponent_get_next_component( - rcal, ICAL_ANY_COMPONENT) + c = icalcomponent_get_next_component(rcal, ICAL_ANY_COMPONENT) ) { if (icalcomponent_isa(c) != ICAL_VTIMEZONE_COMPONENT) { ical_dezonify_recurse(cal, c); } } - /* - * Now look for DTSTART and DTEND properties - */ - for (p=icalcomponent_get_first_property(rcal, ICAL_ANY_PROPERTY); + // Now look for DTSTART and DTEND properties + for ( p=icalcomponent_get_first_property(rcal, ICAL_ANY_PROPERTY); p != NULL; p = icalcomponent_get_next_property(rcal, ICAL_ANY_PROPERTY) ) { @@ -182,35 +186,33 @@ void ical_dezonify_recurse(icalcomponent *cal, icalcomponent *rcal) { || (icalproperty_isa(p) == ICAL_DTEND_PROPERTY) || (icalproperty_isa(p) == ICAL_DUE_PROPERTY) || (icalproperty_isa(p) == ICAL_EXDATE_PROPERTY) - ) { + ) { ical_dezonify_backend(cal, rcal, p); } } } -/* - * Convert all DTSTART and DTEND properties in all subcomponents to UTC. - * This function will search any VTIMEZONE subcomponents to learn the - * relevant timezone information. - */ +// Convert all DTSTART and DTEND properties in all subcomponents to UTC. +// This function will search any VTIMEZONE subcomponents to learn the +// relevant timezone information. void ical_dezonify(icalcomponent *cal) { icalcomponent *vt = NULL; - lprintf(9, "ical_dezonify() started\n"); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify() started"); +#endif - /* Convert all times to UTC */ + // Convert all times to UTC ical_dezonify_recurse(cal, cal); - /* Strip out VTIMEZONE subcomponents -- we don't need them anymore */ - while (vt = icalcomponent_get_first_component( - cal, ICAL_VTIMEZONE_COMPONENT), vt != NULL) { + // Strip out VTIMEZONE subcomponents -- we don't need them anymore. + while (vt = icalcomponent_get_first_component(cal, ICAL_VTIMEZONE_COMPONENT), vt != NULL) { icalcomponent_remove_component(cal, vt); icalcomponent_free(vt); } - lprintf(9, "ical_dezonify() completed\n"); +#ifdef DBG_ICAL + syslog(LOG_DEBUG, "ical_dezonify() completed"); +#endif } - - -#endif /* WEBCIT_WITH_CALENDAR_SERVICE */