Platform SDK: CDO 1.2.1 |
A meeting is an appointment applicable to one or more messaging users. If you wish to organize a meeting, you start with an appointment that specifies the time and place, and you send it to the other users that are to be involved.
To organize a meeting using the CDO Library
The hierarchy of relevant objects is as follows:
Session object
Folder object
Messages collection
AppointmentItem
Recipients collection
Recipient
RecurrencePattern
MeetingItem
You create a meeting by setting the AppointmentItem object's MeetingStatus property to CdoMeeting and sending it to one or more recipients. The appointment becomes a meeting as of the moment you call its Send method. In response to this, CDO automatically instantiates a MeetingItem object in your Inbox and every Recipient object's Inbox. Each MeetingItem object becomes a member of the Inbox Messages collection, and it can be treated programmatically just like the regular Message objects in the collection.
To accept a meeting request, a recipient calls the MeetingItem object's Respond method with CdoResponseAccepted in the RespondType parameter. Respond returns another MeetingItem object, which the recipient can Send back to the organizer. Calling Respond with either CdoResponseAccepted or CdoResponseTentative causes an associated AppointmentItem object to be created in the recipient's active calendar folder.
A recipient can call the MeetingItem object's GetAssociatedAppointment method to obtain the associated AppointmentItem object. GetAssociatedAppointment returns the appointment created by CDO in that recipient's calendar folder, not the original appointment from which you created the meeting. You are identified in the Organizer property of every recipient's associated appointment.
To decline a meeting request, a recipient calls Respond with RespondType set to CdoResponseDeclined, and then Send. No AppointmentItem object is created in the recipient's calendar folder in this case.
If you decide to cancel a meeting, set the original appointment's MeetingStatus property to CdoMeetingCanceled and Send it again to all the recipients. Only you can cancel a meeting that you organized.
You can make an appointment recurring by calling its GetRecurrencePattern method, which returns a child RecurrencePattern object describing the recurrence characteristics. You can then change the RecurrencePattern object's properties from their default values to specify the recurrence settings you want. The appointment can later be restored to nonrecurring status with the ClearRecurrencePattern method. It is usually best to make an appointment recurring before generating a meeting from it.
If you wish to edit an individual recurrence of a recurring appointment to make it different from other recurrences in the series, you must first instantiate it. To do this, you perform the following steps:
A meeting can be obtained from its parent Messages collection using the collection’s Item property. To get to the Messages collection in a folder, use the Folder object’s Messages property. If you know a meeting’s unique identifier, you can obtain it directly from the Session object’s GetMessage method.
This code fragment creates and sends an appointment for a meeting at 9:00 the next morning:
Dim objSess As Session Dim objCalFold As Folder ' calendar folder to create appointments in Dim colAppts As Messages ' appointments collection in calendar folder Dim objNewAppt As AppointmentItem Dim colRecips As Recipients ' users to be invited to the meeting Set objCalFold = objSess.GetDefaultFolder(CdoDefaultFolderCalendar) Set colAppts = objCalFold.Messages Set objNewAppt = colAppts.Add ' no parameters when adding appointments With objNewAppt .MeetingStatus = CdoMeeting ' required before calling .Send .Importance = CdoHigh .Location = "My office" .Subject = "Extremely important meeting tomorrow at 9:00 AM!" .Text = "We will discuss stock distribution." .StartTime = DateAdd("d", 1, DateAdd("h", 9, Date)) .EndTime = DateAdd("h", 1, .StartTime) ' meeting to last one hour Set colRecips = .Recipients ' empty collection of users to invite End With With colRecips ' populate collection with invitees .Add "John Doe", "jdoe@microsoft.com" ' can't use parentheses! .Add "Mary Coe", "mcoe@microsoft.com" .Resolve ' default to dialog in case of name ambiguities End With objNewAppt.Send ' appointment becomes a meeting at this moment