Catch up on everthing we announced at this year's Firebase Summit. Learn more

একাধিক প্রকল্প কনফিগার করুন

এই পৃষ্ঠাটি বর্ণনা করে যে কীভাবে আপনার অ্যাপে একাধিক ফায়ারবেস প্রকল্প ব্যবহার করবেন।

অনেক অ্যাপ্লিকেশান শুধুমাত্র একটি একক Firebase প্রকল্প এবং ডিফল্ট সেট আপ শুরু নির্দেশিকা বর্ণিত প্রয়োজন। একাধিক ফায়ারবেস প্রজেক্ট ব্যবহার করা কখন উপযোগী হতে পারে তার উদাহরণগুলির মধ্যে রয়েছে:

  • বিল্ড টাইপ বা টার্গেটের উপর ভিত্তি করে বিভিন্ন ফায়ারবেস প্রজেক্ট ব্যবহার করার জন্য আপনার ডেভেলপমেন্ট এনভায়রনমেন্ট সেট আপ করা।
  • আপনার অ্যাপে একাধিক ফায়ারবেস প্রকল্প থেকে সামগ্রী অ্যাক্সেস করা।

বিভিন্ন পরিবেশ সমর্থন

একটি সাধারণ ব্যবহারের ক্ষেত্রে আপনার উন্নয়ন এবং উত্পাদন পরিবেশের জন্য পৃথক ফায়ারবেস প্রকল্পগুলিকে সমর্থন করা।

ওয়েব এবং অ্যাডমিন SDK গুলিকে তাদের প্রারম্ভিক ফাংশনগুলিতে সরাসরি মানগুলি পাস করে কনফিগার করা হয়৷ এই SDK-এর জন্য, আপনি ডেভেলপমেন্ট বা প্রোডাকশন কনফিগারেশন ভেরিয়েবল নির্বাচন করতে রানটাইম চেক ব্যবহার করতে পারেন।

Android এবং Apple প্ল্যাটফর্মের (এবং তাদের ঐক্য এবং সি ++ চাদরে) সাধারণত একটি কনফিগারেশন ফাইল থেকে কনফিগারেশন লোড: GoogleService-Info.plist অ্যাপল প্ল্যাটফর্মের উপর এবং google-services.json Android এর উপর। এই ফাইলগুলি একটি অপশন বস্তু (মধ্যে পড়া হয় FIROption বা FirebaseOptions ) যে Firebase আবেদন বস্তু (দ্বারা উল্লেখ করা হয় FIRApp বা FirebaseApp )।

এই প্ল্যাটফর্মগুলির জন্য, প্রতিটি পরিবেশের জন্য বিভিন্ন কনফিগারেশন ফাইল ব্যবহারের মাধ্যমে পরিবেশের মধ্যে স্যুইচিং সাধারণত একটি বিল্ড টাইম সিদ্ধান্ত হিসাবে প্রয়োগ করা হয়।

আপনার অ্যাপল অ্যাপ্লিকেশনে একাধিক পরিবেশ সমর্থন করুন

ডিফল্টরূপে, FirebaseApp.configure() লোড করা হবে GoogleService-Info.plist ফাইল আবেদন সঙ্গে bundled। যদি আপনার বিকাশ এবং উত্পাদন পরিবেশগুলি Xcode-এ পৃথক লক্ষ্য হিসাবে কনফিগার করা হয়, আপনি করতে পারেন:

  • ডাউনলোড উভয় GoogleService-Info.plist ফাইল
  • দুটি ফাইল বিভিন্ন ডিরেক্টরিতে সংরক্ষণ করুন
  • আপনার Xcode প্রকল্পে উভয় যোগ করুন
  • টার্গেট মেম্বারশিপ প্যানেল ব্যবহার করে বিভিন্ন টার্গেটের সাথে বিভিন্ন ফাইল সংযুক্ত করুন:

লক্ষ্য সদস্যতা প্যানেল

তৈরী করে একটি একক লক্ষ্য অংশ হন, সবচেয়ে ভাল বিকল্প উভয় কনফিগারেশন ফাইল অনন্য নাম (যেমন দিতে হয় GoogleService-Info-Free.plist এবং GoogleService-Info-Paid.plist )। তারপর রানটাইমে কোন plist লোড করতে হবে তা বেছে নিন। এটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:

// Load a named file.
let filePath = Bundle.main.path(forResource: "MyGoogleService", ofType: "plist")
guard let fileopts = FirebaseOptions(contentsOfFile: filePath!)
  else { assert(false, "Couldn't load config file") }
FirebaseApp.configure(options: fileopts)

আপনার অ্যান্ড্রয়েড অ্যাপ্লিকেশনে একাধিক পরিবেশ সমর্থন করুন

অ্যান্ড্রয়েড সালে google-service.json ফাইল Google পরিষেবাগুলি gradle প্লাগইন দ্বারা অ্যান্ড্রয়েড স্ট্রিং সম্পদ প্রক্রিয়াকরণ করা যায়। আপনি দেখতে পারেন যা সম্পদের উপর Google পরিষেবাগুলি প্লাগইন ডকুমেন্টেশনে নির্মিত প্রসেসিং JSON ফাইল

আপনি একাধিক থাকতে পারে google-services.json বিভিন্ন ফাইল বিল্ড রূপগুলো স্থাপন দ্বারা google-services.json অ্যাপ্লিকেশন মডিউল রুট অধীনে প্রতিটি ভেরিয়েন্ট নামকরণ ডেডিকেটেড ডিরেক্টরিগুলি থেকে ফাইলগুলিকে। উদাহরণস্বরূপ, যদি আপনার "উন্নয়ন" এবং "রিলিজ" বিল্ড ফ্লেভার থাকে, তাহলে আপনার কনফিগারেশন এইভাবে সংগঠিত হতে পারে:

app/
    google-services.json
    src/development/google-services.json
    src/release/google-services.json
    ...

আরো জানতে, Google পরিষেবাগুলি প্লাগইন ডকুমেন্টেশন দেখুন JSON ফাইল যোগ করার পদ্ধতি

এই সংস্থানগুলি তারপর লোড করা হয় FirebaseInitProvider , যা আপনার আবেদন কোড সামনে চলে এবং সূচনা যারা মান ব্যবহার Firebase API গুলি।

যেহেতু এই প্রদানকারী শুধুমাত্র পরিচিত নাম দিয়ে রিসোর্স পড়ছেন, অন্য একটি বিকল্প হল Google পরিষেবা গ্রেডল প্লাগইন ব্যবহার করার পরিবর্তে সরাসরি আপনার অ্যাপে স্ট্রিং রিসোর্স যোগ করা। আপনি এটি দ্বারা এটি করতে পারেন:

  • সরানো হচ্ছে google-services আপনার রুট থেকে প্লাগ ইন build.gradle
  • মুছে ফেলা হচ্ছে google-services.json আপনার প্রকল্প থেকে
  • সরাসরি স্ট্রিং সংস্থান যোগ করা হচ্ছে
  • একবার মুছে apply plugin: 'com.google.gms.google-services' আপনার অ্যাপ্লিকেশান থেকে build.gradle

আপনার অ্যাপ্লিকেশন একাধিক প্রকল্প ব্যবহার করুন

কখনও কখনও আপনাকে একই API ব্যবহার করে বিভিন্ন প্রকল্প অ্যাক্সেস করতে হবে - উদাহরণস্বরূপ, একাধিক ডাটাবেস উদাহরণ অ্যাক্সেস করা। বেশিরভাগ ক্ষেত্রেই একটি কেন্দ্রীয় ফায়ারবেস অ্যাপ্লিকেশন অবজেক্ট থাকে যা সমস্ত Firebase API-এর কনফিগারেশন পরিচালনা করে। এই বস্তুটি আপনার স্বাভাবিক সেটআপের অংশ হিসাবে আরম্ভ করা হয়েছে। যাইহোক, যখন আপনি একটি একক অ্যাপ্লিকেশন থেকে একাধিক প্রকল্প অ্যাক্সেস করতে চান, প্রতিটিকে পৃথকভাবে উল্লেখ করার জন্য আপনাকে একটি স্বতন্ত্র Firebase অ্যাপ্লিকেশন অবজেক্টের প্রয়োজন হবে। এই অন্যান্য দৃষ্টান্তগুলি শুরু করা আপনার উপর নির্ভর করে।

উভয় ক্ষেত্রেই, Firebase অ্যাপ্লিকেশনের কনফিগারেশন ডেটা ধরে রাখতে আপনাকে প্রথমে একটি Firebase অপশন অবজেক্ট তৈরি করতে হবে। বিকল্পগুলির জন্য সম্পূর্ণ ডকুমেন্টেশন নিম্নলিখিত ক্লাসগুলির জন্য API রেফারেন্স ডকুমেন্টেশনে পাওয়া যাবে:

একটি অ্যাপ্লিকেশনে একাধিক প্রকল্প সমর্থন করার জন্য এই ক্লাসগুলির ব্যবহার নিম্নলিখিত উদাহরণগুলিতে দেখানো হয়েছে:

সুইফট

// Configure with manual options. Note that projectID and apiKey, though not
// required by the initializer, are mandatory.
let secondaryOptions = FirebaseOptions(googleAppID: "1:27992087142:ios:2a4732a34787067a",
                                       gcmSenderID: "27992087142")
secondaryOptions.apiKey = "AIzaSyBicqfAZPvMgC7NZkjayUEsrepxuXzZDsk"
secondaryOptions.projectID = "projectid-12345"

// The other options are not mandatory, but may be required
// for specific Firebase products.
secondaryOptions.bundleID = "com.google.firebase.devrel.FiroptionConfiguration"
secondaryOptions.trackingID = "UA-12345678-1"
secondaryOptions.clientID = "27992087142-ola6qe637ulk8780vl8mo5vogegkm23n.apps.googleusercontent.com"
secondaryOptions.databaseURL = "https://myproject.firebaseio.com"
secondaryOptions.storageBucket = "myproject.appspot.com"
secondaryOptions.androidClientID = "12345.apps.googleusercontent.com"
secondaryOptions.deepLinkURLScheme = "myapp://"
secondaryOptions.storageBucket = "projectid-12345.appspot.com"
secondaryOptions.appGroupID = nil

জাভা

// Manually configure Firebase Options. The following fields are REQUIRED:
//   - Project ID
//   - App ID
//   - API Key
FirebaseOptions options = new FirebaseOptions.Builder()
        .setProjectId("my-firebase-project")
        .setApplicationId("1:27992087142:android:ce3b6448250083d1")
        .setApiKey("AIzaSyADUe90ULnQDuGShD9W23RDP0xmeDc6Mvw")
        // setDatabaseURL(...)
        // setStorageBucket(...)
        .build();

কোটলিন+কেটিএক্স

// Manually configure Firebase Options. The following fields are REQUIRED:
//   - Project ID
//   - App ID
//   - API Key
val options = FirebaseOptions.Builder()
        .setProjectId("my-firebase-project")
        .setApplicationId("1:27992087142:android:ce3b6448250083d1")
        .setApiKey("AIzaSyADUe90ULnQDuGShD9W23RDP0xmeDc6Mvw")
        // .setDatabaseUrl(...)
        // .setStorageBucket(...)
        .build()

ওয়েব

// The following fields are REQUIRED:
//  - Project ID
//  - App ID
//  - API Key
const secondaryAppConfig = {
    projectId: "<PROJECT_ID>",
    appId: "<APP_ID>",
    apiKey: "<API_KEY>",
    // databaseURL: "...",
    // storageBucket: "...",
};

সি++

firebase::AppOptions secondary_app_options;

// API key, app ID, and project ID are always required.
secondary_app_options.set_api_key("<API_KEY>");
secondary_app_options.set_app_id("<GOOGLE_APP_ID>");
secondary_app_options.set_project_id("<PROJECT_ID>");

// The following options are specific to individual Firebase products
// and may not always be required.
secondary_app_options.set_database_url("<DATABASE_URL>");
secondary_app_options.set_messaging_sender_id("<SENDER_ID>");
secondary_app_options.set_storage_bucket("<STORAGE_BUCKET>");

ঐক্য

Firebase.AppOptions secondaryAppOptions = new Firebase.AppOptions {
  ApiKey = "<API_KEY>",
  AppId = "<GOOGLE_APP_ID>",
  ProjectId = "<PROJECT_ID>"
};

Node.js

const secondaryServiceAccount = require('./path/to/serviceAccountKey.json');

// All required options are specified by the service account,
// add service-specific configuration like databaseURL as needed.
const secondaryAppConfig = {
    credential: cert(secondaryServiceAccount),
    // databaseURL: 'https://<DATABASE_NAME>.firebaseio.com'
};

জাভা

FileInputStream serviceAccount = new FileInputStream("path/to/serviceAccountKey.json");

FirebaseOptions secondaryAppConfig = new FirebaseOptions.Builder()
  .setCredential(FirebaseCredentials.fromCertificate(serviceAccount))
  .setDatabaseUrl("https://<DATABASE_NAME>.firebaseio.com/")
  .build();

আপনি এই অপশন অবজেক্ট শুরু করার পরে, আপনি এটি একটি অতিরিক্ত ফায়ারবেস অ্যাপ্লিকেশন ইন্সট্যান্স কনফিগার করতে ব্যবহার করতে পারেন। নোট করুন যে সমস্ত আমরা নিচে দেখানো উদাহরণ স্ট্রিং মাধ্যমিক ব্যবহার করুন। এই নামটি আবেদন উদাহরণস্বরূপ পুনরুদ্ধার করতে এবং ডিফল্ট উদাহরণস্বরূপ সহ অন্যান্য দৃষ্টান্ত, থেকে আলাদা করার জন্য ব্যবহার করা হয় (নামে [ডিফল্ট])। অন্য ফায়ারবেস প্রকল্পের উদ্দেশ্যে ব্যবহারের জন্য আপনার উপযুক্ত একটি স্ট্রিং বাছাই করা উচিত।

নিম্নলিখিত স্নিপেটগুলি একটি বিকল্প রিয়েলটাইম ডেটাবেসের সাথে সংযোগ প্রদর্শন করে (অন্যান্য Firebase বৈশিষ্ট্যগুলির জন্য APIগুলি একই প্যাটার্ন অনুসরণ করে)।

সুইফট

// Configure an alternative FIRApp.
FirebaseApp.configure(name: "secondary", options: secondaryOptions)

// Retrieve a previous created named app.
guard let secondary = FirebaseApp.app(name: "secondary")
  else { assert(false, "Could not retrieve secondary app") }


// Retrieve a Real Time Database client configured against a specific app.
let secondaryDb = Database.database(app: secondary)

জাভা

// Initialize with secondary app
FirebaseApp.initializeApp(this /* Context */, options, "secondary");

// Retrieve secondary FirebaseApp
FirebaseApp secondary = FirebaseApp.getInstance("secondary");

কোটলিন+কেটিএক্স

// Initialize secondary FirebaseApp.
Firebase.initialize(this /* Context */, options, "secondary")

// Retrieve secondary FirebaseApp.
val secondary = Firebase.app("secondary")
// Get the database for the other app.
val secondaryDatabase = Firebase.database(secondary)

ওয়েব

// Initialize another app with a different config
const secondaryApp = firebase.initializeApp(secondaryAppConfig, "secondary");
// Access services, such as the Realtime Database
// secondaryApp.database();

সি++

firebase::App* secondary_app = firebase::App::Create(secondary_app_options, "Secondary");
firebase::database::Database* secondary_database = firebase::database::Database::GetInstance(secondary_app);

ঐক্য

var secondaryApp = Firebase.FirebaseApp.Create(secondaryAppOptions, "Secondary"));
var secondaryDatabase = Firebase.Database.FirebaseDatabase.getInstance(secondaryApp);

Node.js

// Initialize another app with a different config
const secondary = initializeApp(secondaryAppConfig, 'secondary');
// Access services, such as the Realtime Database
// const secondaryDatabase = secondary.database();

জাভা

// Initialize another app with a different config
FirebaseApp secondaryApp = FirebaseApp.initializeApp(secondaryAppConfig, "secondary");

// Retrieve the database.
FirebaseDatabase secondaryDatabase = FirebaseDatabase.getInstance(secondaryApp);

বিশ্লেষণের জন্য নির্ভরযোগ্য রিপোর্টিং নিশ্চিত করুন

Google Analytics অ্যাপ স্টার্ট আপ ফ্লোতে খুব তাড়াতাড়ি ইভেন্টগুলি সংগ্রহ করে, কিছু ক্ষেত্রে প্রাথমিক ফায়ারবেস অ্যাপ ইন্সট্যান্স কনফিগার হওয়ার আগে। এইসব ক্ষেত্রে, Firebase অ্যান্ড্রয়েড রিসোর্স বা বোঝায় GoogleService-Info.plist দোকান ঘটনা সঠিক Google অ্যাপ্লিকেশান আইডি সন্ধান করার অ্যাপল প্ল্যাটফর্মের উপর। এই কারণে, আমরা যেখানেই সম্ভব ডিফল্ট কনফিগারেশন পদ্ধতি ব্যবহার করার পরামর্শ দিই।

রানটাইম কনফিগারেশন প্রয়োজন হলে, নিম্নলিখিত সতর্কতা নোট করুন:

  1. আপনি যদি AdMob ব্যবহার করেন এবং প্রস্তাবিত হিসাবে স্টার্টআপে বিজ্ঞাপনের অনুরোধ করেন, তাহলে সম্পদ ভিত্তিক কনফিগারেশন পদ্ধতি ব্যবহার না করার সময় আপনি মোবাইল বিজ্ঞাপনের সাথে সম্পর্কিত কিছু Analytics ডেটা মিস করতে পারেন।
  2. আপনার অ্যাপের প্রতিটি বিতরণ করা ভেরিয়েন্টে শুধুমাত্র একটি Google অ্যাপ আইডি সরবরাহ করুন। উদাহরণস্বরূপ, যদি আপনি একটি নির্দিষ্ট সঙ্গে আপনার অ্যাপের সংস্করণ 1 অর্ণবপোত GOOGLE_APP_ID কনফিগারেশন তারপর একটি ভিন্ন আইডি দিয়ে আপলোড সংস্করণ 2, এটা হতে পারে Analytics ডেটা বাদ দেয়া হবে।
  3. অ্যাপল প্ল্যাটফর্মে GoogleService-Info.plist আপনার প্রকল্পের যদি আপনি রান সময়ে বিভিন্ন কনফিগারেশন সরবরাহ করছে, এই আপাত পরিবর্তন ঘটাতে পারে না জোড়েন GOOGLE_APP_ID এবং হারিয়ে অ্যানালিটিক্স স্থাপিত।