OUTBOX: How to tell if the DST Rebasing Tool has been run on a mailbox?
The rebasing tool adds time zone information to appointments that it touches. This time zone information is the same that Outlook 2007 (and patched versions of CDO 1.21) puts on appointments when it creates them. These time zone structures are described here…
https://blogs.msdn.com/stephen_griffin/archive/2006/12/06/outlook-2007-timezone-structures.aspx
What that means is that we cannot discern between appointments that were touched by the rebasing tool and ones that were created or modified by “new” clients (Outlook 2007 or DST patched versions of CDO 1.21). There isn’t any marking on the mailbox itself so what you would have to do is iterate through items in the calendar folder and look for these properties on calendar items. If they exist on any appointment in the calendar then you know that the rebasing tool and/or “new” clients have been there.
You would need to use MAPI, CDO 1.21, or Outlook 2007’s object model to write this code. MAPI is not scriptable and you may not have Outlook 2007 available to you so I would suggest CDO 1.21. The following is a small VBA example which uses CDO 1.21 that you can run in Outlook which will pop up a message box telling you if new clients have been to this mailbox.
Sub Main()
Dim oSession As New MAPI.Session
oSession.Logon , , False, False, , True
Dim oFolder As MAPI.Folder
Set oFolder = oSession.GetDefaultFolder(CdoDefaultFolderCalendar)
Dim oMessages As MAPI.Messages
Set oMessages = oFolder.Messages
Dim oAppt As MAPI.AppointmentItem
Dim oFields As MAPI.Fields
Dim oField As MAPI.Field
For Each oAppt In oMessages
On Error Resume Next
Set oFields = oAppt.Fields
Set oField = oFields.Item("0x825E", "0220060000000000C000000000000046")
If Not oField Is Nothing Then
MsgBox "New clients have been here."
Exit For
End If
Next
End Sub
…You can use this VBA code as the beginnings of a script to identify appointments that have been touched by the rebasing or “new clients”. If you don’t get any message box from this script that “New clients have been here” then you know either one of two things: 1) You don’t have any appointments in the calendar that you are the organizer of or 2) The rebasing tool or new clients have not touched any appointments in this calendar…
References:
CDOLive: Property Tags and Types
https://www.cdolive.com/cdo10.htm
BLOG: Outlook 2007 Time Zone Structures
https://blogs.msdn.com/stephen_griffin/archive/2006/12/06/outlook-2007-timezone-structures.aspx
More Information:
GLEN: Creating a Summary Email of all appointments within a Users Calendar for given period
https://gsexdev.blogspot.com/2007/02/creating-summary-email-of-all.html
GLEN: Creating a Report of Meeting Organizers for all appointments in all calendars on a Server via WebDAV
https://gsexdev.blogspot.com/2007/02/creating-report-of-meeting-organizers.html
Comments
Anonymous
February 28, 2007
What I need is an end user based method that displays all appointments that have the old TZ bias that the requesting user created. The use case is, user goes to web page, clicks a link which brings them to a page that shows them their bad appointments. From there they can either click the link to open the appt or go directly into Outlook 2003 and correct. We aren't using the rebasing tool but making users responsible. Giving them verification that they fixed it is very helpful. Thanks!Anonymous
March 02, 2007
Microsoft Exchange PHP WebDAV Examples How to analyze Exchange Server SMTP log files in Microsoft ExcelAnonymous
March 06, 2007
Doug, There is no way to identify which appointments have a "bad" bias. Outlook versions pre-Outlook 2007 don't put these time zone properties on an appointemnt. If this property is not available on an appointment it doesn't mean that the appointment needs to be rebased. -MattAnonymous
March 09, 2007
The comment has been removedAnonymous
March 09, 2007
From what I read it sounds like your Java applicaiton calls into J-Integra which then calls into CDO (I assume CDO 1.21). You are correct that CDO 1.21 does maintain its own timezone information so you will need to patch CDO.dll. If you have Exchange 2003 Server or Exchange 2003 System Manager installed on your application server to get CDO then you will need to install the Exchange 2003 update... http://support.microsoft.com/kb/926666 If you have Outlook 2003 installed on your application server then you will need to install the Outlook 2003 update... http://support.microsoft.com/default.aspx?scid=kb;EN-US;932962Anonymous
March 12, 2007
mstehle, Thanks for help. But I have couple questions. In my problem, the DST appointments are 5 hours off and non-DST appointments are 6 hours. It does not seems to be DST problem. correct? Also, I have not figure out how to dowload the hotfix from http://support.microsoft.com/default.aspx?scid=kb;EN-US;932962. Does I need a support contract with MS to do this? Thanks again.Anonymous
March 12, 2007
The hotfix mentioned in KB 932962 is not available for download from this article. As the it says, "...contact Microsoft Customer Support Services to obtain the hotfix...". You will not be charged for this incident if all you want is to get the hotfix and you don't have to be a Premier customer. As far as the problems with J-Integra creating appointments that are 5 and 6 hours off, I would recommend that you follow up with the vendor. Unless you can create a simple CDO 1.21 script that creates appointments to reproduce the behavior.