Penyedia Kontak dan Informasi Afinitas

Mulai di Android 10, data terkait afinitas kontak, yang dikelola oleh komponen Penyedia Kontak (sumber data yang terlihat di aplikasi kontak perangkat), diakses secara berbeda dibandingkan di Android 9 dan yang lebih rendah.

Sebelum Android 10, aplikasi menggunakan Penyedia Kontak untuk mengakses data dan mentransfernya antara perangkat dan layanan online. Android 10 menampilkan perubahan terkait aksesibilitas data untuk memastikan peningkatan privasi pengguna di semua perangkat Android 10 yang menggunakan Penyedia Kontak. Pertama, database yang mendasarinya tidak berisi data afinitas kontak. Oleh karena itu, aplikasi tidak dapat menulis atau membaca darinya. Perubahan tersebut antara lain sebagai berikut:

  • Penyedia Kontak tidak merekam data terkait afinitas kontak, seperti berapa kali pengguna dihubungi, terakhir kali kontak, aplikasi yang digunakan, orang yang dihubungi, atau data historis terkait lainnya.
  • Kelas MultiAutoCompleteTextView di API pelengkapan otomatis Penyedia Kontak tidak mengurutkan hasil kueri menurut penghitung interaksi.
  • Kerangka kerja Android tidak memberikan peringkat kontak implisit. (Namun, peringkat kontak eksplisit yang dikontrol pengguna (seperti kontak berbintang ) tetap ada).

Untuk menerapkan perubahan ini, lakukan salah satu hal berikut:

  • Gunakan Penyedia Kontak terbaru.
  • Perbarui versi Anda (jika Anda menggunakan versi bercabang).

Selain itu, perbarui aplikasi apa pun yang mengandalkan fitur Penyedia Kontak yang tidak digunakan lagi . Versi API yang dirancang sebagai solusi untuk fungsi yang tidak digunakan lagi tidak diizinkan.

Untuk Android 9 dan yang lebih rendah, data interaksi kontak dari Penyedia Kontak belum dihapus. Sebagai gantinya, data interaksi kontak dihapus secara berkala (kira-kira sekali per hari) untuk mensimulasikan yang setara di Android 10. Penyedia Kontak menyimpan informasi ini, tetapi hanya untuk sementara.

Perubahan API

Perubahan ini diharapkan berdampak besar pada API. Misalnya, peringkat pelengkapan otomatis tidak akan berfungsi dengan baik. Dampak potensial pada perilaku API mencakup hal-hal berikut:

  • Penyedia Kontak tidak akan menyimpan preferensi pengguna untuk, atau interaksi dengan, kontak di kolom tabel ContactsContract.Contacts .
  • API pelengkapan otomatis tidak akan mengurutkan hasil berdasarkan penghitung interaksi.
  • Kolom TIMES_CONTACTED / TIMES_USED dan LAST_TIME_CONTACTED / LAST_TIME_USED tidak akan diperbarui.
    • Ini jelas (ke null atau disetel ke 0, tergantung pada kolom yang terpengaruh) setelah memutakhirkan ke Android 10.
    • Pemeringkatan dalam API kueri pelengkapan otomatis mengembalikan hasil yang diurutkan menurut abjad, tidak pernah berdasarkan informasi afinitas.
    • Panggilan API untuk kontak yang sering (misalnya, menggunakan string filter CONTENT_FREQUENT_URI ) tidak memberikan hasil.

Umumnya, jika salah satu elemen API Penyedia Kontak yang tidak digunakan lagi menggunakan penghitung, penghitung tersebut (bila digunakan di Android 10) berisi 0, dan mengembalikan 0 saat ditanyakan. Permintaan pembaruan dari API yang terpengaruh diabaikan. Misalnya, kelas ContactsContract.DataUsageFeedback tidak digunakan lagi, jadi pembaruan dan penghapusan panggilan ke kelas ini diabaikan.

Bidang yang memengaruhi API

Bidang ini telah berubah di Android 10:

Kolom yang terpengaruh di Android 10 mungkin ada di API yang berbeda, seperti yang ditunjukkan pada tabel di bawah. Bidang API yang tidak digunakan lagi mengembalikan perilaku seperti yang tercantum. Karena salah satu bidang yang tidak digunakan lagi ini dapat digunakan di beberapa API Anda, verifikasi kasus penggunaan Anda.

Kelas bidang API 10 pengembalian
ContactsContract.Contacts
ContactsContract.RawContacts
ContactsContract.Data
ContactsContract.Entity
ContactOptionsColumns
TIMES_CONTACTED
LAST_TIME_CONTACTED
Kolom ini selalu berisi 0, terlepas dari bagaimana mereka digunakan. Upaya untuk mengubahnya diabaikan.
Contacts markAsContacted() Tidak ada operasi.
ContactsContract.DataUsageFeedback

update
delete

Tidak ada operasi.
ContactsContract.Contacts Sering ( berbintang + sering)
CONTENT_STREQUENT_FILTER_URI
CONTENT_STREQUENT_URI
CONTENT_FREQUENT_URI
Mengembalikan kontak berbintang saja. Tidak ada kontak yang sering dikembalikan.
ContactsContract.CommonDataKinds.Email
ContactsContract.CommonDataKinds.Phone
ContactsContract.CommonDataKinds.Callable
Filter (juga disebut pelengkapan otomatis) API

CONTENT_FILTER_URI
ENTERPRISE_CONTENT_FILTER_URI

Hasil tidak diurutkan berdasarkan afinitas. Ini diurutkan berdasarkan bintang dan nama .

Alternatif

Tidak ada alternatif untuk bidang API yang tidak digunakan lagi. Solusi yang dirancang untuk menghindari pembatasan ini, baik dalam bentuk API baru atau bidang baru, tidak diizinkan.

Penerapan

Anda tidak perlu melakukan apa pun untuk menerapkan perubahan ini. Mereka adalah bagian dari inisiatif untuk meningkatkan privasi pengguna di platform OS Android. Namun, jika aplikasi Anda mengandalkan fitur yang tidak digunakan lagi, Anda mungkin ingin memperbarui aplikasi untuk mengimbangi perubahan apa pun. Selain itu, jika Anda menggunakan Penyedia Kontak versi bercabang, Anda harus memperbarui Penyedia Kontak Anda.

Tidak ada kustomisasi

Jangan menyesuaikan atau mengatasi perubahan informasi afinitas kontak. Mereka dibangun ke dalam kerangka kerja, dan membuat perubahan apa pun membuat Anda keluar dari kepatuhan. Jangan pernah mengubah pengaturan default atau memberikan alternatif pintu belakang.