Firebase রিমোট কনফিগারেশনের সাথে আপনার Firebase AI লজিক অ্যাপকে গতিশীলভাবে আপডেট করুন

আপনার অ্যাপ থেকে Firebase AI Logic SDK ব্যবহার করে Gemini API কল করার সময়, আপনার অনুরোধে বেশ কিছু প্যারামিটার থাকে যা জেনারেটিভ AI প্রতিক্রিয়া নিয়ন্ত্রণ করে। এগুলোর মধ্যে সাধারণত মডেলের নাম, মডেল তৈরির কনফিগারেশন (সর্বোচ্চ টোকেন, তাপমাত্রা, ইত্যাদি), সুরক্ষা সেটিংস, সিস্টেম নির্দেশাবলী এবং প্রম্পট ডেটা অন্তর্ভুক্ত থাকে।

বেশিরভাগ ক্ষেত্রে, বিভিন্ন পরিস্থিতিতে প্রয়োজন অনুযায়ী বা চাহিদামাফিক আপনি এগুলো পরিবর্তন করতে চাইবেন:

  • নতুন কোনো অ্যাপ প্রকাশ না করেই আপনার জেনারেটিভ এআই মডেল আপডেট করুন। আগের সংস্করণগুলো বন্ধ হয়ে যাওয়ার আগেই আপনি নতুন ও স্থিতিশীল মডেল সংস্করণে আপগ্রেড করতে পারেন, আপনার ব্যবহারকারীদের প্রয়োজন ও বৈশিষ্ট্যের ওপর ভিত্তি করে কম খরচের বা উচ্চ পারফরম্যান্সের মডেলে যেতে পারেন, অথবা শর্তসাপেক্ষে সর্বাধুনিক ও সেরা মডেলগুলো নির্দিষ্ট ব্যবহারকারী গোষ্ঠীর (যেমন বিটা টেস্টার) জন্য চালু করতে পারেন।
  • মডেলটি অ্যাক্সেস করার অবস্থান এমনভাবে সেট করুন যাতে এটি আপনার ব্যবহারকারীদের কাছাকাছি থাকে।
  • বিভিন্ন সিস্টেম নির্দেশাবলী এবং প্রম্পট A/B টেস্ট করুন, তারপর বিজয়ী পরীক্ষার মানগুলি ধীরে ধীরে আপনার ব্যবহারকারীদের কাছে চালু করুন।
  • আপনার অ্যাপে জেনারেটিভ এআই ফিচারগুলো দ্রুত প্রকাশ বা গোপন করতে ফিচার ফ্ল্যাগ ব্যবহার করুন।

Firebase Remote Config এই সবকিছু এবং আরও অনেক কিছু করে, যা আপনাকে আপনার অ্যাপের নতুন সংস্করণ প্রকাশ না করেই, Firebase কনসোলে সেট করা বৈশিষ্ট্যগুলির সাথে মেলে এমন অ্যাপ ইনস্ট্যান্সগুলির জন্য প্রয়োজন অনুযায়ী এবং শর্তসাপেক্ষে প্যারামিটারের মান আপডেট করার সুযোগ দেয়।

এই সমাধান নির্দেশিকাটি নির্দিষ্ট প্রস্তাবিত ব্যবহারের ক্ষেত্রসমূহ প্রদান করে এবং আপনার জেনারেটিভ এআই অ্যাপে কীভাবে Remote Config যোগ করতে হয় তা বর্ণনা করে।

কোড বাস্তবায়নে যান

আপনার অ্যাপের সাথে Firebase Remote Config কেন ব্যবহার করবেন?

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

জেনারেটিভ এআই অ্যাপের সাথে Remote Config অপরিহার্য ব্যবহারসমূহ

নিম্নলিখিত অপরিহার্য ব্যবহারের ক্ষেত্রগুলিতে আমরা Firebase AI Logic-এর সাথে Remote Config ব্যবহার করার পরামর্শ দিই:

  • অ্যাপ আপডেট ছাড়াই সর্বশেষ মডেল সংস্করণে আপগ্রেড করুন : প্রয়োজন অনুযায়ী মডেলের নাম পরিবর্তন করতে Remote Config প্যারামিটার ব্যবহার করুন, যাতে আপনার পছন্দের জেমিনি মডেলের সর্বশেষ সংস্করণটি উপলব্ধ হওয়া মাত্রই আপনি সেটিতে আপগ্রেড করতে পারেন।

  • অ্যাপ আপডেট ছাড়াই সিস্টেমের নির্দেশাবলী এবং সুরক্ষা সেটিংস আপডেট করুন : সিস্টেমের নির্দেশাবলী এবং সুরক্ষা সেটিংস Remote Config প্যারামিটারের ভিতরে সংরক্ষণ করুন, যাতে ডেপ্লয়মেন্টের পরে কোনো সমস্যা খুঁজে পেলে আপনি প্রয়োজন অনুযায়ী সেগুলি পরিবর্তন করতে পারেন।

  • ঝুঁকি হ্রাস করুন এবং এআই নিরাপত্তা নিশ্চিত করুন : আপনার iOS এবং Android ব্যবহারকারীদের কাছে জেনারেটিভ এআই পরিবর্তনগুলি নিরাপদে এবং পর্যায়ক্রমে প্রকাশ করতে Remote Config রোলআউট ব্যবহার করুন।

জেনারেটিভ এআই অ্যাপের সাথে Remote Config উন্নত এবং প্রস্তাবিত ব্যবহারসমূহ

আপনার অ্যাপে Remote Config এবং Google Analytics যুক্ত করার পর, আপনি এর উন্নত ব্যবহারগুলো অন্বেষণ করতে পারেন:

  • ক্লায়েন্টের অবস্থানের উপর ভিত্তি করে অবস্থান নির্ধারণ করুন : ক্লায়েন্টের শনাক্ত করা অবস্থানের উপর ভিত্তি করে মডেলটি অ্যাক্সেস করার অবস্থান নির্ধারণ করতে Remote Config শর্তাবলী ব্যবহার করুন।

  • বিভিন্ন মডেল নিয়ে পরীক্ষা করুন : আপনার নির্দিষ্ট ব্যবহারের জন্য সবচেয়ে উপযুক্ত মডেলটি খুঁজে পেতে, দ্রুত বিভিন্ন জেনারেটিভ এআই মডেল পরীক্ষা করুন ও সেগুলোর মধ্যে পরিবর্তন করুন, অথবা বিভিন্ন ব্যবহারকারী গোষ্ঠীর জন্য ভিন্ন ভিন্ন মডেল ব্যবহার করুন।

  • মডেলের কর্মক্ষমতা অপ্টিমাইজ করুন : সিস্টেম প্রম্পট, সর্বোচ্চ আউটপুট টোকেন, তাপমাত্রা এবং অন্যান্য সেটিংসের মতো মডেলের প্যারামিটারগুলো সূক্ষ্মভাবে সমন্বয় করুন।

  • ক্লায়েন্ট অ্যাট্রিবিউটের উপর ভিত্তি করে ভিন্ন সিস্টেম নির্দেশাবলী, প্রম্পট এবং মডেল কনফিগারেশন ব্যবহার করুন : Google Analytics সাথে Remote Config ব্যবহার করার সময়, আপনি ক্লায়েন্ট অ্যাট্রিবিউট বা কাস্টম অডিয়েন্সের উপর ভিত্তি করে শর্ত তৈরি করতে পারেন এবং এই অ্যাট্রিবিউটগুলোর উপর ভিত্তি করে বিভিন্ন প্যারামিটার সেট করতে পারেন।

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

  • প্রতিটি ব্যবহারকারীর জন্য অভিজ্ঞতা ব্যক্তিগতকরণ করুন : আপনার মোবাইল অ্যাপ এবং গেমগুলিতে Remote Config পার্সোনালাইজেশন ব্যবহার করে প্রতিটি ব্যবহারকারীর জন্য সর্বোত্তম জেনারেটিভ এআই সেটিংস স্বয়ংক্রিয়ভাবে নির্ধারণ করুন।

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

  • অ্যাপের অভিজ্ঞতা ও ফলাফল উন্নত করুন : আপনার মোবাইল অ্যাপ ও গেমে Remote Config সহ A/B Testing ব্যবহার করে বিভিন্ন ব্যবহারকারী গোষ্ঠীর মধ্যে জেনারেটিভ এআই প্যারামিটারের পরিবর্তন পরীক্ষা করুন এবং দেখুন কীভাবে তা রিটেনশন ও রেভিনিউ-এর মতো মূল মেট্রিকগুলোকে প্রভাবিত করে।

Firebase Remote Config সাহায্যে আপনার জেনারেটিভ এআই অ্যাপকে ইন্সট্রুমেন্টেশন করে, আপনি নমনীয়, নিরাপদ এবং সাশ্রয়ী এআই-চালিত অ্যাপ্লিকেশন তৈরি করতে পারেন এবং একই সাথে আপনার ব্যবহারকারীদের জন্য আনন্দদায়ক অভিজ্ঞতা তৈরি করতে পারেন।

আপনার অ্যাপে Firebase Remote Config যোগ করুন

এই সমাধান নির্দেশিকায়, আপনি Firebase AI Logic SDK ব্যবহার করে আপনার অ্যাপের প্যারামিটারগুলো ডায়নামিকভাবে আপডেট করতে Firebase Remote Config ব্যবহার করবেন। আপনি শিখবেন কীভাবে:

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

পূর্বশর্ত

এই নির্দেশিকাটি ধরে নেয় যে আপনি আপনার প্ল্যাটফর্মের জন্য অ্যাপ তৈরি করতে পরিচিত।

শুরু করার আগে, নিম্নলিখিত বিষয়গুলো নিশ্চিত করে নিন:

  • Firebase AI Logic গেটিং স্টার্টেড গাইডটি সম্পূর্ণ করুন, যেখানে আপনার Firebase প্রজেক্ট সেট আপ করা, আপনার অ্যাপকে Firebase-এর সাথে সংযুক্ত করা, SDK যোগ করা, আপনার নির্বাচিত " Gemini API " প্রোভাইডারের জন্য ব্যাকএন্ড সার্ভিস ইনিশিয়ালাইজ করা এবং একটি মডেল ইনস্ট্যান্স তৈরি করার পদ্ধতি বর্ণনা করা হয়েছে।

  • আপনার Firebase প্রজেক্টে Google Analytics সক্রিয় করুন এবং আপনার অ্যাপে এর SDK যোগ করুন (শর্তসাপেক্ষ টার্গেটিং-এর জন্য এটি আবশ্যক, যেমন ক্লায়েন্ট ডিভাইসের অবস্থানের উপর ভিত্তি করে মডেলটি অ্যাক্সেস করার স্থান নির্ধারণ করা)।

ধাপ ১ : Firebase কনসোলে প্যারামিটারের মান সেট করুন।

একটি Remote Config ক্লায়েন্ট টেমপ্লেট তৈরি করুন এবং অ্যাপে ডেটা আনা ও ব্যবহারের জন্য প্যারামিটার ও ভ্যালু কনফিগার করুন।

  1. Firebase কনসোলে আপনার Firebase প্রজেক্টটি খুলুন। এরপর, নেভিগেশন মেনু থেকে Run এক্সপ্যান্ড করে Remote Config সিলেক্ট করুন।

  2. পৃষ্ঠার শীর্ষে থাকা ক্লায়েন্ট/সার্ভার নির্বাচক থেকে ক্লায়েন্ট নির্বাচন করা হয়েছে কিনা, তা নিশ্চিত করুন।

  3. Create Configuration-এ ক্লিক করে একটি ক্লায়েন্ট টেমপ্লেট শুরু করুন (অথবা আপনি যদি আগে ক্লায়েন্ট টেমপ্লেট ব্যবহার করে থাকেন তবে Add parameter-এ ক্লিক করুন )।

  4. Remote Config ব্যবহার করে আপনি যে প্যারামিটারগুলো নিয়ন্ত্রণ করতে চান, তা নির্ধারণ করুন। উদাহরণস্বরূপ:

    প্যারামিটার নাম বর্ণনা প্রকার ডিফল্ট মান
    model_name মডেলের নাম। উপলব্ধ মডেলের নামগুলো দেখুন। স্ট্রিং gemini-2.5-flash
    system_instructions সিস্টেম নির্দেশাবলী হলো একটি 'ভূমিকার' মতো, যা মডেলের আচরণকে প্রভাবিত করার জন্য অন্তিম ব্যবহারকারীর কাছ থেকে পরবর্তী কোনো নির্দেশাবলী পাওয়ার আগে মডেলে যোগ করা হয়। স্ট্রিং You are a helpful assistant who knows everything there is to know about Firebase!
    prompt আপনার জেনারেটিভ এআই ফিচারের সাথে ব্যবহারের জন্য ডিফল্ট প্রম্পট। স্ট্রিং I am a developer who wants to know more about Firebase!
    vertex_location শুধুমাত্র Vertex AI Gemini API ব্যবহার করার ক্ষেত্রেই প্রযোজ্য।
    মডেলটি অ্যাক্সেস করার অবস্থান নিয়ন্ত্রণ করুন। Google Analytics দ্বারা শনাক্তকৃত ক্লায়েন্টের অবস্থানের উপর ভিত্তি করে এই বিকল্পটি কনফিগার করতে আপনি শর্তাবলী নির্ধারণ করতে পারেন।
    স্ট্রিং global
  5. প্যারামিটার যোগ করা শেষ হলে, 'পরিবর্তনগুলি প্রকাশ করুন' (Publish changes ) বোতামে ক্লিক করুন। যদি এটি একটি নতুন Remote Config টেমপ্লেট না হয়, তবে পরিবর্তনগুলি পর্যালোচনা করুন এবং আবার 'পরিবর্তনগুলি প্রকাশ করুন' (Publish changes) বোতামে ক্লিক করুন।

ধাপ ২ : আপনার অ্যাপে Remote Config যোগ করুন এবং চালু করুন।

Remote Config লাইব্রেরিটি যোগ করুন এবং আপনার অ্যাপের মধ্যে Remote Config সেট আপ করুন।

সুইফট

Firebase AI Logic সেটআপের অংশ হিসেবে, আপনি ইতিমধ্যেই আপনার অ্যাপে Firebase SDK যোগ করেছেন, কিন্তু আপনাকে Remote Config ও যোগ করতে হবে।

  1. Xcode-এ, প্রজেক্টটি খোলা থাকা অবস্থায়, File > Add Package Dependencies -এ যান।

  2. firebase-ios-sdk নির্বাচন করুন এবং তারপরে 'Add package'-এ ক্লিক করুন।

  3. প্রজেক্ট নেভিগেটর থেকে, আপনার অ্যাপ > টার্গেট > আপনার অ্যাপ নির্বাচন করুন।

  4. জেনারেল ট্যাব থেকে ফ্রেমওয়ার্কস, লাইব্রেরিস এবং এমবেডেড কন্টেন্ট পর্যন্ত স্ক্রল করুন।

  5. + এ ক্লিক করুন এবং FirebaseRemoteConfig বেছে নিন, তারপর Add এ ক্লিক করুন।

  6. আপনার কোডে FirebaseRemoteConfig ইম্পোর্টটি যোগ করুন:

    import FirebaseRemoteConfig
    
  7. আপনার অ্যাপের জন্য উপযুক্ত ক্লাসের ভিতরে Firebase ইনিশিয়ালাইজ করুন এবং আপনার মূল অ্যাপ্লিকেশন লজিকে Remote Config যোগ করুন।

    এখানে, আপনি Remote Config এবং Remote Config রিয়েল-টাইম লিসেনারকে ইম্পোর্ট হিসেবে অন্তর্ভুক্ত করবেন, যাতে অ্যাপটি রিয়েল-টাইমে নতুন ভ্যালু ফেচ করতে পারে, এবং একটি ন্যূনতম ফেচ ইন্টারভাল যোগ করবেন:

    let remoteConfig = RemoteConfig.remoteConfig()
    let settings = RemoteConfigSettings()
    settings.minimumFetchInterval = 3600
    remoteConfig.configSettings = settings
    

    কুইকস্টার্ট অ্যাপে , এটি VertexAISampleApp ভিতরে AppDelegate ক্লাসের মধ্যে থাকবে।

Kotlin

  1. আপনার মডিউল (অ্যাপ-লেভেল) গ্রেডল ফাইলে (সাধারণত app/build.gradle.kts বা app/build.gradle ) Remote Config ডিপেন্ডেন্সিটি যোগ করুন:

    dependencies {
        implementation(platform("com.google.firebase:firebase-bom:34.11.0"))
        implementation("com.google.firebase:firebase-ai")
        implementation("com.google.firebase:firebase-config")
        // ... other dependencies
    }
    
  2. আপনার মূল অ্যাপ্লিকেশন লজিকে Remote Config যোগ করুন। এখানে, আপনি Remote Config ইনিশিয়ালাইজ করবেন এবং একটি ন্যূনতম ফেচ ইন্টারভাল যোগ করবেন:

    val remoteConfig: FirebaseRemoteConfig = Firebase.remoteConfig
    val configSettings = remoteConfigSettings {
    minimumFetchIntervalInSeconds = 3600
    }
    remoteConfig.setConfigSettingsAsync(configSettings)
    

Java

  1. আপনার মডিউল (অ্যাপ-লেভেল) গ্রেডল ফাইলে (সাধারণত app/build.gradle.kts বা app/build.gradle ) Remote Config ডিপেন্ডেন্সিটি যোগ করুন:

    dependencies {
        implementation(platform("com.google.firebase:firebase-bom:34.11.0"))
        implementation("com.google.firebase:firebase-ai")
        implementation("com.google.firebase:firebase-config")
        // ... other dependencies
    }
    
  2. আপনার মূল অ্যাপ্লিকেশন লজিকে Remote Config যোগ করুন। এখানে, আপনি Remote Config ইনিশিয়ালাইজ করবেন এবং একটি ন্যূনতম ফেচ ইন্টারভাল যোগ করবেন:

    FirebaseRemoteConfig mFirebaseRemoteConfig = FirebaseRemoteConfig.getInstance();
    FirebaseRemoteConfigSettings configSettings = new FirebaseRemoteConfigSettings.Builder()
        .setMinimumFetchIntervalInSeconds(3600)
        .build();
    mFirebaseRemoteConfig.setConfigSettingsAsync(configSettings);
    

Web

  1. আপনার কোডটি একটি টেক্সট এডিটরে খুলুন এবং Remote Config ইম্পোর্ট করুন:

    import { getRemoteConfig } from 'firebase/remote-config';
    
  2. আপনার প্রধান ফাংশনের ভিতরে এবং Firebase AI Logic SDK-এর জন্য Firebase অ্যাপটি ইনিশিয়ালাইজ করার পরে, Remote Config ইনিশিয়ালাইজ করুন:

      // Initialize Remote Config and get a reference to the service
      const remoteConfig = getRemoteConfig(app);
    
  3. সর্বনিম্ন ফেচ ব্যবধান সেট করুন:

    remoteConfig.settings.minimumFetchIntervalMillis = 3600000;
    

Dart

  1. আপনার ফ্লাটার প্রজেক্ট ডিরেক্টরি থেকে, নিম্নলিখিত কমান্ডটি ব্যবহার করে Remote Config ইনস্টল ও যুক্ত করুন:

    flutter pub add firebase_remote_config
    
  2. ./lib/main.dart খুলুন এবং Firebase AI Logic সমর্থন করার জন্য আপনার যোগ করা অন্যান্য ইম্পোর্টগুলোর পরে এই ইম্পোর্টটি যোগ করুন:

    import 'package:firebase_vertexai/firebase_ai.dart';
    import 'package:firebase_core/firebase_core.dart';
    import 'package:firebase_remote_config/firebase_remote_config.dart';
    
  3. আপনার অ্যাপে _modelName , _systemInstructions , এবং _prompt ভেরিয়েবলগুলো যোগ করুন, যাতে আপনি পরে সেগুলো ব্যবহার করতে পারেন:

    late final String _modelName;
    late final String _systemInstructions;
    late final String _prompt;
    
  4. Remote Config অবজেক্ট ইনস্ট্যান্সটি নিন এবং ঘন ঘন রিফ্রেশের জন্য ন্যূনতম ফেচ ইন্টারভাল সেট করুন। ফায়ারবেস ইনিশিয়ালাইজ করার পরে এটি যোগ করতে ভুলবেন না।

      final remoteConfig = FirebaseRemoteConfig.instance;
      await remoteConfig.setConfigSettings(RemoteConfigSettings(
        fetchTimeout: const Duration(seconds: 3600),
        minimumFetchInterval: const Duration(seconds: 3600),
      ));
    

ঐক্য

  1. এই নির্দেশাবলী অনুসরণ করে আপনার ইউনিটি প্রজেক্টে Remote Config যোগ করুন।

  2. Remote Config অবজেক্ট ইনস্ট্যান্সটি নিন এবং ঘন ঘন রিফ্রেশের জন্য ন্যূনতম ফেচ ইন্টারভাল সেট করুন। ফায়ারবেস ইনিশিয়ালাইজ করার পরে এটি যোগ করতে ভুলবেন না।

    var remoteConfig = FirebaseRemoteConfig.DefaultInstance;
    const int MillisecondsPerSecond = 1000;
    await remoteConfig.SetConfigSettingsAsync(new ConfigSettings() {
      FetchTimeoutInMilliseconds = 3600 * MillisecondsPerSecond,
      MinimumFetchIntervalInMilliseconds = 3600 * MillisecondsPerSecond
    });
    

ধাপ ৩ : অ্যাপের ভেতরের প্যারামিটার মানগুলো সেট করুন

আপনার Remote Config অবজেক্টে অ্যাপের ভেতরের ডিফল্ট প্যারামিটার মানগুলো সেট করা উচিত। এটি নিশ্চিত করে যে, আপনার অ্যাপটি Remote Config সার্ভিস থেকে মান সংগ্রহ করতে না পারলেও প্রত্যাশিতভাবে কাজ করবে।

সুইফট

  1. Firebase কনসোলে, Remote Config খুলুন।

  2. প্যারামিটার ট্যাবে, মেনুটি খুলুন এবং 'Download default values' নির্বাচন করুন।

  3. নির্দেশিত হলে, iOS-এর জন্য .plist সক্রিয় করুন, তারপর 'Download file'-এ ক্লিক করুন।

  4. ফাইলটি আপনার অ্যাপ্লিকেশন ডিরেক্টরিতে সংরক্ষণ করুন।

    স্যাম্পল অ্যাপটি ব্যবহার করলে, এটি FirebaseVertexAI/Sample/VertexAISample মধ্যে সেভ করুন।

  5. Xcode-এ, আপনার অ্যাপের উপর রাইট-ক্লিক করুন এবং Add Files নির্বাচন করুন।

    স্যাম্পলটি ব্যবহার করতে চাইলে, VertexAISample-এর উপর রাইট-ক্লিক করুন এবং Add Files to "VertexAISample" নির্বাচন করুন।

  6. remote_config_defaults.plist নির্বাচন করুন, তারপর Add-এ ক্লিক করুন।

  7. ডিফল্ট ফাইলটি উল্লেখ করার জন্য আপনার অ্যাপ কোড আপডেট করুন:

    // Set default values for Remote Config parameters.
    remoteConfig.setDefaults(fromPlist: "remote_config_defaults")
    

Kotlin

  1. Firebase কনসোল থেকে Remote Config খুলুন।

  2. প্যারামিটার ট্যাবে, মেনুটি খুলুন এবং 'Download default values' নির্বাচন করুন।

  3. নির্দেশিত হলে, Android-এর জন্য .xml সক্রিয় করুন, তারপর 'Download file'-এ ক্লিক করুন।

  4. ফাইলটি আপনার অ্যাপের XML রিসোর্স ডিরেক্টরিতে সংরক্ষণ করুন।

  5. আপনার পূর্বে যোগ করা configSettings পরে ডিফল্টগুলো যোগ করতে আপনার প্রধান অ্যাক্টিভিটি ফাইলটি আপডেট করুন:

    // Set default values for Remote Config parameters.
    remoteConfig.setDefaultsAsync(R.xml.remote_config_defaults)
    

Java

  1. Firebase কনসোলে, Remote Config খুলুন।

  2. প্যারামিটার ট্যাবে, মেনুটি খুলুন এবং 'Download default values' নির্বাচন করুন।

  3. নির্দেশিত হলে, Android-এর জন্য .xml সক্রিয় করুন, তারপর 'Download file'-এ ক্লিক করুন।

  4. ফাইলটি আপনার অ্যাপের XML রিসোর্স ডিরেক্টরিতে সংরক্ষণ করুন।

  5. আপনার পূর্বে যোগ করা configSettings পরে ডিফল্টগুলো যোগ করতে আপনার প্রধান অ্যাক্টিভিটি ফাইলটি আপডেট করুন:

    // Set default values for Remote Config parameters.
    mFirebaseRemoteConfig.setDefaultsAsync(R.xml.remote_config_defaults);
    

Web

আপনি আপনার কোডে সরাসরি ডিফল্ট মানগুলো সেট করতে পারেন:

// Set default values for Remote Config parameters.
remoteConfig.defaultConfig = {
  model_name: 'gemini-2.5-flash',
  system_instructions:
    'You are a helpful assistant who knows everything there is to know about Firebase!',
  prompt: 'I am a developer who wants to know more about Firebase!',
  vertex_location: 'global',
};

Dart

আপনি আপনার কোডে সরাসরি ডিফল্ট মানগুলো সেট করতে পারেন:

// Set default values for Remote Config parameters.
remoteConfig.setDefaults(const {
  "model_name": "gemini-2.5-flash",
  "system_instructions": "You are a helpful assistant who knows everything there is to know about Firebase!",
  "prompt": "I am a developer who wants to know more about Firebase!",
  "vertex_location": "global"
});

ঐক্য

আপনি আপনার কোডে সরাসরি ডিফল্ট মানগুলো সেট করতে পারেন:

// Set default values for Remote Config parameters.
await remoteConfig.SetDefaultsAsync(
  new System.Collections.Generic.Dictionary<string, object>() {
    { "model_name", "gemini-2.5-flash" },
    { "system_instructions", "You are a helpful assistant who knows everything there is to know about Firebase!" },
    { "prompt", "I am a developer who wants to know more about Firebase!" },
    { "vertex_location", "global" }
  }
);

ধাপ ৪ : মানগুলি আনুন এবং সক্রিয় করুন

ডিফল্ট মান সেট করার পর, মানগুলো আনতে ও সক্রিয় করতে নিম্নলিখিতটি যোগ করুন।

সুইফট

// Fetch and activate Remote Config values
remoteConfig.fetchAndActivate { status, error in
  if let error = error {
    print("Error fetching Remote Config: \(error.localizedDescription)")
  }
}

যখনই কোনো নতুন Remote Config টেমপ্লেট প্রকাশিত হবে, এটি Remote Config অবজেক্টটিকে আপডেট করবে।

Kotlin

// Fetch and activate Remote Config values
remoteConfig.fetchAndActivate()
      .addOnCompleteListener(this) { task ->
          if (task.isSuccessful) {
              val updated = task.result
              Log.d(TAG, "Remote Config values fetched and activated: $updated")
          } else {
              Log.e(TAG, "Error fetching Remote Config", task.exception)
          }
      }

Java

  // Fetch and activate Remote Config values
  mFirebaseRemoteConfig.fetchAndActivate()
    .addOnCompleteListener(this, new OnCompleteListener<Boolean>() {
        @Override
        public void onComplete(@NonNull Task<Boolean> task) {
            if (task.isSuccessful()) {
                boolean updated = task.getResult();
                Log.d(TAG, "Config params updated: " + updated);
            } else {
                Log.e(TAG, "Error fetching Remote Config", task.exception)
            }
          }
    });

Web

  1. আপনার ইম্পোর্ট তালিকায় getValue এবং fetchAndActivate যোগ করুন:

    import { getValue, fetchAndActivate } from 'firebase/remote-config';
    
  2. সেই কোডটি খুঁজুন যেখানে আপনি ডিফল্ট Remote Config ভ্যালুগুলো নির্দিষ্ট করেন। সেই কোড ব্লকের ঠিক পরেই, কনফিগটি ফেচ ও অ্যাক্টিভেট করতে এবং modelName , systemInstructions , prompt , ও vertexLocation কনস্ট্যান্টগুলোতে ভ্যালু অ্যাসাইন করতে নিম্নলিখিত কোডটি যোগ করুন।

    // Fetch and activate Remote Config.
    try {
      await fetchAndActivate(remoteConfig);
    } catch(err) {
      console.error('Remote Config fetch failed', err);
    }
    
    console.log('Remote Config fetched.');
    
    // Assign Remote Config values.
    const modelName = getValue(remoteConfig, 'model_name').asString();
    const systemInstructions = getValue(remoteConfig, 'system_instructions').asString();
    const prompt = getValue(remoteConfig, 'prompt').asString();
    const vertexLocation = getValue(remoteConfig, 'vertex_location').asString();
    

Dart

// Fetch and activate Remote Config.
remoteConfig.fetchAndActivate();

// Assign Remote Config values.
String? _modelName = remoteConfig.getString("model_name");
String? _systemInstructions = remoteConfig.getString("system_instructions");
String? _prompt = remoteConfig.getString("prompt");
String? _vertexLocation = remoteConfig.getString("vertex_location");

ঐক্য

// Fetch and activate Remote Config values.
await remoteConfig.FetchAndActivateAsync();

ধাপ ৫ : একটি রিয়েল-টাইম Remote Config লিসেনার যোগ করুন

আপনার অ্যাপে একটি রিয়েল-টাইম Remote Config লিসেনার যোগ করুন, যাতে Remote Config টেমপ্লেটে আপনার করা পরিবর্তনগুলো আপডেট হওয়ার সাথে সাথেই ক্লায়েন্টে পৌঁছে যায়।

নিম্নলিখিত কোডটি কোনো প্যারামিটারের মান পরিবর্তিত হলেই Remote Config অবজেক্টটি আপডেট করে।

সুইফট

// Add real-time Remote Config
remoteConfig.addOnConfigUpdateListener { configUpdate, error in
  guard let configUpdate = configUpdate, error == nil else {
    print("Error listening for config updates: \(error?.localizedDescription ?? "No error available")")
    return
  }

  print("Updated keys: \(configUpdate.updatedKeys)")
  remoteConfig.activate { changed, error in
    guard error == nil else {
      print("Error activating config: \(error?.localizedDescription ?? "No error available")")
      return
    }
    print("Activated config successfully")
  }
}

Kotlin

ঐচ্ছিকভাবে, আপনি addOnCompleteListener অ্যাক্টিভেশনের ভিতরে একটি অ্যাকশনও কনফিগার করতে পারেন:

      // Add a real-time Remote Config listener
      remoteConfig.addOnConfigUpdateListener(object : ConfigUpdateListener {
          override fun onUpdate(configUpdate : ConfigUpdate) {
              Log.d(ContentValues.TAG, "Updated keys: " + configUpdate.updatedKeys);
              remoteConfig.activate().addOnCompleteListener {
                  // Optionally, add an action to perform on update here.
              }
          }

          override fun onError(error : FirebaseRemoteConfigException) {
              Log.w(ContentValues.TAG, "Config update error with code: " + error.code, error)
          }
      }

Java

ঐচ্ছিকভাবে, আপনি addOnCompleteListener অ্যাক্টিভেশনের ভিতরে একটি অ্যাকশনও কনফিগার করতে পারেন:

  // Add a real-time Remote Config listener
  remoteConfig.addOnConfigUpdateListener(new ConfigUpdateListener() {
      @Override
      public void onUpdate(ConfigUpdate configUpdate) {
          Log.d(ContentValues.TAG, "Updated keys: " + configUpdate.getUpdatedKeys());
                remoteConfig.activate().addOnCompleteListener(new OnCompleteListener<Boolean>() {
                  @Override
                  public void onComplete(@NonNull Task<Boolean> task) {
                      // Optionally, add an action to perform on update here.
                  }
              });
          }

      @Override
      public void onError(FirebaseRemoteConfigException error) {
          Log.w(ContentValues.TAG, "Config update error with code: " + error.getCode(), error);
      }
  });

Web

 // Add a real-time Remote Config listener
 onConfigUpdate(remoteConfig, {
   next: (configUpdate) => {
      console.log("Updated keys:", configUpdate.getUpdatedKeys());
      if (configUpdate.getUpdatedKeys().has("welcome_message")) {
         activate(remoteConfig).then(() => {
         showWelcomeMessage();
         });
      }
   },
   error: (error) => {
      console.log("Config update error:", error);
   },
   complete: () => {
      console.log("Listening stopped.");
   }
});

Dart

// Add a real-time Remote Config listener
remoteConfig.onConfigUpdated.listen((event) async {
  await remoteConfig.activate();
});

ঐক্য

// Add a real-time Remote Config listener to automatically update whenever
// a new template is published.
// Note: the parameters can be anonymous as they are unused.

remoteConfig.OnConfigUpdateListener += (_, _) => {
  remoteConfig.ActivateAsync();
};

ধাপ ৬ : Remote Config ভ্যালু ব্যবহার করার জন্য জেমিনি এপিআই রিকোয়েস্টগুলো আপডেট করুন।

এই পৃষ্ঠায় প্রদানকারী-নির্দিষ্ট বিষয়বস্তু এবং কোড দেখতে আপনার জেমিনি এপিআই প্রদানকারীর উপর ক্লিক করুন।

এখন যেহেতু Remote Config সম্পূর্ণরূপে কনফিগার করা হয়েছে, আপনার কোড আপডেট করে হার্ড-কোডেড মানগুলির পরিবর্তে Remote Config থেকে প্রাপ্ত মানগুলি ব্যবহার করুন।

সুইফট

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
let vertexLocation = remoteConfig.configValue(forKey: "vertex_location").stringValue
let ai = FirebaseAI.firebaseAI(backend: .vertexAI(location: vertexLocation))

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
let modelName = remoteConfig.configValue(forKey: "model_name").stringValue
let systemInstructions = remoteConfig.configValue(forKey: "system_instructions").stringValue

let model = ai.generativeModel(
  modelName: modelName,
  systemInstruction: ModelContent(role: "system", parts: systemInstructions)
)

// Provide a prompt that contains text
// The text in the prompt will be sourced from Remote Config
let userPrompt = remoteConfig.configValue(forKey: "prompt").stringValue

// To generate text output, call `generateContent` with the text input
let response = try await model.generateContent(userPrompt)
if let text = response.text {
  print(text)
}

Kotlin

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
val ai = Firebase.ai(backend = GenerativeBackend.vertexAI(location = remoteConfig.getString("vertex_location")))

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
val model = ai.generativeModel(
  modelName = remoteConfig.getString("model_name"),
  systemInstruction = content { text(remoteConfig.getString("system_instructions")) }
)

// To generate text output, call `generateContent` with the text input
// The text in the prompt will be sourced from Remote Config
val response = model.generateContent(remoteConfig.getString("prompt"))
print(response.text)

Java

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
FirebaseAI ai = FirebaseAI.getInstance(
        GenerativeBackend.vertexAI(remoteConfig.getString("vertex_location")));

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
GenerativeModel gm = ai.generativeModel(
        /* modelName */ remoteConfig.getString("model_name"),
        /* generationConfig (optional) */ null,
        /* safetySettings (optional) */ null,
        /* tools (optional) */ null,
        /* toolsConfig (optional) */ null,
        /* systemInstruction (optional) */ new Content.Builder()
                .addText(remoteConfig.getString("system_instructions")).build(),
        /* requestOptions (optional) */ new RequestOptions()
);
GenerativeModelFutures model = GenerativeModelFutures.from(gm);

// Provide a prompt that contains text
// The text in the prompt will be sourced from Remote Config
Content userPrompt = new Content.Builder().addText(
        remoteConfig.getString("prompt")).build();

// To generate text output, call `generateContent` with the text input
ListenableFuture<GenerateContentResponse> response = model.generateContent(userPrompt);
Futures.addCallback(response, new FutureCallback<GenerateContentResponse>() {
    @Override
    public void onSuccess(GenerateContentResponse result) {
        String resultText = result.getText();
        System.out.println(resultText);
    }

    @Override
    public void onFailure(Throwable t) {
        t.printStackTrace();
    }
}, executor);

Web

// Initialize FirebaseApp
const firebaseApp = initializeApp(firebaseConfig);

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
const ai = getAI(firebaseApp, { backend: new VertexAIBackend(vertexLocation) });

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
const model = getGenerativeModel(ai, {
  model: modelName,
  systemInstruction: systemInstruction
});

// Wrap in an async function so you can use await
async function run() {
  // Provide a prompt that contains text
  // The text in the prompt will be sourced from Remote Config
  const userPrompt = prompt;

  // To generate text output, call `generateContent` with the text input
  const result = await model.generateContent(userPrompt);

  const response = result.response;
  const text = response.text();
  console.log(text);
}

Dart

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
final ai = await FirebaseAI.vertexAI(location: _vertexLocation);

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
final model =
      ai.generativeModel(
        model: _modelName,
        systemInstruction: Content.system(_systemInstructions),
      );

// Provide a prompt that contains text
// The text in the prompt will be sourced from Remote Config
final _userPrompt = [Content.text(_prompt)];

// To generate text output, call `generateContent` with the text input
final response = await model.generateContent(_userPrompt);
print(response.text);

ঐক্য

// Initialize the Vertex AI Gemini API backend service
// The location for where to access the model will be sourced from Remote Config
var vertexLocation = remoteConfig.GetValue("vertex_location").StringValue;
var ai = FirebaseAI.GetInstance(FirebaseAI.Backend.VertexAI(vertexLocation));

// Create a `GenerativeModel` and add system instructions into its config
// Both the model name and the system instructions will be sourced from Remote Config
var modelName = remoteConfig.GetValue("model_name").StringValue;
var systemInstructions = remoteConfig.GetValue("system_instructions").StringValue;

var model = ai.GetGenerativeModel(
  modelName: modelName,
  systemInstruction: ModelContent.Text(systemInstructions)
);

// Provide a prompt that contains text
// The text in the prompt will be sourced from Remote Config
var userPrompt = remoteConfig.GetValue("prompt").StringValue;

// To generate text output, call `GenerateContentAsync` with the text input
var response = await model.GenerateContentAsync(userPrompt);
UnityEngine.Debug.Log(response.Text ?? "No text in response.");

ধাপ ৭ : অ্যাপটি চালান।

অ্যাপটি বিল্ড ও রান করুন এবং এটি ঠিকমতো কাজ করছে কিনা তা যাচাই করুন। Firebase কনসোলের Remote Config পেজ থেকে আপনার কনফিগারেশনে পরিবর্তন আনুন, পরিবর্তনগুলো পাবলিশ করুন এবং ফলাফল যাচাই করুন।

পরবর্তী পদক্ষেপ

  • Remote Config সম্পর্কে আরও জানুন।

  • টার্গেটিং সক্ষম করতে আপনার ক্লায়েন্ট কোডে Google Analytics যোগ করুন।

  • মোবাইল অ্যাপ এবং গেমের জন্য:

    • Remote Config এবং A/B Testing ব্যবহার করে বিভিন্ন মডেলের সেটিংস পরীক্ষা করুন।

    • Remote Config রোলআউট ব্যবহার করে মডেল প্যারামিটারের পরিবর্তনগুলো পর্যায়ক্রমে প্রকাশ করুন (শুধুমাত্র iOS+ এবং Android-এর জন্য)।

    • স্বতন্ত্র ব্যবহারকারীদের জন্য সর্বোত্তম সেটিংস নির্ধারণ করতে মেশিন লার্নিং ব্যবহার করার জন্য Remote Config পার্সোনালাইজেশন ব্যবহার করুন (শুধুমাত্র iOS+, Android, এবং Unity-এর জন্য)।