Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi ActiveX) Google Contacts - Retrieve All ContactsDemonstrates how to retrieve the full list of contacts for the Google Contacts API.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB; ... procedure TForm1.Button1Click(Sender: TObject); var jsonToken: TChilkatJsonObject; success: Integer; gAuth: TChilkatAuthGoogle; rest: TChilkatRest; bAutoReconnect: Integer; sbResponseBody: TChilkatStringBuilder; xml: TChilkatXml; totalResults: Integer; startIndex: Integer; itemsPerPage: Integer; fac: TCkFileAccess; numEntries: Integer; i: Integer; idUrl: WideString; contactId: WideString; fullName: WideString; emailAddress: WideString; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // -------------------------------------------------------------------------------------------------------- // Note: The code for setting up the Chilkat REST object and making the initial connection can be done once. // Once connected, the REST object may be re-used for many REST API calls. // (It's a good idea to put the connection setup code in a separate function/subroutine.) // -------------------------------------------------------------------------------------------------------- // It is assumed we previously obtained an OAuth2 access token. // This example loads the JSON access token file // saved by this example: Get Google Contacts OAuth2 Access Token jsonToken := TChilkatJsonObject.Create(Self); success := jsonToken.LoadFile('qa_data/tokens/googleContacts.json'); if (success <> 1) then begin Memo1.Lines.Add('Failed to load googleContacts.json'); Exit; end; gAuth := TChilkatAuthGoogle.Create(Self); gAuth.AccessToken := jsonToken.StringOf('access_token'); rest := TChilkatRest.Create(Self); // Connect using TLS. bAutoReconnect := 1; success := rest.Connect('www.google.com',443,1,bAutoReconnect); // Provide the authentication credentials (i.e. the access token) rest.SetAuthGoogle(gAuth.ControlInterface); // ---------------------------------------------- // OK, the REST connection setup is completed.. // ---------------------------------------------- // To retrieve the contacts, we need to send the following: // GET /m8/feeds/contacts/default/full // GData-Version: 3.0 rest.AddHeader('GData-Version','3.0'); sbResponseBody := TChilkatStringBuilder.Create(Self); success := rest.FullRequestNoBodySb('GET','/m8/feeds/contacts/default/full',sbResponseBody.ControlInterface); if (success <> 1) then begin Memo1.Lines.Add(rest.LastErrorText); Exit; end; // A successful response will have a status code equal to 200. if (rest.ResponseStatusCode <> 200) then begin Memo1.Lines.Add('response status code = ' + IntToStr(rest.ResponseStatusCode)); Memo1.Lines.Add('response status text = ' + rest.ResponseStatusText); Memo1.Lines.Add('response header: ' + rest.ResponseHeader); Memo1.Lines.Add('response body: ' + sbResponseBody.GetAsString()); Exit; end; // If the 200 response was received, then the contacts XML is contained // in the response body. xml := TChilkatXml.Create(Self); xml.LoadSb(sbResponseBody.ControlInterface,0); // See below for a sample response body. xml.SaveXml('qa_output/google_contacts.xml'); // Now let's parse the XML... // Get the the total number of results, the start index, and the items per page. // We'll likely NOT get the full list, but will instead get the 1st page. totalResults := xml.GetChildIntValue('openSearch:totalResults'); startIndex := xml.GetChildIntValue('openSearch:startIndex'); itemsPerPage := xml.GetChildIntValue('openSearch:itemsPerPage'); Memo1.Lines.Add('totalResults = ' + IntToStr(totalResults)); Memo1.Lines.Add('startIndex = ' + IntToStr(startIndex)); Memo1.Lines.Add('itemsPerPage = ' + IntToStr(itemsPerPage)); // We'll borrow a method from FileAccess to get the contactId from the URL string (see the code in the while loop) fac := TCkFileAccess.Create(Self); // Iterate over each contact. numEntries := xml.NumChildrenHavingTag('entry'); i := 0; while i < numEntries do begin xml.I := i; Memo1.Lines.Add(IntToStr(i + 1) + ' ----'); Memo1.Lines.Add('title: ' + xml.GetChildContent('entry[i]|title')); // The entry "id" child contains a URL having this format: // <id>http://www.google.com/m8/feeds/contacts/{userEmail}/base/{contactId}</id> // Let's get the URL and parse the contactId from it.. idUrl := xml.GetChildContent('entry[i]|id'); Memo1.Lines.Add('id: ' + idUrl); // Use the parsing ability of GetFileName to get the contactId contactId := fac.GetFileName(idUrl); Memo1.Lines.Add('contactId: ' + contactId); fullName := xml.ChilkatPath('entry[i]|gd:name|gd:fullName|*'); if (xml.LastMethodSuccess = 1) then begin Memo1.Lines.Add('fullName: ' + fullName); end; emailAddress := xml.ChilkatPath('entry[i]|gd:email|(address)'); if (xml.LastMethodSuccess = 1) then begin Memo1.Lines.Add('email address: ' + emailAddress); end; i := i + 1; end; // The response body XML looks something like this: // <feed xmlns="http://www.w3.org/2005/Atom" // xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/" // xmlns:gContact="http://schemas.google.com/contact/2008" // xmlns:batch="http://schemas.google.com/gdata/batch" // xmlns:gd="http://schemas.google.com/g/2005" // gd:etag="feedEtag"> // <id>userEmail</id> // <updated>2008-12-10T10:04:15.446Z</updated> // <category scheme="http://schemas.google.com/g/2005#kind" term="http://schemas.google.com/contact/2008#contact"/> // <link rel="http://schemas.google.com/g/2005#feed" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full"/> // <link rel="http://schemas.google.com/g/2005#post" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full"/> // <link rel="http://schemas.google.com/g/2005#batch" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full/batch"/> // <link rel="self" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full?max-results=25"/> // <author> // <name>User</name> // <email>userEmail</email> // </author> // <generator version="1.0" uri="http://www.google.com/m8/feeds"> // Contacts // </generator> // <openSearch:totalResults>349</openSearch:totalResults> // <openSearch:startIndex>1</openSearch:startIndex> // <openSearch:itemsPerPage>25</openSearch:itemsPerPage> // <entry gd:etag="contactEtag"> // <id> // http://www.google.com/m8/feeds/contacts/userEmail/base/contactId // </id> // <updated>2008-12-10T04:45:03.331Z</updated> // <app:edited xmlns:app="http://www.w3.org/2007/app">2008-12-10T04:45:03.331Z</app:edited> // <category scheme="http://schemas.google.com/g/2005#kind" // term="http://schemas.google.com/contact/2008#contact"/> // <title>Fitzwilliam Darcy</title> // <gd:name> // <gd:fullName>Fitzwilliam Darcy</gd:fullName> // </gd:name> // <link rel="http://schemas.google.com/contacts/2008/rel#photo" type="image/*" // href="https://www.google.com/m8/feeds/photos/media/userEmail/contactId" // gd:etag="photoEtag"/> // <link rel="self" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full/contactId"/> // <link rel="edit" type="application/atom+xml" // href="https://www.google.com/m8/feeds/contacts/userEmail/full/contactId"/> // <gd:phoneNumber rel="http://schemas.google.com/g/2005#home" // primary="true"> // 456 // </gd:phoneNumber> // <gd:extendedProperty name="pet" value="hamster"/> // <gContact:groupMembershipInfo deleted="false" // href="http://www.google.com/m8/feeds/groups/userEmail/base/groupId"/> // <gd:email rel="http://schemas.google.com/g/2005#other" address="darcyf@example.com" primary="true" /> // </entry> // <!-- Other entries ... --> // </feed> // end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.