Chilkat • HOME • Android™ • AutoIt • C • C# • C++ • Chilkat2-Python • CkPython • Classic ASP • DataFlex • Delphi DLL • Go • Java • Node.js • Objective-C • PHP Extension • Perl • PowerBuilder • PowerShell • PureBasic • Ruby • SQL Server • Swift • Tcl • Unicode C • Unicode C++ • VB.NET • VBScript • Visual Basic 6.0 • Visual FoxPro • Xojo Plugin
(PHP Extension) Update a Google ContactDemonstrates how to update a Google Contact.
<?php // The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number. // For example, if using Chilkat v9.5.0.48, then include as shown here: include("chilkat_9_5_0.php"); // 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 = new CkJsonObject(); $success = $jsonToken->LoadFile('qa_data/tokens/googleContacts.json'); if ($success != true) { print 'Failed to load googleContacts.json' . "\n"; exit; } $gAuth = new CkAuthGoogle(); $gAuth->put_AccessToken($jsonToken->stringOf('access_token')); $rest = new CkRest(); // Connect using TLS. $bAutoReconnect = true; $success = $rest->Connect('www.google.com',443,true,$bAutoReconnect); // Provide the authentication credentials (i.e. the access token) $rest->SetAuthGoogle($gAuth); // ---------------------------------------------- // OK, the REST connection setup is completed.. // ---------------------------------------------- // To update a contact, we'll first get the contact information, // then we'll make changes to the XML and then PUT the update. // To retrieve the contact, send the following: // GET /m8/feeds/contacts/default/full/{contactId} // GData-Version: 3.0 $rest->AddHeader('GData-Version','3.0'); $sbPath = new CkStringBuilder(); $sbPath->Append('/m8/feeds/contacts/default/full/{contactId}'); // Get the contact having contactId = "5b6d64980b1ed462" $numReplacements = $sbPath->Replace('{contactId}','5b6d64980b1ed462'); $sbResponseBody = new CkStringBuilder(); $success = $rest->FullRequestNoBodySb('GET',$sbPath->getAsString(),$sbResponseBody); if ($success != true) { print $rest->lastErrorText() . "\n"; exit; } // A successful response will have a status code equal to 200. if ($rest->get_ResponseStatusCode() != 200) { print 'response status code = ' . $rest->get_ResponseStatusCode() . "\n"; print 'response status text = ' . $rest->responseStatusText() . "\n"; print 'response header: ' . $rest->responseHeader() . "\n"; print 'response body: ' . $sbResponseBody->getAsString() . "\n"; exit; } // If the 200 response was received, then the contacts XML is contained // in the response body. $xml = new CkXml(); $xml->LoadSb($sbResponseBody,false); // Get the etag: $lastKnownEtag = $xml->getAttrValue('gd:etag'); print 'lastKnownEtag = ' . $lastKnownEtag . "\n"; // Update the XML. // We're going to add or update with the following information: // <gd:name> // <gd:givenName>Joe</gd:givenName> // <gd:familyName>Sample</gd:familyName> // <gd:fullName>Joe Sample</gd:fullName> // </gd:name> // <content type="text">RIP Joe Sample, a great musician...</content> // <gd:extendedProperty name="pet" value="hamster"/> $xml->UpdateChildContent('gd:name|gd:givenName','Joe'); $xml->UpdateChildContent('gd:name|gd:familyName','Sample'); $xml->UpdateChildContent('gd:name|gd:fullName','Joe Sample'); $xml->UpdateChildContent('content','RIP Joe Sample, a great musician...'); $xml->UpdateAttrAt('content',true,'type','text'); $xml->UpdateAttrAt('gd:extendedProperty',true,'name','pet'); $xml->UpdateAttrAt('gd:extendedProperty',true,'value','hamster'); // Send the following: // PUT /m8/feeds/contacts/default/full/{contactId} // If-Match: {lastKnownEtag} // GData-Version: 3.0 // Content-Type: application/atom+xml $rest->ClearAllHeaders(); $rest->AddHeader('If-Match',$lastKnownEtag); $rest->AddHeader('GData-Version','3.0'); $rest->AddHeader('Content-Type','application/atom+xml'); $sbRequestBody = new CkStringBuilder(); $xml->GetXmlSb($sbRequestBody); // The sbPath already contains the correct path.. $success = $rest->FullRequestSb('PUT',$sbPath->getAsString(),$sbRequestBody,$sbResponseBody); if ($success != true) { print $rest->lastErrorText() . "\n"; exit; } // A successful response will have a status code equal to 200. if ($rest->get_ResponseStatusCode() != 200) { print 'response status code = ' . $rest->get_ResponseStatusCode() . "\n"; print 'response status text = ' . $rest->responseStatusText() . "\n"; print 'response header: ' . $rest->responseHeader() . "\n"; print 'response body: ' . $sbResponseBody->getAsString() . "\n"; exit; } // If the 200 response was received, then the updated contact XML is contained // in the response body. $xml->LoadSb($sbResponseBody,false); print 'Response Body:' . "\n"; print $xml->getXml() . "\n"; print 'Success.' . "\n"; ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.