如何从asp应用程序更新Google日历事件?

时间:2013-02-14 14:03:45

标签: asp.net .net api

我想在Google日历中插入事件的主键,然后在EventQuery调用后检索它以更新该事件

我在Evententry类中找不到任何属性来分配主键,然后检索更新该事件。

1 个答案:

答案 0 :(得分:0)

可以使用下面的方法使用ExtendedProperty来完成

1.Assign an ID (same as you set in your DB) to each event you add through
  ExtendedProperty . 
2.When updating / deleting you pass the ID and use Query to fetch it for you
3.If the event is found you can delete / update the specific event

Google.GData.Calendar.EventEntry Entry = new Google.GData.Calendar.EventEntry();

//create the ExtendedProperty and add the EventID in the new event object, 
//so it can be deleted / updated later
ExtendedProperty oExtendedProperty = new ExtendedProperty();
oExtendedProperty.Name = "EventID";
oExtendedProperty.Value = GoogleAppointmentObj.EventID;
Entry.ExtensionElements.Add(oExtendedProperty);

string ThisFeedUri = "http://www.google.com/calendar/feeds/" + CalendarID 
+ "/private/full";
Uri postUri = new Uri(ThisFeedUri);

//create an event query object and attach the EventID to it in Extraparameters
EventQuery Query = new EventQuery(ThisFeedUri);
Query.ExtraParameters = "extq=[EventID:" + GoogleAppointmentObj.EventID + "]";
Query.Uri = postUri;

//Find the event with the specific ID
EventFeed calFeed = CalService.Query(Query);

//if search contains result then delete
if (calFeed != null && calFeed.Entries.Count > 0)
{
   foreach (EventEntry SearchedEntry in calFeed.Entries)
   {
      SearchedEntry.Delete();
      //To update comment the code above and uncomment the code below 
      //CalService.Update(SearchedEntry);
      break;
   }
}
else
{
    InsertedEntry = CalService.Insert(postUri, Entry);
}