The ADO.NET Providers for Google
and SharePoint make it easy to retrieve
and update data in both Google's web services
and SharePoint. This article shows how the SQL interface to data makes it easy to build applications that need to move data from one source to another.
The application described here is a demo Windows application that synchronizes calendar
events between Google
and SharePoint, but the RSSBus Providers can be used to achieve integrations on both the .NET
and the Java platforms, including more sophisticated features like full automation.
Getting the
Events
Step 1: Google accounts can have several calendars. Obtain a list of a user's Google Calendars by issuing a query to the Calendars table. For example: SELECT * FROM Calendars.
Step 2: In order to get a list of the
events from a given Google Calendar, issue a query to the CalendarEvents table while specifying the CalendarId from the Calendars table. The resulting
events can be further filtered by using the StartDateTime or EndDateTime columns. For example:
SELECT * FROM CalendarEvents
WHERE (CalendarId = '
[email protected]')
AND (StartDateTime >= '1/1/2012')
AND (StartDateTime <= '2/1/2012')
Step 3: SharePoint stores data in Lists. There are various types of lists, e.g., document lists
and calendar lists. A SharePoint account can have several lists of the same type. To find all the calendar lists in SharePoint, use the ListLists stored procedure
and inspect the BaseTemplate column.
Step 4: The SharePoint data provider models each SharPoint list as a table. Get the
events in a particular calendar by querying the table with the same name as the list. The
events may be filtered further by specifying the EventDate or EndDate columns. For example:
SELECT * FROM Calendar
WHERE (EventDate >= '1/1/2012')
AND (EventDate <= '2/1/2012')
Synchronizing the
Events
Synchronizing the
events is a simple process. Once the
events from Google
and SharePoint are available they can be compared
and synchronized based on user preference. The sample application does this based on user input, but it is easy to create one that does the synchronization automatically. The INSERT, UPDATE,
and DELETE statements available in both data providers makes it easy to create, update, or delete
events as needed.
Pre-Built Demo Application
The executable for the demo application can be downloaded here. Note that this demo is built using BETA builds of the ADO.NET Provider for Google V2
and ADO.NET Provider for SharePoint V2,
and will expire in 2013.
Source Code
You can download the full source of the demo application here. You will need the Google ADO.NET Data Provider V2
and the SharePoint ADO.NET Data Provider V2, which can be obtained here.