Android प्लैटफ़ॉर्म, ऐप्लिकेशन सैंडबॉक्सिंग के कॉन्सेप्ट का इस्तेमाल करता है. इससे, ऐप्लिकेशन कोड के लिए प्रोसेस की सीमाओं के साथ-साथ, बेहतर तरीके से लागू करने और सुरक्षा की सीमाओं को बनाए रखने में मदद मिलती है. ऐप्लिकेशन में तीसरे पक्ष का कोड शामिल करना आम बात है. अक्सर, इसे SDK टूल के तौर पर शामिल किया जाता है. जैसे, विज्ञापन दिखाने के लिए इस्तेमाल किए जाने वाले SDK टूल या ऐनलिटिक्स के लिए इस्तेमाल किए जाने वाले SDK टूल. इस सुविधा की मदद से, ऐप्लिकेशन डेवलपर अपने ऐप्लिकेशन को अलग बनाने पर ध्यान दे सकते हैं. साथ ही, विषय के विशेषज्ञों के काम का फ़ायदा उठाकर, अपने ऐप्लिकेशन को बेहतर बना सकते हैं.
ज़्यादातर ऑपरेटिंग सिस्टम की तरह, Android SDKs को होस्ट ऐप्लिकेशन के सैंडबॉक्स में चलाया जाता है. साथ ही, ये होस्ट ऐप्लिकेशन के विशेषाधिकारों और अनुमतियों के साथ-साथ, होस्ट ऐप्लिकेशन की मेमोरी और स्टोरेज का ऐक्सेस भी इनहेरिट करते हैं. इस आर्किटेक्चर की मदद से, SDK टूल और ऐप्लिकेशन को आसानी से इंटिग्रेट किया जा सकता है. हालांकि, इससे उपयोगकर्ता के ऐसे डेटा को इकट्ठा और शेयर करने की संभावना भी बनती है जिसकी जानकारी ज़ाहिर नहीं की गई है. इसके अलावा, हो सकता है कि ऐप्लिकेशन डेवलपर को तीसरे पक्ष के SDK टूल के फ़ंक्शन और उससे ऐक्सेस किए गए डेटा के बारे में पूरी जानकारी न हो. इस वजह से, अपने ऐप्लिकेशन के डेटा इकट्ठा करने और शेयर करने के तरीकों के बारे में बताना मुश्किल हो जाता है.
हमने Android 14 में, प्लैटफ़ॉर्म की एक नई सुविधा जोड़ी है. इसकी मदद से, तीसरे पक्ष के SDK टूल, SDK टूल के रनटाइम नाम के खास रनटाइम एनवायरमेंट में चल सकते हैं. SDK टूल का रनटाइम, उपयोगकर्ताओं के डेटा को गारंटी के साथ सुरक्षित तरीके से इकट्ठा करने और शेयर करने के ये बेहतर उपाय देता है:
- बदला गया एक्ज़ीक्यूशन एनवायरमेंट
- SDK टूल के लिए, बेहतर तरीके से बताई गई अनुमतियां और डेटा ऐक्सेस करने के अधिकार
हम इस डिज़ाइन के बारे में, मोबाइल ऐप्लिकेशन के विज्ञापन देने वाली कम्यूनिटी से फ़ीडबैक ले रहे हैं. हम डेवलपर कम्यूनिटी से भी सुझाव, राय या शिकायतें पाने के लिए तैयार हैं. इससे हमें एसडीके रनटाइम के आने वाले वर्शन को बेहतर बनाने में मदद मिलेगी. इसमें, इस्तेमाल के अन्य उदाहरणों के लिए सहायता भी शामिल है.
लक्ष्य
इस प्रस्ताव का मकसद ये लक्ष्य हासिल करना है:
- प्रोसेस को अलग-अलग रखने और एपीआई और डेटा ऐक्सेस कंट्रोल को बेहतर तरीके से तय करने की मदद से, तीसरे पक्ष के SDK टूल के ज़रिए उपयोगकर्ता के ऐप्लिकेशन डेटा को बिना बताए ऐक्सेस और शेयर करने की सुविधा को कम करें. इस दस्तावेज़ के अलग सेक्शन में, प्रोसेस को अलग रखने के बारे में ज़्यादा जानें.
- तीसरे पक्ष के SDK टूल की मदद से, उपयोगकर्ता के ऐप्लिकेशन के इस्तेमाल को बिना बताए ट्रैक करने की सुविधा को कम करें. इसके लिए, SDK टूल के लिए यूनीक और लगातार मौजूद रहने वाले आइडेंटिफ़ायर को ऐक्सेस करने की सुविधा को सीमित करें.
- ऐप्लिकेशन डेवलपर और असली उपयोगकर्ताओं पर बोझ कम करके, ऐप्लिकेशन में SDK टूल के अपडेट को सुरक्षित तरीके से तेज़ी से डिस्ट्रिब्यूट करें. इस दस्तावेज़ के किसी दूसरे सेक्शन में, भरोसेमंद SDK टूल के डिस्ट्रिब्यूशन के लिए सुझाए गए मॉडल के बारे में ज़्यादा जानें.
- ऐप्लिकेशन डेवलपर को अपने ऐप्लिकेशन के डेटा को ऐक्सेस और शेयर करने के तरीकों के बारे में बेहतर तरीके से जानकारी देने में मदद करता है.
- SDK टूल के डेवलपर को, JNI कोड जैसी कुछ असुरक्षित भाषा के कॉन्स्ट्रक्ट को सीमित करके, अन्य SDK टूल से होने वाली गड़बड़ी को रोकने में मदद मिलती है.
- मीडिया दिखाने वाले रिमोट व्यू पर पूरा कंट्रोल करके, विज्ञापन दिखाने के लिए इस्तेमाल किए जाने वाले SDK टूल को अमान्य ट्रैफ़िक और विज्ञापन धोखाधड़ी का पता लगाने और उसे रोकने में मदद करता है.
- ऐप्लिकेशन और SDK टूल के डेवलपर पर, ज़्यादा से ज़्यादा असर न पड़े.
SDK टूल, अलग-अलग प्रोसेस में काम करते हैं
SDK टूल के रनटाइम की सुविधा, काम करने वाले SDK टूल को ऐप्लिकेशन के लिए अलग प्रोसेस में काम करने की अनुमति देती है. इस दस्तावेज़ के बाकी हिस्से में, इन SDK टूल को रनटाइम के साथ काम करने वाले (RE) SDK टूल कहा गया है. यह प्लैटफ़ॉर्म, ऐप्लिकेशन की प्रोसेस और उसके SDK टूल के रनटाइम के बीच, दोनों तरफ़ से कम्यूनिकेशन की सुविधा देता है. ज़्यादा जानकारी के लिए, इस दस्तावेज़ का कम्यूनिकेशन सेक्शन देखें. नॉन-आरई एसडीके टूल, ऐप्लिकेशन की प्रोसेस में पहले की तरह ही बने रहेंगे. इन डायग्राम में इन बदलावों के बारे में बताया गया है:
SDK टूल के लिए भरोसेमंद डिस्ट्रिब्यूशन का नया मॉडल
ऐप्लिकेशन से SDK टूल को अलग करने का यह प्रस्ताव, एक और अलग करने के कॉन्सेप्ट को बढ़ावा देता है. यह कॉन्सेप्ट, SDK टूल और ऐप्लिकेशन के डिस्ट्रिब्यूशन के लिए है. हमारे प्रस्ताव के मुताबिक, SDK टूल को डिस्ट्रिब्यूट करने और इंस्टॉल करने के लिए, भरोसेमंद तरीके का इस्तेमाल करना ज़रूरी है. इससे यह पक्का किया जा सकेगा कि ऐप्लिकेशन के SDK टूल के रनटाइम में सही SDK टूल इंस्टॉल किए गए हैं. इससे, ऐप्लिकेशन इस्तेमाल करने वाले लोगों और डेवलपर को अमान्य SDK टूल लोड होने से बचाने में मदद मिलती है. साथ ही, ऐप्लिकेशन स्टोर को ऐप्लिकेशन डेवलपर से SDK टूल डिस्ट्रिब्यूशन का बोझ कम करने में मदद मिलती है.
अब SDK टूल को डिस्ट्रिब्यूशन के लिए ऐप स्टोर पर अपलोड करने से पहले, अपने ऐप्लिकेशन के साथ स्टैटिक तौर पर लिंक और पैकेज करने की ज़रूरत नहीं होगी. इसके बजाय, यह प्रोसेस होगी:
- SDK टूल के डेवलपर, अपने ऐप्लिकेशन के अलावा, अलग से भी ऐप्लिकेशन स्टोर पर अपने SDK टूल के वर्शन अपलोड कर सकते हैं.
- ऐप्लिकेशन डेवलपर, SDK टूल की डिपेंडेंसी के वर्शन के हिसाब से जानकारी दे सकते हैं. साथ ही, वे ऐसी ऐप्लिकेशन रिलीज़ बना सकते हैं और अपलोड कर सकते हैं जिसमें असल SDK टूल की डिपेंडेंसी शामिल न हों.
- जब कोई उपयोगकर्ता इस ऐप्लिकेशन को डाउनलोड करता है, तो इंस्टॉलेशन की प्रोसेस में ऐप्लिकेशन के तय किए गए एसडीके डिपेंडेंसी का इस्तेमाल किया जा सकता है. इसके बाद, उन्हें ऐप्लिकेशन स्टोर से डाउनलोड किया जा सकता है.
डिस्ट्रिब्यूशन के इस नए तरीके की मदद से, SDK टूल के डेवलपर अपने SDK टूल में ऐसे बदलाव कर पाएंगे जिनसे ऐप्लिकेशन के काम करने में कोई रुकावट न आए. जैसे, एपीआई या उनके सेमेंटेक्स में कोई बदलाव न करना. साथ ही, ऐप्लिकेशन डेवलपर की मदद के बिना, डिवाइसों पर SDK टूल को डिस्ट्रिब्यूट किया जा सकेगा. SDK टूल में ऐसे बदलाव किए जा सकते हैं जिनसे ऐप्लिकेशन के काम करने में कोई रुकावट न आए. इन बदलावों को डिप्लॉय या रोल-बैक किया जा सकता है. इसके लिए, ज़रूरी नहीं है कि ऐप्लिकेशन डेवलपर, नए SDK टूल का इस्तेमाल करके अपने ऐप्लिकेशन फिर से बनाएं या असली उपयोगकर्ता अपने ऐप्लिकेशन अपडेट करें. ऐप्लिकेशन के डेवलपर को अब भी, ऐप्लिकेशन के काम करने के तरीके में होने वाले बदलावों को अपडेट करना होगा. हालांकि, SDK टूल के डेवलपर, ऐप्लिकेशन के काम करने के तरीके में होने वाले ऐसे बदलावों और गड़बड़ियों को ठीक करने के तरीकों को ज़्यादा लोगों तक तुरंत और एक जैसा पहुंचा सकते हैं. इससे, ऐप्लिकेशन के वर्शन के लिए सहायता देने की ज़रूरत कम हो जाती है.
यहां दिए गए डायग्राम में, एसडीके डिस्ट्रिब्यूशन में किए जाने वाले बदलावों के बारे में बताया गया है:
SDK टूल और ऐप्लिकेशन बनाने, चलाने, और डिस्ट्रिब्यूट करने के तरीके में बदलाव
यह, SDK टूल के रनटाइम और डिस्ट्रिब्यूशन टेक्नोलॉजी के लिए, एक शुरुआती प्रस्ताव है. नीचे दिए गए सेक्शन में, इन मुख्य कैटगरी में कई बदलावों का सुझाव दिया गया है:
- ऐक्सेस: अनुमतियां, मेमोरी, स्टोरेज
- कार्रवाई: भाषाएं, रनटाइम में बदलाव, लाइफ़साइकल, मीडिया रेंडरिंग
- कम्यूनिकेशन: ऐप्लिकेशन से SDK टूल और SDK टूल से SDK टूल
- डेवलपमेंट: इस मॉडल को बनाने, डीबग करने, और उसकी जांच करने का तरीका
- डिस्ट्रिब्यूशन: Android, ऐप्लिकेशन, और SDK टूल के सभी वर्शन को डिस्ट्रिब्यूट, अपडेट, और रोल बैक करने का तरीका
इस दस्तावेज़ में, अक्सर पूछे जाने वाले सवाल भी शामिल हैं. इनसे आपको सामान्य सवालों के जवाब पाने में मदद मिलेगी.
यह डिज़ाइन का शुरुआती प्रस्ताव है. हम समझते हैं कि यह बदलाव, नेटवर्क के कुछ सदस्यों के लिए अहम हो सकता है. इसलिए, हम आपसे लगातार सुझाव, राय या शिकायतें मांग रहे हैं. कृपया समस्या ट्रैकर के ज़रिए ऐसा करें.
ऐक्सेस
किसी सिस्टम की निजता मैनेज करने का मतलब है कि अलग-अलग पक्षों के लिए, अलग-अलग संसाधनों को ऐक्सेस करने का तरीका तय करना. निजता की सुरक्षा के लिए, हम ऐप्लिकेशन, SDK टूल, और उपयोगकर्ता के डेटा को ऐक्सेस करने के लिए मॉडल को अपडेट करने का सुझाव देते हैं. इससे, कम से कम विशेषाधिकार के सिद्धांत का पालन किया जा सकेगा. इससे, संवेदनशील डेटा को बिना अनुमति के ऐक्सेस करने से रोका जा सकेगा.
SDK टूल से जुड़ी अनुमतियां
SDK टूल के रनटाइम में, उपयोगकर्ता की दी गई अनुमतियों को इनहेरिट करने के बजाय, अनुमतियों का एक अलग सेट होगा. विज्ञापन से जुड़े SDK टूल के इस्तेमाल की अनुमतियों के बारे में शुरुआती रिसर्च के आधार पर, हम यह सुझाव दे रहे हैं कि SDK टूल के रनटाइम में SDK टूल, डिफ़ॉल्ट रूप से इन अनुमतियों को ऐक्सेस कर पाएंगे:
INTERNET
: किसी वेब सेवा के साथ इंटरैक्ट करने के लिए, इंटरनेट का ऐक्सेस.ACCESS_NETWORK_STATE
: नेटवर्क की जानकारी ऐक्सेस करना.READ_BASIC_PHONE_STATE
: फ़ोन की स्थिति की जानकारी ऐक्सेस करना. उदाहरण के लिए, मोबाइल नेटवर्क का टाइप.- निजता बनाए रखने वाले एपीआई को ऐक्सेस करने की अनुमतियां. ये एपीआई, क्रॉस-ऐप्लिकेशन आइडेंटिफ़ायर को ऐक्सेस किए बिना, विज्ञापन दिखाने की मुख्य सुविधाएं उपलब्ध कराते हैं.
AD_ID
: विज्ञापन आईडी का अनुरोध करने की सुविधा. यह इस बात पर भी निर्भर करेगा कि ऐप्लिकेशन के पास इस अनुमति का ऐक्सेस है या नहीं.
फ़िलहाल, हम इस बात की जांच कर रहे हैं कि अन्य अनुमतियों को अनुमति दी जा सकती है या नहीं. साथ ही, यह भी पता लगा रहे हैं कि अन्य अनुमतियों को अनुमति देने का तरीका क्या होगा. इससे, ऐप्लिकेशन इस्तेमाल करने वाले लोगों की निजता और ऐप्लिकेशन के इस्तेमाल पर पड़ने वाले असर को कम किया जा सकेगा. हम उन इस्तेमाल के उदाहरणों के लिए सुझाव/राय या राय देने का अनुरोध करते हैं जो अनुमतियों के इस सेट से मेल नहीं खाते.
मेमोरी
SDK टूल के रनटाइम में, अपनी प्रोसेस के आधार पर अलग मेमोरी स्पेस होगा. इस स्ट्रक्चर की वजह से, डिफ़ॉल्ट रूप से SDK टूल को ऐप्लिकेशन के मेमोरी स्पेस का ऐक्सेस नहीं मिलेगा. साथ ही, ऐप्लिकेशन भी SDK टूल के मेमोरी स्पेस को ऐक्सेस नहीं कर पाएगा. हमारा सुझाव है कि कम से कम अधिकारों के सिद्धांत के मुताबिक, इस डिफ़ॉल्ट व्यवहार को बनाए रखा जाए.
स्टोरेज
इस प्रस्ताव का मकसद, एसडीके टूल के सामान्य काम के लिए स्टोरेज को ऐक्सेस करने की ज़रूरत को संतुलित करना है. साथ ही, स्टोरेज को हमेशा सेव रखने की सुविधा का इस्तेमाल करके, क्रॉस-ऐप्लिकेशन और सभी प्रोसेस की ट्रैकिंग को कम करना है. हम स्टोरेज को ऐक्सेस करने के मौजूदा तरीके में ये अपडेट करने का सुझाव दे रहे हैं:
- कोई ऐप्लिकेशन, अपने SDK टूल का स्टोरेज सीधे तौर पर ऐक्सेस नहीं कर पाएगा. इसके अलावा, SDK टूल भी ऐप्लिकेशन का स्टोरेज सीधे तौर पर ऐक्सेस नहीं कर पाएगा.
- SDK, डिवाइस के बाहरी स्टोरेज को ऐक्सेस नहीं कर पाएंगे.
- हर SDK टूल के रनटाइम में, सभी SDK टूल के लिए ऐक्सेस किया जा सकने वाला स्टोरेज और किसी SDK टूल के लिए निजी स्टोरेज, दोनों शामिल होंगे.
मौजूदा स्टोरेज मॉडल की तरह ही, स्टोरेज के साइज़ पर भी कोई सीमा नहीं होगी. SDK, ऐसेट को कैश मेमोरी में सेव करने के लिए स्टोरेज का इस्तेमाल कर सकते हैं. SDK के चालू न होने पर, यह स्टोरेज समय-समय पर मिटा दिया जाता है.
प्लान लागू करना
ऐप्लिकेशन, SDK टूल, और उपयोगकर्ताओं के बीच निजी सिस्टम को पक्का करने के लिए, कोड फ़ॉर्मैट, भाषा के कॉन्स्ट्रक्ट, ऐक्सेस किए जा सकने वाले एपीआई, और सिस्टम डेटा जैसे एक्सीक्यूशन कॉन्टेक्स्ट को निजता की इन सीमाओं को बेहतर बनाना होगा. इसके अलावा, कम से कम इन सीमाओं को गच्चा देने के अवसर नहीं होने चाहिए. साथ ही, हम रिच प्लैटफ़ॉर्म और SDKs के ज़्यादातर रनटाइम की सुविधाओं का ऐक्सेस बनाए रखना चाहते हैं. यहां हम रनटाइम एनवायरमेंट में अपडेट का एक सेट सुझाते हैं, ताकि इस संतुलन को बनाए रखा जा सके.
कोड
Android कोड (ऐप्लिकेशन और SDK टूल) को मुख्य रूप से Android रनटाइम (ART) सेड्यूस किया जाता है. भले ही, कोड को Kotlin या Java में लिखा गया हो. ART के बेहतरीन फ़ीचर और भाषा के कॉन्स्ट्रक्ट के साथ-साथ, अन्य विकल्पों के मुकाबले पुष्टि करने की सुविधा, खास तौर पर नेटिव कोड की तुलना में, फ़ंक्शन और निजता को सही तरीके से संतुलित करती है. हमारा सुझाव है कि रनटाइम के साथ काम करने वाले SDK टूल के कोड में, JNI ऐक्सेस की सुविधा के बजाय सिर्फ़ Dex बाइटकोड शामिल किया जाए.
हम जानते हैं कि कुछ मामलों में, नेटिव कोड का इस्तेमाल करने के लिए, कस्टम पैकेज किए गए SQLite का इस्तेमाल करना ज़रूरी होता है. ऐसे मामलों में, SQLite को किसी अन्य विकल्प से बदलना होगा. जैसे, Android SDK टूल में पहले से मौजूद SQLite का वर्शन.
SELinux
Android पर, हर प्रोसेस (रूट के तौर पर चलने वाली प्रोसेस भी) किसी खास SELinux कॉन्टेक्स्ट के साथ चलती है. इससे, कर्नेल को सिस्टम सेवाओं, फ़ाइलों, डिवाइसों, और अन्य प्रोसेस के ऐक्सेस कंट्रोल को मैनेज करने में मदद मिलती है. हम SDK टूल के ज़्यादातर इस्तेमाल के उदाहरणों को बनाए रखने की कोशिश कर रहे हैं. साथ ही, निजता की सुरक्षा से जुड़ी नीतियों को गच्चा देने की कोशिशों को कम करना चाहते हैं. इसलिए, हम SDK टूल के रनटाइम के लिए, नॉन-सिस्टम ऐप्लिकेशन के SELinux कॉन्टेक्स्ट से ये अपडेट करने का सुझाव दे रहे हैं:
- सिस्टम की सेवाओं का सीमित सेट ऐक्सेस किया जा सकेगा. (डिज़ाइन में बदलाव किया जा रहा है)
- SDK टूल, सिर्फ़ अपने APK में कोड लोड और एक्ज़ीक्यूट कर पाएंगे.
- सिस्टम प्रॉपर्टी का सीमित सेट ऐक्सेस किया जा सकेगा. (डिज़ाइन में बदलाव किया जा रहा है)
API
SDK टूल के रनटाइम में, रिफ़्लेक्शन और एपीआई को शुरू करने की अनुमति है. हालांकि, किसी SDK टूल को रिफ़्लेक्शन का इस्तेमाल करने या रनटाइम की सुविधा वाले किसी अन्य SDK टूल पर एपीआई को कॉल करने की अनुमति नहीं होगी. हम आने वाले समय में, पाबंदी वाले एपीआई के बारे में पूरी जानकारी शेयर करेंगे.
इसके अलावा, निजता को बेहतर बनाने के लिए, Android प्लैटफ़ॉर्म के हाल ही में रिलीज़ किए गए वर्शन में, हमेशा मौजूद रहने वाले आइडेंटिफ़ायर के ऐक्सेस पर ज़्यादा पाबंदियां लगाई गई हैं. SDK टूल के रनटाइम के लिए, हम आइडेंटिफ़ायर के ऐक्सेस को और सीमित करने का सुझाव देते हैं. इन आइडेंटिफ़ायर का इस्तेमाल, क्रॉस-ऐप्लिकेशन ट्रैकिंग के लिए किया जा सकता है.
SDK टूल के रनटाइम एपीआई को सिर्फ़ फ़ोरग्राउंड में चल रहे ऐप्लिकेशन से ऐक्सेस किया जा सकता है.
SdkSandboxManager
एपीआई को बैकग्राउंड में चल रहे ऐप्लिकेशन से ऐक्सेस करने की कोशिश करने पर, SecurityException
को दिखाया जाता है.
आखिर में, RE-SDKs किसी भी समय उपयोगकर्ता को सूचनाएं भेजने के लिए, सूचनाओं के एपीआई का इस्तेमाल नहीं कर सकते.
जीवनचक्र
फ़िलहाल, ऐप्लिकेशन के SDK टूल, अपने होस्ट ऐप्लिकेशन के लाइफ़साइकल के हिसाब से काम करते हैं. इसका मतलब है कि जब ऐप्लिकेशन फ़ोरग्राउंड में आता है या उससे बाहर निकलता है, बंद हो जाता है या मेमोरी की कमी की वजह से ऑपरेटिंग सिस्टम उसे जबरन बंद कर देता है, तो ऐप्लिकेशन के SDK टूल भी ऐसा ही करते हैं. ऐप्लिकेशन के SDK टूल को अलग प्रोसेस में बांटने के हमारे प्रस्ताव का मतलब है कि लाइफ़साइकल में ये बदलाव होंगे:
- उपयोगकर्ता या ऑपरेटिंग सिस्टम, ऐप्लिकेशन को बंद कर सकता है. इसके तुरंत बाद, SDK Runtime अपने-आप बंद हो जाएगा.
ऑपरेटिंग सिस्टम, ज़्यादा मेमोरी इस्तेमाल होने या SDK टूल में किसी गड़बड़ी की वजह से, SDK टूल के रनटाइम को बंद कर सकता है.
Android 14 में, जब कोई ऐप्लिकेशन फ़ोरग्राउंड में होता है, तो SDK टूल का रनटाइम ज़्यादा प्राथमिकता के साथ चलता है और उसे बंद होने की संभावना कम होती है. जब ऐप्लिकेशन बैकग्राउंड में चला जाता है, तो SDK टूल के रनटाइम की प्रोसेस की प्राथमिकता कम हो जाती है और इसे बंद किया जा सकता है. ऐप्लिकेशन के फ़ोरग्राउंड में वापस आने के बाद भी, SDK टूल के रनटाइम की प्रोसेस की प्राथमिकता कम ही रहती है. इसलिए, ऐप्लिकेशन की तुलना में, इसकी मेमोरी पूरी तरह से भर जाने पर, इसे बंद कर दिया जाएगा.
Android 14 और इसके बाद के वर्शन के लिए, ऐप्लिकेशन और SDK टूल के रनटाइम की प्रोसेस की प्राथमिकताएं अलाइन की जाती हैं. ऐप्लिकेशन और SDK टूल के रनटाइम के लिए,
ActivityManager.RunningAppProcessInfo.importance
की प्रोसेस की प्राथमिकताएं एक जैसी होनी चाहिए.अगर ऐप्लिकेशन चालू होने के दौरान SDK टूल का रनटाइम बंद हो जाता है, तो SDK टूल के रनटाइम की स्थिति और पहले से लोड किए गए सभी SDK टूल और रिमोट व्यू मिट जाते हैं. उदाहरण के लिए, अगर SDK टूल में कोई ऐसा अपवाद है जिसे मैनेज नहीं किया जा सका. ऐप्लिकेशन डेवलपर, SDK टूल के रनटाइम के बंद होने की समस्या को हल करने के लिए, यहां दिए गए किसी भी तरीके का इस्तेमाल कर सकता है:
- इस प्रपोज़ल में, ऐप्लिकेशन डेवलपर को लाइफ़साइकल से जुड़े कॉलबैक मैथड दिए गए हैं. इनकी मदद से, यह पता लगाया जा सकता है कि SDK टूल का रनटाइम कब खत्म हुआ.
- अगर विज्ञापन दिखाए जाने के दौरान SDK टूल का रनटाइम खत्म हो जाता है, तो हो सकता है कि विज्ञापन उम्मीद के मुताबिक काम न करें. उदाहरण के लिए, हो सकता है कि व्यू स्क्रीन पर फ़्रीज़ हो जाएं और अब वे इंटरैक्टिव न हों. अगर विज्ञापन व्यू से उपयोगकर्ता अनुभव पर कोई असर नहीं पड़ता है, तो ऐप्लिकेशन उसे हटा सकता है.
- ऐप्लिकेशन, SDK टूल लोड करने और विज्ञापनों का अनुरोध करने की कोशिश फिर से कर सकता है.
- Android 14 के लिए, अगर SDK टूल के रनटाइम में SDK टूल लोड होने के दौरान उसे बंद कर दिया जाता है और ऐप्लिकेशन डेवलपर ने ऊपर बताए गए लाइफ़साइकल कॉलबैक के तरीकों को रजिस्टर नहीं किया है, तो ऐप्लिकेशन डिफ़ॉल्ट रूप से बंद हो जाता है. सिर्फ़ वे ऐप्लिकेशन प्रोसेस बंद हो जाती हैं और सामान्य तरीके से बाहर निकल जाती हैं जिनमें SDK टूल लोड किए गए हैं.
- अगर ऐप्लिकेशन में
SandboxedSdk
जैसे बाइंडर ऑब्जेक्ट का इस्तेमाल किया जाता है, तो एसडीके टूल के साथ इंटरैक्ट करने के लिए, एसडीके टूल से मिले बाइंडर ऑब्जेक्टDeadObjectException
दिखाते हैं.
आने वाले समय में, लाइफ़साइकल के इस मॉडल में बदलाव हो सकता है.
अगर ऐप्लिकेशन में बार-बार गड़बड़ियां होती हैं, तो ऐप्लिकेशन डेवलपर को SDK टूल के बिना ऐप्लिकेशन को काम करने के लिए तैयार रखना चाहिए. इसके अलावा, अगर SDK टूल ऐप्लिकेशन के मुख्य फ़ंक्शन के लिए ज़रूरी है, तो उपयोगकर्ता को इसकी सूचना देनी चाहिए. ऐप्लिकेशन से SDK टूल के इंटरैक्शन के बारे में ज़्यादा जानकारी के लिए, इस दस्तावेज़ का कम्यूनिकेशन सेक्शन देखें.
नॉन-आरई SDK टूल, अपने एम्बेड किए गए ऐप्लिकेशन के लिए उपलब्ध स्टैंडर्ड ओएस प्राइमिटिव का इस्तेमाल करना जारी रख सकते हैं. इनमें सेवाएं, गतिविधियां, और ब्रॉडकास्ट शामिल हैं. हालांकि, आरई SDK टूल ऐसा नहीं कर सकते.
खास मामले
नीचे दिए गए मामलों में, यह सुविधा काम नहीं करती. साथ ही, इनमें अनचाहा व्यवहार दिख सकता है:
- अगर एक से ज़्यादा ऐप्लिकेशन एक ही यूआईडी शेयर करते हैं, तो हो सकता है कि SDK टूल का रनटाइम ठीक से काम न करे. आने वाले समय में, शेयर किए गए यूआईडी के लिए सहायता जोड़ी जा सकती है.
- एक से ज़्यादा प्रोसेस वाले ऐप्लिकेशन के लिए, SDK को मुख्य प्रोसेस में लोड किया जाना चाहिए.
मीडिया रेंडरिंग
ऐसे SDK भी हैं जो ऐप्लिकेशन के तय किए गए व्यू में टेक्स्ट, इमेज, और वीडियो जैसे कॉन्टेंट को रेंडर करते हैं. इसे पूरा करने के लिए, हम रिमोट-रेंडरिंग का सुझाव देते हैं. इसमें SDK टूल, SDK टूल के रनटाइम में मीडिया को रेंडर करेगा. हालांकि, मीडिया को ऐप्लिकेशन के तय किए गए व्यू में रेंडर करने के लिए, SurfaceControlViewHost
एपीआई का इस्तेमाल किया जाएगा. इससे SDK टूल को, इस मीडिया को उपयोगकर्ता के लिए निजी तरीके से रेंडर करने की सुविधा मिलती है. साथ ही, रेंडर किए गए मीडिया के साथ उपयोगकर्ता के अमान्य या धोखाधड़ी वाले इंटरैक्शन को रोकने और उनका पता लगाने में मदद मिलती है.
नेटिव विज्ञापन, ऐसे विज्ञापन होते हैं जिन्हें SDK टूल के बजाय ऐप्लिकेशन से रेंडर किया जाता है. ये विज्ञापन, SDK टूल के रनटाइम में मौजूद SDK टूल के साथ काम करेंगे. सिग्नल इकट्ठा करने और क्रिएटिव फ़ेच करने की प्रोसेस, नॉन-नेटिव विज्ञापनों के साथ लगातार होती रहेगी. इस बारे में अभी जांच जारी है.
इन-स्ट्रीम वीडियो विज्ञापन, किसी ऐप्लिकेशन में प्लेयर में दिखाए जाने वाले वीडियो के साथ इन-स्ट्रीम में चलते हैं. SDK में प्लेयर या व्यू के बजाय, ऐप्लिकेशन में प्लेयर में वीडियो चलने की वजह से, रेंडरिंग मॉडल अन्य विज्ञापन फ़ॉर्मैट से अलग होता है. हम सर्वर-साइड विज्ञापन इंसर्शन और SDK टूल पर आधारित विज्ञापन इंसर्शन, दोनों के साथ काम करने के तरीकों को एक्सप्लोर कर रहे हैं.
सिस्टम की परफ़ॉर्मेंस
हम यह कोशिश कर रहे हैं कि SDK टूल के रनटाइम से, उपयोगकर्ता के डिवाइसों पर सिस्टम की परफ़ॉर्मेंस पर कम से कम असर पड़े. इसके लिए, हम कुछ तरीके डिज़ाइन कर रहे हैं. हालांकि, ज़्यादातर मामलों में ऐसा हो सकता है कि Android (Go edition) जैसे कुछ एंट्री-लेवल Android 14 डिवाइसों पर, SDK टूल के रनटाइम का इस्तेमाल न किया जा सके. ऐसा इसलिए, क्योंकि इन डिवाइसों में सिस्टम के संसाधन बहुत सीमित होते हैं. हम जल्द ही, SDK टूल के रनटाइम का इस्तेमाल करने के लिए ज़रूरी शर्तों के बारे में बताएंगे.
संचार
फ़िलहाल, ऐप्लिकेशन और SDK टूल एक ही प्रोसेस में काम करते हैं. इसलिए, इनके बीच बिना किसी रुकावट के और बिना किसी मध्यस्थ के कम्यूनिकेशन होता है. इसके अलावा, Android एक ऐप्लिकेशन से दूसरे ऐप्लिकेशन के साथ कम्यूनिकेट करने की अनुमति देता है. भले ही, कम्यूनिकेशन की प्रोसेस SDK टूल से शुरू और खत्म होती हो. डेटा शेयर करने के लिए, यह मॉडल कई तरह के इस्तेमाल के उदाहरणों के साथ-साथ, ऐप्लिकेशन के बीच और ऐप्लिकेशन में SDK टूल के बीच, बिना जानकारी दिए डेटा शेयर करने की सुविधा देता है. हम इस कम्यूनिकेशन मॉडल में ये अपडेट करने का सुझाव दे रहे हैं, ताकि इस तरह के कम्यूनिकेशन की वैल्यू और हमारे बताए गए लक्ष्यों को पूरा करने के बीच संतुलन बना रहे.
ऐप्लिकेशन से SDK टूल
ऐप्लिकेशन और SDK टूल के बीच का इंटरफ़ेस, SDK टूल के साथ कम्यूनिकेट करने का सबसे सामान्य तरीका है. साथ ही, SDK टूल के एपीआई में, उपयोगकर्ताओं के लिए कई तरह के फ़ायदे और इनोवेशन मौजूद होते हैं. हम SDK टूल की नई सुविधाओं और उनसे जुड़े फ़ायदों को बनाए रखने की कोशिश करते हैं. इसलिए, हमारे प्रस्ताव से SDK टूल को ऐप्लिकेशन के लिए एपीआई उपलब्ध कराने में मदद मिलती है. साथ ही, यह पक्का किया जाता है कि ऐप्लिकेशन इन सभी इनोवेशन का फ़ायदा ले पाएं.
SDK टूल के रनटाइम की प्रोसेस की सीमा के स्ट्रक्चर को ध्यान में रखते हुए, हम ऐप्लिकेशन में ऐक्सेस की जा सकने वाली मार्शलिंग लेयर बनाने का सुझाव दे रहे हैं. इससे ऐप्लिकेशन और SDK टूल के बीच, एपीआई कॉल और रिस्पॉन्स या कॉलबैक को इस सीमा के अंदर भेजा जा सकेगा. हमारा सुझाव है कि इस मार्शलिंग लेयर का इंटरफ़ेस, SDK टूल के डेवलपर तय करेंगे. साथ ही, इसे आधिकारिक ओपन-सोर्स बिल्ड टूल से जनरेट किया जाएगा.
इस प्रस्ताव के ज़रिए, हम ऐप्लिकेशन और SDK टूल के डेवलपर से, बोइलरप्लेट मार्शलिंग का काम हटाना चाहते हैं. साथ ही, SDK टूल के डेवलपर को सुविधाएं उपलब्ध कराते हुए, यह पक्का करना चाहते हैं कि निजता से जुड़े हमारे लक्ष्यों को पूरा करने के लिए, SDK टूल का कोड SDK टूल के रनटाइम में चलता रहे. अगर हमें यह तरीका अपनाना है, तो एपीआई डेफ़िनिशन लैंग्वेज और टूल को आपके सुझावों के साथ डिज़ाइन करना होगा.
सामान्य इंटरैक्शन मॉडल इस तरह का होगा:
- ऐप्लिकेशन, इंटरफ़ेस के ज़रिए SDK टूल को कॉल करता है और कॉलबैक पास करता है.
- एसडीके, अनुरोधों को असिंक्रोनस तरीके से पूरा करता है और कॉलबैक का इस्तेमाल करके जवाब देता है.
- इसे किसी भी पब्लिशर-सदस्य मॉडल के लिए सामान्य किया जा सकता है. इसका मतलब है कि कोई ऐप्लिकेशन, कॉलबैक की मदद से SDK टूल में इवेंट की सदस्यता ले सकता है. साथ ही, जब ये इवेंट होते हैं, तो कॉलबैक ट्रिगर हो जाते हैं.
इस प्रस्ताव के नए क्रॉस-प्रोसेस स्ट्रक्चर का एक नतीजा यह है कि दो प्रोसेस लाइफ़साइकल को मैनेज करना होगा: एक ऐप्लिकेशन के लिए और दूसरा SDK टूल के रनटाइम के लिए. हमारा प्रस्ताव है कि हम इस प्रोसेस को ज़्यादा से ज़्यादा ऑटोमेट करें, ताकि ऐप्लिकेशन और SDK टूल के डेवलपर पर इसका कम से कम असर पड़े. इस डायग्राम में, हमने एक तरीका बताया है जिस पर हम काम कर रहे हैं:
इस प्लैटफ़ॉर्म पर ऐप्लिकेशन के लिए नए एपीआई उपलब्ध कराए जाएंगे, ताकि वे SDK टूल को SDK Runtime प्रोसेस में डाइनैमिक तौर पर लोड कर सकें. साथ ही, प्रोसेस की स्थिति में हुए बदलावों के बारे में सूचना पा सकें और SDK Runtime में लोड किए गए SDK टूल के साथ इंटरैक्ट कर सकें.
पिछली इमेज में दिए गए ग्राफ़ में, मार्शलिंग लेयर के बिना, ऐप्लिकेशन से एसडीके के बीच कम लेवल पर होने वाले कम्यूनिकेशन को दिखाया गया है.
ऐप्लिकेशन, SDK टूल के रनटाइम प्रोसेस में चल रहे SDK टूल के साथ, इन चरणों के ज़रिए संपर्क करता है:
कोई ऐप्लिकेशन, किसी SDK टूल के साथ इंटरैक्ट करने से पहले, प्लैटफ़ॉर्म से SDK टूल लोड करने का अनुरोध करता है. सिस्टम के सही तरीके से काम करने की पुष्टि करने के लिए, ऐप्लिकेशन अपनी मेनिफ़ेस्ट फ़ाइल में उन SDK टूल के बारे में बताएंगे जिन्हें उन्हें लोड करना है. साथ ही, सिर्फ़ इन SDK टूल को लोड करने की अनुमति होगी.
यहां दिए गए कोड स्निपेट में, एपीआई का उदाहरण दिया गया है:
SdkSandboxManager.loadSdk(String sdkName, Bundle data, Executor executor, OutcomeReceiver<SandboxedSdk, LoadSdkException> receiver)
SDK टूल को सूचना मिलती है कि उसे लोड कर लिया गया है और वह अपना इंटरफ़ेस दिखाता है. इस इंटरफ़ेस का इस्तेमाल, ऐप्लिकेशन प्रोसेस के लिए किया जाता है. प्रोसेस की सीमा के बाहर इंटरफ़ेस शेयर करने के लिए, इसे
IBinder
ऑब्जेक्ट के तौर पर दिखाना होगा.बाउंड सेवाओं की गाइड में,
IBinder
देने के अलग-अलग तरीके बताए गए हैं. आपने जो भी तरीका चुना हो, वह SDK और कॉलर ऐप्लिकेशन के बीच एक जैसा होना चाहिए. डायग्राम में उदाहरण के तौर पर, एआईडीएल का इस्तेमाल किया गया है.SdkSandboxManager
कोIBinder
इंटरफ़ेस मिलता है और वह इसे ऐप्लिकेशन पर भेज देता है.ऐप्लिकेशन को
IBinder
मिलता है और उसे SDK टूल के इंटरफ़ेस में कास्ट किया जाता है. इसके बाद, इसके फ़ंक्शन को कॉल किया जाता है:IBinder binder = sandboxSdk.getInterface(); ISdkInterface mySdkInterface = ISdkInterface.Stub.asInterface(binder); mySdkInterface.something();
ऐप्लिकेशन, SDK टूल से मीडिया को रेंडर भी कर सकता है. इसके लिए, यह तरीका अपनाएं:
इस दस्तावेज़ के मीडिया रेंडरिंग सेक्शन में बताया गया है कि किसी ऐप्लिकेशन को व्यू में मीडिया रेंडर करने के लिए SDK टूल पाने के लिए, वह
requestSurfacePackage()
को कॉल कर सकता है और सहीSurfaceControlViewHost.SurfacePackage
फ़ेच कर सकता है.यहां दिए गए कोड स्निपेट में, एपीआई का उदाहरण दिया गया है:
SdkSandboxManager.requestSurfacePackage(String sdkName, Bundle extraParams, Executor executor, OutcomeReceiver<Bundle, RequestSurfacePackageException> receiver)
इसके बाद, ऐप्लिकेशन
SurfaceView
में मौजूदsetChildSurfacePackage
एपीआई की मदद से, लौटाए गएSurfacePackage
कोSurfaceView
में एम्बेड कर सकता है.यहां दिए गए कोड स्निपेट में, एपीआई का उदाहरण दिया गया है:
SurfaceView.setChildSurfacePackage(SurfacePackage surfacePackage)
हमारा सुझाव है कि IBinder
और requestSurfacePackage()
एपीआई, सामान्य हों और ऐप्लिकेशन सीधे तौर पर उन्हें कॉल न कर पाएं. इसके बजाय, इन एपीआई को ऊपर बताए गए जनरेट किए गए एपीआई रेफ़रंस से "शिम" लेयर में कॉल किया जाएगा, ताकि ऐप्लिकेशन डेवलपर पर बोझ कम हो.
SDK टूल से SDK टूल
एक ही ऐप्लिकेशन में मौजूद दो SDK टूल को अक्सर एक-दूसरे से इंटरैक्ट करना पड़ता है. ऐसा तब हो सकता है, जब किसी SDK टूल को अलग-अलग SDK टूल से बनाया गया हो. साथ ही, ऐसा तब भी हो सकता है, जब कॉल करने वाले ऐप्लिकेशन के अनुरोध को पूरा करने के लिए, अलग-अलग पक्षों के दो SDK टूल को मिलकर काम करना पड़े.
इन दो मामलों पर ध्यान देना ज़रूरी है:
- जब दोनों SDK टूल, रनटाइम के साथ काम करते हैं. इस मामले में, दोनों SDK टूल, SDK टूल के रनटाइम में सभी सुरक्षा सुविधाओं के साथ काम कर रहे हैं. SDK टूल, ऐप्लिकेशन में जिस तरह से कम्यूनिकेट करते हैं उस तरह से अब नहीं कर पा रहे हैं. इसलिए,
SdkSandboxController
में एक एपीआई जोड़ा गया है, ताकि लोड किए गए सभी RE-SDK टूल के लिए,SandboxedSdk
ऑब्जेक्ट फ़ेच किए जा सकें. इससे, RE-SDK टूल को SDK टूल के रनटाइम में लोड किए गए अन्य SDK टूल के साथ कम्यूनिकेट करने में मदद मिलती है. - जब सिर्फ़ एक SDK टूल, रनटाइम के साथ काम करता है.
- अगर कॉल करने वाला SDK टूल ऐप्लिकेशन में चल रहा है, तो यह SDK टूल के रनटाइम में दूसरे SDK टूल को कॉल करने वाले ऐप्लिकेशन से अलग नहीं होता.
- अगर कॉल करने वाला SDK टूल SDK टूल के रनटाइम में चल रहा है, तो इस प्रस्ताव में ऐप्लिकेशन से SDK टूल वाले सेक्शन में बताए गए
IBinder
का इस्तेमाल करके, किसी तरीके को एक्सपोज़ करने का सुझाव दिया गया है. यह तरीका, ऐप्लिकेशन में मौजूद कोड को सुनता है, प्रोसेस करता है, और दिए गए कॉलबैक के साथ जवाब देता है. - ऐसा हो सकता है कि रनटाइम की सुविधा वाले विज्ञापन SDK टूल, खुद को रजिस्टर न कर पाएं. इसलिए, हमारा सुझाव है कि आप एक मीडिएटर SDK टूल बनाएं. इसमें किसी भी पार्टनर या ऐप्लिकेशन के SDK टूल को ऐप्लिकेशन की सीधी डिपेंडेंसी के तौर पर शामिल करें. साथ ही, रजिस्टर करने की प्रोसेस को मैनेज करें. यह मध्यस्थ SDK टूल, रनटाइम की सुविधा के बिना काम करने वाले SDK टूल या ऐप्लिकेशन की अन्य डिपेंडेंसी के बीच और रनटाइम की सुविधा वाले मध्यस्थ के बीच, अडैप्टर के तौर पर काम करके, कम्यूनिकेशन की सुविधा देता है.
SDK टूल के बीच कम्यूनिकेशन के लिए सुविधाओं के सेट को इन कैटगरी में बांटा गया है:
- SDK टूल के रनटाइम में, SDK टूल के बीच कम्यूनिकेशन (डेवलपर के लिए उपलब्ध सबसे नए रिलीज़ में उपलब्ध)
- ऐप्लिकेशन और SDK टूल के रनटाइम के बीच SDK टूल-SDK टूल का कम्यूनिकेशन (डेवलपर के लिए उपलब्ध सबसे नए रिलीज़ के बीटा वर्शन में उपलब्ध है)
- मीडिएशन के लिए व्यू और रिमोट रेंडरिंग कैसे काम करनी चाहिए (प्रपोज़ल पर काम जारी है)
प्राइमिटिव डिज़ाइन किए जा रहे हैं, इसलिए इस्तेमाल के इन उदाहरणों पर विचार किया जा रहा है:
- मीडिएशन और बिडिंग. विज्ञापन दिखाने वाले कई SDK टूल, मीडिएशन या बिडिंग की सुविधा देते हैं. इसमें, SDK टूल किसी विज्ञापन इंप्रेशन (मीडिएशन) के लिए या नीलामी (बिडिंग) चलाने के लिए सिग्नल इकट्ठा करने के लिए, कई अन्य SDK टूल को कॉल करता है. आम तौर पर, कोऑर्डिनेट करने वाला SDK टूल, कोऑर्डिनेट करने वाले SDK टूल से मिले अडैप्टर की मदद से, दूसरे SDK टूल को कॉल करता है. ऊपर दिए गए प्राइमिटिव के हिसाब से, सामान्य तरीके से काम करने के लिए, कोऑर्डिनेट करने वाला SDK टूल, RE या नॉन-RE, सभी RE और नॉन-RE SDK टूल को ऐक्सेस कर सकता है. इस संदर्भ में रेंडरिंग की जांच की जा रही है.
- सुविधा की खोज. कुछ SDK टूल में छोटे SDK टूल होते हैं. ये इंटर-SDK डिस्कवरी की प्रोसेस की मदद से, ऐप्लिकेशन डेवलपर को दिखाए जाने वाले फ़ीचर सेट का पता लगाते हैं. रजिस्टर करने और खोजने के प्राइमिटिव की मदद से, इस इस्तेमाल के उदाहरण को चालू किया जा सकता है.
- पब्लिशर-सदस्यता मॉडल. कुछ SDK टूल को इवेंट का मुख्य पब्लिशर बनाने के लिए डिज़ाइन किया गया है. दूसरे SDK टूल या ऐप्लिकेशन, कॉलबैक की मदद से सूचनाएं पाने के लिए इसकी सदस्यता ले सकते हैं. ऊपर दिए गए प्राइमिटिव, इस इस्तेमाल के उदाहरण के साथ काम करने चाहिए.
ऐप्लिकेशन-टू-ऐप्लिकेशन
ऐप्लिकेशन-टू-ऐप्लिकेशन कम्यूनिकेशन तब होता है, जब कम्यूनिकेट करने वाली दो प्रोसेस में से कम से कम एक प्रोसेस, रनटाइम की सुविधा वाला SDK टूल हो. साथ ही, यह बिना बताए डेटा शेयर करने का संभावित वेक्टर है. इसलिए, SDK टूल का रनटाइम, क्लाइंट ऐप्लिकेशन के अलावा किसी दूसरे ऐप्लिकेशन के साथ सीधे तौर पर कम्यूनिकेशन चैनल सेट अप नहीं कर सकता. इसके अलावा, यह किसी दूसरे ऐप्लिकेशन के लिए बनाए गए किसी दूसरे SDK टूल के रनटाइम में मौजूद SDK टूल के साथ भी सीधे तौर पर कम्यूनिकेशन चैनल सेट अप नहीं कर सकता. ऐसा करने के लिए, ये तरीके अपनाए जाते हैं:
- SDK टूल, अपने मेनिफ़ेस्ट में
<service>
,<contentprovider>
या<activity>
जैसे कॉम्पोनेंट तय नहीं कर सकता. - SDK टूल,
ContentProvider
पब्लिश नहीं कर सकता या ब्रॉडकास्ट नहीं भेज सकता. - SDK टूल, किसी दूसरे ऐप्लिकेशन की ऐक्टिविटी लॉन्च कर सकता है. हालांकि, इंटेंट में क्या भेजा जा सकता है, इस पर पाबंदियां होती हैं. उदाहरण के लिए, इस इंटेंट में कोई अतिरिक्त या कस्टम कार्रवाई नहीं जोड़ी जा सकती.
- SDK टूल, सिर्फ़ अनुमति वाली सेवाओं को शुरू या उनसे बंधा जा सकता है.
- एसडीके टूल, सिस्टम
ContentProvider
(जैसे,com.android.providers.settings.SettingsProvider
) का सिर्फ़ एक सबसेट ऐक्सेस कर सकता है. इस सबसेट में, मिले डेटा में आइडेंटिफ़ायर नहीं होते और इसका इस्तेमाल उपयोगकर्ता का फ़िंगरप्रिंट बनाने के लिए नहीं किया जा सकता. ये जांच,ContentResolver
का इस्तेमाल करकेContentProvider
को ऐक्सेस करने पर भी लागू होती हैं. - SDK टूल, सिर्फ़ सुरक्षित ब्रॉडकास्ट रिसीवर (जैसे कि
android.intent.action.AIRPLANE_MODE
) के सबसेट को ऐक्सेस कर सकता है.
मेनिफ़ेस्ट टैग
SDK टूल इंस्टॉल होने के बाद, PackageManager
SDK टूल के मेनिफ़ेस्ट को पार्स करता है. अगर पाबंदी वाले मेनिफ़ेस्ट टैग मौजूद हैं, तो SDK टूल इंस्टॉल नहीं हो पाता. उदाहरण के लिए, हो सकता है कि SDK टूल, <service>, <activity>, <provider>
या <receiver>
जैसे कॉम्पोनेंट की जानकारी न दे और मेनिफ़ेस्ट में <permission>
का एलान न करे. SDK टूल के रनटाइम में, ऐसे टैग काम नहीं करते जिन्हें इंस्टॉल नहीं किया जा सका. ऐसे टैग जो इंस्टॉल नहीं होते, लेकिन चुपचाप अनदेखा कर दिए जाते हैं, हो सकता है कि वे Android के आने वाले वर्शन में काम करें.
ये जांच, बिल्ड टाइम टूल भी लागू कर सकते हैं. SDK टूल, SDK बंडल बनाने के लिए इनका इस्तेमाल करता है. साथ ही, ऐप्लिकेशन स्टोर पर अपलोड करते समय भी ये जांच लागू की जा सकती हैं.
गतिविधि से जुड़ी सहायता
SDK टूल के रनटाइम एनवायरमेंट में मौजूद SDK टूल, अपनी मेनिफ़ेस्ट फ़ाइल में गतिविधि टैग नहीं जोड़ सकते. साथ ही, Context.startActivity
का इस्तेमाल करके अपनी गतिविधियां शुरू नहीं कर सकते.
इसके बजाय, जब अनुरोध किया जाता है, तो प्लैटफ़ॉर्म SDK टूल के लिए गतिविधियां बनाता है और उन्हें SDK टूल के साथ शेयर करता है.
प्लैटफ़ॉर्म गतिविधि android.app.Activity
टाइप की है. प्लैटफ़ॉर्म गतिविधि, ऐप्लिकेशन की किसी एक गतिविधि से शुरू होती है और यह ऐप्लिकेशन टास्क का हिस्सा होती है.
FLAG_ACTIVITY_NEW_TASK
का इस्तेमाल नहीं किया जा सकता.
किसी SDK टूल को गतिविधि शुरू करने के लिए, उसे SdkSandboxActivityHandler
टाइप का एक इंस्टेंस रजिस्टर करना चाहिए. इसका इस्तेमाल, गतिविधि शुरू करने के लिए ऐप्लिकेशन के SdkSandboxManager::startSdkSandboxActivity(Activity, IBinder)
को कॉल करने पर, गतिविधि बनाने के बारे में सूचना देने के लिए किया जाता है.
किसी गतिविधि का अनुरोध करने का फ़्लो, नीचे दिए गए ग्राफ़ में दिखाया गया है.
डेवलेपमेंट
इस प्रस्ताव का एक मुख्य सिद्धांत यह है कि डेवलपर के पारिस्थितिक तंत्र पर पड़ने वाले असर को कम से कम किया जाए. इस प्रस्ताव में, डेवलपर को RE ऐप्लिकेशन और SDK टूल लिखने, बनाने, और डीबग करने के लिए, डेवलपमेंट टूल का पूरा सेट उपलब्ध कराया जाता है. इस प्रस्ताव की पूरी तरह से पुष्टि करने के लिए, रीइंस्टॉल किए जा सकने वाले ऐप्लिकेशन और SDK टूल को कॉन्फ़िगर करने, बनाने, और उनमें बदलाव करने के तरीके में कुछ बदलाव किए गए हैं.
लेखन
Android Studio और उससे जुड़े टूल को SDK टूल के रनटाइम के हिसाब से अपडेट किया जाएगा. इससे यह पक्का करने में मदद मिलेगी कि डेवलपर ने अपने रीइंस्टॉल किए जा सकने वाले ऐप्लिकेशन और SDK टूल को सही तरीके से कॉन्फ़िगर किया है. साथ ही, यह भी पक्का किया जा सकेगा कि लेगसी या काम न करने वाले कॉल को ज़रूरत पड़ने पर, नए विकल्पों पर अपडेट किया गया है. लेखन के दौरान, हमारे प्रस्ताव के मुताबिक डेवलपर को कुछ कदम उठाने होंगे.
ऐप्लिकेशन डेवलपर
ऐप्लिकेशन को अपने ऐप्लिकेशन मेनिफ़ेस्ट में, अपने आरई एसडीके टूल और एसडीके टूल सर्टिफ़िकेट की डिपेंडेंसी बतानी होंगी. हम अपने प्रस्ताव में, ऐप्लिकेशन डेवलपर के इस बयान को सच्चाई के सोर्स के तौर पर इस्तेमाल करते हैं. उदाहरण के लिए:
- नाम: SDK टूल या लाइब्रेरी का पैकेज नाम.
- मेजर वर्शन: SDK टूल का मेजर वर्शन कोड.
- सर्टिफ़िकेट डाइजेस्ट: SDK टूल के बिल्ड का सर्टिफ़िकेट डाइजेस्ट. हमारा सुझाव है कि किसी दिए गए बिल्ड के लिए, SDK टूल के डेवलपर को इस वैल्यू को ऐप्लिकेशन स्टोर से हासिल करके रजिस्टर करना चाहिए.
यह सिर्फ़ ऐप स्टोर से डिस्ट्रिब्यूट किए गए SDK टूल पर लागू होता है, भले ही वे RE हों या नहीं. SDK टूल को स्टैटिक तरीके से लिंक करने वाले ऐप्लिकेशन, डिपेंडेंसी के मौजूदा तरीकों का इस्तेमाल करेंगे.
हमारा मकसद डेवलपर पर कम से कम असर डालना है. इसलिए, यह ज़रूरी है कि SDK टूल के रनटाइम के साथ काम करने वाला टारगेट एपीआई लेवल तय करने के बाद, ऐप्लिकेशन डेवलपर को सिर्फ़ एक ही बिल्ड की ज़रूरत पड़े. भले ही, वह बिल्ड उन डिवाइसों पर काम करता हो जो SDK टूल के रनटाइम के साथ काम करते हैं या नहीं.
SDK टूल के डेवलपर
हमारे सुझाए गए डिज़ाइन में, RE SDK टूल के डेवलपर को मेनिफ़ेस्ट में, SDK टूल या लाइब्रेरी इकाई को दिखाने वाले नए एलिमेंट के बारे में साफ़ तौर पर बताना होगा. इसके अलावा, डिपेंडेंसी के वैल्यू के जैसे ही एक सेट और एक छोटा वर्शन भी देना होगा:
- नाम: SDK टूल या लाइब्रेरी का पैकेज नाम.
- मेजर वर्शन: SDK टूल का मेजर वर्शन कोड.
- माइनर वर्शन: SDK टूल का माइनर वर्शन कोड.
अगर RE SDK टूल के डेवलपर के पास बिल्ड टाइम डिपेंडेंसी के तौर पर अन्य RE SDK टूल हैं, तो उन्हें उनका एलान उसी तरह करना होगा जिस तरह कोई ऐप्लिकेशन डेवलपर उसी डिपेंडेंसी का एलान करता है. RE SDK टूल, नॉन-RE SDK टूल पर निर्भर होते हैं. इसलिए, वे उन्हें स्टैटिक तौर पर लिंक करते हैं. इससे ऐसी समस्याएं हो सकती हैं जिनका पता, बिल्ड के समय या टेस्ट पास के दौरान चलेगा. ऐसा तब होगा, जब नॉन-RE SDK टूल के लिए ऐसी सुविधाओं की ज़रूरत हो जिनका SDK रनटाइम इस्तेमाल नहीं करता या जब उन्हें ऐप्लिकेशन की प्रोसेस में चलाना ज़रूरी हो.
RE SDK टूल के डेवलपर, RE की सुविधा वाले डिवाइसों के अलावा, उन डिवाइसों के लिए भी सहायता जारी रखना चाहेंगे जिनमें यह सुविधा नहीं है. जैसे, Android 12 या उससे पहले के वर्शन वाले डिवाइस. साथ ही, दस्तावेज़ के सिस्टम की परफ़ॉर्मेंस से जुड़े सेक्शन में बताए गए, कम सिस्टम रिसोर्स वाले Android 14 वाले एंट्री-लेवल डिवाइसों के लिए भी सहायता जारी रखना चाहेंगे. हम इस बात पर काम कर रहे हैं कि SDK टूल के डेवलपर, रीयल टाइम और नॉन-रीयल टाइम, दोनों तरह के एनवायरमेंट के लिए एक ही कोड-बेस का इस्तेमाल कर सकें.
बिल्ड
ऐप्लिकेशन डेवलपर
हमें उम्मीद है कि ऐप्लिकेशन डेवलपर को, ऐप्लिकेशन बनाने के चरण में थोड़ा बदलाव दिखेगा. लिंटिंग, कंपाइलेशन, और बिल्ड के लिए, मशीन पर SDK टूल की डिपेंडेंसी मौजूद होनी चाहिए. भले ही, उन्हें स्थानीय तौर पर डिस्ट्रिब्यूट किया गया हो या ऐप्लिकेशन स्टोर से डिस्ट्रिब्यूट किया गया हो. हमारा सुझाव है कि Android Studio, ऐप्लिकेशन डेवलपर से सामान्य इस्तेमाल के लिए, इन जानकारी को छिपाए और इसे ज़्यादा से ज़्यादा पारदर्शी बनाए.
हालांकि, हमें उम्मीद है कि डीबग करने के लिए, डीबग बिल्ड में सभी कोड और सिंबल शामिल होने चाहिए. हालांकि, रिलीज़ बिल्ड में ऐप्लिकेशन स्टोर से डिस्ट्रिब्यूट किए गए सभी SDK टूल (RE या नहीं) को आखिरी आर्टफ़ैक्ट से हटाया जा सकता है.
हम अभी इस सुविधा के डिज़ाइन के शुरुआती चरण में हैं. जैसे-जैसे इस पर काम आगे बढ़ेगा, हम इस बारे में ज़्यादा जानकारी शेयर करेंगे.
SDK टूल के डेवलपर
हम इस बात पर काम कर रहे हैं कि SDK टूल के नॉन-आरई और आरई वर्शन को डिस्ट्रिब्यूशन के लिए, एक आर्टफ़ैक्ट में बनाया जा सके. इससे, ऐप्लिकेशन डेवलपर को किसी SDK टूल के RE और नॉन-RE वर्शन के लिए, अलग-अलग बिल्ड बनाने की ज़रूरत नहीं पड़ेगी.
ऐप्लिकेशन की तरह ही, ऐप्लिकेशन स्टोर पर डिस्ट्रिब्यूट किए गए डिपेंडेंसी SDK टूल को भी मशीन पर मौजूद होना चाहिए, ताकि उन्हें लिंटिंग, कंपाइलेशन, और बिल्ड किया जा सके. हमें उम्मीद है कि Android Studio में यह आसानी से किया जा सकेगा.
टेस्ट करना
ऐप्लिकेशन डेवलपर
हमारे प्रस्ताव में बताया गया है कि ऐप्लिकेशन डेवलपर, Android 14 पर चलने वाले डिवाइसों पर अपने ऐप्लिकेशन को सामान्य तरीके से टेस्ट कर पाएंगे. ऐप्लिकेशन बनाने के बाद, उसे RE डिवाइस या एमुलेटर पर इंस्टॉल किया जा सकता है. इंस्टॉल करने की इस प्रोसेस से यह पक्का होगा कि डिवाइस या एमुलेटर के लिए, SDK टूल के रनटाइम में सही SDK टूल इंस्टॉल हो जाएं. भले ही, SDK टूल किसी रिमोट SDK टूल के डेटाबेस से खींचे गए हों या बिल्ड सिस्टम के कैश मेमोरी से.
SDK टूल के डेवलपर
एसडीके टूल के डेवलपर, आम तौर पर डिवाइसों और एमुलेटर पर इन-हाउस टेस्ट ऐप्लिकेशन का इस्तेमाल करके, अपने डेवलपमेंट की जांच करते हैं. हमारे प्रस्ताव से इसमें कोई बदलाव नहीं होगा. साथ ही, इन-ऐप्लिकेशन पुष्टि करने के लिए, वही चरण अपनाए जाएंगे जो ऊपर ऐप्लिकेशन डेवलपर के लिए बताए गए हैं. इसमें, आरई और नॉन-आरई, दोनों तरह के ऐप्लिकेशन के लिए एक ही बिल्ड आर्टफ़ैक्ट का इस्तेमाल किया जाएगा. SDK टूल के डेवलपर, अपने कोड को सिलसिलेवार तरीके से देख पाएंगे. भले ही, वह SDK टूल के रनटाइम में हो या नहीं. हालांकि, ऐडवांस डीबगिंग और प्रोफ़ाइलिंग टूल पर कुछ सीमाएं हो सकती हैं. इस बारे में जांच जारी है.
डिस्ट्रिब्यूशन
ऐप्लिकेशन को उसके SDK टूल से अलग करने के लिए, डिज़ाइन से जुड़े हमारे प्रस्ताव की वजह से, ऐप्लिकेशन स्टोर पर SDK टूल उपलब्ध कराने की संभावना पैदा हुई है. यह सामान्य तौर पर हो सकता है. यह किसी खास ऐप स्टोर के लिए नहीं है. इसके फ़ायदे साफ़ तौर पर बताए गए हैं:
- SDK टूल की क्वालिटी और एकरूपता को पक्का करना.
- SDK टूल के डेवलपर के लिए पब्लिकेशन को आसान बनाना.
- इंस्टॉल किए गए ऐप्लिकेशन में, SDK टूल के माइनर वर्शन के अपडेट को तेज़ी से रोल आउट करना.
SDK टूल को डिस्ट्रिब्यूट करने के लिए, ऐप्लिकेशन स्टोर को इनमें से ज़्यादातर सुविधाएं उपलब्ध करानी होंगी:
- SDK टूल के डेवलपर के लिए, ऐप्लिकेशन स्टोर पर उपलब्ध कराए जाने वाले SDK टूल को स्टोर पर अपलोड करने, उन्हें अपडेट करने, वापस रोल करने, और शायद उन्हें हटाने का तरीका.
- यह एक ऐसा तरीका है जिससे यह पक्का किया जा सकता है कि SDK टूल और उसके सोर्स, ऐप्लिकेशन और उसके सोर्स भरोसेमंद हैं. साथ ही, इससे उनकी डिपेंडेंसी को हल करने में भी मदद मिलती है.
- डिवाइसों पर उन्हें भरोसेमंद और बेहतर परफ़ॉर्मेंस के साथ डिप्लॉय करने का तरीका.
समय के साथ बदलती पाबंदियां
हमें उम्मीद है कि Android के नए वर्शन के साथ, SDK टूल के रनटाइम में कोड पर लगने वाली पाबंदियां भी बदल जाएंगी. ऐप्लिकेशन के साथ काम करने की सुविधा को पक्का करने के लिए, हम किसी SDK टूल के लेवल के लिए, मुख्य मॉड्यूल के अपडेट के साथ इन पाबंदियों में बदलाव नहीं करेंगे. किसी targetSdkVersion
के साथ जुड़ा व्यवहार तब तक सुरक्षित रखा जाता है, जब तक कि ऐप्लिकेशन स्टोर की नीति के तहत उस targetSdkVersion
के लिए सहायता बंद नहीं कर दी जाती. साथ ही, targetSdkVersion
को ऐप्लिकेशन के मुकाबले तेज़ी से बंद किया जा सकता है.
Android SDK के सभी वर्शन में पाबंदियां बार-बार बदल सकती हैं. खास तौर पर, शुरुआती कुछ रिलीज़ में ऐसा हो सकता है.
इसके अलावा, हम एक कैनरी मशीन बना रहे हैं, ताकि बाहरी और अंदरूनी जांचकर्ताओं को एक ऐसे ग्रुप में शामिल किया जा सके जिसे Android के अगले वर्शन के लिए पाबंदियों का प्रस्तावित सेट मिलता है. इससे हमें पाबंदियों के सेट में किए गए बदलावों के बारे में सुझाव और भरोसा पाने में मदद मिलेगी.
अक्सर पूछे जाने वाले सवाल
-
विज्ञापन से जुड़ा एसडीके टूल क्या होता है?
विज्ञापन से जुड़ा SDK टूल, ऐसे ऐप्लिकेशन पर उपयोगकर्ताओं को व्यावसायिक मकसद से मैसेज भेजकर, उन्हें टारगेट करने में मदद करता है जिनका मालिकाना हक विज्ञापन देने वाले के पास नहीं होता. इसमें, ऐसे ऐनलिटिक्स SDK टूल शामिल हैं जिनमें बाद में टारगेटिंग के लिए उपयोगकर्ता ग्रुप बनाए जा सकते हैं. साथ ही, इसमें विज्ञापन दिखाने वाले SDK टूल, विज्ञापनों के लिए गलत इस्तेमाल और धोखाधड़ी को रोकने वाले SDK टूल, यूज़र ऐक्टिविटी को बढ़ाने वाले SDK टूल, और एट्रिब्यूशन SDK टूल भी शामिल हैं. हालांकि, इसमें और भी चीज़ें शामिल हो सकती हैं.
-
क्या कोई भी SDK टूल, SDK टूल के रनटाइम में चल सकता है?
हालांकि, शुरुआत में हमारा ध्यान विज्ञापन से जुड़े SDK टूल पर है, लेकिन जिन डेवलपर के पास ऐसे SDK टूल हैं जो विज्ञापन से जुड़े नहीं हैं और जो उपयोगकर्ता की निजता को बनाए रखने के लिए काम करना चाहते हैं और जिनके मुताबिक वे ऊपर बताई गई शर्तों के मुताबिक काम कर सकते हैं वे SDK टूल के रनटाइम में चल रहे अपने SDK टूल के बारे में सुझाव, शिकायत या राय दे सकते हैं. हालांकि, SDK टूल के सभी डिज़ाइन के साथ काम करने के लिए, SDK टूल के रनटाइम को डिज़ाइन नहीं किया गया है. दस्तावेज़ में बताई गई सीमाओं के अलावा, SDK टूल के रनटाइम का इस्तेमाल उन SDK टूल के लिए नहीं किया जा सकता जिन्हें होस्टिंग ऐप्लिकेशन के साथ रीयल-टाइम या ज़्यादा थ्रूपुट वाले कम्यूनिकेशन की ज़रूरत होती है.
-
प्रोसेस के Java-आधारित रनटाइम में अलग-अलग प्रोसेस के बजाय, प्रोसेस को अलग-अलग क्यों रखना चाहिए?
फ़िलहाल, Java पर आधारित रनटाइम, Android उपयोगकर्ताओं को निजता की गारंटी देने के लिए ज़रूरी सुरक्षा सीमाओं को आसानी से लागू नहीं करता. ऐसा करने के लिए, कई सालों तक काम करना पड़ सकता है. हालांकि, इस बात की कोई गारंटी नहीं है कि यह कामयाब होगा. इसलिए, Privacy Sandbox में प्रोसेस की सीमाओं का इस्तेमाल किया जाता है. यह एक ऐसी टेक्नोलॉजी है जिसे समय-समय पर जांचा गया है और जिसे अच्छी तरह समझा गया है.
-
क्या SDK टूल को SDK टूल के रनटाइम प्रोसेस में ले जाने से, डाउनलोड किए जाने वाले ऐप्लिकेशन के साइज़ या डिवाइस के स्टोरेज में बचत होगी?
अगर एक ही वर्शन के रनटाइम के साथ काम करने वाले SDK टूल के साथ कई ऐप्लिकेशन इंटिग्रेट किए जाते हैं, तो इससे डाउनलोड साइज़ और डिस्क स्टोरेज कम हो सकता है.
-
SDK टूल के रनटाइम में, ऐप्लिकेशन के लाइफ़साइकल से जुड़े किस तरह के इवेंट का ऐक्सेस होगा. जैसे, ऐप्लिकेशन के बैकग्राउंड में जाने पर क्या होगा?
हम अपने क्लाइंट ऐप्लिकेशन के ऐप्लिकेशन-लेवल लाइफ़साइकल इवेंट (जैसे, ऐप्लिकेशन बैकग्राउंड में जाना, ऐप्लिकेशन फ़ोरग्राउंड में जाना) पर SDK टूल के रनटाइम की सूचना देने के लिए, डिज़ाइन से जुड़ी सहायता पर काम कर रहे हैं. डिज़ाइन और सैंपल कोड, आने वाले समय में डेवलपर के लिए उपलब्ध कराए जाएंगे.
आपके लिए सुझाव
- ध्यान दें: JavaScript बंद होने पर लिंक टेक्स्ट दिखता है
- SDK Runtime के लिए डेवलपर गाइड