| <p>This sample demonstrates how an application can communicate with a | 
 | cloud-based service and synchronize its data with data stored locally in a | 
 | content provider. The sample uses two related parts of the Android framework | 
 | — the account manager and the synchronization manager (through a sync | 
 | adapter). It also demonstrates how to provide users the ability to create | 
 | and edit synchronized contacts using a custom editor.</p> | 
 |  | 
 | <p> The <a | 
 | href="../../../reference/android/accounts/AccountManager.html">account | 
 | manager</a> allows sharing of credentials across multiple applications and | 
 | services. Users enter the credentials for each account only once — | 
 | applications with the <code>USE_CREDENTIALS</code> permission can then query the | 
 | account manager to obtain an auth token for the account. An authenticator (a | 
 | pluggable component of account manager) requests credentials from the user, | 
 | validates them with an authentication server running in the cloud, and then | 
 | stores them to the account manager. This sample demonstrates how to write an | 
 | authenticator for your service by extending the new  <code><a | 
 | href="../../../reference/android/accounts/AbstractAccountAuthenticator.html"> | 
 | AbstractAccountAuthenticator</a></code> abstract class. </p> | 
 |  | 
 | <p>The sync adapter (essential to the synchronization service) declares the | 
 | account type and ContentProvider authority to the sync manager. This sample | 
 | demosntrates how to write your own sync adapters by extending the <code><a | 
 | href="../../../reference/android/content/AbstractThreadedSyncAdapter.html"> | 
 | AbstractThreadedSyncAdapter</a></code> abstract class and implementing the | 
 | <code>onPerformSync()</code> method, which gets called whenever the sync manager | 
 | issues a sync operation for that sync adapter. </p> | 
 |  | 
 | <p class="note"><strong>Update:</strong> This sample has been updated for Android 4.0 to | 
 | demonstrate new features, including: syncing and viewing contact groups, handling the "invite" | 
 | intent, and a few other improvements.</p> | 
 |  | 
 | <p> The cloud-based service for this sample application is running at: </p> | 
 | <p style="margin-left:2em;">http://samplesyncadapter2.appspot.com/</p> | 
 |  | 
 | <p>When you install this sample application, a new syncable "SampleSyncAdapter" | 
 | account will be added to your phone's account manager. You can go to "Settings | | 
 | Accounts & Sync" to view the account and change its sync settings. </p> | 
 |  | 
 | <img alt="Screenshot 1" src="../images/SampleSyncAdapter1.png" /> | 
 | <img alt="Screenshot 2" src="../images/SampleSyncAdapter2.png" /> | 
 | <img alt="Screenshot 3" src="../images/SampleSyncAdapter3.png" /> |