એન્ડ્રોઇડ સ્ટુડિયોમાં "getCredentialAsync: કોઈ પ્રદાતા નિર્ભરતા મળી નથી" ભૂલને ઉકેલી રહ્યું છે

એન્ડ્રોઇડ સ્ટુડિયોમાં getCredentialAsync: કોઈ પ્રદાતા નિર્ભરતા મળી નથી ભૂલને ઉકેલી રહ્યું છે
એન્ડ્રોઇડ સ્ટુડિયોમાં getCredentialAsync: કોઈ પ્રદાતા નિર્ભરતા મળી નથી ભૂલને ઉકેલી રહ્યું છે

એન્ડ્રોઇડ સાઇન-ઇનમાં ઓળખપત્રની સમસ્યાઓને સમજવી

Android સ્ટુડિયોમાં Google સાઇન-ઇન બટન બનાવવું એ અમલીકરણ માટે એક આકર્ષક સુવિધા હોઈ શકે છે, જે વપરાશકર્તાઓ માટે સીમલેસ ઓથેન્ટિકેશન ઓફર કરે છે. જો કે, જ્યારે ભૂલો ગમે છે "getCredentialAsync: કોઈ પ્રદાતા નિર્ભરતા મળી નથી" ઊભી થાય છે, તે ઝડપથી ઠોકર બની શકે છે. આ સમસ્યા ઘણીવાર વિકાસના પ્રવાહમાં વિક્ષેપ પાડે છે અને ઑનલાઇન માર્ગદર્શિકાઓ પર આધાર રાખતા વિકાસકર્તાઓ માટે નોંધપાત્ર અવરોધ બની શકે છે. 🤔

મારા તાજેતરના પ્રોજેક્ટ્સમાંના એક દરમિયાન, મને આ જ સમસ્યાનો સામનો કરવો પડ્યો. એન્ડ્રોઇડ ઇમ્યુલેટર પર પરીક્ષણ કરતી વખતે, મેં તેના વિશે ચેતવણી પણ જોઈ Google Play સેવાઓ જૂની છે. જરૂરી અને ઇન્સ્ટોલ કરેલ પ્લે સર્વિસ વર્ઝન વચ્ચેનો મેળ ન ખાવો ખરેખર અનપેક્ષિત વર્તનનું કારણ બની શકે છે. અવલંબનને અપડેટ કરવાથી સમસ્યાનું નિરાકરણ થયું નથી, જે મને ડિબગિંગ રેબિટ હોલની નીચે લઈ જાય છે. 🚧

અજમાયશ અને ભૂલ દ્વારા, મેં શોધ્યું કે આ ભૂલને સંબોધવા માટે OAuth ગોઠવણી, ક્રેડન્શિયલ મેનેજર અને Play સેવાઓ સુસંગતતા કેવી રીતે એકસાથે આવે છે તે સમજવાની જરૂર છે. આ લેખ તમને મુશ્કેલીનિવારણ અને આ સમસ્યાઓને અસરકારક રીતે ઠીક કરવાનાં પગલાંઓ વિશે માર્ગદર્શન આપશે, તમારી નિરાશાના કલાકો બચાવશે.

પછી ભલે તમે શિખાઉ છો કે અનુભવી વિકાસકર્તા, આ પડકારોને કેવી રીતે ઉકેલવા તે શીખવાથી તમારી Android વિકાસ કુશળતા વધે છે. ચાલો આ ભૂલના મૂળ કારણમાં ડાઇવ કરીએ અને તમારા Google સાઇન-ઇન બટનને હેતુ મુજબ કાર્ય કરવા માટે પગલાં લેવા યોગ્ય ઉકેલોનું અન્વેષણ કરીએ. 🌟

આદેશ ઉપયોગનું ઉદાહરણ
CredentialManager.create(context) સાઇન-ઇન હેતુઓ માટે Google ID ટોકન્સ જેવા ઓળખપત્રોને મેનેજ કરવા માટે જરૂરી ક્રેડેન્શિયલ મેનેજર દાખલાનો પ્રારંભ કરે છે.
GetCredentialRequest.Builder() સાઇન-ઇન ફ્લોમાં સામેલ કરવા માટે Google ID ટોકન્સ જેવા જરૂરી વિકલ્પોનો ઉલ્લેખ કરીને ઓળખપત્રો પુનઃપ્રાપ્ત કરવા માટેની વિનંતીનું નિર્માણ કરે છે.
GetGoogleIdOption.Builder() Google ID ટોકન પુનઃપ્રાપ્તિ માટેના રૂપરેખાંકનને વ્યાખ્યાયિત કરે છે, જેમાં અધિકૃત એકાઉન્ટ્સ દ્વારા ફિલ્ટર કરવું કે સર્વર ક્લાયંટ ID અને નોન્સનો સમાવેશ થાય છે.
GoogleIdTokenCredential.createFrom() પ્રમાણીકરણ માટે જરૂરી ID ટોકન ઍક્સેસ કરવાની મંજૂરી આપતા, GoogleIdTokenCredential ઑબ્જેક્ટ બનાવવા માટે કાચો ઓળખપત્ર ડેટાનું વિશ્લેષણ કરે છે.
MessageDigest.getInstance("SHA-256") ટોકન વિનંતી પ્રક્રિયા દરમિયાન અખંડિતતા અને સુરક્ષાની ખાતરી કરીને, નોન્સ વેલ્યુ માટે સુરક્ષિત હેશ જનરેટ કરે છે.
GoogleApiAvailability.getInstance() ઉપકરણ પર Google Play સેવાઓની ઉપલબ્ધતા તપાસે છે, પ્રમાણીકરણ પ્રવાહ સાથે સુસંગતતાની ખાતરી કરવામાં મદદ કરે છે.
isGooglePlayServicesAvailable(context) ઉપકરણ પર Google Play સેવાઓની સ્થિતિ પરત કરે છે, જે દર્શાવે છે કે જરૂરી સંસ્કરણ ઇન્સ્ટોલ કરેલું છે કે અપડેટની જરૂર છે.
runBlocking કોરોટીનને અવરોધિત રીતે ચલાવવા માટે પરીક્ષણમાં ઉપયોગમાં લેવાય છે, ખાતરી કરો કે તમામ અસુમેળ કાર્યો દાવાઓ ચકાસવામાં આવે તે પહેલાં પૂર્ણ થાય છે.
Toast.makeText(context, message, duration).show() વપરાશકર્તાને સંક્ષિપ્ત સંદેશ પ્રદર્શિત કરે છે, સામાન્ય રીતે સાઇન-ઇન પ્રક્રિયા દરમિયાન ભૂલો અથવા સફળ ક્રિયાઓ પર પ્રતિસાદ આપવા માટે વપરાય છે.
fold("") { str, it ->fold("") { str, it -> } બાઈટ એરે પર પુનરાવર્તિત કરીને, દરેક બાઈટને હેક્સાડેસિમલ રજૂઆતમાં ફોર્મેટ કરીને સ્ટ્રિંગ એકઠા કરે છે, જેનો ઉપયોગ ઘણીવાર હેશ મૂલ્યો બનાવવા માટે થાય છે.

એન્ડ્રોઇડ ઓથેન્ટિકેશનમાં ઓળખપત્રની સમસ્યાઓ હલ કરવી

પ્રદાન કરેલ સ્ક્રિપ્ટ્સ Android એપ્લિકેશનમાં Google સાઇન-ઇન બટનને એકીકૃત કરવાની સમસ્યાને સંબોધિત કરે છે, ખાસ કરીને getCredentialAsync કોઈ પ્રદાતા નિર્ભરતા ન મળી ભૂલને નિયંત્રિત કરવા પર ધ્યાન કેન્દ્રિત કરે છે. સોલ્યુશનનો મુખ્ય ભાગ આમાં રહેલો છે ઓળખપત્ર વ્યવસ્થાપક API, જે પ્રમાણીકરણ ટોકન્સની ઍક્સેસને કેન્દ્રિય બનાવીને ઓળખપત્ર વ્યવસ્થાપનને સરળ બનાવે છે. `CredentialManager.create(context)` આદેશ ઓળખપત્ર વ્યવસ્થાપકને પ્રારંભ કરે છે, જે અમને ઓળખપત્રોની સુરક્ષિત રીતે વિનંતી કરવાની મંજૂરી આપે છે. ઉદાહરણ તરીકે, મલ્ટી-એકાઉન્ટ સેટઅપ્સ પર કામ કરતી વખતે અથવા ઇમ્યુલેટર પર એપ્લિકેશનનું પરીક્ષણ કરતી વખતે આ ખાસ કરીને મદદરૂપ થાય છે, જ્યાં ગોઠવણી ભૂલો સામાન્ય છે. 😄

`GetCredentialRequest.Builder()` અને `GetGoogleIdOption.Builder()` આદેશો વિનંતીના પરિમાણોને વ્યાખ્યાયિત કરે છે. આ સ્ક્રિપ્ટમાં, તેઓ અધિકૃત એકાઉન્ટ્સને ફિલ્ટર કરવા અને સર્વરની ક્લાયંટ ID પ્રદાન કરવા જેવી વિગતોનો ઉલ્લેખ કરે છે. આ વિકલ્પો નિર્ણાયક છે કારણ કે ખોટી ગોઠવણી વારંવાર વર્ણવેલ જેવી ભૂલો તરફ દોરી જાય છે. દાખલા તરીકે, જો સર્વર ક્લાયંટ ID તમારા ફાયરબેઝ સેટઅપ સાથે મેળ ખાતું નથી, તો Google સાઇન-ઇન પ્રક્રિયા નિષ્ફળ જશે. `MessageDigest.getInstance("SHA-256")` નો ઉપયોગ કરીને કાચા નોન્સને હેશ કરીને, સ્ક્રિપ્ટ પ્રમાણીકરણ માટે અનન્ય, ટેમ્પર-પ્રૂફ સ્ટ્રિંગ જનરેટ કરીને સુરક્ષાની ખાતરી કરે છે. આ પગલું માત્ર શ્રેષ્ઠ પ્રેક્ટિસ જ નથી - સંવેદનશીલ વપરાશકર્તા ડેટાને હેન્ડલ કરતી એપ્લિકેશનો માટે આ એક આવશ્યકતા છે. 🔒

અન્ય આવશ્યક ઘટક સાથે સુસંગતતા છે Google Play સેવાઓ. બીજી સ્ક્રિપ્ટ `GoogleApiAvailability.getInstance()` અને `isGooglePlayServicesAvailable(સંદર્ભ)` નો ઉપયોગ કરીને ઉપકરણના પ્લે સેવાઓના સંસ્કરણને તપાસવા પર ધ્યાન કેન્દ્રિત કરે છે. જો જૂની આવૃત્તિ મળી આવે, તો તે વપરાશકર્તાને અપડેટ કરવા માટે સંકેત આપે છે. આ વાસ્તવિક-વિશ્વની સમસ્યા છે, ખાસ કરીને ઇમ્યુલેટર પર આધાર રાખનારા વિકાસકર્તાઓ માટે, કારણ કે તેઓ ઘણી વખત જૂની પ્લે સેવાઓ પહેલાથી ઇન્સ્ટોલ કરેલી હોય છે. આને સંબોધિત કરીને, સ્ક્રિપ્ટ સમગ્ર ઉપકરણોમાં સરળ કામગીરીને સુનિશ્ચિત કરે છે, ભૂલ-સંભવિત વાતાવરણને ઘટાડે છે અને મૂલ્યવાન ડીબગીંગ સમય બચાવે છે.

અંતિમ સ્ક્રિપ્ટ એકમ પરીક્ષણોનો ઉપયોગ કરીને Google સાઇન-ઇન સહાયક વર્ગની કાર્યક્ષમતાનું પરીક્ષણ કરે છે. તે માન્ય કરે છે કે `getGoogleIdToken` કાર્ય યોગ્ય રીતે કાર્ય કરે છે અને માન્ય ટોકન પરત કરે છે. આ મોડ્યુલર અભિગમ માત્ર પુનઃઉપયોગીતા માટે કોડનું આયોજન કરતું નથી પણ બહુવિધ વાતાવરણમાં વિશ્વસનીયતાની બાંયધરી પણ આપે છે. એવી ટીમમાં કામ કરવાની કલ્પના કરો કે જ્યાં જુદા જુદા સભ્યો ફ્રન્ટ-એન્ડ અને બેક-એન્ડ એકીકરણને સંભાળી રહ્યા હોય—સારી ટિપ્પણી કરેલ, આના જેવી ટેસ્ટેબલ સ્ક્રિપ્ટો સહયોગને નોંધપાત્ર રીતે સરળ બનાવે છે. આ સોલ્યુશન્સ પરફોર્મન્સ ઓપ્ટિમાઇઝેશન અને ડેવલપર-ફ્રેંડલી પ્રેક્ટિસ બંનેને મૂર્તિમંત કરે છે, જે મજબૂત અને માપી શકાય તેવા પ્રમાણીકરણ પ્રવાહને સુનિશ્ચિત કરે છે. 🌟

Android માં Google સાઇન-ઇન ઓળખપત્ર સમસ્યાઓનું નિરાકરણ

ઑપ્ટિમાઇઝ મોડ્યુલારિટી અને ગૂગલ ક્રેડેન્શિયલ મેનેજર સાથે કોટલિનનો ઉપયોગ કરીને ઉકેલ.

import android.content.Context
import androidx.credentials.CredentialManager
import androidx.credentials.GetCredentialRequest
import androidx.credentials.exceptions.GetCredentialException
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch
import kotlinx.coroutines.withContext

class GoogleSignInHelper(private val context: Context) {
    private val credentialManager: CredentialManager = CredentialManager.create(context)

    suspend fun getGoogleIdToken(serverClientId: String, rawNonce: String): String? {
        return withContext(Dispatchers.IO) {
            try {
                val hashedNonce = hashNonce(rawNonce)
                val googleIdOption = GetGoogleIdOption.Builder()
                    .setFilterByAuthorizedAccounts(false)
                    .setServerClientId(serverClientId)
                    .setNonce(hashedNonce)
                    .build()
                val request = GetCredentialRequest.Builder()
                    .addCredentialOption(googleIdOption)
                    .build()
                val result = credentialManager.getCredential(request, context)
                val googleIdTokenCredential = GoogleIdTokenCredential.createFrom(result.credential.data)
                googleIdTokenCredential.idToken
            } catch (e: GetCredentialException) {
                null
            }
        }
    }

    private fun hashNonce(rawNonce: String): String {
        val md = MessageDigest.getInstance("SHA-256")
        val digest = md.digest(rawNonce.toByteArray())
        return digest.fold("") { str, it -> str + "%02x".format(it) }
    }
}

Google Play સેવાઓ સાથે સુસંગતતાની ખાતરી કરવી

કોટલિનનો ઉપયોગ કરીને Google Play સેવાઓ તપાસવા અને અપડેટ કરવાનો ઉકેલ.

import android.content.Context
import android.content.pm.PackageManager
import android.widget.Toast
import com.google.android.gms.common.ConnectionResult
import com.google.android.gms.common.GoogleApiAvailability

fun checkGooglePlayServices(context: Context): Boolean {
    val googleApiAvailability = GoogleApiAvailability.getInstance()
    val resultCode = googleApiAvailability.isGooglePlayServicesAvailable(context)
    return if (resultCode == ConnectionResult.SUCCESS) {
        true
    } else {
        if (googleApiAvailability.isUserResolvableError(resultCode)) {
            googleApiAvailability.getErrorDialog(context as Activity, resultCode, 2404)?.show()
        } else {
            Toast.makeText(context, "This device is not supported", Toast.LENGTH_LONG).show()
        }
        false
    }
}

Google સાઇન-ઇન હેલ્પર માટે યુનિટ ટેસ્ટ

Google ID ટોકન પુનઃપ્રાપ્તિને માન્ય કરવા માટે એકમ પરીક્ષણ.

import kotlinx.coroutines.runBlocking
import org.junit.Assert
import org.junit.Test

class GoogleSignInHelperTest {

    @Test
    fun testGetGoogleIdToken() = runBlocking {
        val helper = GoogleSignInHelper(context)
        val rawNonce = "testNonce"
        val serverClientId = "your-server-client-id"
        val idToken = helper.getGoogleIdToken(serverClientId, rawNonce)
        Assert.assertNotNull("ID token should not be null", idToken)
    }
}

એન્ડ્રોઇડ સ્ટુડિયોમાં ઓળખપત્ર વ્યવસ્થાપકની સમસ્યાઓનું નિવારણ

તમારી Android એપ્લિકેશનમાં Google સાઇન-ઇનને એકીકૃત કરતી વખતે, અયોગ્ય રૂપરેખાંકન અથવા પર્યાવરણ સેટિંગ્સને કારણે ક્રડેન્શિયલ મેનેજર સાથે સમસ્યાઓ ઊભી થઈ શકે છે. એક અવગણવામાં આવતું પાસું એ ઇમ્યુલેટર પર્યાવરણ અને જરૂરી Google Play સેવાઓ વચ્ચેની ક્રિયાપ્રતિક્રિયા છે. જો ઇમ્યુલેટર પરનું પ્લે સર્વિસ વર્ઝન એપના જરૂરી વર્ઝન સાથે મેળ ખાતું નથી, તો ઓળખપત્ર મેનેજર ઓળખપત્રો મેળવવામાં નિષ્ફળ જાય છે, પરિણામે ભૂલો જેવી "getCredentialAsync કોઈ પ્રદાતા નિર્ભરતા મળી નથી". વાસ્તવિક-વિશ્વનું ઉદાહરણ જૂની પ્લે સેવાઓ સાથે પૂર્વ-ઇન્સ્ટોલ કરેલ ઇમ્યુલેટર પર ડિબગિંગ હશે, જે API ની આવશ્યકતાઓને પૂર્ણ કરતું નથી. 🌟

અન્ય સામાન્ય દેખરેખ એ Google ક્લાઉડ કન્સોલમાં OAuth ઓળખપત્રોનું ખોટું સેટઅપ છે. કોડમાં આપેલ ક્લાયન્ટ ID, Firebaseમાં તમારી ઍપ માટે અધિકૃત ઓળખપત્રો સાથે મેળ ખાતી હોવી જોઈએ. મેળ ન ખાતી ગોઠવણી ઘણીવાર ટોકન પાર્સિંગ ભૂલો અથવા ઓળખપત્રો પુનઃપ્રાપ્ત કરવામાં નિષ્ફળતા તરફ દોરી જાય છે. બહુવિધ પ્રોજેક્ટ્સ સાથે કામ કરતી વખતે અને અજાણતાં ખોટી પ્રોજેક્ટ સેટિંગ્સનો ઉપયોગ કરતી વખતે વિકાસકર્તાઓ વારંવાર આનો સામનો કરે છે. Firebase, Google Cloud Console અને તમારી એપ્લિકેશનનો કોડ સમન્વયિત છે તેની ખાતરી કરવાથી મુશ્કેલીનિવારણના કલાકો બચી શકે છે.

છેલ્લે, લોગકેટ જેવા અદ્યતન ડીબગીંગ સાધનો સૂક્ષ્મ ભૂલોને ઓળખવા માટે અનિવાર્ય હોઈ શકે છે. લૉગ્સનું અવલોકન કરીને, વિકાસકર્તાઓ નિર્ધારિત કરી શકે છે કે નિષ્ફળતા Play સેવાઓ અથવા અયોગ્ય નોન્સ હેન્ડલિંગને કારણે છે. દાખલા તરીકે, ખરાબ રીતે હેશ કરેલ નોન્સ માન્ય દેખાઈ શકે છે પરંતુ Google ના API દ્વારા નકારવામાં આવશે. અસરકારક ડિબગીંગ અને સીમલેસ યુઝર ઓથેન્ટિકેશન સુનિશ્ચિત કરવા માટે આ લોગનું અર્થઘટન કેવી રીતે કરવું તે સમજવું મહત્વપૂર્ણ છે. 💡

Google સાઇન-ઇન અને ઓળખપત્ર વ્યવસ્થાપક વિશે સામાન્ય પ્રશ્નો

  1. હું ઇમ્યુલેટર પર Google Play સેવાઓને કેવી રીતે અપડેટ કરી શકું?
  2. તમે નવીનતમ સંસ્કરણ મેળવવા માટે ઇમ્યુલેટર સેટિંગ્સ પર નેવિગેટ કરીને, અપડેટ્સ માટે તપાસ કરીને અથવા Android સ્ટુડિયોમાં SDK મેનેજર ચલાવીને Play સેવાઓને અપડેટ કરી શકો છો.
  3. "getCredentialAsync કોઈ પ્રદાતા નિર્ભરતા મળી નથી" નો અર્થ શું છે?
  4. આ ભૂલ સૂચવે છે કે ક્રેડેન્શિયલ મેનેજર જરૂરી અવલંબન શોધી શક્યું નથી, ઘણીવાર ગુમ થયેલ લાઇબ્રેરીઓ અથવા જૂની પ્લે સેવાઓને કારણે.
  5. હું કેવી રીતે ખાતરી કરી શકું કે મારી નોન્સ યોગ્ય રીતે હેશ કરવામાં આવી છે?
  6. MessageDigest.getInstance("SHA-256") પદ્ધતિનો ઉપયોગ કરો અને ખાતરી કરો કે તેનું આઉટપુટ લોગમાં પ્રિન્ટ કરીને અપેક્ષિત ફોર્મેટ સાથે મેળ ખાય છે.
  7. Google સાઇન-ઇનમાં ક્લાયન્ટ IDની ભૂમિકા શું છે?
  8. ક્લાઈન્ટ આઈડી તમારી એપને Googleની ઓથેન્ટિકેશન સિસ્ટમમાં ઓળખે છે. હંમેશા માન્ય ID સાથે setServerClientId(ClientID) ફંક્શનનો ઉપયોગ કરો.
  9. શું હું ઓળખપત્ર વ્યવસ્થાપક વિના ફાયરબેઝ પ્રમાણીકરણનો ઉપયોગ કરી શકું?
  10. હા, પરંતુ ક્રેડન્શિયલ મેનેજર ટોકન્સ અને ઓળખપત્રોનું સંચાલન કરીને પ્રક્રિયાને સરળ બનાવે છે, તેને વધુ કાર્યક્ષમ વિકલ્પ બનાવે છે.

ઓથેન્ટિકેશન પડકારો પર કાબુ મેળવવો

Google સાઇન-ઇન બટનને એકીકૃત કરવાથી વપરાશકર્તાઓ માટે પ્રમાણીકરણ સુવ્યવસ્થિત થઈ શકે છે પરંતુ સાવચેત ગોઠવણીની જરૂર છે. Play સેવાઓ સુસંગતતા અને OAuth સેટઅપ જેવી સામાન્ય મુશ્કેલીઓને દૂર કરીને, તમે ભૂલોને અસરકારક રીતે ઉકેલી શકો છો. નિર્ભરતા અને API વચ્ચેના આંતરપ્રક્રિયાને સમજવું એ સીમલેસ કાર્યક્ષમતાની ચાવી છે. 🌟

ડિબગીંગ માટે મજબૂત અભિગમ સાથે, જેમ કે લોગકેટનો લાભ ઉઠાવવો અને પર્યાવરણનું સંપૂર્ણ પરીક્ષણ કરવું, વિકાસકર્તાઓ વિશ્વસનીય સાઇન-ઇન પ્રક્રિયાની ખાતરી કરી શકે છે. આ પદ્ધતિ માત્ર ભૂલોનું નિરાકરણ જ નહીં પરંતુ કાર્યક્ષમતાને પણ શ્રેષ્ઠ બનાવે છે, જે વપરાશકર્તા-મૈત્રીપૂર્ણ અનુભવ માટે માર્ગ મોકળો કરે છે. તમારી એપ્લિકેશનનો પ્રમાણીકરણ પ્રવાહ સુરક્ષિત અને કાર્યક્ષમ બંને હશે. 💡

સંદર્ભો અને સંસાધનો
  1. ફાયરબેઝ સાથે Google સાઇન-ઇનને એકીકૃત કરવા અંગેની વિગતો સત્તાવાર દસ્તાવેજોમાં મળી શકે છે: ફાયરબેઝ પ્રમાણીકરણ દસ્તાવેજીકરણ .
  2. એન્ડ્રોઇડ ક્રેડેન્શિયલ મેનેજર API નો ઉપયોગ કરવા પર માર્ગદર્શન અહીં ઉપલબ્ધ છે: એન્ડ્રોઇડ ઓળખપત્ર વ્યવસ્થાપક માર્ગદર્શિકા .
  3. Google Play સેવાઓ સંસ્કરણ સમસ્યાઓ ઉકેલવા માટે, આનો સંદર્ભ લો: ગૂગલ પ્લે સાથે એન્ડ્રોઇડ ઇમ્યુલેટર .
  4. ડિબગીંગ ટીપ્સ અને ઉદાહરણો વ્યવહારુ અનુભવ અને ઓનલાઈન ફોરમ દ્વારા જાણ કરવામાં આવી હતી જેમ કે: સ્ટેક ઓવરફ્લો એન્ડ્રોઇડ ફોરમ .