ফায়ারবেসের সাথে ক্যাশে

প্রতিবেদনের জন্য লুকার স্টুডিওর নিজস্ব ক্যাশে সিস্টেম রয়েছে। আপনার সংযোগকারী তৈরি করার সময়, আপনি দ্রুত প্রতিবেদনের সুবিধার্থে একটি কাস্টম ক্যাশে প্রয়োগ করতে পারেন এবং APR হার-সীমা এড়াতে পারেন।

উদাহরণস্বরূপ, আপনি একটি সংযোগকারী তৈরি করছেন যা একটি নির্দিষ্ট জিপ কোডের জন্য গত 7 দিনের ঐতিহাসিক আবহাওয়ার ডেটা প্রদান করে। আপনার সংযোগকারীটি বেশ জনপ্রিয় হয়ে উঠছে তবে আপনি যে বাহ্যিক API থেকে ডেটা আনছেন তার কঠোর হারের সীমা রয়েছে৷ API শুধুমাত্র প্রতিদিন তার ডেটা আপডেট করে, তাই একটি নির্দিষ্ট জিপ কোডের জন্য, একই ডেটা এক দিনের মধ্যে একাধিকবার আনতে হবে না। এই সমাধান নির্দেশিকা ব্যবহার করে, আপনি প্রতিটি জিপ কোডের জন্য একটি দৈনিক ক্যাশে প্রয়োগ করতে পারেন।

প্রয়োজনীয়তা

  • একটি ফায়ারবেস রিয়েলটাইম ডাটাবেস । আপনার যদি একটিতে অ্যাক্সেস না থাকে তবে একটি Google ক্লাউড প্ল্যাটফর্ম (GCP) প্রকল্প তৈরি করুন এবং আপনার নিজস্ব Firebase রিয়েলটাইম ডেটাবেস উদাহরণ তৈরি করতে শুরু করুন নির্দেশিকা অনুসরণ করুন৷
  • ফায়ারবেস রিয়েলটাইম ডেটাবেস থেকে ডেটা পড়তে এবং লেখার জন্য একটি GCP পরিষেবা অ্যাকাউন্ট।
  • একটি কমিউনিটি সংযোগকারী যা একটি উৎস থেকে ডেটা নিয়ে আসে।

সীমাবদ্ধতা

  • এই সমাধানটি লুকার স্টুডিও অ্যাডভান্সড সার্ভিসের সাথে ব্যবহার করা যাবে না। আপনি যখন Looker Studio Advanced Services ব্যবহার করেন, তখন Apps Script-এ আপনার সংযোগকারী কোডের ডেটাতে অ্যাক্সেস থাকে না। সুতরাং আপনি অ্যাপস স্ক্রিপ্ট ব্যবহার করে ডেটা ক্যাশে করতে পারবেন না।
  • রিপোর্ট সম্পাদক এবং দর্শকরা এই নির্দিষ্ট ক্যাশে রিসেট করতে পারবেন না।

সমাধান

একটি পরিষেবা অ্যাকাউন্ট বাস্তবায়ন করুন

  1. আপনার Google ক্লাউড প্রকল্পে একটি পরিষেবা অ্যাকাউন্ট তৈরি করুন
  2. ক্লাউড প্রোজেক্টে এই পরিষেবা অ্যাকাউন্টের BigQuery অ্যাক্সেস আছে কিনা তা নিশ্চিত করুন।
    • প্রয়োজনীয় আইডেন্টিটি এবং অ্যাক্সেস ম্যানেজমেন্ট (IAM) ভূমিকা: Firebase Admin
  3. পরিষেবা অ্যাকাউন্ট কী পেতে JSON ফাইলটি ডাউনলোড করুন। আপনার সংযোগকারী প্রকল্পের স্ক্রিপ্ট বৈশিষ্ট্যে ফাইলের বিষয়বস্তু সংরক্ষণ করুন। কীগুলি যোগ করার পরে, অ্যাপস স্ক্রিপ্ট UI-তে এটির মতো দেখতে হবে:
    স্ক্রিপ্ট বৈশিষ্ট্যে পরিষেবা অ্যাকাউন্ট কী সংরক্ষণ করা হচ্ছে
  4. আপনার Apps স্ক্রিপ্ট প্রকল্পে Apps স্ক্রিপ্ট লাইব্রেরির জন্য OAuth2 অন্তর্ভুক্ত করুন
  5. পরিষেবা অ্যাকাউন্টের জন্য প্রয়োজনীয় OAuth2 কোড প্রয়োগ করুন:
firestore-cache/src/firebase.js
var SERVICE_ACCOUNT_CREDS = 'SERVICE_ACCOUNT_CREDS';
var SERVICE_ACCOUNT_KEY = 'private_key';
var SERVICE_ACCOUNT_EMAIL = 'client_email';
var BILLING_PROJECT_ID = 'project_id';

var scriptProperties = PropertiesService.getScriptProperties();

/**
 * Copy the entire credentials JSON file from creating a service account in GCP.
 * Service account should have `Firebase Admin` IAM role.
 */
function getServiceAccountCreds() {
  return JSON.parse(scriptProperties.getProperty(SERVICE_ACCOUNT_CREDS));
}

function getOauthService() {
  var serviceAccountCreds = getServiceAccountCreds();
  var serviceAccountKey = serviceAccountCreds[SERVICE_ACCOUNT_KEY];
  var serviceAccountEmail = serviceAccountCreds[SERVICE_ACCOUNT_EMAIL];

  return OAuth2.createService('FirebaseCache')
    .setAuthorizationBaseUrl('https://accounts.google.com/o/oauth2/auth')
    .setTokenUrl('https://accounts.google.com/o/oauth2/token')
    .setPrivateKey(serviceAccountKey)
    .setIssuer(serviceAccountEmail)
    .setPropertyStore(scriptProperties)
    .setCache(CacheService.getScriptCache())
    .setScope([
      'https://www.googleapis.com/auth/userinfo.email',
      'https://www.googleapis.com/auth/firebase.database'
    ]);
}

Firebase থেকে পড়তে এবং লিখতে কোড প্রয়োগ করুন

আপনি ফায়ারবেস রিয়েলটাইম ডাটাবেসে পড়তে এবং লিখতে Firebase Database REST API ব্যবহার করবেন। নিম্নলিখিত কোড এই API অ্যাক্সেস করার জন্য প্রয়োজনীয় পদ্ধতি প্রয়োগ করে।

getData() প্রয়োগ করুন

ক্যাশিং ছাড়া আপনার বিদ্যমান getData() কোডের কাঠামোটি এইরকম হওয়া উচিত:

firestore-cache/src/without-caching.js
/*
 * This file is only to demonstrate how the `getData()` fucntion would look
 * like without the Firebase Realtime Database caching. It is not a part of
 * the connector code and should not be included in Apps Script / Clasp.
 */

function getData(request) {
  var requestedFields = getFields().forIds(
    request.fields.map(function(field) {
      return field.name;
    })
  );

  var fetchedData = fetchAndParseData(request);
  var data = getFormattedData(fetchedData, requestedFields);

  return {
    schema: requestedFields.build(),
    rows: data
  };
}

আপনার getData() কোডে ক্যাশিং ব্যবহার করতে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. ডেটার 'খণ্ড' বা 'ইউনিট' নির্ধারণ করুন যা ক্যাশে করা উচিত।
  2. ক্যাশে ডেটার ন্যূনতম ইউনিট সংরক্ষণ করতে একটি অনন্য কী তৈরি করুন।
    উদাহরণ বাস্তবায়নের জন্য, configparams থেকে zipcode কী হিসাবে ব্যবহার করা হচ্ছে।
    ঐচ্ছিক : প্রতি-ব্যবহারকারী ক্যাশের জন্য, বেস কী এবং ব্যবহারকারীর পরিচয় সহ একটি যৌগিক কী তৈরি করুন। উদাহরণ বাস্তবায়ন:
    js var baseKey = getBaseKey(request); var userEmail = Session.getEffectiveUser().getEmail(); var hasheduserEmail = getHashedValue(userEmail); var compositeKey = baseKey + hasheduserEmail;

  3. ক্যাশে ডেটা বিদ্যমান থাকলে, ক্যাশে তাজা কিনা তা পরীক্ষা করুন।
    উদাহরণে, একটি নির্দিষ্ট জিপ কোডের জন্য ক্যাশে করা ডেটা বর্তমান তারিখের সাথে সংরক্ষিত হয়। যখন ক্যাশে থেকে ডেটা পুনরুদ্ধার করা হয়, তখন ক্যাশের তারিখ বর্তমান তারিখের বিপরীতে চেক করা হয়।

    var cacheForZipcode = {
      data: <data being cached>,
      ymd: <current date in YYYYMMDD format>
    }
    
  4. যদি ক্যাশ করা ডেটা বিদ্যমান না থাকে বা ক্যাশে করা ডেটা তাজা না হয়, উৎস থেকে ডেটা আনুন এবং ক্যাশে সংরক্ষণ করুন।

নিম্নলিখিত উদাহরণে, main.js ক্যাশিং প্রয়োগের সাথে getData() কোড অন্তর্ভুক্ত করে।

উদাহরণ কোড

অতিরিক্ত সম্পদ

Chrome UX সংযোগকারী হাজার হাজার ব্যবহারকারীকে একটি ~20GB BigQuery টেবিলের উপর ভিত্তি করে একটি ড্যাশবোর্ডের সুবিধা দেয়৷ এই সংযোগকারী দুটি স্তরযুক্ত ক্যাশিং পদ্ধতির জন্য Apps স্ক্রিপ্ট ক্যাশে পরিষেবা সহ Firebase রিয়েলটাইম ডেটাবেস ব্যবহার করে। বাস্তবায়নের বিশদ বিবরণের জন্য কোড দেখুন।