ভূমিকা
আপনার অ্যান্ড্রয়েড অ্যাপ্লিকেশনে গুগল এপিআই বা ফায়ারবেস পরিষেবা সক্রিয় করার অংশ হিসেবে আপনাকে আপনার build.gradle ফাইলে google-services প্লাগইনটি যোগ করতে হতে পারে:
dependencies {
classpath 'com.google.gms:google-services:4.4.4'
// ...
}
google-services প্লাগইনটির দুটি প্রধান কাজ রয়েছে:
-
google-services.jsonফাইলটি প্রসেস করে অ্যান্ড্রয়েড রিসোর্স তৈরি করুন যা আপনার অ্যাপ্লিকেশনের কোডে ব্যবহার করা যাবে। আরও তথ্যের জন্য "Adding the JSON File" দেখুন। আপনার সক্রিয় করা পরিষেবাগুলির জন্য প্রয়োজনীয় মৌলিক লাইব্রেরিগুলির নির্ভরতা যোগ করুন। এই ধাপে আপনাকে আপনার
app/build.gradleফাইলে Google Services Gradle প্লাগইনটি প্রয়োগ করতে হবে, যেমনটি নিচে দেখানো হয়েছে:
apply plugin: 'com.google.gms.google-services'./gradlew :app:dependenciesচালিয়ে আপনি এই ধাপের ফলাফল দেখতে পারেন।
JSON ফাইল যোগ করা
google-services.json ফাইলটি সাধারণত app/ ডিরেক্টরিতে (অ্যান্ড্রয়েড স্টুডিও অ্যাপ মডিউলের রুটে) রাখা হয়। সংস্করণ 2.2.0 থেকে প্লাগইনটি বিল্ড টাইপ এবং প্রোডাক্ট ফ্লেভার-নির্দিষ্ট JSON ফাইল সমর্থন করে। নিম্নলিখিত সমস্ত ডিরেক্টরি কাঠামো বৈধ:
// dogfood and release are build types. app/ google-services.json src/dogfood/google-services.json src/release/google-services.json ...
দ্রষ্টব্য: রিলিজ ডিরেক্টরিতে একটি google-services.json ফাইল রাখলে আপনি আপনার প্রোডাকশন APK-গুলোর জন্য একটি আলাদা Firebase প্রজেক্ট রক্ষণাবেক্ষণ করতে পারবেন।
যখন পণ্যের ফ্লেভারগুলো ব্যবহৃত হয়, তখন এই আরও জটিল ডিরেক্টরি কাঠামোগুলোও বৈধ থাকে।
// free and paid are product flavors. app/ google-services.json src/dogfood/paid/google-services.json src/release/free/google-services.json ...
JSON ফাইল প্রক্রিয়াকরণ
google-services.json ফাইলটির মৌলিক কাঠামোটি নিম্নরূপ:
{
"project_info": {...},
"client": [...],
} project_info অবজেক্টটিতে আপনার প্রজেক্ট সম্পর্কিত সাধারণ তথ্য থাকে, অন্যদিকে client অ্যারের প্রতিটি সদস্যে সেইসব ক্লায়েন্টের (অ্যান্ড্রয়েড অ্যাপ) তথ্য থাকে, যেগুলো আপনি প্রজেক্টে যুক্ত করেছেন।
আপনার অ্যান্ড্রয়েড অ্যাপের জন্য JSON ফাইলটি প্রসেস করার সময়, প্লাগইনটি নিম্নলিখিত লজিকের উপর ভিত্তি করে শুধুমাত্র সেই client অবজেক্টটি ব্যবহার করে যা আপনার প্যাকেজ নামের (বর্তমান বিল্ড টাইপের জন্য) সাথে মেলে:
-
clientঅ্যারের প্রতিটি সদস্যের জন্য:-
client_info/android_client_info/package_nameএর মান যাচাই করুন - যদি প্যাকেজের নামটি এই মানের সাথে মিলে যায়, তাহলে মেম্বার অবজেক্টটি ফেরত দিন।
-
- যদি
clientকোনো সদস্য প্যাকেজ নামের সাথে মেলে না, তাহলে একটি ব্যতিক্রম প্রদর্শিত হয়।
এই ডকুমেন্টের বাকি অংশে, আমরা {YOUR_CLIENT} ব্যবহার করে উপরোক্ত পদ্ধতি দ্বারা নির্ধারিত client অ্যারের সদস্যকে বোঝাব।
JSON প্রক্রিয়াকরণের প্রধান ফলাফল হলো দুটি XML ফাইল তৈরি করা, যেগুলোকে আপনি আপনার জাভা কোডে অ্যান্ড্রয়েড রিসোর্স হিসেবে ব্যবহার করতে পারবেন। নিচে প্রতিটি ফাইলের একটি করে উদাহরণ দেওয়া হলো:
app/build/generated/res/google-services/{build_type}/values/values.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<! -- Present in all applications -->
<string name="google_app_id" translatable="false">1:1035469437089:android:73a4fb8297b2cd4f</string>
<! -- Present in applications with the appropriate services configured -->
<string name="gcm_defaultSenderId" translatable="false">1035469437089</string>
<string name="default_web_client_id" translatable="false">337894902146-e4uksm38sne0bqrj6uvkbo4oiu4hvigl.apps.googleusercontent.com</string>
<string name="ga_trackingId" translatable="false">UA-65557217-3</string>
<string name="firebase_database_url" translatable="false">https://example-url.firebaseio.com</string>
<string name="google_api_key" translatable="false">AIzbSyCILMsOuUKwN3qhtxrPq7FFemDJUAXTyZ8</string>
<string name="google_crash_reporting_api_key" translatable="false">AIzbSyCILMsOuUKwN3qhtxrPq7FFemDJUAXTyZ8</string>
<string name="project_id" translatable="false">mydemoapp</string>
</resources>app/build/generated/res/google-services/{flavor}/{build_type}/xml/global_tracker.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="ga_trackingId" translatable="false">UA-65557218-3</string>
</resources> XML ফাইলগুলোর প্রতিটি ভ্যালু নিচের লোকেশনগুলোতে থাকা google-services.json ফাইলের মধ্যে পাওয়া যাবে। যদি আপনার অ্যান্ড্রয়েড প্রজেক্টের কোনো কনফিগারেশনের কারণে আপনি google-services প্লাগইনটি ব্যবহার করতে না পারেন, তাহলে আপনি এই ভ্যালুগুলো ব্যবহার করে নিরাপদে ম্যানুয়ালি XML ফাইলগুলো পুনরায় তৈরি করতে পারেন:
google_app_id :
{YOUR_CLIENT}/client_info/mobilesdk_app_idgcm_defaultSenderId :
project_info/project_number
ডিফল্ট_ওয়েব_ক্লায়েন্ট_আইডি :
{YOUR_CLIENT}/oauth_client/client_id (client_type == 3)
ga_trackingId :
{YOUR_CLIENT}/services/analytics-service/analytics_property/tracking_idfirebase_database_url :
project_info/firebase_url
google_api_key :
{YOUR_CLIENT}/api_key/current_keygoogle_crash_reporting_api_key :
{YOUR_CLIENT}/api_key/current_keyপ্রকল্প_আইডি :
project_info/project_id
সমস্যা সমাধান
বিল্ড করার সময় আমি নিম্নলিখিত ত্রুটি বার্তাটি পাই: "মডিউলের রুট ফোল্ডারে google-services.json ফাইলটি অনুপস্থিত। এটি ছাড়া গুগল সার্ভিসেস প্লাগইনটি কাজ করতে পারবে না"।
ফায়ারবেস কনসোল আপনাকে google-services.json ফাইলটি ডাউনলোড করতে সাহায্য করবে। এছাড়াও, বেশিরভাগ এপিআই-এর কুইকস্টার্ট গাইডে এই ফাইলটি তৈরি করার নির্দেশাবলী দেওয়া থাকে। google-services.json ফাইলটি ডাউনলোড করার পর, সেটি আপনার অ্যান্ড্রয়েড স্টুডিও প্রজেক্টের app/ ফোল্ডারে কপি করুন, অথবা আপনি যদি একাধিক বিল্ড টাইপ ব্যবহার করেন তবে app/src/{build_type} ফোল্ডারে কপি করুন।
প্রশ্ন: আমি 'R.string.gcm_defaultSenderId', 'R.xml.global_tracker' ইত্যাদি সিম্বলগুলো খুঁজে পাচ্ছি না।
এ: নিশ্চিত করুন যে আপনার build.gradle ফাইলের প্যাকেজ নামটি google-services.json ফাইলটি তৈরি করার সময় আপনার দেওয়া প্যাকেজ নামের সাথে মেলে। আপনি যদি নিশ্চিত না হন, তবে আবার গেটিং স্টার্টেড ফ্লোটি অনুসরণ করুন এবং একটি নতুন json ফাইল তৈরি করুন।